1260 lines
51 KiB
GLSL
1260 lines
51 KiB
GLSL
// Copyright (c) Microsoft Corporation.
|
|
// Licensed under the MIT License.
|
|
|
|
// NOTE: MRTK Shaders are versioned via the MRTK.Shaders.sentinel file.
|
|
// When making changes to any shader's source file, the value in the sentinel _must_ be incremented.
|
|
|
|
Shader "Mixed Reality Toolkit/Standard"
|
|
{
|
|
Properties
|
|
{
|
|
// Main maps.
|
|
_Color("Color", Color) = (1.0, 1.0, 1.0, 1.0)
|
|
_MainTex("Albedo", 2D) = "white" {}
|
|
[Enum(AlbedoAlphaMode)] _AlbedoAlphaMode("Albedo Alpha Mode", Float) = 0 // "Transparency"
|
|
[Toggle] _AlbedoAssignedAtRuntime("Albedo Assigned at Runtime", Float) = 0.0
|
|
_Cutoff("Alpha Cutoff", Range(0.0, 1.0)) = 0.5
|
|
_Metallic("Metallic", Range(0.0, 1.0)) = 0.0
|
|
_Smoothness("Smoothness", Range(0.0, 1.0)) = 0.5
|
|
[Toggle(_CHANNEL_MAP)] _EnableChannelMap("Enable Channel Map", Float) = 0.0
|
|
[NoScaleOffset] _ChannelMap("Channel Map", 2D) = "white" {}
|
|
[Toggle(_NORMAL_MAP)] _EnableNormalMap("Enable Normal Map", Float) = 0.0
|
|
[NoScaleOffset] _NormalMap("Normal Map", 2D) = "bump" {}
|
|
_NormalMapScale("Scale", Float) = 1.0
|
|
[Toggle(_EMISSION)] _EnableEmission("Enable Emission", Float) = 0.0
|
|
[HDR]_EmissiveColor("Emissive Color", Color) = (0.0, 0.0, 0.0, 1.0)
|
|
[Toggle(_TRIPLANAR_MAPPING)] _EnableTriplanarMapping("Triplanar Mapping", Float) = 0.0
|
|
[Toggle(_USE_SSAA)] _EnableSSAA("Super Sample Anti Aliasing", Float) = 0.0
|
|
_MipmapBias("Mipmap Bias", Range(-5.0, 0.0)) = -2.0
|
|
[Toggle(_LOCAL_SPACE_TRIPLANAR_MAPPING)] _EnableLocalSpaceTriplanarMapping("Local Space", Float) = 0.0
|
|
_TriplanarMappingBlendSharpness("Blend Sharpness", Range(1.0, 16.0)) = 4.0
|
|
|
|
// Rendering options.
|
|
[Toggle(_DIRECTIONAL_LIGHT)] _DirectionalLight("Directional Light", Float) = 1.0
|
|
[Toggle(_SPECULAR_HIGHLIGHTS)] _SpecularHighlights("Specular Highlights", Float) = 1.0
|
|
[Toggle(_SPHERICAL_HARMONICS)] _SphericalHarmonics("Spherical Harmonics", Float) = 0.0
|
|
[Toggle(_REFLECTIONS)] _Reflections("Reflections", Float) = 0.0
|
|
[Toggle(_REFRACTION)] _Refraction("Refraction", Float) = 0.0
|
|
_RefractiveIndex("Refractive Index", Range(0.0, 3.0)) = 0.0
|
|
[Toggle(_RIM_LIGHT)] _RimLight("Rim Light", Float) = 0.0
|
|
_RimColor("Rim Color", Color) = (0.5, 0.5, 0.5, 1.0)
|
|
_RimPower("Rim Power", Range(0.0, 8.0)) = 0.25
|
|
[Toggle(_VERTEX_COLORS)] _VertexColors("Vertex Colors", Float) = 0.0
|
|
[Toggle(_VERTEX_EXTRUSION)] _VertexExtrusion("Vertex Extrusion", Float) = 0.0
|
|
_VertexExtrusionValue("Vertex Extrusion Value", Float) = 0.0
|
|
[Toggle(_VERTEX_EXTRUSION_SMOOTH_NORMALS)] _VertexExtrusionSmoothNormals("Vertex Extrusion Smooth Normals", Float) = 0.0
|
|
_BlendedClippingWidth("Blended Clipping With", Range(0.0, 10.0)) = 1.0
|
|
[Toggle(_CLIPPING_BORDER)] _ClippingBorder("Clipping Border", Float) = 0.0
|
|
_ClippingBorderWidth("Clipping Border Width", Range(0.0, 1.0)) = 0.025
|
|
_ClippingBorderColor("Clipping Border Color", Color) = (1.0, 0.2, 0.0, 1.0)
|
|
[Toggle(_NEAR_PLANE_FADE)] _NearPlaneFade("Near Plane Fade", Float) = 0.0
|
|
[Toggle(_NEAR_LIGHT_FADE)] _NearLightFade("Near Light Fade", Float) = 0.0
|
|
_FadeBeginDistance("Fade Begin Distance", Range(0.0, 10.0)) = 0.85
|
|
_FadeCompleteDistance("Fade Complete Distance", Range(0.0, 10.0)) = 0.5
|
|
_FadeMinValue("Fade Min Value", Range(0.0, 1.0)) = 0.0
|
|
|
|
// Fluent options.
|
|
[Toggle(_HOVER_LIGHT)] _HoverLight("Hover Light", Float) = 1.0
|
|
[Toggle(_HOVER_COLOR_OVERRIDE)] _EnableHoverColorOverride("Hover Color Override", Float) = 0.0
|
|
_HoverColorOverride("Hover Color Override", Color) = (1.0, 1.0, 1.0, 1.0)
|
|
[Toggle(_PROXIMITY_LIGHT)] _ProximityLight("Proximity Light", Float) = 0.0
|
|
[Toggle(_PROXIMITY_LIGHT_COLOR_OVERRIDE)] _EnableProximityLightColorOverride("Proximity Light Color Override", Float) = 0.0
|
|
[HDR]_ProximityLightCenterColorOverride("Proximity Light Center Color Override", Color) = (1.0, 0.0, 0.0, 0.0)
|
|
[HDR]_ProximityLightMiddleColorOverride("Proximity Light Middle Color Override", Color) = (0.0, 1.0, 0.0, 0.5)
|
|
[HDR]_ProximityLightOuterColorOverride("Proximity Light Outer Color Override", Color) = (0.0, 0.0, 1.0, 1.0)
|
|
[Toggle(_PROXIMITY_LIGHT_SUBTRACTIVE)] _ProximityLightSubtractive("Proximity Light Subtractive", Float) = 0.0
|
|
[Toggle(_PROXIMITY_LIGHT_TWO_SIDED)] _ProximityLightTwoSided("Proximity Light Two Sided", Float) = 0.0
|
|
_FluentLightIntensity("Fluent Light Intensity", Range(0.0, 1.0)) = 1.0
|
|
[Toggle(_ROUND_CORNERS)] _RoundCorners("Round Corners", Float) = 0.0
|
|
_RoundCornerRadius("Round Corner Radius", Range(0.0, 0.5)) = 0.25
|
|
_RoundCornerMargin("Round Corner Margin", Range(0.0, 0.5)) = 0.01
|
|
[Toggle(_INDEPENDENT_CORNERS)] _IndependentCorners("Independent Corners", Float) = 0.0
|
|
_RoundCornersRadius("Round Corners Radius", Vector) = (0.5 ,0.5, 0.5, 0.5)
|
|
[Toggle(_BORDER_LIGHT)] _BorderLight("Border Light", Float) = 0.0
|
|
[Toggle(_BORDER_LIGHT_USES_HOVER_COLOR)] _BorderLightUsesHoverColor("Border Light Uses Hover Color", Float) = 0.0
|
|
[Toggle(_BORDER_LIGHT_REPLACES_ALBEDO)] _BorderLightReplacesAlbedo("Border Light Replaces Albedo", Float) = 0.0
|
|
[Toggle(_BORDER_LIGHT_OPAQUE)] _BorderLightOpaque("Border Light Opaque", Float) = 0.0
|
|
_BorderWidth("Border Width", Range(0.0, 1.0)) = 0.1
|
|
_BorderMinValue("Border Min Value", Range(0.0, 1.0)) = 0.1
|
|
_EdgeSmoothingValue("Edge Smoothing Value", Range(0.0, 0.2)) = 0.002
|
|
_BorderLightOpaqueAlpha("Border Light Opaque Alpha", Range(0.0, 1.0)) = 1.0
|
|
[Toggle(_INNER_GLOW)] _InnerGlow("Inner Glow", Float) = 0.0
|
|
_InnerGlowColor("Inner Glow Color (RGB) and Intensity (A)", Color) = (1.0, 1.0, 1.0, 0.75)
|
|
_InnerGlowPower("Inner Glow Power", Range(2.0, 32.0)) = 4.0
|
|
[Toggle(_IRIDESCENCE)] _Iridescence("Iridescence", Float) = 0.0
|
|
[NoScaleOffset] _IridescentSpectrumMap("Iridescent Spectrum Map", 2D) = "white" {}
|
|
_IridescenceIntensity("Iridescence Intensity", Range(0.0, 1.0)) = 0.5
|
|
_IridescenceThreshold("Iridescence Threshold", Range(0.0, 1.0)) = 0.05
|
|
_IridescenceAngle("Iridescence Angle", Range(-0.78, 0.78)) = -0.78
|
|
[Toggle(_ENVIRONMENT_COLORING)] _EnvironmentColoring("Environment Coloring", Float) = 0.0
|
|
_EnvironmentColorThreshold("Environment Color Threshold", Range(0.0, 3.0)) = 1.5
|
|
_EnvironmentColorIntensity("Environment Color Intensity", Range(0.0, 1.0)) = 0.5
|
|
_EnvironmentColorX("Environment Color X (RGB)", Color) = (1.0, 0.0, 0.0, 1.0)
|
|
_EnvironmentColorY("Environment Color Y (RGB)", Color) = (0.0, 1.0, 0.0, 1.0)
|
|
_EnvironmentColorZ("Environment Color Z (RGB)", Color) = (0.0, 0.0, 1.0, 1.0)
|
|
|
|
// Advanced options.
|
|
[Enum(RenderingMode)] _Mode("Rendering Mode", Float) = 0 // "Opaque"
|
|
[Enum(CustomRenderingMode)] _CustomMode("Mode", Float) = 0 // "Opaque"
|
|
[Enum(UnityEngine.Rendering.BlendMode)] _SrcBlend("Source Blend", Float) = 1 // "One"
|
|
[Enum(UnityEngine.Rendering.BlendMode)] _DstBlend("Destination Blend", Float) = 0 // "Zero"
|
|
[Enum(UnityEngine.Rendering.BlendOp)] _BlendOp("Blend Operation", Float) = 0 // "Add"
|
|
[Enum(UnityEngine.Rendering.CompareFunction)] _ZTest("Depth Test", Float) = 4 // "LessEqual"
|
|
[Enum(DepthWrite)] _ZWrite("Depth Write", Float) = 1 // "On"
|
|
_ZOffsetFactor("Depth Offset Factor", Float) = 0 // "Zero"
|
|
_ZOffsetUnits("Depth Offset Units", Float) = 0 // "Zero"
|
|
[Enum(UnityEngine.Rendering.ColorWriteMask)] _ColorWriteMask("Color Write Mask", Float) = 15 // "All"
|
|
[Enum(UnityEngine.Rendering.CullMode)] _CullMode("Cull Mode", Float) = 2 // "Back"
|
|
_RenderQueueOverride("Render Queue Override", Range(-1.0, 5000)) = -1
|
|
[Toggle(_IGNORE_Z_SCALE)] _IgnoreZScale("Ignore Z Scale", Float) = 0.0
|
|
[Toggle(_STENCIL)] _Stencil("Enable Stencil Testing", Float) = 0.0
|
|
_StencilReference("Stencil Reference", Range(0, 255)) = 0
|
|
[Enum(UnityEngine.Rendering.CompareFunction)]_StencilComparison("Stencil Comparison", Int) = 0
|
|
[Enum(UnityEngine.Rendering.StencilOp)]_StencilOperation("Stencil Operation", Int) = 0
|
|
}
|
|
|
|
SubShader
|
|
{
|
|
Pass
|
|
{
|
|
Name "Main"
|
|
Tags{ "RenderType" = "Opaque" "LightMode" = "ForwardBase" }
|
|
LOD 100
|
|
Blend[_SrcBlend][_DstBlend]
|
|
BlendOp[_BlendOp]
|
|
ZTest[_ZTest]
|
|
ZWrite[_ZWrite]
|
|
Cull[_CullMode]
|
|
Offset[_ZOffsetFactor],[_ZOffsetUnits]
|
|
ColorMask[_ColorWriteMask]
|
|
|
|
Stencil
|
|
{
|
|
Ref[_StencilReference]
|
|
Comp[_StencilComparison]
|
|
Pass[_StencilOperation]
|
|
}
|
|
|
|
CGPROGRAM
|
|
|
|
#pragma vertex vert
|
|
#pragma fragment frag
|
|
|
|
#pragma multi_compile_instancing
|
|
#pragma multi_compile _ LIGHTMAP_ON
|
|
#pragma multi_compile _ UNITY_UI_CLIP_RECT
|
|
#pragma multi_compile _ _HOVER_LIGHT_MEDIUM _HOVER_LIGHT_HIGH
|
|
#pragma multi_compile _ _CLIPPING_PLANE _CLIPPING_SPHERE _CLIPPING_BOX
|
|
|
|
#pragma shader_feature _ _ALPHATEST_ON _ALPHABLEND_ON
|
|
#pragma shader_feature _DISABLE_ALBEDO_MAP
|
|
#pragma shader_feature _ _METALLIC_TEXTURE_ALBEDO_CHANNEL_A _SMOOTHNESS_TEXTURE_ALBEDO_CHANNEL_A
|
|
#pragma shader_feature _CHANNEL_MAP
|
|
#pragma shader_feature _NORMAL_MAP
|
|
#pragma shader_feature _EMISSION
|
|
#pragma shader_feature _TRIPLANAR_MAPPING
|
|
#pragma shader_feature _LOCAL_SPACE_TRIPLANAR_MAPPING
|
|
#pragma shader_feature _USE_SSAA
|
|
#pragma shader_feature _DIRECTIONAL_LIGHT
|
|
#pragma shader_feature _SPECULAR_HIGHLIGHTS
|
|
#pragma shader_feature _SPHERICAL_HARMONICS
|
|
#pragma shader_feature _REFLECTIONS
|
|
#pragma shader_feature _REFRACTION
|
|
#pragma shader_feature _RIM_LIGHT
|
|
#pragma shader_feature _VERTEX_COLORS
|
|
#pragma shader_feature _VERTEX_EXTRUSION
|
|
#pragma shader_feature _VERTEX_EXTRUSION_SMOOTH_NORMALS
|
|
#pragma shader_feature _CLIPPING_BORDER
|
|
#pragma shader_feature _NEAR_PLANE_FADE
|
|
#pragma shader_feature _NEAR_LIGHT_FADE
|
|
#pragma shader_feature _HOVER_LIGHT
|
|
#pragma shader_feature _HOVER_COLOR_OVERRIDE
|
|
#pragma shader_feature _PROXIMITY_LIGHT
|
|
#pragma shader_feature _PROXIMITY_LIGHT_COLOR_OVERRIDE
|
|
#pragma shader_feature _PROXIMITY_LIGHT_SUBTRACTIVE
|
|
#pragma shader_feature _PROXIMITY_LIGHT_TWO_SIDED
|
|
#pragma shader_feature _ROUND_CORNERS
|
|
#pragma shader_feature _INDEPENDENT_CORNERS
|
|
#pragma shader_feature _BORDER_LIGHT
|
|
#pragma shader_feature _BORDER_LIGHT_USES_HOVER_COLOR
|
|
#pragma shader_feature _BORDER_LIGHT_REPLACES_ALBEDO
|
|
#pragma shader_feature _BORDER_LIGHT_OPAQUE
|
|
#pragma shader_feature _INNER_GLOW
|
|
#pragma shader_feature _IRIDESCENCE
|
|
#pragma shader_feature _ENVIRONMENT_COLORING
|
|
#pragma shader_feature _IGNORE_Z_SCALE
|
|
|
|
#include "UnityCG.cginc"
|
|
#include "UnityUI.cginc"
|
|
#include "UnityStandardConfig.cginc"
|
|
#include "UnityStandardUtils.cginc"
|
|
#include "MixedRealityShaderUtils.cginc"
|
|
|
|
// This define will get commented in by the UpgradeShaderForUniversalRenderPipeline method.
|
|
//#define _RENDER_PIPELINE
|
|
|
|
#if defined(_TRIPLANAR_MAPPING) || defined(_DIRECTIONAL_LIGHT) || defined(_SPHERICAL_HARMONICS) || defined(_REFLECTIONS) || defined(_RIM_LIGHT) || defined(_PROXIMITY_LIGHT) || defined(_ENVIRONMENT_COLORING)
|
|
#define _NORMAL
|
|
#else
|
|
#undef _NORMAL
|
|
#endif
|
|
|
|
#if defined(_CLIPPING_PLANE) || defined(_CLIPPING_SPHERE) || defined(_CLIPPING_BOX)
|
|
#define _CLIPPING_PRIMITIVE
|
|
#else
|
|
#undef _CLIPPING_PRIMITIVE
|
|
#endif
|
|
|
|
#if defined(_NORMAL) || defined(_CLIPPING_PRIMITIVE) || defined(_NEAR_PLANE_FADE) || defined(_HOVER_LIGHT) || defined(_PROXIMITY_LIGHT)
|
|
#define _WORLD_POSITION
|
|
#else
|
|
#undef _WORLD_POSITION
|
|
#endif
|
|
|
|
#if defined(UNITY_UI_CLIP_RECT)
|
|
#define _LOCAL_POSITION
|
|
#else
|
|
#undef _LOCAL_POSITION
|
|
#endif
|
|
|
|
#if defined(_ALPHATEST_ON) || defined(UNITY_UI_CLIP_RECT) || defined(_CLIPPING_PRIMITIVE) || defined(_ROUND_CORNERS)
|
|
#define _ALPHA_CLIP
|
|
#else
|
|
#undef _ALPHA_CLIP
|
|
#endif
|
|
|
|
#if defined(_ALPHABLEND_ON)
|
|
#define _TRANSPARENT
|
|
#undef _ALPHA_CLIP
|
|
#else
|
|
#undef _TRANSPARENT
|
|
#endif
|
|
|
|
#if defined(_VERTEX_EXTRUSION) || defined(_ROUND_CORNERS) || defined(_BORDER_LIGHT)
|
|
#define _SCALE
|
|
#else
|
|
#undef _SCALE
|
|
#endif
|
|
|
|
#if defined(_DIRECTIONAL_LIGHT) || defined(_RIM_LIGHT)
|
|
#define _FRESNEL
|
|
#else
|
|
#undef _FRESNEL
|
|
#endif
|
|
|
|
#if defined(_ROUND_CORNERS) || defined(_BORDER_LIGHT) || defined(_INNER_GLOW)
|
|
#define _DISTANCE_TO_EDGE
|
|
#else
|
|
#undef _DISTANCE_TO_EDGE
|
|
#endif
|
|
|
|
#if !defined(_DISABLE_ALBEDO_MAP) || defined(_TRIPLANAR_MAPPING) || defined(_CHANNEL_MAP) || defined(_NORMAL_MAP) || defined(_DISTANCE_TO_EDGE) || defined(_IRIDESCENCE)
|
|
#define _UV
|
|
#else
|
|
#undef _UV
|
|
#endif
|
|
|
|
struct appdata_t
|
|
{
|
|
float4 vertex : POSITION;
|
|
// The default UV channel used for texturing.
|
|
float2 uv : TEXCOORD0;
|
|
#if defined(LIGHTMAP_ON)
|
|
// Reserved for Unity's light map UVs.
|
|
float2 uv1 : TEXCOORD1;
|
|
#endif
|
|
// Used for smooth normal data (or UGUI scaling data).
|
|
float4 uv2 : TEXCOORD2;
|
|
// Used for UGUI scaling data.
|
|
float2 uv3 : TEXCOORD3;
|
|
#if defined(_VERTEX_COLORS)
|
|
fixed4 color : COLOR0;
|
|
#endif
|
|
fixed3 normal : NORMAL;
|
|
#if defined(_NORMAL_MAP)
|
|
fixed4 tangent : TANGENT;
|
|
#endif
|
|
UNITY_VERTEX_INPUT_INSTANCE_ID
|
|
};
|
|
|
|
struct v2f
|
|
{
|
|
float4 position : SV_POSITION;
|
|
#if defined(_BORDER_LIGHT)
|
|
float4 uv : TEXCOORD0;
|
|
#elif defined(_UV)
|
|
float2 uv : TEXCOORD0;
|
|
#endif
|
|
#if defined(LIGHTMAP_ON)
|
|
float2 lightMapUV : TEXCOORD1;
|
|
#endif
|
|
#if defined(_VERTEX_COLORS)
|
|
fixed4 color : COLOR0;
|
|
#endif
|
|
#if defined(_SPHERICAL_HARMONICS)
|
|
fixed3 ambient : COLOR1;
|
|
#endif
|
|
#if defined(_IRIDESCENCE)
|
|
fixed3 iridescentColor : COLOR2;
|
|
#endif
|
|
#if defined(_WORLD_POSITION)
|
|
#if defined(_NEAR_PLANE_FADE)
|
|
float4 worldPosition : TEXCOORD2;
|
|
#else
|
|
float3 worldPosition : TEXCOORD2;
|
|
#endif
|
|
#endif
|
|
#if defined(_LOCAL_POSITION)
|
|
float3 localPosition : TEXCOORD7;
|
|
#endif
|
|
#if defined(_SCALE)
|
|
float3 scale : TEXCOORD3;
|
|
#endif
|
|
#if defined(_NORMAL)
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
fixed3 worldNormal : COLOR3;
|
|
fixed3 triplanarNormal : COLOR4;
|
|
float3 triplanarPosition : TEXCOORD6;
|
|
#elif defined(_NORMAL_MAP)
|
|
fixed3 tangentX : COLOR3;
|
|
fixed3 tangentY : COLOR4;
|
|
fixed3 tangentZ : COLOR5;
|
|
#else
|
|
fixed3 worldNormal : COLOR3;
|
|
#endif
|
|
#endif
|
|
UNITY_VERTEX_INPUT_INSTANCE_ID
|
|
UNITY_VERTEX_OUTPUT_STEREO
|
|
};
|
|
|
|
UNITY_INSTANCING_BUFFER_START(Props)
|
|
UNITY_DEFINE_INSTANCED_PROP(float4, _Color)
|
|
|
|
#if defined(_CLIPPING_PLANE)
|
|
UNITY_DEFINE_INSTANCED_PROP(fixed, _ClipPlaneSide)
|
|
UNITY_DEFINE_INSTANCED_PROP(float4, _ClipPlane)
|
|
#endif
|
|
|
|
#if defined(_CLIPPING_SPHERE)
|
|
UNITY_DEFINE_INSTANCED_PROP(fixed, _ClipSphereSide)
|
|
UNITY_DEFINE_INSTANCED_PROP(float4x4, _ClipSphereInverseTransform)
|
|
#endif
|
|
|
|
#if defined(_CLIPPING_BOX)
|
|
UNITY_DEFINE_INSTANCED_PROP(fixed, _ClipBoxSide)
|
|
UNITY_DEFINE_INSTANCED_PROP(float4x4, _ClipBoxInverseTransform)
|
|
#endif
|
|
|
|
UNITY_INSTANCING_BUFFER_END(Props)
|
|
|
|
sampler2D _MainTex;
|
|
fixed4 _MainTex_ST;
|
|
|
|
#if defined(_ALPHA_CLIP)
|
|
fixed _Cutoff;
|
|
#endif
|
|
|
|
#if defined(UNITY_UI_CLIP_RECT)
|
|
float4 _ClipRect;
|
|
#endif
|
|
|
|
fixed _Metallic;
|
|
fixed _Smoothness;
|
|
|
|
#if defined(_CHANNEL_MAP)
|
|
sampler2D _ChannelMap;
|
|
#endif
|
|
|
|
#if defined(_NORMAL_MAP)
|
|
sampler2D _NormalMap;
|
|
float _NormalMapScale;
|
|
#endif
|
|
|
|
#if defined(_EMISSION)
|
|
fixed4 _EmissiveColor;
|
|
#endif
|
|
|
|
#if defined(_USE_SSAA)
|
|
float _MipmapBias;
|
|
#endif
|
|
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
float _TriplanarMappingBlendSharpness;
|
|
#endif
|
|
|
|
#if defined(_DIRECTIONAL_LIGHT)
|
|
#if defined(_RENDER_PIPELINE)
|
|
CBUFFER_START(_LightBuffer)
|
|
float4 _MainLightPosition;
|
|
half4 _MainLightColor;
|
|
CBUFFER_END
|
|
#else
|
|
fixed4 _LightColor0;
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_REFRACTION)
|
|
fixed _RefractiveIndex;
|
|
#endif
|
|
|
|
#if defined(_RIM_LIGHT)
|
|
fixed3 _RimColor;
|
|
fixed _RimPower;
|
|
#endif
|
|
|
|
#if defined(_VERTEX_EXTRUSION)
|
|
float _VertexExtrusionValue;
|
|
#endif
|
|
|
|
|
|
#if defined(_CLIPPING_PRIMITIVE)
|
|
float _BlendedClippingWidth;
|
|
#endif
|
|
|
|
#if defined(_CLIPPING_BORDER)
|
|
fixed _ClippingBorderWidth;
|
|
fixed3 _ClippingBorderColor;
|
|
#endif
|
|
|
|
#if defined(_NEAR_PLANE_FADE)
|
|
float _FadeBeginDistance;
|
|
float _FadeCompleteDistance;
|
|
fixed _FadeMinValue;
|
|
#endif
|
|
|
|
#if defined(_HOVER_LIGHT) || defined(_NEAR_LIGHT_FADE)
|
|
#if defined(_HOVER_LIGHT_HIGH)
|
|
#define HOVER_LIGHT_COUNT 10
|
|
#elif defined(_HOVER_LIGHT_MEDIUM)
|
|
#define HOVER_LIGHT_COUNT 4
|
|
#else
|
|
#define HOVER_LIGHT_COUNT 2
|
|
#endif
|
|
#define HOVER_LIGHT_DATA_SIZE 2
|
|
float4 _HoverLightData[HOVER_LIGHT_COUNT * HOVER_LIGHT_DATA_SIZE];
|
|
#if defined(_HOVER_COLOR_OVERRIDE)
|
|
fixed3 _HoverColorOverride;
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_PROXIMITY_LIGHT) || defined(_NEAR_LIGHT_FADE)
|
|
#define PROXIMITY_LIGHT_COUNT 2
|
|
#define PROXIMITY_LIGHT_DATA_SIZE 6
|
|
float4 _ProximityLightData[PROXIMITY_LIGHT_COUNT * PROXIMITY_LIGHT_DATA_SIZE];
|
|
#if defined(_PROXIMITY_LIGHT_COLOR_OVERRIDE)
|
|
float4 _ProximityLightCenterColorOverride;
|
|
float4 _ProximityLightMiddleColorOverride;
|
|
float4 _ProximityLightOuterColorOverride;
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_HOVER_LIGHT) || defined(_PROXIMITY_LIGHT) || defined(_BORDER_LIGHT)
|
|
fixed _FluentLightIntensity;
|
|
#endif
|
|
|
|
#if defined(_ROUND_CORNERS)
|
|
#if defined(_INDEPENDENT_CORNERS)
|
|
float4 _RoundCornersRadius;
|
|
#else
|
|
fixed _RoundCornerRadius;
|
|
#endif
|
|
fixed _RoundCornerMargin;
|
|
#endif
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
fixed _BorderWidth;
|
|
fixed _BorderMinValue;
|
|
#endif
|
|
|
|
#if defined(_BORDER_LIGHT_OPAQUE)
|
|
fixed _BorderLightOpaqueAlpha;
|
|
#endif
|
|
|
|
#if defined(_ROUND_CORNERS) || defined(_BORDER_LIGHT)
|
|
float _EdgeSmoothingValue;
|
|
#endif
|
|
|
|
#if defined(_INNER_GLOW)
|
|
fixed4 _InnerGlowColor;
|
|
fixed _InnerGlowPower;
|
|
#endif
|
|
|
|
#if defined(_IRIDESCENCE)
|
|
sampler2D _IridescentSpectrumMap;
|
|
fixed _IridescenceIntensity;
|
|
fixed _IridescenceThreshold;
|
|
fixed _IridescenceAngle;
|
|
#endif
|
|
|
|
#if defined(_ENVIRONMENT_COLORING)
|
|
fixed _EnvironmentColorThreshold;
|
|
fixed _EnvironmentColorIntensity;
|
|
fixed3 _EnvironmentColorX;
|
|
fixed3 _EnvironmentColorY;
|
|
fixed3 _EnvironmentColorZ;
|
|
#endif
|
|
|
|
#if defined(_DIRECTIONAL_LIGHT)
|
|
static const fixed _MinMetallicLightContribution = 0.7;
|
|
static const fixed _IblContribution = 0.1;
|
|
#endif
|
|
|
|
#if defined(_SPECULAR_HIGHLIGHTS)
|
|
static const float _Shininess = 800.0;
|
|
#endif
|
|
|
|
#if defined(_FRESNEL)
|
|
static const float _FresnelPower = 8.0;
|
|
#endif
|
|
|
|
#if defined(_NEAR_LIGHT_FADE)
|
|
static const float _MaxNearLightDistance = 10.0;
|
|
|
|
inline float NearLightDistance(float4 light, float3 worldPosition)
|
|
{
|
|
return distance(worldPosition, light.xyz) + ((1.0 - light.w) * _MaxNearLightDistance);
|
|
}
|
|
#endif
|
|
|
|
#if defined(_HOVER_LIGHT)
|
|
inline float HoverLight(float4 hoverLight, float inverseRadius, float3 worldPosition)
|
|
{
|
|
return (1.0 - saturate(length(hoverLight.xyz - worldPosition) * inverseRadius)) * hoverLight.w;
|
|
}
|
|
#endif
|
|
|
|
#if defined(_PROXIMITY_LIGHT)
|
|
inline float ProximityLight(float4 proximityLight, float4 proximityLightParams, float4 proximityLightPulseParams, float3 worldPosition, float3 worldNormal, out fixed colorValue)
|
|
{
|
|
float proximityLightDistance = dot(proximityLight.xyz - worldPosition, worldNormal);
|
|
#if defined(_PROXIMITY_LIGHT_TWO_SIDED)
|
|
worldNormal = proximityLightDistance < 0.0 ? -worldNormal : worldNormal;
|
|
proximityLightDistance = abs(proximityLightDistance);
|
|
#endif
|
|
float normalizedProximityLightDistance = saturate(proximityLightDistance * proximityLightParams.y);
|
|
float3 projectedProximityLight = proximityLight.xyz - (worldNormal * abs(proximityLightDistance));
|
|
float projectedProximityLightDistance = length(projectedProximityLight - worldPosition);
|
|
float attenuation = (1.0 - normalizedProximityLightDistance) * proximityLight.w;
|
|
colorValue = saturate(projectedProximityLightDistance * proximityLightParams.z);
|
|
float pulse = step(proximityLightPulseParams.x, projectedProximityLightDistance) * proximityLightPulseParams.y;
|
|
|
|
return smoothstep(1.0, 0.0, projectedProximityLightDistance / (proximityLightParams.x * max(pow(normalizedProximityLightDistance, 0.25), proximityLightParams.w))) * pulse * attenuation;
|
|
}
|
|
|
|
inline fixed3 MixProximityLightColor(fixed4 centerColor, fixed4 middleColor, fixed4 outerColor, fixed t)
|
|
{
|
|
fixed3 color = lerp(centerColor.rgb, middleColor.rgb, smoothstep(centerColor.a, middleColor.a, t));
|
|
return lerp(color, outerColor, smoothstep(middleColor.a, outerColor.a, t));
|
|
}
|
|
#endif
|
|
|
|
#if defined(_ROUND_CORNERS)
|
|
inline float PointVsRoundedBox(float2 position, float2 cornerCircleDistance, float cornerCircleRadius)
|
|
{
|
|
return length(max(abs(position) - cornerCircleDistance, 0.0)) - cornerCircleRadius;
|
|
}
|
|
|
|
inline float RoundCornersSmooth(float2 position, float2 cornerCircleDistance, float cornerCircleRadius)
|
|
{
|
|
return smoothstep(1.0, 0.0, PointVsRoundedBox(position, cornerCircleDistance, cornerCircleRadius) / _EdgeSmoothingValue);
|
|
}
|
|
|
|
inline float RoundCorners(float2 position, float2 cornerCircleDistance, float cornerCircleRadius)
|
|
{
|
|
#if defined(_TRANSPARENT)
|
|
return RoundCornersSmooth(position, cornerCircleDistance, cornerCircleRadius);
|
|
#else
|
|
return (PointVsRoundedBox(position, cornerCircleDistance, cornerCircleRadius) < 0.0);
|
|
#endif
|
|
}
|
|
#endif
|
|
|
|
#if defined(_IRIDESCENCE)
|
|
fixed3 Iridescence(float tangentDotIncident, sampler2D spectrumMap, float threshold, float2 uv, float angle, float intensity)
|
|
{
|
|
float k = tangentDotIncident * 0.5 + 0.5;
|
|
float4 left = tex2D(spectrumMap, float2(lerp(0.0, 1.0 - threshold, k), 0.5), float2(0.0, 0.0), float2(0.0, 0.0));
|
|
float4 right = tex2D(spectrumMap, float2(lerp(threshold, 1.0, k), 0.5), float2(0.0, 0.0), float2(0.0, 0.0));
|
|
|
|
float2 XY = uv - float2(0.5, 0.5);
|
|
float s = (cos(angle) * XY.x - sin(angle) * XY.y) / cos(angle);
|
|
return (left.rgb + s * (right.rgb - left.rgb)) * intensity;
|
|
}
|
|
#endif
|
|
|
|
v2f vert(appdata_t v)
|
|
{
|
|
v2f o;
|
|
UNITY_SETUP_INSTANCE_ID(v);
|
|
UNITY_INITIALIZE_OUTPUT(v2f, o);
|
|
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(o);
|
|
UNITY_TRANSFER_INSTANCE_ID(v, o);
|
|
|
|
float4 vertexPosition = v.vertex;
|
|
|
|
#if defined(_WORLD_POSITION) || defined(_VERTEX_EXTRUSION)
|
|
float3 worldVertexPosition = mul(unity_ObjectToWorld, vertexPosition).xyz;
|
|
#endif
|
|
|
|
#if defined(_SCALE)
|
|
o.scale.x = length(mul(unity_ObjectToWorld, float4(1.0, 0.0, 0.0, 0.0)));
|
|
o.scale.y = length(mul(unity_ObjectToWorld, float4(0.0, 1.0, 0.0, 0.0)));
|
|
#if defined(_IGNORE_Z_SCALE)
|
|
o.scale.z = o.scale.x;
|
|
#else
|
|
o.scale.z = length(mul(unity_ObjectToWorld, float4(0.0, 0.0, 1.0, 0.0)));
|
|
#endif
|
|
#if !defined(_VERTEX_EXTRUSION_SMOOTH_NORMALS)
|
|
// uv3.y will contain a negative value when rendered by a UGUI and ScaleMeshEffect.
|
|
if (v.uv3.y < 0.0)
|
|
{
|
|
o.scale.x *= v.uv2.x;
|
|
o.scale.y *= v.uv2.y;
|
|
o.scale.z *= v.uv3.x;
|
|
}
|
|
#endif
|
|
#endif
|
|
|
|
fixed3 localNormal = v.normal;
|
|
|
|
#if defined(_NORMAL) || defined(_VERTEX_EXTRUSION)
|
|
fixed3 worldNormal = UnityObjectToWorldNormal(localNormal);
|
|
#endif
|
|
|
|
#if defined(_VERTEX_EXTRUSION)
|
|
#if defined(_VERTEX_EXTRUSION_SMOOTH_NORMALS)
|
|
worldVertexPosition += UnityObjectToWorldNormal(v.uv2 * o.scale) * _VertexExtrusionValue;
|
|
#else
|
|
worldVertexPosition += worldNormal * _VertexExtrusionValue;
|
|
#endif
|
|
vertexPosition = mul(unity_WorldToObject, float4(worldVertexPosition, 1.0));
|
|
#endif
|
|
|
|
o.position = UnityObjectToClipPos(vertexPosition);
|
|
|
|
#if defined(_WORLD_POSITION)
|
|
o.worldPosition.xyz = worldVertexPosition;
|
|
#endif
|
|
|
|
#if defined(_LOCAL_POSITION)
|
|
o.localPosition.xyz = vertexPosition;
|
|
#endif
|
|
|
|
#if defined(_NEAR_PLANE_FADE)
|
|
float rangeInverse = 1.0 / (_FadeBeginDistance - _FadeCompleteDistance);
|
|
#if defined(_NEAR_LIGHT_FADE)
|
|
float fadeDistance = _MaxNearLightDistance;
|
|
|
|
[unroll]
|
|
for (int hoverLightIndex = 0; hoverLightIndex < HOVER_LIGHT_COUNT; ++hoverLightIndex)
|
|
{
|
|
int dataIndex = hoverLightIndex * HOVER_LIGHT_DATA_SIZE;
|
|
fadeDistance = min(fadeDistance, NearLightDistance(_HoverLightData[dataIndex], o.worldPosition));
|
|
}
|
|
|
|
[unroll]
|
|
for (int proximityLightIndex = 0; proximityLightIndex < PROXIMITY_LIGHT_COUNT; ++proximityLightIndex)
|
|
{
|
|
int dataIndex = proximityLightIndex * PROXIMITY_LIGHT_DATA_SIZE;
|
|
fadeDistance = min(fadeDistance, NearLightDistance(_ProximityLightData[dataIndex], o.worldPosition));
|
|
}
|
|
#else
|
|
float fadeDistance = -UnityObjectToViewPos(vertexPosition).z;
|
|
#endif
|
|
o.worldPosition.w = max(saturate(mad(fadeDistance, rangeInverse, -_FadeCompleteDistance * rangeInverse)), _FadeMinValue);
|
|
#endif
|
|
|
|
#if defined(_BORDER_LIGHT) || defined(_ROUND_CORNERS)
|
|
o.uv.xy = TRANSFORM_TEX(v.uv, _MainTex);
|
|
|
|
float minScale = min(min(o.scale.x, o.scale.y), o.scale.z);
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
float maxScale = max(max(o.scale.x, o.scale.y), o.scale.z);
|
|
float minOverMiddleScale = minScale / (o.scale.x + o.scale.y + o.scale.z - minScale - maxScale);
|
|
|
|
float areaYZ = o.scale.y * o.scale.z;
|
|
float areaXZ = o.scale.z * o.scale.x;
|
|
float areaXY = o.scale.x * o.scale.y;
|
|
|
|
float borderWidth = _BorderWidth;
|
|
#endif
|
|
|
|
if (abs(localNormal.x) == 1.0) // Y,Z plane.
|
|
{
|
|
o.scale.x = o.scale.z;
|
|
o.scale.y = o.scale.y;
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
if (areaYZ > areaXZ && areaYZ > areaXY)
|
|
{
|
|
borderWidth *= minOverMiddleScale;
|
|
}
|
|
#endif
|
|
}
|
|
else if (abs(localNormal.y) == 1.0) // X,Z plane.
|
|
{
|
|
o.scale.x = o.scale.x;
|
|
o.scale.y = o.scale.z;
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
if (areaXZ > areaXY && areaXZ > areaYZ)
|
|
{
|
|
borderWidth *= minOverMiddleScale;
|
|
}
|
|
#endif
|
|
}
|
|
else // X,Y plane.
|
|
{
|
|
o.scale.x = o.scale.x;
|
|
o.scale.y = o.scale.y;
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
if (areaXY > areaYZ && areaXY > areaXZ)
|
|
{
|
|
borderWidth *= minOverMiddleScale;
|
|
}
|
|
#endif
|
|
}
|
|
|
|
o.scale.z = minScale;
|
|
|
|
#if defined(_BORDER_LIGHT)
|
|
float scaleRatio = min(o.scale.x, o.scale.y) / max(o.scale.x, o.scale.y);
|
|
o.uv.z = o.scale.x > o.scale.y ? 1.0 - (borderWidth * scaleRatio) : 1.0 - borderWidth;
|
|
o.uv.w = o.scale.x > o.scale.y ? 1.0 - borderWidth : 1.0 - (borderWidth * scaleRatio);
|
|
#endif
|
|
#elif defined(_UV)
|
|
o.uv = TRANSFORM_TEX(v.uv, _MainTex);
|
|
#endif
|
|
|
|
#if defined(LIGHTMAP_ON)
|
|
o.lightMapUV.xy = v.uv1.xy * unity_LightmapST.xy + unity_LightmapST.zw;
|
|
#endif
|
|
|
|
#if defined(_VERTEX_COLORS)
|
|
o.color = v.color;
|
|
#endif
|
|
|
|
#if defined(_SPHERICAL_HARMONICS)
|
|
o.ambient = ShadeSH9(float4(worldNormal, 1.0));
|
|
#endif
|
|
|
|
#if defined(_IRIDESCENCE)
|
|
float3 rightTangent = normalize(mul((float3x3)unity_ObjectToWorld, float3(1.0, 0.0, 0.0)));
|
|
float3 incidentWithCenter = normalize(mul(unity_ObjectToWorld, float4(0.0, 0.0, 0.0, 1.0)) - _WorldSpaceCameraPos);
|
|
float tangentDotIncident = dot(rightTangent, incidentWithCenter);
|
|
o.iridescentColor = Iridescence(tangentDotIncident, _IridescentSpectrumMap, _IridescenceThreshold, v.uv, _IridescenceAngle, _IridescenceIntensity);
|
|
#endif
|
|
|
|
#if defined(_NORMAL)
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
o.worldNormal = worldNormal;
|
|
#if defined(_LOCAL_SPACE_TRIPLANAR_MAPPING)
|
|
o.triplanarNormal = localNormal;
|
|
o.triplanarPosition = vertexPosition;
|
|
#else
|
|
o.triplanarNormal = worldNormal;
|
|
o.triplanarPosition = o.worldPosition;
|
|
#endif
|
|
#elif defined(_NORMAL_MAP)
|
|
fixed3 worldTangent = UnityObjectToWorldDir(v.tangent.xyz);
|
|
fixed tangentSign = v.tangent.w * unity_WorldTransformParams.w;
|
|
fixed3 worldBitangent = cross(worldNormal, worldTangent) * tangentSign;
|
|
o.tangentX = fixed3(worldTangent.x, worldBitangent.x, worldNormal.x);
|
|
o.tangentY = fixed3(worldTangent.y, worldBitangent.y, worldNormal.y);
|
|
o.tangentZ = fixed3(worldTangent.z, worldBitangent.z, worldNormal.z);
|
|
#else
|
|
o.worldNormal = worldNormal;
|
|
#endif
|
|
#endif
|
|
|
|
return o;
|
|
}
|
|
|
|
fixed4 frag(v2f i, fixed facing : VFACE) : SV_Target
|
|
{
|
|
UNITY_SETUP_INSTANCE_ID(i);
|
|
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
// Calculate triplanar uvs and apply texture scale and offset values like TRANSFORM_TEX.
|
|
fixed3 triplanarBlend = pow(abs(i.triplanarNormal), _TriplanarMappingBlendSharpness);
|
|
triplanarBlend /= dot(triplanarBlend, fixed3(1.0, 1.0, 1.0));
|
|
float2 uvX = i.triplanarPosition.zy * _MainTex_ST.xy + _MainTex_ST.zw;
|
|
float2 uvY = i.triplanarPosition.xz * _MainTex_ST.xy + _MainTex_ST.zw;
|
|
float2 uvZ = i.triplanarPosition.xy * _MainTex_ST.xy + _MainTex_ST.zw;
|
|
|
|
// Ternary operator is 2 instructions faster than sign() when we don't care about zero returning a zero sign.
|
|
float3 axisSign = i.triplanarNormal < 0 ? -1 : 1;
|
|
uvX.x *= axisSign.x;
|
|
uvY.x *= axisSign.y;
|
|
uvZ.x *= -axisSign.z;
|
|
#endif
|
|
|
|
// Texturing.
|
|
#if defined(_DISABLE_ALBEDO_MAP)
|
|
fixed4 albedo = fixed4(1.0, 1.0, 1.0, 1.0);
|
|
#else
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
fixed4 albedo = tex2D(_MainTex, uvX) * triplanarBlend.x +
|
|
tex2D(_MainTex, uvY) * triplanarBlend.y +
|
|
tex2D(_MainTex, uvZ) * triplanarBlend.z;
|
|
#else
|
|
#if defined(_USE_SSAA)
|
|
// Does SSAA on the texture, implementation based off this article: https://medium.com/@bgolus/sharper-mipmapping-using-shader-based-supersampling-ed7aadb47bec
|
|
// per pixel screen space partial derivatives
|
|
float2 dx = ddx(i.uv.xy) * 0.25; // horizontal offset
|
|
float2 dy = ddy(i.uv.xy) * 0.25; // vertical offset
|
|
// supersampled 2x2 ordered grid
|
|
fixed4 albedo = 0;
|
|
albedo += tex2Dbias(_MainTex, float4(i.uv.xy + dx + dy, 0.0, _MipmapBias));
|
|
albedo += tex2Dbias(_MainTex, float4(i.uv.xy - dx + dy, 0.0, _MipmapBias));
|
|
albedo += tex2Dbias(_MainTex, float4(i.uv.xy + dx - dy, 0.0, _MipmapBias));
|
|
albedo += tex2Dbias(_MainTex, float4(i.uv.xy - dx - dy, 0.0, _MipmapBias));
|
|
albedo *= 0.25;
|
|
#else
|
|
fixed4 albedo = tex2D(_MainTex, i.uv);
|
|
#endif
|
|
#endif
|
|
#endif
|
|
|
|
|
|
#ifdef LIGHTMAP_ON
|
|
albedo.rgb *= DecodeLightmap(UNITY_SAMPLE_TEX2D(unity_Lightmap, i.lightMapUV));
|
|
#endif
|
|
|
|
#if defined(_CHANNEL_MAP)
|
|
fixed4 channel = tex2D(_ChannelMap, i.uv);
|
|
_Metallic = channel.r;
|
|
albedo.rgb *= channel.g;
|
|
_Smoothness = channel.a;
|
|
#else
|
|
#if defined(_METALLIC_TEXTURE_ALBEDO_CHANNEL_A)
|
|
_Metallic = albedo.a;
|
|
albedo.a = 1.0;
|
|
#elif defined(_SMOOTHNESS_TEXTURE_ALBEDO_CHANNEL_A)
|
|
_Smoothness = albedo.a;
|
|
albedo.a = 1.0;
|
|
#endif
|
|
#endif
|
|
|
|
// Primitive clipping.
|
|
#if defined(_CLIPPING_PRIMITIVE)
|
|
float primitiveDistance = 1.0;
|
|
#if defined(_CLIPPING_PLANE)
|
|
fixed clipPlaneSide = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipPlaneSide);
|
|
float4 clipPlane = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipPlane);
|
|
primitiveDistance = min(primitiveDistance, PointVsPlane(i.worldPosition.xyz, clipPlane) * clipPlaneSide);
|
|
#endif
|
|
#if defined(_CLIPPING_SPHERE)
|
|
fixed clipSphereSide = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipSphereSide);
|
|
float4x4 clipSphereInverseTransform = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipSphereInverseTransform);
|
|
primitiveDistance = min(primitiveDistance, PointVsSphere(i.worldPosition.xyz, clipSphereInverseTransform) * clipSphereSide);
|
|
#endif
|
|
#if defined(_CLIPPING_BOX)
|
|
fixed clipBoxSide = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipBoxSide);
|
|
float4x4 clipBoxInverseTransform = UNITY_ACCESS_INSTANCED_PROP(Props, _ClipBoxInverseTransform);
|
|
primitiveDistance = min(primitiveDistance, PointVsBox(i.worldPosition.xyz, clipBoxInverseTransform) * clipBoxSide);
|
|
#endif
|
|
#if defined(_CLIPPING_BORDER)
|
|
fixed3 primitiveBorderColor = lerp(_ClippingBorderColor, fixed3(0.0, 0.0, 0.0), primitiveDistance / _ClippingBorderWidth);
|
|
albedo.rgb += primitiveBorderColor * (primitiveDistance < _ClippingBorderWidth ? 1.0 : 0.0);
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_DISTANCE_TO_EDGE)
|
|
fixed2 distanceToEdge;
|
|
distanceToEdge.x = abs(i.uv.x - 0.5) * 2.0;
|
|
distanceToEdge.y = abs(i.uv.y - 0.5) * 2.0;
|
|
#endif
|
|
|
|
// Rounded corner clipping.
|
|
#if defined(_ROUND_CORNERS)
|
|
float2 halfScale = i.scale.xy * 0.5;
|
|
float2 roundCornerPosition = distanceToEdge * halfScale;
|
|
|
|
fixed currentCornerRadius;
|
|
|
|
#if defined(_INDEPENDENT_CORNERS)
|
|
|
|
_RoundCornersRadius = clamp(_RoundCornersRadius, 0, 0.5);
|
|
|
|
if (i.uv.x < 0.5)
|
|
{
|
|
if (i.uv.y > 0.5)
|
|
{
|
|
currentCornerRadius = _RoundCornersRadius.x;
|
|
}
|
|
else
|
|
{
|
|
currentCornerRadius = _RoundCornersRadius.w;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (i.uv.y > 0.5)
|
|
{
|
|
currentCornerRadius = _RoundCornersRadius.y;
|
|
}
|
|
else
|
|
{
|
|
currentCornerRadius = _RoundCornersRadius.z;
|
|
}
|
|
}
|
|
#else
|
|
currentCornerRadius = _RoundCornerRadius;
|
|
#endif
|
|
|
|
float cornerCircleRadius = saturate(max(currentCornerRadius - _RoundCornerMargin, 0.01)) * i.scale.z;
|
|
|
|
float2 cornerCircleDistance = halfScale - (_RoundCornerMargin * i.scale.z) - cornerCircleRadius;
|
|
|
|
float roundCornerClip = RoundCorners(roundCornerPosition, cornerCircleDistance, cornerCircleRadius);
|
|
#endif
|
|
|
|
albedo *= UNITY_ACCESS_INSTANCED_PROP(Props, _Color);
|
|
|
|
#if defined(_VERTEX_COLORS)
|
|
albedo *= i.color;
|
|
#endif
|
|
|
|
#if defined(_IRIDESCENCE)
|
|
albedo.rgb += i.iridescentColor;
|
|
#endif
|
|
|
|
// Normal calculation.
|
|
#if defined(_NORMAL)
|
|
fixed3 worldViewDir = normalize(UnityWorldSpaceViewDir(i.worldPosition.xyz));
|
|
#if defined(_REFLECTIONS) || defined(_ENVIRONMENT_COLORING)
|
|
fixed3 incident = -worldViewDir;
|
|
#endif
|
|
fixed3 worldNormal;
|
|
|
|
#if defined(_NORMAL_MAP)
|
|
#if defined(_TRIPLANAR_MAPPING)
|
|
fixed3 tangentNormalX = UnpackScaleNormal(tex2D(_NormalMap, uvX), _NormalMapScale);
|
|
fixed3 tangentNormalY = UnpackScaleNormal(tex2D(_NormalMap, uvY), _NormalMapScale);
|
|
fixed3 tangentNormalZ = UnpackScaleNormal(tex2D(_NormalMap, uvZ), _NormalMapScale);
|
|
tangentNormalX.x *= axisSign.x;
|
|
tangentNormalY.x *= axisSign.y;
|
|
tangentNormalZ.x *= -axisSign.z;
|
|
|
|
// Swizzle world normals to match tangent space and apply Whiteout normal blend.
|
|
tangentNormalX = fixed3(tangentNormalX.xy + i.worldNormal.zy, tangentNormalX.z * i.worldNormal.x);
|
|
tangentNormalY = fixed3(tangentNormalY.xy + i.worldNormal.xz, tangentNormalY.z * i.worldNormal.y);
|
|
tangentNormalZ = fixed3(tangentNormalZ.xy + i.worldNormal.xy, tangentNormalZ.z * i.worldNormal.z);
|
|
|
|
// Swizzle tangent normals to match world normal and blend together.
|
|
worldNormal = normalize(tangentNormalX.zyx * triplanarBlend.x +
|
|
tangentNormalY.xzy * triplanarBlend.y +
|
|
tangentNormalZ.xyz * triplanarBlend.z);
|
|
#else
|
|
fixed3 tangentNormal = UnpackScaleNormal(tex2D(_NormalMap, i.uv), _NormalMapScale);
|
|
worldNormal.x = dot(i.tangentX, tangentNormal);
|
|
worldNormal.y = dot(i.tangentY, tangentNormal);
|
|
worldNormal.z = dot(i.tangentZ, tangentNormal);
|
|
worldNormal = normalize(worldNormal) * facing;
|
|
#endif
|
|
#else
|
|
worldNormal = normalize(i.worldNormal) * facing;
|
|
#endif
|
|
#endif
|
|
|
|
fixed pointToLight = 1.0;
|
|
fixed3 fluentLightColor = fixed3(0.0, 0.0, 0.0);
|
|
|
|
// Hover light.
|
|
#if defined(_HOVER_LIGHT)
|
|
pointToLight = 0.0;
|
|
|
|
[unroll]
|
|
for (int hoverLightIndex = 0; hoverLightIndex < HOVER_LIGHT_COUNT; ++hoverLightIndex)
|
|
{
|
|
int dataIndex = hoverLightIndex * HOVER_LIGHT_DATA_SIZE;
|
|
fixed hoverValue = HoverLight(_HoverLightData[dataIndex], _HoverLightData[dataIndex + 1].w, i.worldPosition.xyz);
|
|
pointToLight += hoverValue;
|
|
#if !defined(_HOVER_COLOR_OVERRIDE)
|
|
fluentLightColor += lerp(fixed3(0.0, 0.0, 0.0), _HoverLightData[dataIndex + 1].rgb, hoverValue);
|
|
#endif
|
|
}
|
|
#if defined(_HOVER_COLOR_OVERRIDE)
|
|
fluentLightColor = _HoverColorOverride.rgb * pointToLight;
|
|
#endif
|
|
#endif
|
|
|
|
// Proximity light.
|
|
#if defined(_PROXIMITY_LIGHT)
|
|
#if !defined(_HOVER_LIGHT)
|
|
pointToLight = 0.0;
|
|
#endif
|
|
[unroll]
|
|
for (int proximityLightIndex = 0; proximityLightIndex < PROXIMITY_LIGHT_COUNT; ++proximityLightIndex)
|
|
{
|
|
int dataIndex = proximityLightIndex * PROXIMITY_LIGHT_DATA_SIZE;
|
|
fixed colorValue;
|
|
fixed proximityValue = ProximityLight(_ProximityLightData[dataIndex], _ProximityLightData[dataIndex + 1], _ProximityLightData[dataIndex + 2], i.worldPosition.xyz, worldNormal, colorValue);
|
|
pointToLight += proximityValue;
|
|
#if defined(_PROXIMITY_LIGHT_COLOR_OVERRIDE)
|
|
fixed3 proximityColor = MixProximityLightColor(_ProximityLightCenterColorOverride, _ProximityLightMiddleColorOverride, _ProximityLightOuterColorOverride, colorValue);
|
|
#else
|
|
fixed3 proximityColor = MixProximityLightColor(_ProximityLightData[dataIndex + 3], _ProximityLightData[dataIndex + 4], _ProximityLightData[dataIndex + 5], colorValue);
|
|
#endif
|
|
#if defined(_PROXIMITY_LIGHT_SUBTRACTIVE)
|
|
fluentLightColor -= lerp(fixed3(0.0, 0.0, 0.0), proximityColor, proximityValue);
|
|
#else
|
|
fluentLightColor += lerp(fixed3(0.0, 0.0, 0.0), proximityColor, proximityValue);
|
|
#endif
|
|
}
|
|
#endif
|
|
|
|
// Border light.
|
|
#if defined(_BORDER_LIGHT)
|
|
fixed borderValue;
|
|
#if defined(_ROUND_CORNERS)
|
|
fixed borderMargin = _RoundCornerMargin + _BorderWidth * 0.5;
|
|
|
|
cornerCircleRadius = saturate(max(currentCornerRadius - borderMargin, 0.01)) * i.scale.z;
|
|
|
|
cornerCircleDistance = halfScale - (borderMargin * i.scale.z) - cornerCircleRadius;
|
|
|
|
borderValue = 1.0 - RoundCornersSmooth(roundCornerPosition, cornerCircleDistance, cornerCircleRadius);
|
|
#else
|
|
borderValue = max(smoothstep(i.uv.z - _EdgeSmoothingValue, i.uv.z + _EdgeSmoothingValue, distanceToEdge.x),
|
|
smoothstep(i.uv.w - _EdgeSmoothingValue, i.uv.w + _EdgeSmoothingValue, distanceToEdge.y));
|
|
#endif
|
|
#if defined(_HOVER_LIGHT) && defined(_BORDER_LIGHT_USES_HOVER_COLOR) && defined(_HOVER_COLOR_OVERRIDE)
|
|
fixed3 borderColor = _HoverColorOverride.rgb;
|
|
#else
|
|
fixed3 borderColor = fixed3(1.0, 1.0, 1.0);
|
|
#endif
|
|
fixed3 borderContribution = borderColor * borderValue * _BorderMinValue * _FluentLightIntensity;
|
|
#if defined(_BORDER_LIGHT_REPLACES_ALBEDO)
|
|
albedo.rgb = lerp(albedo.rgb, borderContribution, borderValue);
|
|
#else
|
|
albedo.rgb += borderContribution;
|
|
#endif
|
|
#if defined(_HOVER_LIGHT) || defined(_PROXIMITY_LIGHT)
|
|
albedo.rgb += (fluentLightColor * borderValue * pointToLight * _FluentLightIntensity) * 2.0;
|
|
#endif
|
|
#if defined(_BORDER_LIGHT_OPAQUE)
|
|
albedo.a = max(albedo.a, borderValue * _BorderLightOpaqueAlpha);
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_ROUND_CORNERS)
|
|
albedo *= roundCornerClip;
|
|
pointToLight *= roundCornerClip;
|
|
#endif
|
|
|
|
#ifdef UNITY_UI_CLIP_RECT
|
|
albedo.a *= UnityGet2DClipping(i.localPosition.xy, _ClipRect);
|
|
#endif
|
|
|
|
#if defined(_ALPHA_CLIP)
|
|
#if !defined(_ALPHATEST_ON)
|
|
_Cutoff = 0.5;
|
|
#endif
|
|
#if defined(_CLIPPING_PRIMITIVE)
|
|
albedo *= (primitiveDistance > 0.0);
|
|
#endif
|
|
clip(albedo.a - _Cutoff);
|
|
albedo.a = 1.0;
|
|
#endif
|
|
|
|
// Blinn phong lighting.
|
|
#if defined(_DIRECTIONAL_LIGHT)
|
|
#if defined(_RENDER_PIPELINE)
|
|
float4 directionalLightDirection = _MainLightPosition;
|
|
#else
|
|
float4 directionalLightDirection = _WorldSpaceLightPos0;
|
|
#endif
|
|
fixed diffuse = max(0.0, dot(worldNormal, directionalLightDirection));
|
|
#if defined(_SPECULAR_HIGHLIGHTS)
|
|
fixed halfVector = max(0.0, dot(worldNormal, normalize(directionalLightDirection + worldViewDir)));
|
|
fixed specular = saturate(pow(halfVector, _Shininess * pow(_Smoothness, 4.0)) * (_Smoothness * 2.0) * _Metallic);
|
|
#else
|
|
fixed specular = 0.0;
|
|
#endif
|
|
#endif
|
|
|
|
// Image based lighting (attempt to mimic the Standard shader).
|
|
#if defined(_REFLECTIONS)
|
|
fixed3 worldReflection = reflect(incident, worldNormal);
|
|
fixed4 iblData = UNITY_SAMPLE_TEXCUBE_LOD(unity_SpecCube0, worldReflection, (1.0 - _Smoothness) * UNITY_SPECCUBE_LOD_STEPS);
|
|
fixed3 ibl = DecodeHDR(iblData, unity_SpecCube0_HDR);
|
|
#if defined(_REFRACTION)
|
|
fixed4 refractColor = UNITY_SAMPLE_TEXCUBE(unity_SpecCube0, refract(incident, worldNormal, _RefractiveIndex));
|
|
ibl *= DecodeHDR(refractColor, unity_SpecCube0_HDR);
|
|
#endif
|
|
#else
|
|
fixed3 ibl = unity_IndirectSpecColor.rgb;
|
|
#endif
|
|
|
|
// Fresnel lighting.
|
|
#if defined(_FRESNEL)
|
|
fixed fresnel = 1.0 - saturate(abs(dot(worldViewDir, worldNormal)));
|
|
#if defined(_RIM_LIGHT)
|
|
fixed3 fresnelColor = _RimColor * pow(fresnel, _RimPower);
|
|
#else
|
|
fixed3 fresnelColor = unity_IndirectSpecColor.rgb * (pow(fresnel, _FresnelPower) * max(_Smoothness, 0.5));
|
|
#endif
|
|
#endif
|
|
// Final lighting mix.
|
|
fixed4 output = albedo;
|
|
#if defined(_SPHERICAL_HARMONICS)
|
|
fixed3 ambient = i.ambient;
|
|
#else
|
|
fixed3 ambient = glstate_lightmodel_ambient + fixed3(0.25, 0.25, 0.25);
|
|
#endif
|
|
fixed minProperty = min(_Smoothness, _Metallic);
|
|
#if defined(_DIRECTIONAL_LIGHT)
|
|
fixed oneMinusMetallic = (1.0 - _Metallic);
|
|
output.rgb = lerp(output.rgb, ibl, minProperty);
|
|
#if defined(_RENDER_PIPELINE)
|
|
fixed3 directionalLightColor = _MainLightColor.rgb;
|
|
#else
|
|
fixed3 directionalLightColor = _LightColor0.rgb;
|
|
#endif
|
|
output.rgb *= lerp((ambient + directionalLightColor * diffuse + directionalLightColor * specular) * max(oneMinusMetallic, _MinMetallicLightContribution), albedo, minProperty);
|
|
output.rgb += (directionalLightColor * albedo * specular) + (directionalLightColor * specular * _Smoothness);
|
|
output.rgb += ibl * oneMinusMetallic * _IblContribution;
|
|
#elif defined(_REFLECTIONS)
|
|
output.rgb = lerp(output.rgb, ibl, minProperty);
|
|
output.rgb *= lerp(ambient, albedo, minProperty);
|
|
#elif defined(_SPHERICAL_HARMONICS)
|
|
output.rgb *= ambient;
|
|
#endif
|
|
|
|
#if defined(_FRESNEL)
|
|
#if defined(_RIM_LIGHT) || !defined(_REFLECTIONS)
|
|
output.rgb += fresnelColor;
|
|
#else
|
|
output.rgb += fresnelColor * (1.0 - minProperty);
|
|
#endif
|
|
#endif
|
|
|
|
#if defined(_EMISSION)
|
|
#if defined(_CHANNEL_MAP)
|
|
output.rgb += _EmissiveColor * channel.b;
|
|
#else
|
|
output.rgb += _EmissiveColor;
|
|
#endif
|
|
#endif
|
|
|
|
// Inner glow.
|
|
#if defined(_INNER_GLOW)
|
|
fixed2 uvGlow = pow(distanceToEdge * _InnerGlowColor.a, _InnerGlowPower);
|
|
output.rgb += lerp(fixed3(0.0, 0.0, 0.0), _InnerGlowColor.rgb, uvGlow.x + uvGlow.y);
|
|
#endif
|
|
|
|
// Environment coloring.
|
|
#if defined(_ENVIRONMENT_COLORING)
|
|
fixed3 environmentColor = incident.x * incident.x * _EnvironmentColorX +
|
|
incident.y * incident.y * _EnvironmentColorY +
|
|
incident.z * incident.z * _EnvironmentColorZ;
|
|
output.rgb += environmentColor * max(0.0, dot(incident, worldNormal) + _EnvironmentColorThreshold) * _EnvironmentColorIntensity;
|
|
|
|
#endif
|
|
|
|
#if defined(_NEAR_PLANE_FADE)
|
|
output *= i.worldPosition.w;
|
|
#endif
|
|
|
|
// Hover and proximity lighting should occur after near plane fading.
|
|
#if defined(_HOVER_LIGHT) || defined(_PROXIMITY_LIGHT)
|
|
output.rgb += fluentLightColor * _FluentLightIntensity * pointToLight;
|
|
#endif
|
|
|
|
// Perform non-alpha clipped primitive clipping on the final output.
|
|
#if defined(_CLIPPING_PRIMITIVE) && !defined(_ALPHA_CLIP)
|
|
output *= saturate(primitiveDistance * (1.0f / _BlendedClippingWidth));
|
|
#endif
|
|
return output;
|
|
}
|
|
|
|
ENDCG
|
|
}
|
|
|
|
// Extracts information for lightmapping, GI (emission, albedo, ...)
|
|
// This pass it not used during regular rendering.
|
|
Pass
|
|
{
|
|
Name "Meta"
|
|
Tags { "LightMode" = "Meta" }
|
|
|
|
CGPROGRAM
|
|
|
|
#pragma vertex vert
|
|
#pragma fragment frag
|
|
|
|
#pragma shader_feature EDITOR_VISUALIZATION
|
|
#pragma shader_feature _EMISSION
|
|
#pragma shader_feature _CHANNEL_MAP
|
|
|
|
#include "UnityCG.cginc"
|
|
#include "UnityMetaPass.cginc"
|
|
|
|
// This define will get commented in by the UpgradeShaderForUniversalRenderPipeline method.
|
|
//#define _RENDER_PIPELINE
|
|
|
|
struct v2f
|
|
{
|
|
float4 vertex : SV_POSITION;
|
|
float2 uv : TEXCOORD0;
|
|
};
|
|
|
|
float4 _MainTex_ST;
|
|
|
|
v2f vert(appdata_full v)
|
|
{
|
|
v2f o;
|
|
o.vertex = UnityMetaVertexPosition(v.vertex, v.texcoord1.xy, v.texcoord2.xy, unity_LightmapST, unity_DynamicLightmapST);
|
|
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
|
|
|
|
return o;
|
|
}
|
|
|
|
sampler2D _MainTex;
|
|
sampler2D _ChannelMap;
|
|
|
|
fixed4 _Color;
|
|
fixed4 _EmissiveColor;
|
|
|
|
#if defined(_RENDER_PIPELINE)
|
|
CBUFFER_START(_LightBuffer)
|
|
float4 _MainLightPosition;
|
|
half4 _MainLightColor;
|
|
CBUFFER_END
|
|
#else
|
|
fixed4 _LightColor0;
|
|
#endif
|
|
|
|
half4 frag(v2f i) : SV_Target
|
|
{
|
|
UnityMetaInput output;
|
|
UNITY_INITIALIZE_OUTPUT(UnityMetaInput, output);
|
|
|
|
output.Albedo = tex2D(_MainTex, i.uv) * _Color;
|
|
#if defined(_EMISSION)
|
|
#if defined(_CHANNEL_MAP)
|
|
output.Emission += tex2D(_ChannelMap, i.uv).b * _EmissiveColor;
|
|
#else
|
|
output.Emission += _EmissiveColor;
|
|
#endif
|
|
#endif
|
|
#if defined(_RENDER_PIPELINE)
|
|
output.SpecularColor = _MainLightColor.rgb;
|
|
#else
|
|
output.SpecularColor = _LightColor0.rgb;
|
|
#endif
|
|
|
|
return UnityMetaFragment(output);
|
|
}
|
|
ENDCG
|
|
}
|
|
}
|
|
|
|
Fallback "Hidden/InternalErrorShader"
|
|
CustomEditor "Microsoft.MixedReality.Toolkit.Editor.MixedRealityStandardShaderGUI"
|
|
}
|