Unity中制作游戏的快照游戏支持玩家拍快照

Unity中制作游戏的快照游戏支持玩家拍快照

有些游戏支持玩家“拍快照”,也就是将游戏的精彩瞬间以图片的形式记录下来的功能。这个功能比较有趣,而且以后的用途也会很广,为此本节打算介绍:截取矩形区域内游戏视图,并将其显示在视图其它区域的方法。具体的操作步骤如下本文选自Unity游戏开发技巧集锦:

(1)在Project视图里,创建一个C#脚本文件,并命名为ScreenTexture。在此脚本中编写如下的代码:

  • 01     using UnityEngine;
  • 02     using System.Collections;
  • 03
  • 04     public class ScreenTexture : MonoBehaviour
  • 05     {
  • 06              //公有成员
  • 07              public int photoWidth = 50;                                    //矩形的宽度
  • 08              public int photoHeight = 50;                                  //矩形的高度
  • 09              public int thumbProportion = 25;                          //截图的显示比例
  • 10              public Color borderColor = Color.white;             //矩形框架的颜色
  • 11              public int borderWidth = 2;                                              //矩形框的宽度
  • 12              //私有成员
  • 13              private Texture2D texture;
  • 14              private Texture2D border;
  • 15              private int screenWidth;
  • 16              private int screenHeight;
  • 17              private int frameWidth;
  • 18              private int frameHeight;
  • 19              private bool shoot = false;
  • 20              // 脚本初始化时,调用此函数
  • 21              void Start ()
  • 22              {
  • 23                       screenWidth = Screen.width;
  • 24                       screenHeight = Screen.height;
  • 25                       frameWidth = Mathf.RoundToInt(screenWidth * photoWidth * 0.01f);
  • 26                       frameHeight = Mathf.RoundToInt(screenHeight * photoHeight * 0.01f);
  • 27                       texture = new Texture2D (frameWidth,frameHeight,TextureFormat.RGB24,false);
  • 28                       border = new Texture2D (1,1,TextureFormat.ARGB32, false);
  • 29                       border.SetPixel(0,0,borderColor);
  • 30                       border.Apply();
  • 31              }
  • 32              // 运行游戏时,每帧都调用此函数
  • 33              void Update ()
  • 34              {
  • 35                        //鼠标左键按下的时候
  • 36                       if (Input.GetKeyUp(KeyCode.Mouse0))
  • 37                                 StartCoroutine(CaptureScreen());
  • 38              }
  • 39              //在Game视图上,绘制纹理
  • 40              void OnGUI ()
  • 41              {
  • 42                        //绘制矩形框的四个边
  • 43                       GUI.DrawTexture(
  • 44                                                   new Rect(
  • 45                                                             (screenWidth*0.5f)-(frameWidth*0.5f) - borderWidth*2,
  • 46                                                             ((screenHeight*0.5f)-(frameHeight*0.5f)) - borderWidth,
  • 47                                                             frameWidth + borderWidth*2,
  • 48                                                             borderWidth),
  • 49                                                   border,ScaleMode.StretchToFill);
  • 50                       GUI.DrawTexture(
  • 51                                                   new Rect(
  • 52                                                             (screenWidth*0.5f)-(frameWidth*0.5f) - borderWidth*2,
  • 53                                                             (screenHeight*0.5f)+(frameHeight*0.5f),
  • 54                                                             frameWidth + borderWidth*2,
  • 55                                                             borderWidth),
  • 56                                                   border,ScaleMode.StretchToFill);
  • 57                       GUI.DrawTexture(
  • 58                                                   new Rect(
  • 59                                                             (screenWidth*0.5f)-(frameWidth*0.5f)- borderWidth*2,
  • 60                                                             (screenHeight*0.5f)-(frameHeight*0.5f),
  • 61                                                             borderWidth,
  • 62                                                             frameHeight),
  • 63                                                   border,ScaleMode.StretchToFill);
  • 64                       GUI.DrawTexture(
  • 65                                                   new Rect(
  • 66                                                             (screenWidth*0.5f)+(frameWidth*0.5f),
  • 67                                                             (screenHeight*0.5f)-(frameHeight*0.5f),
  • 68                                                             borderWidth,
  • 69                                                             frameHeight),
  • 70                                                   border,ScaleMode.StretchToFill);
  • 71                        //绘制矩形框中截取到的Game视图
  • 72                       if(shoot)
  • 73                       {
  • 74                                 GUI.DrawTexture(
  • 75                                                   new Rect (
  • 76                                                             10,
  • 77                                                             10,
  • 78                                                             frameWidth*thumbProportion*0.01f,
  • 79                                                             frameHeight*thumbProportion* 0.01f),
  • 80                                                   texture,ScaleMode.StretchToFill);
  • 81                       }
  • 82              }
  • 83              //截取矩形框里的Game视图
  • 84              IEnumerator CaptureScreen ()
  • 85              {
  • 86                       yield return new WaitForEndOfFrame();
  • 87                       texture.ReadPixels(
  • 88                                 new Rect(
  • 89                                          (screenWidth*0.5f)-(frameWidth*0.5f),
  • 90                                (screenHeight*0.5f)-(frameHeight*0.5f),
  • 91                                frameWidth,
  • 92                                          frameHeight),
  • 93                                 0,0);
  • 94                       texture.Apply();
  • 95                       shoot = true;
  • 96              }
  • 97     }

