From 3e3a2bfd9cc6ab4486a22cba7ff8e082ab14ad12 Mon Sep 17 00:00:00 2001 From: anatawa12 Date: Thu, 7 Nov 2024 09:28:04 +0900 Subject: [PATCH 1/2] chore: skip RegisterTextureUVUsage for nonexistent textures --- Editor/Processors/ShaderMaterialInformation.cs | 1 + 1 file changed, 1 insertion(+) diff --git a/Editor/Processors/ShaderMaterialInformation.cs b/Editor/Processors/ShaderMaterialInformation.cs index fdac7efc..16b19efa 100644 --- a/Editor/Processors/ShaderMaterialInformation.cs +++ b/Editor/Processors/ShaderMaterialInformation.cs @@ -162,6 +162,7 @@ public override void RegisterTextureUVUsage( if ((_supportedKind & ShaderInformationKind.TextureAndUVUsage) == 0) throw new InvalidOperationException("RegisterOtherUVUsage is not registered as supported information"); if (_textureUsageInformations == null) return; + if (_material.HasTexture(textureMaterialPropertyName)) return; UVChannel uvChannel; switch (uvChannels) { From 746b77aeaaef5b2a8a01a7a6b4ef8bf8f04812f6 Mon Sep 17 00:00:00 2001 From: anatawa12 Date: Thu, 7 Nov 2024 09:52:01 +0900 Subject: [PATCH 2/2] fix(liltoon): fur shader support --- Editor/APIInternal/ShaderInformation.Liltoon.cs | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/Editor/APIInternal/ShaderInformation.Liltoon.cs b/Editor/APIInternal/ShaderInformation.Liltoon.cs index b6d4f811..1a07760b 100644 --- a/Editor/APIInternal/ShaderInformation.Liltoon.cs +++ b/Editor/APIInternal/ShaderInformation.Liltoon.cs @@ -122,6 +122,7 @@ public override void GetMaterialInformation(MaterialInformationCallback matInfo) return STAndScrollRotateToMatrix("_MainTex_ST", "_MainTex_ScrollRotate"); } +#region Default.lilblock / DefaultALL.lilblock matInfo.RegisterTextureUVUsage("_DitherTex", SamplerStateInformation.LinearRepeatSampler, UsingUVChannels.NonMesh, null); // dither UV is based on screen space @@ -558,7 +559,18 @@ public override void GetMaterialInformation(MaterialInformationCallback matInfo) } // _BaseMap and _BaseColorMap are unused - +#endregion Default.lilblock + +#region DefaultFurCutout, DefaultFurTransparent, DefaultAll, + // fur + LIL_SAMPLE_2D_ST("_FurNoiseMask", "_MainTex", UsingUVChannels.UV0); + LIL_SAMPLE_2D_ST_WithMat("_FurMask", "_MainTex", uvMain, uvMainMatrix); + LIL_SAMPLE_2D_ST_WithMat("_FurLengthMask", "_MainTex", uvMain, uvMainMatrix); + LIL_SAMPLE_2D_WithMat("_FurLengthMask", SamplerStateInformation.LinearRepeatSampler, UsingUVChannels.UV0, + STToMatrix($"_MainTex_ST")); + LIL_SAMPLE_2D_WithMat("_FurVectorTex", SamplerStateInformation.LinearRepeatSampler, uvMain, uvMainMatrix); + +#endregion // Vertex ID var idMaskProperties = new[] {