位置: 编程技术 - 正文

Unity shader 官网文档全方位学习(一)(unity shader editor)

编辑:rootadmin

推荐整理分享Unity shader 官网文档全方位学习(一)(unity shader editor),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:unity shader视频教程,unity shader editor,unity shader lod,《unity shader入门精要》,unity shaders and effects cookbook,unity shaders and effects cookbook,unity shaders and effects cookbook,unity shader lerp,内容如对您有帮助,希望把文章链接给更多的朋友!

What?? Shader,看起来好高级的样子,是的,这是Unity中高级进阶的必备。因此,兄弟我就在此记下我学习官网的一些心得。

此为一。主要介绍些Surface Shaders的知识。具体的大家也可去官网(如下)学习。

=>lightModel是所采用的光照模型。可以自己写也可使用内置如Lambert和BlinnPhong.

=>optionalparams:可选参数,一堆可选包括透明度,顶点与颜色函数,投射贴花shader等等。具体用到可以细选。

另外这里有一个功能。在Surface shader的CGPROGRAM里添加 #pragma debug [内容]。可在编译结果的文件中看到。写多少都行。但尝试在其他种shader下不行。

三、实例学习:

1.Simple:

第一个。行行来:

第一行:写个名字。这也有讲究的。斜线左边为其父类的组,无则新增,有则累加,右边才是真正的名字。注意,这些shader名不像C#脚本,无需文件名与shader名相同。

第二、三行:接下来就在SubShader里添加内容,SubShader是可以有多个的。然后上一个Tags,此处只用到RenderType这种,另外的还有Rendering order, ForceNoShadowCasting..等。这些本阶段暂不研究。

第四行:上一条指令,里面指定响应方法为surf且采用Lambert的光照模型。这个必须有的。

第五行:这个结构体,记得名字不能改,只能为Input。里面一个四元素的颜色&#;(RGBA)。

第七到第九行:第一个参数,纯输入的上述结构体参数。第二个参数,inout标识,意思是可为输入参数也可为输出参数。Albedo根据前面介绍到的,是一个rgb的&#;,如果给一个1,其实就是float3(1,1,1),就是反射出来的颜色为白色,如果为,则是加强反射强度,并不会改变其颜色。为0或为负数时道理类&#;。

最后Fallback,后方的是自带的shader,可以用自己自定义好的。这里这句的意思是,如果所有subshader在当前显卡都不支持,则默认返回自带的Diffuse。

2.Texture:

这个例子呢。其实只是第一个的基础上添加了一个2D属性显示名为Texture。以下解析:

第一个黑体:添加一个名叫_MainTex的属性,指定其为2D类型且显示为Texture。"white"那块可不是乱写的,是unity的build-in的一些textures的名称,而不是单纯颜色名字。意思是当默认时显示为名叫white的材质。如改成red(即使用名叫red的材质,如果有其他也可叫其名字),则效果如下:

第二个黑体:uv_MainTex。这其中大有玄机,uv开头指代后方材质的uv&#;,因此uv不变,后面的可以根据开头起的名字动态换。还有哦,这种类&#;于_MainTex的命名方式是CG推荐的,其实不用下划线也OK的。

第三个黑体:这个Sampler2D,可以理解为引用一个2D Texture。因为下面的Tex2D函数需要这种类型。所以说这个后面的名字要与Properties里的对应一样才行。

第四个黑体:Tex2D,这玩意就是根据对应材质上所有的点找指定 2DSample上的Texture信息,此处需要其RGB信息,就打出来赋给了其反射&#;。所以对有材质图的情况下,要显示出图,还是要相应的反射其原图的rgb&#;。

3.Normal mapping

这个例子里加了个凹凸贴图,可实现类&#;一些很漂亮的凹凸效果。

第一个黑体:加一个2D类型的材质,默认为bump。(即带有凹凸效果的)。

第二个黑体:上一个采集器。采集下来上面的材质。

第三个黑体:有讲究,这个UnpackNormal是unity自带的标准解压法线用的,所谓解压,我暂时学习到的只是将法线的区间进行变换。由于tex2D(_BumpMap, IN.uv_BumpMap)取出的是带压缩的[0,1]之间,需要转成[-1,1]。这个函数会针对移动平台或OPENGL ES平台采用 RGB法线贴图,其他采用DXT5nm贴图。为此也可自己写。也在网上找到了一些资料,如下参考:

