位置: 编程技术 - 正文

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#打不开)

  • 利息税定义
  • 销售货物收入确认条件
  • 劳务外包人员算不算从业人员
  • 卷式发票是什么样的
  • 报销单与发票金额不符
  • 2019年所得税季度增值税怎么报
  • 个税的专项扣除包括哪些内容
  • 企业所得税不征税收入
  • 天猫费率是什么
  • 民办美术高中有哪些
  • 计提结转本月城建税怎么做账?
  • 预缴0.2%企业所得税计算方法
  • 新三板公司股东人数
  • 建筑业2019年最新税率表
  • 增值税发票单位可以不填吗
  • 取得的增值税发票哪些项目必须开具事项
  • 文化事业建设费征收对象
  • 财务报告报送与信息采集季报怎么填写
  • 固定资产怎么填报
  • 会计档案保管最新规定
  • 记账凭证汇总表和汇总记账凭证有什么区别
  • 法定盈余公积金转增资本不超过25%
  • 一季度所得税费用怎么算
  • 怎么进行现金流量分析
  • 收入负数怎么分录
  • 应收账款重组
  • 上个月留抵进项税额分录
  • 第三方工具查看对方关注抖音
  • php二维数组遍历
  • php json转对象
  • php写入xml
  • kb4577266补丁
  • 视同销售成本如何确认?
  • php事物
  • sci期刊投稿步骤
  • 跨省不动产登记
  • 处理固定资产怎么交税
  • 注意力机制的作用
  • python0基础
  • 低调低调
  • dmesg | grep tty
  • 消费积分如何做账
  • 库存盘亏进项税怎么抵扣
  • 退质保金计入什么科目
  • 微信转账和支付宝转账的区别
  • Python数学建模三剑客
  • 怎么应对降税行业
  • mongodb创建库
  • phpcms怎么用
  • 其他业务收入与营业外收入
  • sql server更新数据
  • 政府补助的界定
  • 衍生工具什么意思
  • 同一个单位能否交五险
  • 公司担保无效的后果
  • 员工外面有自己的公司
  • 买车险要先付钱再上牌吗
  • 初次申报出口退税可能会遇到哪些问题
  • 开出去的发票没有进项发票怎么核算成本?
  • 金税盘每年服务费可以抵扣吗
  • 出口转内销进项税额怎么进附表二
  • 防伪税控技术维护费
  • 从业人数和资产总额指标,应按企业
  • 可抵扣的税票
  • docker设置固定ip
  • mac电脑快速查询
  • Win7安装i219v网卡驱动
  • webtrapnt.exe - webtrapnt进程是什么意思
  • 帝国时代2能在win10
  • vim如何复制粘贴
  • linux 怎么样
  • win8 自动登录
  • 解决胃胀气最快方法
  • android studio入门项目
  • 简单介绍一下自己
  • jquery one()
  • 增强现实的三个特征
  • 方块大作战百科
  • 长春税务局电话举报
  • 省银保监局长是什么级别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设