脚本代码中,40行的OnGUI()函数,使用GUI.DrawTexture()绘制了矩形框,以及矩形框中截取到的游戏视图;84行的CaptureScreen()函数,使用texture.ReadPixels()读取矩形框中的所有像素点,然后存储到texture中。触发“拍照”功能的操作是,在Game视图中的任意位置,单击鼠标左键,即36行代码实现的功能。

(2)将脚本ScreenTexture赋予Main Camera,然后选中Main Camera,在Inspector视图里可以设置脚本组件的一些属性,如图2-19所示本文选自Unity游戏开发技巧集锦。

图2-19  Main Camera上ScreenTexture脚本组件的各属性       图2-20  当前的Scene视图

(3)为游戏的场景添加一些几何体,并调整它们各自的位置,如图2-20所示。

(4)运行游戏,当在Game视图中的任意位置,单击鼠标左键的时候,可在视图的左上角看到矩形框中截取到的游戏视图,如图2-21所示本文选自Unity游戏开发技巧集锦。

图2-21  运行游戏,查看截图的效果

时间: 2024-10-19 19:11:25

Unity中制作游戏的快照游戏支持玩家拍快照的相关文章

unity中制作模拟第一人称视角下的指南针

private int zRotation; public GameObject obj; public void Update() { //obj = GameObject.Find("Camera");   //获取名为Camera的相机对象 zRotation = player.transform.eulerAngles.y; //player是unity第一人称 compass.transform.eulerAngles = new Vector3(0, 0, zRotatio

unity中简单的血条自作

unity中制作血条有很多方法,多数用NGUI:这里我就说说一个简单的血条制作方法吧: 这个血条制作不像NGUI一样,它是靠一段代码就可以实现的,但看起来比较效果比较差,还是看代码吧:  public Texture2D bg;     //血条的背景,需要在外面进行拖拽赋值:  public Texture2D blood;   //血条  float Life=100;            //总的生命值:    public Transform m_Transform;  //绑定血条的

C#开发Unity游戏教程之Unity中方法的参数

C#开发Unity游戏教程之Unity中方法的参数 Unity的方法的参数 出现在脚本中的方法,无论是在定义的时候,还是使用的时候,后面都跟着一对括号“( )”,有意义吗?看起来最多也就是起个快速识别方法的作用吧.既然C#的语法规定方法就应该这么写,肯定是有一定道理的.如果是上升到战略意义的道理,连作者也不是很明白,但是作者知道这对括号里可以添加“参数”. Unity中参数的作用 要说明参数的作用,就必须从方法说起.方法可以处理变量中的数据,进而影响游戏对象的行为逻辑,这是本章前面一直在强调的.

【Unity游戏开发】用C#和Lua实现Unity中的事件分发机制EventDispatcher

一.简介 最近马三换了一家大公司工作,公司制度规范了一些,因此平时的业余时间多了不少.但是人却懒了下来,最近这一个月都没怎么研究新技术,博客写得也是拖拖拉拉,周六周天就躺尸在家看帖子.看小说,要么就是吃鸡,唉!真是罪过罪过.希望能从这篇博客开始有些改善吧,尽量少玩耍,还是多学习吧~ 好了扯得有点远了,来说说我们今天博客的主题——“用C#和Lua实现Unity中的事件分发机制”,事件分发机制或者叫事件监听派发系统,在每个游戏框架中都是不可或缺的一个模块.我们可以用它来解耦,监听网络消息,或者做一些

游戏的物理和数学:Unity中的弹道和移动目标提前量计算

下载地址:http://yunpan.cn/cK6pCrpdhfbTd  提取码 5472 弹道计算是游戏里常见的问题,其中关于击中移动目标的自动计算提前量的话题,看似简单,其实还是挺复杂的数学.网上这方面的资料还真不多,而且都是写的含含糊糊.抽空总结一下自己的方法. 讨论的前提是,假设目标是在3D空间里以匀速直线方式运动. 1.直线弹道在不考虑重力和空气阻力影响的情况下,子弹的弹道呈直线运动.这种情况下,其实是个纯平面几何空间的问题,不需要微积分和线代知识.分析的情况如下图:        

用Qt制作的Android独立游戏《吃药了》发布

一个多月的努力终于有了回报,我自己研究制作的独立游戏<吃药了>,终于在360应用商店上线了. 这一款游戏呢,使用的是Qt开发的.其实开发这款简单的应用之前,我经历了端游和页游,但是对手游开发了解甚少.不过今年5月20日,Qt官方发布了Qt5.3,对Android和iOS的支持变得成熟起来了,于是我打算冒一个险,使用大家从未使用过的Qt来开发手机游戏.这一个月呢,各种心酸各种泪,我曾经感受到整天10多个小时开发的疲惫:我曾经感受到家人的种种催促:我曾经感受到同事们的好言相劝:我曾经感受到自己内心

如何使用纯 CSS 制作四子连珠游戏

序言:你有没有想过单纯使用 CSS 也可以制作一款游戏?甚至可以双人对决?这是一篇非常有趣的文章,作者详细讲解了使用纯 CSS 制作四子连珠游戏的思路以及使用奇淫巧技解决困难问题的方法.因为案例本身比较复杂,而本人水平有限,翻译必有不恰当之处,望指正. 原文:How the Roman Empire Made Pure CSS Connect 4 Possible 翻译:nzbin 实验是学习新技巧.思考新想法.并突破自身极限的有趣的方式."纯 CSS"演示很早就有了,但是随着浏览器和

使用AxureRP7.0制作经典数独小游戏原型,axure游戏原型下载

之前,有同学在Q群中提问,如何使用axure制作经典数独解谜小游戏,当时由于时间关系没有来得及亲手制作,而是给同学们提供了Axure6.5版本的一个数独解谜游戏的原型,本教程由axure原型库网站录制,转载请注明出处!但是那个原型做的太过繁杂,所以仅供大家参考交流:在此,金乌老师特地抽时间给同学们使用AxureRP7.0制作了一下,感觉对实战逻辑分析和axure变量的掌握比较有考验,所以就放出来供大家学习交流使用. 在学习的过程中,如果你仅凭自己现有的对axure的掌握,无法准确分析并组织出原型

unity3f游戏开发之游戏设计中运营重用体系

游戏设计中,运用重用体系重用资源包括有以下几个设计目的: 1).方便玩家识别 为了方便玩家识别某一类游戏中的要素,而采用的设计目的.如某种某种动物的皮毛的道具图标.为了区分不同,除了基本图素相同外,不同之处只是以变换颜色和更改名称加以区分,这样可以方便玩家快速识别图标. 2).降低客户端的容量 游戏中最占用硬盘空间的,其实是大量的资源,如模型文件.贴图等美术资源文件.为了降低客户端的容量,开发者除了要采用压包技术进行资源压包外,在设计的过程中,设计师还要考虑到客户端容量大小的问题(特别是某些2D