LOD:

设置:单个设置Shader.maximumLOD、全局设置Shader.globalMaximumLOD、QualitySettings里面的Maximum LODLevel
原理:小于指定值的shader和subshader才能被使用。
应用:有时候一些显卡虽然支持很多特性,但是效率很低,此时就可以用LOD来进行控制。
内置shader的LOD值:
  VertexLit kind of shaders = 100
  Decal, Reflective VertexLit = 150
  Diffuse = 200
  Diffuse Detail, Reflective Bumped Unlit, Reflective Bumped VertexLit = 250
  Bumped, Specular = 300
  Bumped Specular = 400
  Parallax = 500
  Parallax Specular = 600

注释:Shader自身的LOD会覆盖全局的LOD。

    public Shader targetShader;

    private void Start ()
{
// 全局的值会被Shader本地址覆盖
Shader.globalMaximumLOD = ;
if (targetShader != null)
{
targetShader.maximumLOD = ;
}
}

RenderQueue:

    mtrl.renderQueue = ;

  shader中使用ZTest Always,可以让被遮住的物体也渲染。

AlphaTest:

  固定管线:使用AlphaTest命令

  动态管线:使用clip(alpha - cutoff)指令来实现

  Alpha检测在ps完成计后,即将写入帧之前,通过和一个固定的数值比较,来决定当前ps的计算结果到底要不要写入帧中。

// inside SubShader
Tags { "Queue"="AlphaTest" "RenderType"="TransparentCutout" "IgnoreProjector"="True" } // inside CGPROGRAM in the fragment Shader:
clip(textureColor.a - alphaCutoffValue);

  AlphaTest抗锯齿:

// inside SubShader
Tags { "Queue"="AlphaTest" "RenderType"="TransparentCutout" "IgnoreProjector"="True" } // inside Pass
AlphaToMask On

AlphaBlend:

  shader渲染的最后一步,决定怎样将当前计算结果写入到帧缓存中。

  命令集:

  Blend BlendOp AlplaToMask

// inside SubShader
Tags { "Queue"="Transparent" "RenderType"="Transparent" "IgnoreProjector"="True" } // inside Pass
ZWrite Off
Blend SrcAlpha OneMinusSrcAlpha

  AlphaBlend会有一系列和绘制顺序相关的问题,涉及到的知识点如下:

  (1)Unity通过Queue保证所有的不透明物体Geometry都会在半透明物体Transparent之前被渲染,(Queue标签决定了这个对象的渲染队列);

  (2)Unity保证所有Transparent队列的物体,按distance(物体的远近,不是像素的)从后往前渲染;

  (3)distance的计算方式:使用网格的几何中心点来进行半透明物体的排序。

  对于部分遮挡的物体,还是会产生不正确的遮挡效果。因此我们要么分割网格,要么使用Alpha Test或者开启ZWrite来替代。

AlphaTest和AlphaBlend的性能比较:

  官方文档在这里:https://docs.unity3d.com/Manual/SL-ShaderPerformance.html

  翻译如下:

  固定管线的AlphaTest和可编程管线的clip()函数,在不同平台有不同性能表现:

  (1)多数平台上,AlphaTest这种整个剔除透明像素的做法能获得一点点性能优势;

  (2)在ios和android这样基于PowerVR GUPs的设备上,AlphaTest是非常耗资源的,不要企图使用它来做性能优化,因为它会让游戏更慢(是因为直接丢掉像素,让GPUs的某些优化策略没法执行了)。

  所以结论是:手机上尽量使用AlphaBlend而不是AlphaTest。

ColorMask:

  ColorMask RGB | A | 0 | any combination of R, G, B, A

  ColorMask也是耗费比较大的操作,只在确实需要时使用。

ZWrite/ZTest:

  ZWrite On | Off

  ZTest Less | Greater | LEqual | GEqual | Equal | NotEqual | Always

  关于相机的深度贴图_CameraDepthTexture:

  (1)默认材质都自带RenderType的Tag;

  (2)自定义sahder只有添加RenderType标签才会将深度写到_CameraDepthTexture。

Offset:

  对Z深度的偏移。

  可以让像素看起来更靠前或更靠后,当两个面重叠时,可以手动指定谁相对靠前一些,而且不会战胜z-fitting。

  Offset只会对ZTest的条件做修正,但是并不会改变最后的Z缓冲。

GrabPass:

  抓取当前屏幕当做贴图使用。

