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. React Native 错误锦集

    启动时报错 : React Native version mismatch. JavaScript version: 0.57.4 Native version: 0.55.2 解决方案传送门:htt ...

  2. VB将MSHFlexGrid数据导出到Excel文件通用功能

    1.通用导出Excel功能. 2.将 MSHFlexGrid数据导出到Excel文件通用功能. 3.具体代码如下: '将下列代码保存到一模块文件中,调用方法:Export fgrid1,cd1 Pub ...

  3. django ---- models继承

    django 中各个models之前可以有继承关系.这种继承关系又可以分成三种情况: 1.简单继承 2.抽象继承 3.代理 一.简单继承: model定义 from django.db import ...

  4. vim的全局替换[zz]&把字符替换成回车

    本文出自   http://blog.csdn.net/shuangde800   本文是在学习<使用vi编辑器, Lamb & Robbins编著>时在所记的笔记.   本文内容 ...

  5. WPF使用System.Windows.SystemParameters类获得屏幕分辨率

    转自 http://hi.baidu.com/shirley_cst/item/a55c290c8aa2ee2ca0312da3 示例代码如下所示. double x = SystemParamete ...

  6. 三星 S4 手机误删除相片(相册)后的恢复问题,仅记录处理过程,其它Android手机同样适用

    无意中删除了三星S4手机中相机的相册.过程是这样的,用手机拍了几张照片,觉得最后那张拍得不好,想删除,于是进入相册,看到有那张照片的图标,选择,删除,悲剧发生了! 这里得说三星的不好:在相册中,相册文 ...

  7. Atitti opencv2.4 实现的人脸检测 attilax总结

    Atitti opencv2.4 实现的人脸检测 attilax总结 1.1. 1.OpenCV人脸检测的方法1 1.2. /atiplat_img/src/com/attilax/facedetec ...

  8. [svc]ssh+gg二步认证

    1,安装依赖 yum install python-pip -y pip install docutils yum install gcc python-devel subversion pam pa ...

  9. HTTP 错误 404.13 - Not Found 请求筛选模块被配置为拒绝超过请求内容长度的请求。

    问题:HTTP 错误 404.13 - Not Found 请求筛选模块被配置为拒绝超过请求内容长度的请求. 原因:Web 服务器上的请求筛选被配置为拒绝该请求,因为内容长度超过配置的值(IIS 7 ...

  10. 行为类模式(七):观察者(Observer)

    定义 定义对象间一种一对多的依赖关系,使得当每一个对象改变状态,则所有依赖于它的对象都会得到通知并自动更新. UML 优点 观察者和被观察者之间是松耦合的,分别可以各自独立改变. Subject在发送 ...