Unity3D随意截图并保存
http://blog.csdn.net/awnuxcvbn/article/details/9199245
效果
代码
- <pre name="code" class="csharp">using UnityEngine;
- using System.Collections;
- using System.IO;
- public class CropPicture : MonoBehaviour
- {
- string localPath = "http://192.168.1.100:8080/picture/15.jpg";
- Texture2D image;
- Texture2D cutImage;
- WWW www;
- Rect rect;
- float time;
- Vector2 pos1;
- Vector2 pos2;
- // Use this for initialization
- void Start()
- {
- StartCoroutine(LoadImage());
- }
- // Update is called once per frame
- void Update()
- {
- //点击鼠标左键,记录第一个位置
- if (Input.GetMouseButtonDown(0))
- {
- pos1 = Input.mousePosition;
- time = Time.time;
- if (time > 1f)
- {
- Debug.Log(pos1);
- }
- }
- //放开左键记录第二个位置
- if (Input.GetMouseButtonUp(0))
- {
- pos2 = Input.mousePosition;
- Debug.Log(pos2);
- StartCoroutine(CutImage());
- time = 0;
- }
- }
- void OnGUI()
- {
- //当下载完成
- if (www.isDone)
- {
- GUI.DrawTexture(new Rect(0, 0, 600, 904), image);
- }
- GUI.Button(new Rect(0, 0, 100, 50), "W" + Screen.width + "H" + Screen.height);
- if (pos1 != null)
- {
- GUI.Button(new Rect(0, 50, 150, 50), pos1.ToString());
- }
- if (pos2 != null)
- {
- GUI.Button(new Rect(0, 100, 150, 50), pos2.ToString());
- }
- if (cutImage != null)
- {
- GUI.Button(new Rect(0, 150, 150, 50), "image W" + cutImage.width + "H" + cutImage.height);
- }
- if (rect != null)
- {
- GUI.Button(new Rect(0, 200, 250, 50), rect.ToString());
- }
- }
- //下载图片
- IEnumerator LoadImage()
- {
- www = new WWW(localPath);
- yield return www;
- image = www.texture;
- if (www.error != null)
- {
- Debug.Log(www.error);
- }
- }
- //截图
- IEnumerator CutImage()
- {
- //图片大小
- cutImage = new Texture2D((int)(pos2.x - pos1.x), (int)(pos1.y - pos2.y), TextureFormat.RGB24, true);
- //坐标左下角为0
- rect = new Rect((int)pos1.x, Screen.height - (int)(Screen.height - pos2.y), (int)(pos2.x - pos1.x), (int)(pos1.y - pos2.y));
- yield return new WaitForEndOfFrame();
- cutImage.ReadPixels(rect, 0, 0, true);
- cutImage.Apply();
- yield return cutImage;
- byte[] byt = cutImage.EncodeToPNG();
- //保存截图
- File.WriteAllBytes(Application.streamingAssetsPath + "/CutImage.png", byt);
- }
- }
Unity3D随意截图并保存的更多相关文章
- Unity3d之截图方法
http://blog.csdn.net/highning0007/article/details/37991787 Unity3d之截图方法 分类: Unity3D2013-11-28 17:13 ...
- [Android] 拍照、截图、保存并显示在ImageView控件中
近期在做Android的项目,当中部分涉及到图像处理的内容.这里先讲述怎样调用Camera应用程序进行拍照,并截图和保存显示在ImageView控件中以及遇到的困难和解决方法. PS:作者购买 ...
- opencv 截图并保存
opencv 截图并保存(转载) 代码功能:选择图像中矩形区,按S键截图并保存,Q键退出. #include<opencv2/opencv.hpp> #include<iostrea ...
- html2canvas插件对整个网页或者网页某一部分截图并保存为图片
html2canvas能够实现在用户浏览器端直接对整个或部分页面进行截屏.这个脚本将当前页面渲染成一个canvas图片,通过读取DOM并将不同的样式应用到这些元素上实现.它不需要来自服务器任何渲染,整 ...
- 对html进行截图并保存为本地图片
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- Python+Selenium练习篇之21-如何截图并保存
本文介绍如何利用Selenium的方法进行截图,在测试过程中,是有必要截图,特别是遇到错误的时候进行截图.在selenium for python中主要有三个截图方法,我们挑选其中最常用的一种. ge ...
- Python3.X Selenium 自动化测试中如何截图并保存成功
在selenium for python中主要有三个截图方法,我们挑选其中最常用的一种. 挑最常用的:get_screenshot_as_file() 相关代码如下:(下面的代码可直接复制) # co ...
- selenium 页面截图并保存
import java.io.File; import java.io.IOException; import org.apache.commons.io.FileUtils; import org. ...
- 利用HTML5的Video进行视频截图并保存到本地
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- android 启动流程
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha adb shell 后 用 ps 命令 回车 可以看到 运行的进程. 如下结果: ct ...
- SPOJ1811 && SPOJ1812
SPOJ1811 && SPOJ1812 LCS && LCS2 非常神奇的两道题... 题目大意: 给定n个字符串,求最长公共子串 做法1: 后缀数组: 把字符串连起 ...
- [CSAcademy]Squared Ends
[CSAcademy]Squared Ends 题目大意: 给你一个长度为\(n(n\le10^4)\)的数列\(\{A_i\}(A_i\le10^6)\).定义区间\(A_{[l,r]}\)的代价为 ...
- 启动Tensorboard时发生错误:class BeholderHook(tf.estimator.SessionRunHook): AttributeError: module 'tensorflow.python.estimator.estimator_lib' has no attribute 'SessionRunHook'
报错:class BeholderHook(tf.estimator.SessionRunHook):AttributeError: module 'tensorflow.python.estimat ...
- bzoj 1014 LCP 二分 Hash 匹配
求同一字符串的两个后缀的最长公共前缀. 将字符串按位置放到Splay中维护(每个节点还维护一下该子树的hash),然后二分前缀的长度,用splay计算出指定范围的hash,按hash是否相等来判断是否 ...
- HTML5 元素拖动 - 实现元素左右拖动, 或更改自身排序
1.拖放(Drag 和 drop)是 HTML5 标准的组成部分. 拖放是一种常见的特性,即抓取对象以后拖到另一个位置.在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放. 浏览器支持:Int ...
- 前后端常用通讯方式-- ajax 、websocket
一.前后端常用通讯方式 1. ajax 浏览器发起请求,服务器返回数据,服务器不能主动返回数据,要实现实时数据交互只能是ajax轮询(让浏览器隔个几秒就发送一次请求,然后更新客户端显示.这种方式实际 ...
- KVM虚拟机安装使用教程(Ubantu)
背景: 公司在某电信机房有50台ubantu的实体机,机器配置的ip是192.168.100.x的ip,内存和cpu都是高端配置.假如哪些端口需要对外映射,就通过机房的防火墙完成端口映射. 100.1 ...
- <摘录>Gson对Java嵌套对象和JSON字符串之间的转换
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,具有良好的跨平台特性.近几年来已经和XML一样成为C/S架构中广泛采用的数据格式.有关JSON的更多知识, ...
- 程序猿怎样变身IT讲师
我以前写过一篇文章,"一张图道尽程序猿的出路",里面有一张图: 这张图随着"一张图道尽程序猿的出路"这篇文章,以前被伯乐在线.docin(豆丁网).IT面试.J ...