Shader "James/VP Shader/GrabPass"
{
Properties
{
_MainTex("MainTex", 2D) = "white" {}
}
SubShader
{
// 在所有不透明几何体之后自画,这一点很重要
Tags { "Queue" = "Transparent" }
GrabPass { "_MyGrab" }
Pass
{
CGPROGRAM
#pragma vertex vs
#pragma fragment ps
#include "UnityCG.cginc" struct v2f
{
float4 pos : SV_POSITION;
float3 color : COLOR0;
float2 uv : TEXCOORD0;
}; sampler2D _MainTex;
float4 _MainTex_ST;
sampler2D _MyGrab; v2f vs(appdata_base v)
{
v2f o;
o.pos = mul (UNITY_MATRIX_MVP, v.vertex);
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
return o;
} float4 ps(v2f i):COLOR
{
float4 texColor = tex2D(_MainTex, i.uv);
float4 grabColor = tex2D(_MyGrab, i.uv);
return texColor * grabColor;
}
ENDCG
}
}
FallBack "Diffuse"
}

Fog:

  雾效实现的三种方式:

  (1)全局雾

  RenderSettings.fog = true;
RenderSettings.fogColor = Color.red;
RenderSettings.fogMode = FogMode.Linear;
RenderSettings.fogStartDistance = ;
RenderSettings.fogEndDistance = ;

  (2)Fog指令

  Fog{ Mode Linear Color(, , ) Range ,  }

  (3)Shader计算方式

Shader "James/VP Shader/Fog"
{
Properties {
_MainTex ("Base (RGB)", 2D) = "white" {}
_FogColor("FogColor", Color) = (, , , )
_Density("Density", Range(, )) =
_NearDistance("NearDistance", Float) =
_FarDistance("FarDistance", Float) =
}
SubShader {
Tags { "RenderType"="Opaque" }
Fog { Mode Off }
Pass
{
CGPROGRAM
#pragma vertex vs
#pragma fragment ps
#include "UnityCG.cginc" struct v2f
{
float4 pos : SV_POSITION;
float3 color : COLOR0;
float2 uv : TEXCOORD0;
float4 depth : TEXCOORD1;
}; sampler2D _MainTex;
float4 _MainTex_ST;
float4 _FogColor;
float _Density;
float _NearDistance;
float _FarDistance; v2f vs(appdata_base v)
{
v2f o;
o.pos = mul (UNITY_MATRIX_MVP, v.vertex);
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
o.depth = mul(UNITY_MATRIX_MV, v.vertex);
o.depth.z = -o.depth.z;
o.depth.w = (_FarDistance - _NearDistance) * o.depth.w;
return o;
} float4 ps(v2f i):COLOR
{
float4 texColor = tex2D(_MainTex, i.uv);
float fg = ;
if(i.depth.z > _NearDistance && i.depth.z < _FarDistance)
{
fg = i.depth.z / i.depth.w;
}
else if(i.depth.z > _FarDistance)
{
fg = _FarDistance / i.depth.w;
}
return fg * _Density * _FogColor * texColor;
}
ENDCG
}
}
FallBack "Diffuse"
}

Stencil:

  Stencil-Test在Z-Test和Alpha-Test之前,如果模板检测不通过,则像素直接被丢掉而不会执行fragment函数。

Shader "James/VP Shader/Stencil"
{
Properties {
_MainTex ("Base (RGB)", 2D) = "white" {}
_refVal("Stencil Ref Value",int)=
}
SubShader {
Tags { "RenderType"="Opaque" }
ZTest Always
Stencil
{
Ref [_refVal]
Comp GEqual
Pass Replace
Fail keep
ZFail keep
}
Pass
{
CGPROGRAM
#pragma vertex vs
#pragma fragment ps
#include "UnityCG.cginc" struct v2f
{
float4 pos : SV_POSITION;
float3 color : COLOR0;
float2 uv : TEXCOORD0;
}; sampler2D _MainTex;
float4 _MainTex_ST; v2f vs(appdata_base v)
{
v2f o;
o.pos = mul (UNITY_MATRIX_MVP, v.vertex);
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
return o;
} float4 ps(v2f i):COLOR
{
float4 texColor = tex2D(_MainTex, i.uv);
return texColor;
}
ENDCG
}
}
FallBack "Diffuse"
}

