http://blog.csdn.net/highning0007/article/details/37991787

分类: Unity3D2013-11-28 17:13 1014人阅读 评论(2) 收藏 举报

下面是我总结的、在u3d中的,三种截屏方法:

1、使用Application类下的CaptureScreenshot方法。

[csharp] view plaincopy
  1. void CaptureScreen()
  2. {
  3. Application.CaptureScreenshot("Screenshot.png", 0);
  4. }

这个方法,截取的是某一帧时整个游戏的画面,或者说是全屏截图吧。

a、不能针对某一个相机(camera)的画面,进行截图。

b、对局部画面截图,实现起来不方便,效率也低,不建议在项目中使用:

虽然CaptureScreenshot这个方法呢,本身是不要做到这一点的。但是我们可以走曲线救国的路线来实现它。思路是这样的:你可以先用这个方法截图一个全屏,然后通过路径获取到这个截图;接下来就通过相关的图形类来,取得这个截图的局部区域并保存下来,这样就能得到一个局部截图了。在这里我就不实现它了,不过有兴趣的可以试试,肯定是可以实现的。

2、这第二个截图的方法是,使用Texture2d类下的相关方法,也可实现截图功能。

[csharp] view plaincopy
  1. /// <summary>
  2. /// Captures the screenshot2.
  3. /// </summary>
  4. /// <returns>The screenshot2.</returns>
  5. /// <param name="rect">Rect.截图的区域,左下角为o点</param>
  6. Texture2D CaptureScreenshot2(Rect rect)
  7. {
  8. // 先创建一个的空纹理,大小可根据实现需要来设置
  9. Texture2D screenShot = new Texture2D((int)rect.width, (int)rect.height, TextureFormat.RGB24,false);
  10. // 读取屏幕像素信息并存储为纹理数据,
  11. screenShot.ReadPixels(rect, 0, 0);
  12. screenShot.Apply();
  13. // 然后将这些纹理数据,成一个png图片文件
  14. byte[] bytes = screenShot.EncodeToPNG();
  15. string filename = Application.dataPath + "/Screenshot.png";
  16. System.IO.File.WriteAllBytes(filename, bytes);
  17. Debug.Log(string.Format("截屏了一张图片: {0}", filename));
  18. // 最后,我返回这个Texture2d对象,这样我们直接,所这个截图图示在游戏中,当然这个根据自己的需求的。
  19. return screenShot;
  20. }

截全屏(如下图, 注:有ui):
CaptureScreenshot2( new Rect( Screen.width*0f, Screen.height*0f, Screen.width*1f, Screen.height*1f));


截中间4分之(如下图):
CaptureScreenshot2( new Rect( Screen.width*0.25f, Screen.height*0.25f, Screen.width*0.5f, Screen.height*0.5f));

这里使用了几个Texture2d类的方法,使用上也有一些要注意的地方,自己看吧。

当然,这个方法也不要到实现针对某个相机的截图的功能。不过关键接口已经出现了,它就是Texture2d.ReadPixels(),这段就不说了,接着往下看吧!

3、这第三个方法,最牛了,可以针对某个相机进行截图。

这样的话,我就可截下,我的Avatar在游戏中场景中所看的画面了,UI界面(用一个专门的camera显示)什么的是不应该有的。要做到这一点,我们应该将分出一个camera来专门显示ui界面,用另一个camera相机来场景显示场景画面。然后,我们只对场景相机进行截屏就是了。所以这关键点就是:如何实现对某个相机进行截屏了。这里用到一个新的类是RenderTexture。

代码如下:

[csharp] view plaincopy
  1. /// <summary>
  2. /// 对相机截图。
  3. /// </summary>
  4. /// <returns>The screenshot2.</returns>
  5. /// <param name="camera">Camera.要被截屏的相机</param>
  6. /// <param name="rect">Rect.截屏的区域</param>
  7. Texture2D CaptureCamera(Camera camera, Rect rect)
  8. {
  9. // 创建一个RenderTexture对象
  10. RenderTexture rt = new RenderTexture((int)rect.width, (int)rect.height, 0);
  11. // 临时设置相关相机的targetTexture为rt, 并手动渲染相关相机
  12. camera.targetTexture = rt;
  13. camera.Render();
  14. //ps: --- 如果这样加上第二个相机,可以实现只截图某几个指定的相机一起看到的图像。
  15. //ps: camera2.targetTexture = rt;
  16. //ps: camera2.Render();
  17. //ps: -------------------------------------------------------------------
  18. // 激活这个rt, 并从中中读取像素。
  19. RenderTexture.active = rt;
  20. Texture2D screenShot = new Texture2D((int)rect.width, (int)rect.height, TextureFormat.RGB24,false);
  21. screenShot.ReadPixels(rect, 0, 0);// 注:这个时候,它是从RenderTexture.active中读取像素
  22. screenShot.Apply();
  23. // 重置相关参数,以使用camera继续在屏幕上显示
  24. camera.targetTexture = null;
  25. //ps: camera2.targetTexture = null;
  26. RenderTexture.active = null; // JC: added to avoid errors
  27. GameObject.Destroy(rt);
  28. // 最后将这些纹理数据,成一个png图片文件
  29. byte[] bytes = screenShot.EncodeToPNG();
  30. string filename = Application.dataPath + "/Screenshot.png";
  31. System.IO.File.WriteAllBytes(filename, bytes);
  32. Debug.Log(string.Format("截屏了一张照片: {0}", filename));
  33. return screenShot;
  34. }

