位置: 编程技术 - 正文

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

  • 全国增值税专用发票计算机稽核网络系统工程
  • 保险中的车
  • 税盘维护费抵扣
  • 单位产品销售税金
  • 公司员工社保怎么办理的
  • 互联网公司如何盈利
  • 会计核算差错
  • 怎么算应纳税收多少
  • 哪些收入减免所得税
  • 贷款金融资产减值的会计分录怎么写?
  • 递延资产放在资产负债表哪里
  • 当月发票入库核销怎么算
  • 注册公司买车划算吗
  • 建筑企业跨地区
  • 社保发票是普票还是专票
  • 无票收入如何做账
  • 如何判断发票是否重复
  • 借贷在会计中的增和减
  • 工资薪金总额包括哪些内容
  • 货币资金怎么核对账实相符
  • 发票失联企业不处理的后果
  • 计提固定资产折旧
  • 发票已抵扣未入账
  • boot mac os from
  • 在win10中怎么从edge旧ie浏览器
  • windows11永久解决蓝屏
  • linux mint 20.1安装
  • 因质量问题被扣钱怎么办
  • 哪些发票可以作为替代发票
  • w10如何删除微软拼音
  • php数组有哪几种类型
  • 中国国防科技大学 博士
  • Cusco Cathedral on the Plaza de Armas, Cusco, Peru (© sharptoyou/Shutterstock)
  • 文件不小心删除了怎么恢复
  • 2022-8-29 javaweb 第一天 servlet/tomcat
  • java获取resources下文件路径
  • 帝国cms商城教程
  • 银行手续费需要开发票吗
  • 工会经费计提按应付职工薪酬借方还是贷方?
  • 发票含税和不含税的区别
  • 预缴所得税年底处理账务吗
  • 企业之间交换房地产要交土地增值税吗
  • 外贸出口增值税附表二填哪项
  • 团体意外险投保
  • 企业注册资本的规定
  • 税控盘退费怎么做会计分录
  • 园林绿化行业的市场需求是什么
  • 人力资源外包服务企业
  • 住宿发票 抵扣
  • 当天开具的发票当天不能勾选认证吗?
  • 出售金融商品的增值税计税依据
  • 其他综合收益转出
  • 错误原始凭证怎么写
  • 账簿设制的一般程序
  • 创建mysql表sql语句
  • mysql8.0远程连接
  • mysql如何跨库查询
  • ubuntu zmq
  • 班班通一直正在启动什么原因
  • centos建站教程
  • Windows虚拟机怎么打开
  • mac开机慢开机以后特别卡
  • win10系统开机蓝屏得重启后才能开机
  • cocos2dx scrollview
  • Unity3D游戏开发标准教程
  • opengl顶点坐标纹理坐标关系
  • 国际安卓应用市场
  • 衬线字体和无衬线字体各自的用途
  • js中的json
  • pythonista pygame
  • jquery动态添加css样式
  • node.js和ajax的顺序
  • 轻松实现财富自由
  • python5.7汉诺塔
  • jquery常用的5个方法
  • 国家税务网上办税
  • 企业清算所得税申报表填写范本
  • 火灾损失进项税额怎么处理
  • 小规模纳税人30万免税政策
  • 2021河南税务政策
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设