Pass的通用指令开关的更多相关文章

  1. 关于Unity中混合模式、Alpha测试、深度测试、通道遮罩、面剔除的使用----渲染通道通用指令(二)

    混合模式 着色完成后,需要把颜色混合到帧缓冲区里面,涉及到源和目标. 1:在所有计算完成后,决定当前的计算结果输出到帧缓冲区时,如何混合源和目标,通常用来绘制半透明的物体;2: Blend Off 关 ...

  2. U3D shaderlab 相关指令开关

    Subshader { [Tags] [CommonState] Passdef [Passdef ...] }Tags分为SubShader Tags和Pass Tags,Tags放在SubShad ...

  3. Groovy脚本-通用SQL开关

    备注:使用Groovy语言进行编写,看不懂的同学请先了解Groovy脚本. Groovy学习地址:https://www.cnblogs.com/tiechui2015/p/10828457.html ...

  4. 关于Unity中LOD和渲染队列----渲染通道通用指令(一)

    每个shader里面有很多的subshader,如果所以的subshader都不执行的话就,就执行fallback.每个subshader都可以设置一个LOD,整个shader也有一个LOD. 系统就 ...

  5. AIX 第3章 指令记录

    [ssdb01.shz.hn|oracle|/home/oracle]$oslevel -rq  --查看系统已安装的维护级别 Known Recommended Maintenance Levels ...

  6. [三] java虚拟机 JVM字节码 指令集 bytecode 操作码 指令分类用法 助记符

    说明,本文的目的在于从宏观逻辑上介绍清楚绝大多数的字节码指令的含义以及分类 只要认真阅读本文必然能够对字节码指令集有所了解 如果需要了解清楚每一个指令的具体详尽用法,请参阅虚拟机规范 指令简介 计算机 ...

  7. Delphi中PointerMath指令

    Type   Switch   Syntax   {$POINTERMATH ON} or {$POINTERMATH OFF}   Default   {$POINTERMATH OFF}   Sc ...

  8. Redis指令与数据结构(二)

    0.Redis目录结构 1)Redis介绍及部署在CentOS7上(一) 2)Redis指令与数据结构(二) 3)Redis客户端连接以及持久化数据(三) 4)Redis高可用之主从复制实践(四) 5 ...

  9. 深入理解java虚拟机(六)字节码指令简介

    Java虚拟机指令是由(占用一个字节长度.代表某种特定操作含义的数字)操作码Opcode,以及跟随在其后的零至多个代表此操作所需参数的称为操作数 Operands 构成的.由于Java虚拟机是面向操作 ...

随机推荐

  1. C#基础第六天-作业答案-利用面向对象的思想去实现名片

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  2. jmeter Best Practices

    性能测试最佳实践之JMeter 16. Best Practices 16.1 Always use latest version of JMeter The performance of JMete ...

  3. Hadoop JobTracker和NameNode运行时参数查看

      1)JobTracker运行时参数: hadoop@ubuntu:/home/zhangchao3$ ps -ef | grep job hadoop 29563 1 0 11:34 pts/12 ...

  4. 《Java Concurrency》读书笔记,使用JDK并发包构建程序

    1. java.util.concurrent概述 JDK5.0以后的版本都引入了高级并发特性,大多数的特性在java.util.concurrent包中,是专门用于多线并发编程的,充分利用了现代多处 ...

  5. cocos2d-x 模态对话框的实现

    心情不好,恩.不扯淡了.直接讲. ================================== 在泰然看了一篇实现模态对话框的文章,写的还不错,然后在其基础上加了我简单加了一层灰色透明背景,这 ...

  6. 外部程序启动App

    第一种:直接通过包名: Intent LaunchIntent = getPackageManager().getLaunchIntentForPackage("com.joyodream. ...

  7. pyenv管理多python版本

    手动安装 cd ~ git clone git://github.com/yyuu/pyenv.git .pyenv echo 'export PYENV_ROOT="$HOME/.pyen ...

  8. Replace 在动态sql中的实现

    set @stsqlReplace=' update ChgCfm set cfmdate=replace(cfmdate,'''''''',''''), cfmstatu=replace(cfmst ...

  9. pandas数组和numpy数组在使用索引数组过滤数组时的区别

    numpy array 过滤后的数组,索引值从 0 开始. pandas Series 过滤后的 Series ,保持原来的索引,原来索引是几,就是几. 什么意思呢,来看个栗子: import num ...

  10. linux命令(39):shell 打印偶数行,奇数行 ,行号

    awk 命令: 1. 打印行号和内容: awk '{print NR":"$0}' 2. 输出:偶数行和奇数行到文件 awk '{print $0.txt > NR%2.tx ...