位置: 编程技术 - 正文

unity游戏开发之NGUI的UISprite染色(unity游戏开发入门经典)

编辑:rootadmin

推荐整理分享unity游戏开发之NGUI的UISprite染色(unity游戏开发入门经典),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:unity游戏开发流程,unity程序开发,unity 开发游戏,unity游戏项目开发教程,unity开发的小游戏,unity游戏开发技术详解与典型案例,unity游戏开发技术详解与典型案例,unity游戏项目开发教程,内容如对您有帮助,希望把文章链接给更多的朋友!

欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多U3D资源、U3D培训视频、U3D教程、U3D常见问题、U3D项目源码,我们致力于打造业内unity3d培训、学习第一品牌。

游戏的UI开发中经常会遇到染色问题。例如按钮失效变灰的效果,同一个道具通过策划表配的颜色&#;染上红绿蓝紫等颜色,效果如下

最笨最挫的方法当然是让美术多出几个资源图,这样的一个缺点是浪费资源,在手游上资源的大小显得尤为重要。而且不好维护和复用,修改一个资源需要同时修改其他颜色的多个同类资源。一种比较好的解决方案是通过更换渲染的材质,用染色材质代替原来的材质,然后把原来材质的主纹理和透明纹理赋&#;给新的材质。这样就可以实现用程序动态切换颜色,而且只需要一个基础资源,节省资源大小,容易维护。

下面给出这个解决方案的流程图,如下图所示

下面写一个例子,通过按r键,g键,b键,y键来动态切换染红色,染绿色,染蓝色,灰化效果。项目的GameObject图如下

染色普通颜色的材质对应的shader如下

