[Unity]用同一份material在不同mesh上绘制不同图案

2024-04-13 10:32

本文主要是介绍[Unity]用同一份material在不同mesh上绘制不同图案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

假设游戏中有256个相同材质的物体上要分别绘制数字1~256,需要占256个drawcall吗?可以batch到1个drawcall吗?

简化一下问题:假如有4个Plane,我们要用下面这张材质分别在它们上面画1,2,3,4四个数字,可以做到只消耗一个drawcall吗?当然可以,关键就是使用顶点色保存uv信息.因为我们不能把uv信息保存在material中或者运行时给它赋值(会破坏batching),(关于划掉的部分,运行时也可以赋值而不破坏batching,只不过需要一些步骤,参考文末的gpu instancing的文章)所以我们要把信息存到模型本身上.

给每个模型挂一个脚本TestMeshColor.cs来设置它的顶点色(让美术自己出256个不同模型怕是美术要弄死你,包容量也不允许)代码如下:

using UnityEngine;
public class TestMeshColor : MonoBehaviour
{private Mesh mesh;public Color color;void Start (){mesh = GetComponent<MeshFilter>().mesh;Color[] colors = new Color[mesh.vertexCount];for (int i = 0; i < colors.Length; i++)colors[i] = color;mesh.colors = colors;}
}

 

然后在Inspector里输入public color的值(当然也可以用代码赋值).顶点色rgba四个通道,正好可以存Tiling x,y和Offset x,y,这里我们只用r和g通道存Offset,分别取(0,0),(0,1),(1,0),(1,1).

Tiling直接写在Material里(因为4个Plane的Tiling是一样的).

 

然后在Plane的shader中读取顶点色并转换为相应的uv:

Shader "Custom/TestMeshColor"
{Properties{_MainTex ("Texture", 2D) = "white" {}}SubShader{Tags { "RenderType"="Opaque" }Cull OffPass{CGPROGRAM#pragma vertex vert#pragma fragment frag#include "UnityCG.cginc"struct v2f{float4 vertex : SV_POSITION;float2 uv : TEXCOORD0;};sampler2D _MainTex;float4 _MainTex_ST;v2f vert (appdata_full v){v2f o;o.vertex = UnityObjectToClipPos(v.vertex);o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);o.uv += float2(v.color.x * 256 / 2, v.color.y * 256 / 2);//这里v.color要乘以256还原回来return o;}fixed4 frag (v2f i) : SV_Target{fixed4 col = tex2D(_MainTex, i.uv);return col;}ENDCG}}
}

结果如下(要运行起来哈不然没刷顶点色你会发现全是3),注意背景占掉了一个drawcall所以drawcall是2.有人问为什么顺序不是1,2,3,4啊,因为Offset的y是下方0上方1.这个我就不细调了反正知道意思就行了.

如果模型本身已经有顶点色了,可以尝试用MeshRenderer.additionalVertexStream再加一套UV来存信息,不过我没有试过,是老外一个帖子中提到的:https://forum.unity.com/threads/how-to-use-different-property-in-one-materials-shader.438588/

补充:

其实还有更简单的办法,用gpu instancing,传送门:

https://catlikecoding.com/unity/tutorials/rendering/part-19/

 

其他参考链接:

1.https://answers.unity.com/questions/1258951/changing-vertex-colors-break-batching.html

2.https://forum.unity.com/threads/tricks-for-dynamically-batching-materials-that-need-to-change-color.448821/

 

 

这篇关于[Unity]用同一份material在不同mesh上绘制不同图案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/899889

相关文章

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.

如何用Python绘制简易动态圣诞树

《如何用Python绘制简易动态圣诞树》这篇文章主要给大家介绍了关于如何用Python绘制简易动态圣诞树,文中讲解了如何通过编写代码来实现特定的效果,包括代码的编写技巧和效果的展示,需要的朋友可以参考... 目录代码:效果:总结 代码:import randomimport timefrom math

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。