4.Rim Lighting

新增的一些东西,我都用数字标注了。以下进行详细解读:

第一处(//1):上一个Color类型的显示为Rim Color的变量。颜色&#;RGBA对应0.,0.,0.,0.0

第二处(//2):这个Range类型的变量,结果还是一个float。只是这个float是在这个range之内。为什么这么定义呢。如果超多,或过小,则使用range内指明的&#;代替。

第三处(//3):viewDir 意为World Space View Direction。就是当前坐标的视角方向。这里有个从相关网上找的图:链接: color的吧。对!下面那个盒子就是用些shader的效果。

5.Detail Texture

这个最好理解了。

前面三个一样。上一个2D Texture。

最后一个黑体:在原先的反射基础上,在加一层,Texture的反射。

就是这样啦。最后上几个截图,大家一定就明白。

6.Detail Texture in Screen Space

这个比较有趣,是从上个例子的基础上将第二层叠加上的2D Texture根据当前屏幕的UV进行叠加,而不是根据自身的UV。这样带有含此shader材质的物体的贴图就会跟着移动到的位置而变换图片。

这里只需要说三点:

1.关于screenPos:screenPos是一个三维点,但是用齐次坐标的形式表示出来就是(x,y,z,w),根据齐次坐标的性质。(x,y,z,w)的齐次坐标对应三维点(x/w,y/w,z/w)。因此把w&#;除掉可以看来是一种Normalize的作法,这样就取出了实际的屏幕xy的UV&#;。

2.对screenUV进行倍剩:此处剩float2(8,6)意为将原获取到屏幕尺寸进行拉大的倍数。即x轴拉大8倍,y轴拉大6倍。

3.如何就平铺了刚好一行8个,一列6个了呢? 原因我觉得是在于2d Texture自己是按Normalize后进行铺的,因此在//2(刚转完标准的)screenPos后,将其剩多少即便将原图铺多少张。

OK。明了。其实这个东西可以拿来做放大镜的应用。上图:

7. Cubemap reflection

这两段都是加一个cubemap的反射。第二段相比之下是在有normal反射的基础上加的。Cubemap这东西,可设置几种面的不能渲染图,这方面可用于做天空盒。因为这样可以从各个角度看过去以显示不同的渲染效果。

以下说明:

1. worldRefl:即为世界空间的反射向量。

2. texCUBE:将反射向量一个个的往_Cube反射盒上找出然后做为Emission反射出来。

3. 第二个例子只是将其用在Normal反射后,这样一定要多添加一个INTERNAL_DATA的属性,另外也需用到WorldReflectionVectore方法取其利用Normal后的反射向量&#;。

类&#;于的效果,可见官网中的。我这也有一个,有点像打了光的样子。

Unity shader 官网文档全方位学习(一)(unity shader editor)

8.Slices via World Space Position

在看完这段后,我自己另外又加一段,以作对比:

第二个黑体:frac是取小数的函数,如1. 取出来是 0.。clip函数用于清Pixel的,负&#;情况下才进行清pixel。且越小,即绝对&#;越大则清越多。 这里注意那个* 5,仔细一想,如果frac出来的&#;越大,-0.5&#;就越大,绝对&#;就越小,因此这样清掉的pixel越少,所以就可以间接的增加分段的次数。那为什么要&#;IN.worldPos.z*0.1呢,主要原因就是空开的断添加一个倾斜角度,可以用空间思想想下。

我的那段,就是将要clip的坐标换掉,换成屏幕的。这样你移动物体时,clip掉的部分会变化。

最后,上下效果图:

9.Normal Extrusion with Vertex Modifier

这是个自定义vertex的例子,效果可以实现点坐标的放大缩小,以形成肥仔与瘦棍的效果,哈哈。

第一个黑体(//1):添加一个可选参数为vertex,主要是为了给其添加一个函数vert。

第二个黑体(//2):这个_Amount对应开头的那个属性_Amount。具体是个Range&#;,可在shader界面外通过滑动条改变这个&#;。默认为0.5。

第三个黑体(//3):这里除了之前学过的东西外,多了个appdata_full的结构体。这里面的结构(载自UNITY官方论坛)如下:

第四个黑体(//4):就是像为个点,换当前法线向量的指定倍数进行扩展。

上效果:

.Custom data computed per-vertex

这个例子是用来渲染颜色的。我的分析如下:

第一处(//1):取一个颜色&#;,float3,对应RGB。

第二处(//2):较前个例子,多一个Input类型的参数,只为输出使用。

第三处(//3):UNITY_INITIALIZE_OUTPUT(type,name)这个函数大有用处,主要是将叫[name]的变量请空改成type类型。以下是从HLSLSupport.cginc里找到的定义:

第四处(//4):RGB颜色&#;当然只能为正&#;,所以使用绝对&#;去取normal的&#;。

第五处(//5):在原先已经渲染上texture颜色&#;的基础上,加上这层自定义的颜色&#;。

上效果:

.Final Color Modifier

这个例子是跟上面例子的对比,前种使用普通反射进行叠加上颜色,此处则是直接使用finalcolor对其颜色进行处理,这种可以处理整个模型的固定颜色&#;的渲染。以下做简要的分析:

1.finalcolor:mycolor :这个是另一种可选参数,就是用户自定义的颜色处理函数。函数名为mycolor.

2.mycolor函数:注意到函数除了有surf的两个参数外,还多了个颜色参数,这个颜色参数就是当前模型上颜色对象,对他的更改将直接影响全部来自于lightmap,light probe和一些相关资源的颜色&#;。

效果:

.Custom Fog with Final Color Modifier

这个很高难度,里面还有些之前没用到过的函数,以下是我的理解:

第一处(//1):mul是矩阵相乘的函数。UNITY_MATRIX_MVP是model、view、projection三个矩阵相乘出来的4x4的矩阵。v.vertex是一个float4的变量,可理解成4x1的矩阵,两者相乘,则得出一个float4,这个&#;就是视角窗口的坐标&#;,这个坐标就跟camera的关联了。

第二处(//2):这个fog的浮点&#;就是其强度,范围一般在-1到1之间,说一般,只是我个人建议的&#;,设成其他也行,只是没多大意义。越负就越黑。再看后面这个点积,这个仔细一想,不难理解,其实就是为了达到一种扩散的效果,因此两个一样的向量相乘,其实就是直接对坐标做平方扩展,这样fog就更有雾的感觉。

第三处(//3):这个宏不好找,就看官方对这个例子的解释为正向渲染时的额外通道。字面不好理解,多多尝试过可以有所发现,其实就是在雾气渐渐消失处那块额外的渲染区。可以将fogColor = 0; 改成fogColor = fixed3(1,0,0)。外面雾气颜色再选成白色,效果则如下:

雾气改成绿色后:效果如下:

第四处(//4):lerp函数是个有趣的函数。第一个参数是左边界,第二个参数是右边界,第三个相当于一个&#;介于0到1之间的游标。游标为0,则为左边界,为1为右边界,取中间&#;则是以此类推,取插&#;。其实也可以把它看成百分比。这里的fog则可以看来那个游标,&#;越大,则越接近fogColor,越小越接近原色。

原shader所出来的效果再来张:

.Linear Fog

这个官方只贴出了代码,无任何解释。网上也未曾看到有人解答,在此为大家分析下。其实这个与上面那个例子相比之下,采用的fog的源头变了,这里是获取rendersettings里的fog来设置Fog的颜色、强度与起点终点等。以下进行解析:

第一处(//1):LOD ,是个代号,设成此的目的就是限制shader级别只到为止,高过的不采用,即使显卡支持,也不会使用高过的shader级别的渲染方式。官方的解释:

第五处(//5):将4中算得的diff置反过来。

第六处(//6):则将算出来的离视角的距离与0到1之间进行比对,小于0则为0,大于1则为1,范围之内就是其原&#;,总的来说,利用clamp函数防止其出界。

分析下原理:咱们先将rendersetting里的颜色设成红色,fog start 设成0, fog end设成。这时算出的diff = , invdiff = 1/。将原fog的计算稍做简化,得出如下结果:

fog = clamp((1 - pos/) , 0 , 1);这个式子很是明了,pos是距离,即距离越远,clamp里&#;越小,根据后面这句:

我们就可以判断出其越靠近fogColor,雾气就会越重。

最后上个效果图:这里选的是Linear的fog。

到此,所有的surface shader的官方例子都详细的介绍完了。哎,开源中国对cg无什么代码显示支持,大家要代码看不清,可以直接去官网上去面看。

Particle system study section 1 Preview:1.Theparticlesystemexistthephenomenonofscalingwithcameraviewpoint.2.Changethelegacyparticlesystemintonewparticlesystem.Details:1.Aftereffectsparticlesystem.Thetextureofparticlesystemisimageseq

Unity3D-SLua+ProtocolBuffers构建说明 Unity3D-SLuaProtocolBuffers构建说明.因为项目使用lua与protocalbuffer结构的架构。所以近来对lua与protocalbuffer进行了些深入的了解。对构建sluaprotocalbuffer的体会进

C#多线程与Unity中的使用 C#的多线程是一个非常有用的功能,测试如下:(自动加i)usingUnityEngine;usingSystem.Collections;usingSystem.Threading;publicclassTest:MonoBehaviour{ThreadmyThread;//定义的线

标签: unity shader editor

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

上一篇:unity 读取xml 信息(unity 读取xml文件)

下一篇:Particle system study section 1

  • 营业额超500万会罚款吗
  • 税收减免是否属于收入
  • 小微企业免征增值税申报表怎样填
  • 企业奖金会计分录
  • 公司的个人所得税是多少
  • 公司买车计算方式
  • 旅游发票可以抵扣吗
  • 非税收入票据能报销吗
  • 结转本月收入类账户到本年利润会计分录
  • 用于本企业职工的福利应当征收消费税吗
  • 融资租赁租金会计科目
  • 企业外购固定资产的成本包括购买价款和相关税费
  • 支付结算办法主要内容
  • 收到股本的现金怎么做账
  • 收到基金计入什么科目
  • 个税系统中允许捐赠比例是多少?
  • 技术研发费加计扣除政策
  • 办公室零食知乎
  • 企业更换银行卡意味着什么
  • 光伏安装工程公司有哪些
  • 应交税费进项税额在借方说明什么
  • 会计新手入门
  • 出口退税款的账户是什么
  • 关联公司代付款帐怎么做
  • 利息收入会计如何做账
  • 一式三联的收据哪一联要盖财务章
  • win11如何连接网址
  • 考后审核是什么时候
  • i7笔记本cpu性能天梯图
  • 快启动u盘装系统教程
  • php怎么自学
  • pop是什么文件
  • 企业办理银行结汇流程
  • 预收房租需要缴纳个税么
  • 企业所得税涉税风险通知书
  • 制造业成本核算明细表
  • 个人独资企业怎么做账
  • 双轨制会计核算原则
  • 一场雷雨还是一阵雷雨
  • php使用while循环计算1到100的和
  • axure简单教程
  • gpt3 plug
  • thinkphp自动加载类
  • css 3有哪些新特性
  • 兼职人员的工资怎么做账
  • 为什么选择我们公司
  • 以前年度的企业所得税怎么入账
  • 发票一式两联
  • 营业外支出增加记借方还是贷方
  • 库存商品可以领用加工吗
  • mysql常用语
  • 建安企业费用有哪些
  • 自产产品用于业务招待费
  • 暂估金额为含税金额
  • 免费样品销售给客户怎么入账
  • 应交消费税等于
  • mysql 分组语句
  • mysql5.6解压版安装教程
  • linux系统vim编辑readonly option
  • win7如何给电脑硬盘加密
  • vistaie9安装所需更新补丁
  • Windows Server 2008病毒偷改账号的安全隐患
  • 苹果正式推送ios
  • win10网络身份验证失败
  • linux open o_direct
  • apache zipfile
  • win7能不能安装vs2019
  • 怎么删除windows7
  • 加载的读音
  • linux igb
  • linux和windows的区别?
  • jquery的css方法
  • 批处理调用ftp
  • unity打包64位出错
  • 欢迎使用来电提醒业务是什么意思
  • android知识点大全
  • 如何动态加载外部文件
  • 残疾人拿药能报销吗?
  • 小规模税控盘服务费怎么填增值税申报表
  • 智能财税证书含金量如何
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设