[plain]Shader "Winter/ChangeColor" { Properties { _MainTex ("Base (RGB)", 2D) = "white" {} _Color ("Main Color", Color) = (1,1,1,1) } SubShader { Tags { "Queue" = "Transparent&#;" } LOD Pass { ZWrite On ZTest Off Blend SrcAlpha OneMinusSrcAlpha Lighting Off //Cull Off CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" sampler2D _MainTex; fixed4 _Color; float _ColorCtrl; struct v2f { float4 pos : SV_POSITION; float2 uv : TEXCOORD0; }; float4 _MainTex_ST; v2f vert (appdata_base v) { v2f o; o.pos = mul (UNITY_MATRIX_MVP, v.vertex); o.uv = TRANSFORM_TEX (v.texcoord, _MainTex); return o; } fixed4 frag (v2f i) : COLOR { fixed4 texcol = tex2D (_MainTex, i.uv); result = texcol * _Color; result.a = texcol.a; return result; } ENDCG } } } 不同颜色要创建不同的材质,并且设置其颜色&#;,如下unity游戏开发之NGUI的UISprite染色(unity游戏开发入门经典)

灰化效果比较特殊,颜色&#;不能弄成(0,0,0,1)或者(1,1,1,1)。需要用到灰化函数

最终颜色的r = (原图r&#;原图g&#;原图b)*0.

最终颜色的g = (原图r&#;原图g&#;原图b)*0.

最终颜色的b = (原图r&#;原图g&#;原图b)*0.

最终颜色的透明&#; = 原图的透明&#;

根据上面,有下面的灰化shader

[plain]Shader "Winter/Gray" { Properties { _MainTex ("Base (RGB)", 2D) = "white" { } } SubShader { Tags { "Queue" = "Transparent&#;" } Pass { Lighting Off ZTest Off Cull Off Blend SrcAlpha OneMinusSrcAlpha CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" sampler2D _MainTex; sampler2D _AlphaTex; half4 _Color; struct v2f { float4 pos : SV_POSITION; float2 uv : TEXCOORD0; }; half4 _MainTex_ST; half4 _AlphaTex_ST; v2f vert (appdata_base v) { v2f o; o.pos = mul (UNITY_MATRIX_MVP, v.vertex); o.uv = TRANSFORM_TEX (v.texcoord, _MainTex); return o; } half4 frag (v2f i) : COLOR { half4 texcol = tex2D (_MainTex, i.uv); half4 result = half4((texcol.r &#; texcol.g &#; texcol.b) * 0.f,(texcol.r &#; texcol.g &#; texcol.b) * 0.f,(texcol.r &#; texcol.g &#; texcol.b) * 0.f,texcol.a); return result; } ENDCG } } } 接着就是要修改Ngui的UISprite源码,添加一个渲染的材质WinterMaterial, 在读取material&#;的时候,如果有自定义的渲染材质,则需要读取自定义渲染材质

[csharp]public override Material material { get { Material mat = base.material; if (mat == null) { mat = (mAtlas != null) ? mAtlas.spriteMaterial : null; mSprite = null; material = mat; if (mat != null) UpdateUVs(true); } if (WinterMaterial!=null) { return WinterMaterial; } else { return mat; } } } 然后,添加以下几个染色函数

[csharp]public void ShowAsRed() { ShowAsColor(" WinterRedMat); } public void ShowAsGreen() { ShowAsColor(" WinterGreenMat); } public void ShowAsBlue() { ShowAsColor(" WinterBlueMat); }//需要添加染色&#;的,则需要添加材质和染色函数 public void ShowAsGray() { StartCoroutine(<span style="font-family: Arial, Helvetica, sans-serif;">//自定义的www函数</span> [csharp] IzUtils.LoadAB(" (w) => {//assetbundle是打包好的材质 Material mat = w.assetBundle.mainAsset as Material; mat.mainTexture = material.mainTexture; WinterMaterial = mat; w.assetBundle.Unload(false); RefreshPanel(gameObject); }) ); } private void ShowAsColor(string matName, Material colorMaterial) { if (WinterMaterial == null || colorMaterial != WinterMaterial) { if (colorMaterial == null) { StartCoroutine( IzUtils.LoadAB(matName, (w) => { Material mat = w.assetBundle.mainAsset as Material; mat.mainTexture = material.mainTexture; colorMaterial = mat; WinterMaterial = mat; w.assetBundle.Unload(false); RefreshPanel(gameObject); }) ); } else { WinterMaterial = colorMaterial; RefreshPanel(gameObject); } } } GameObject GetMostClosePanel(Transform rootTrans) { if (rootTrans.GetComponent<UIPanel>() != null) { return rootTrans.gameObject; } else if (rootTrans.parent == null) { return null; } else { return GetMostClosePanel(rootTrans.parent); } } GameObject panelObj = null; public bool selfRefresh = true; void RefreshPanel(GameObject go) { if (!selfRefresh) return; if (panelObj == null) { panelObj = GetMostClosePanel(go.transform); } if (panelObj != null) { panelObj.GetComponent<UIPanel>().enabled = false; panelObj.GetComponent<UIPanel>().enabled = true; go.SetActive(false); go.SetActive(true); } }

主程序调用方法

[csharp]using UnityEngine; using System.Collections; public class ChangeColorExample : MonoBehaviour { private UISprite m_kSprite; void Start () [csharp] { GameObject obj = GameObject.Find("Root/Camera/Anchor/Panel/Sprite"); m_kSprite = obj.GetComponent<UISprite>(); void Update() { if (Input.GetKeyUp(KeyCode.R)) { m_kSprite.ShowAsRed(); } else if (Input.GetKeyUp(KeyCode.G)) { m_kSprite.ShowAsGreen(); } else if (Input.GetKeyUp(KeyCode.B)) { m_kSprite.ShowAsBlue(); } else if (Input.GetKeyUp(KeyCode.Y)) { m_kSprite.ShowAsGray(); } } 核心的代码部分如上图所示,这样就可以通过按键rgby来切换染红绿蓝灰的效果。效果如上面第一幅图所示。

总结,用程序来实现动态染色可以高度复用资源,节省空间大小。但是资源的划分需要注意的一点是,如果在一个UIPanel里面有两个不同图集需要用同一个材质进行染色,那么会出现其中的一个出现纹理错乱的现象。目前的解决方案是做多一个颜色&#;相同的材质,不同的图集用不同的染色材质,这样可以解决上面说的纹理错乱现象。另一个方法是设法把不同的图集弄到一块,这样也可以避免这个问题。

更多精彩请点击

Unity3D C#打开外部应用程序,并检测应用程序是否关闭退出 欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多U3D资源、U3D培训视频、U3D教程、U3D常见问题、U3D项目源码,我们致力于打造业内unity3d

Unity3d脚本执行顺序详解 欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多U3D资源、U3D培训视频、U3D教程、U3D常见问题、U3D项目源码,我们致力于打造业内unity3d

Unity3D 错误nativeVideoFrameCallback的解决方法 欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多U3D资源、U3D培训视频、U3D教程、U3D常见问题、U3D项目源码,我们致力于打造业内unity3d

标签: unity游戏开发入门经典

本文链接地址:https://www.jiuchutong.com/biancheng/372938.html 转载请保留说明!

上一篇:U3D游戏开发要思考的问题(游戏开发unity3d)

下一篇:Unity3D C#打开外部应用程序,并检测应用程序是否关闭退出(unityc#打不开)

  • 汇算清缴时纳税调整表调增金额是怎么算出来的
  • 季报现金流量表可以不填吗
  • 增值税即征即退收入要交企业所得税吗
  • 收到税收返还会计分录
  • 怎样填列分析资产负债表
  • 发票票种核定怎么提交
  • 招待用酒可以抵扣所得税吗
  • 应税凭证和纳税凭证的区别
  • 关于商业健康保险产品的规范和条件
  • 什么叫增值税还是所得税
  • 银行摘要冲账是什么意思
  • 帐外资产 如何记账
  • 基建工程施工单位罚款如何做账?
  • 总公司和分公司的合作协议
  • 经营预算的基本内容包括
  • 支付水电费如何记账
  • 在window10中可以使用什么窗口
  • rtc resume
  • 开增值税专用发票必须走公账吗
  • hpwuschd application
  • 结转损益类收入科目的余额会计分录
  • mmtray2k.exe有什么作用 是什么进程 mmtray2k进程查询
  • 弗拉维亚王朝
  • 在laravel中,界面文件应该放在以下哪个路径下
  • PHP:imagestringup()的用法_GD库图像处理函数
  • 无形资产的账务处理候文江视频
  • 特殊性税务处理的条件
  • 为什么微信转账不成功
  • 购车人丢失发票怎么查
  • 西西弗书店主管级
  • 去噪扩散概率模型
  • 企业营运资金管理存在的问题
  • 怎么配置opencv
  • 工程项目成本核算的依据主要有
  • 销售产品消费税计入什么科目
  • html爱心代码简单
  • 应收账款和应付账款都是负数
  • 外贸公司主要是做什么产品
  • python描述器有什么用
  • 学生誓词最新2022年
  • 有关事业单位无编人员的规定
  • 国家税务总局关于营改增后土地增值税
  • centos7阿里云源
  • 一般纳税人报税需要填哪些表
  • MySQL创建数据库语句
  • 认缴资本怎么填
  • 房地产企业帐套设置
  • 外出经营预交企业所得税税率
  • 收款单属于什么科目
  • 费用报销单如何粘贴票据
  • 建安类资质指什么资质
  • 费用分摊怎么开口说好
  • 保险发票计入什么科目
  • 财产租赁合同印花税计税依据
  • 验资 银行
  • 认证后的进项税额留抵退税
  • 会计账簿的设计意义
  • 债权人接受债务人土地抵押,还会被其他债权人查封?
  • 存储过程失效怎么办
  • sql server 3417错误
  • 使用SSIS创建同步数据库数据任务的方法
  • 如何编译安装
  • linux怎么vi
  • win8系统怎么搜索软件
  • zui哪个版本最好
  • windows中创建的任务计划可以多久执行一次任务?
  • js解析文本文件
  • easyui combobox设置值
  • cocos2dx-3.2+lua 常用函数
  • js遍历获取指定数据
  • jquery树形菜单
  • javascript获取浏览器代理设置
  • jquery中获取元素的三种方法
  • 通用申报表水利基金怎么填
  • 济南税务开票软件是什么
  • 河南税务公众号缴费养老保险
  • 辽宁社保网上申报流程图
  • 合格的税务人
  • 个人所得税必须企业代扣代缴吗
  • 每辆车车船税都一样吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设