多的我就不说了,相关知识自己去找资料吧,因为我也不懂!

直接上图了。

无ui的全屏图:

只有ui的全屏图:

有ui有场景的全屏图(只指定这两个相机哦,相关提示在代码的“//ps”中):

转载请在文首注明出处:http://blog.csdn.net/anyuanlzh/article/details/17008909

Unity3d之截图方法的更多相关文章

  1. Unity3d中Update()方法的替身

    在网上看到一些资料说Unity3d的Update方法是如何如何不好,影响性能.作为一个菜鸟,之前我还觉得挺好用的,完全没用什么影响性能的问题存在.现在发现确实有很大的问题,我习惯把一大堆检测判断放在U ...

  2. python web自动化测试中失败截图方法汇总

    在使用web自动化测试中,用例失败则自动截图的网上也有,但实际能落地的却没看到,现总结在在实际应用中失败截图的几种方法: 一.使用unittest框架截图方法:   1.在tearDown中写入截图的 ...

  3. selenium-java,UI自动化截图方法

    截图方法: import java.io.File; import java.io.IOException; import org.apache.commons.io.FileUtils; impor ...

  4. C#截图操作(几种截图方法)

    公共函数获取屏幕截图private Bitmap GetScreenCapture(){ Rectangle tScreenRect = new Rectangle(0, 0, Screen.Prim ...

  5. Java&Selenium截图方法封装

    Java&Selenium截图方法封装 package util; import org.apache.commons.io.FileUtils; import org.openqa.sele ...

  6. Python+Appium自动化测试(7)-截图方法

    一,selenium模块的两种截图方法 get_screenshot_as_file(filename) 参数filename为截图文件保存的绝对路径,如: driver.get_screenshot ...

  7. (转)Unity3d的3种截图方法

    下面是我总结的.在u3d中的,三种截屏方法: 1.使用Application类下的CaptureScreenshot方法. void CaptureScreen() { Application.Cap ...

  8. unity3d中dllimport方法的使用,以接入腾讯平台为例!!!

    说到有关dllimport方法可能还有很多人比较陌生,其实我自己也说不太清楚,大概说说什么时候要用它. 事实上功能类似于调用android的第三包,我们想要使用苹果上特定的api或者第三方平台的一些东 ...

  9. Python + Appium 获取当前屏幕的截图方法的封装

    使用方法:get_screenshot_as_file(filename),来自于selenium\webdriver\remote\webdiver.py def take_screenShot(s ...

随机推荐

  1. linux 后台运行nohup & ctrl+z

    使用Linux时,经常希望有些命令结果不在前台显示,如sh脚本,耗时的命令等.一般情况下,使用 & 将命令结果后台运行,如sh test.sh,脚本后台执行. 有时候命令已经在前台执行了,需要 ...

  2. LeetCode(55): 跳跃游戏

    Medium! 题目描述: 给定一个非负整数数组,你最初位于数组的第一个位置. 数组中的每个元素代表你在该位置可以跳跃的最大长度. 判断你是否能够到达最后一个位置. 示例 1: 输入: [2,3,1, ...

  3. MySQL----数据库操作2

    数据库高级操作: SHOW DATABASES; 显示数据库 CREATE DATABASE 数据库名称 DEFAULT CHARSET utf8 COLLATE utf8_general_ci CR ...

  4. eclipse的操作

    IDEA至少在4G内存的电脑才能使用 eclipse中:项目名字小写 close project:关掉项目 删除未尽的项目导入eclipse中的步骤: 左边右键>>>import&l ...

  5. Masm615+notepad++6.8.8搭建汇编开发环境

    前言:很早以前搭过,做了笔记的.现在重新玩汇编,按照笔记撘环境,谁知道坑了自己两个小时,气的我现在打字手都在抖 准备工作: 1.Masm615汇编环境,下载地址:https://pan.baidu.c ...

  6. django 如何动态使用Q查询函数

    这个Q和F用得少, 需要时,总是独立的存在于那时,显得有些突兀, 这次想将filter,order,Q集合在一起, 查询了很多资料,还是有一些困难, 但即可以将Q查询比较优雅的动态生成. 比如: # ...

  7. HashTable、HashMap、ConcurrentHashMap的区别

    HashTable是做了同步的,HashMap未考虑同步.所以HashMap在单线程情况下效率较高:HashTable在的多线程情况下,同步操作能保证程序执行的正确性. HashMap是非线程安全的, ...

  8. c++ primer 笔记 (一)

    昨天开始看的<C++ Primer>,确实不错.希望这周抓紧看完,每天做下笔记,以便以后复习. main函数返回一个值给操作系统   操作系统通过main函数返回的值来确定程序是否成功执行 ...

  9. BZOJ1103 [POI2007]大都市meg dfs序 线段树

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1103 题意概括 一棵树上,一开始所有的边权值为1,我们要支持两种操作: 1. 修改某一条边的权值为 ...

  10. Selenium 获取文本信息方法+select(定位)

    1.通过先定位到具体的元素然后通过text方法获取文本信息,如获取控件名称等 driver.find_element_by_xpath("//div[/h1").text 2.直接 ...