Fix text rendering more

This commit is contained in:
Andrew Cassidy 2020-08-21 23:44:58 -07:00
parent ae351c021f
commit 93c3ff8a49
5 changed files with 44 additions and 32 deletions

View File

@ -4,7 +4,7 @@
#include "AutoLight.cginc" #include "AutoLight.cginc"
#include "Lighting.cginc" #include "Lighting.cginc"
#define CLIP_MARGIN 0.1 #define CLIP_MARGIN 0.05
#define EDGE_MARGIN 0.01 #define EDGE_MARGIN 0.01
// UNIFORM VARIABLES // UNIFORM VARIABLES
@ -85,7 +85,7 @@ struct DecalSurfaceInput
#ifdef DECAL_BASE_NORMAL #ifdef DECAL_BASE_NORMAL
float3 normal; float3 normal;
#endif #endif //DECAL_BASE_NORMAL
float3 vertex_normal; float3 vertex_normal;
float3 viewDir; float3 viewDir;
@ -150,9 +150,7 @@ inline float BoundsDist(float3 p, float3 normal, float3 projNormal) {
float dist = max(max(q.x, q.y), q.z); // pseudo SDF float dist = max(max(q.x, q.y), q.z); // pseudo SDF
float ndist = EDGE_MARGIN - dot(normal, projNormal); // SDF to normal float ndist = EDGE_MARGIN - dot(normal, projNormal); // SDF to normal
return 10 * max(dist, ndist); // return intersection return 10 * max(dist, ndist); // return intersection
#endif #endif //DECAL_PREVIEW
} }
#endif #endif

View File

@ -3,8 +3,15 @@ Shader "ConformalDecals/Text Blit"
Properties Properties
{ {
_MainTex("_MainTex (RGB spec(A))", 2D) = "white" {} _MainTex("_MainTex (RGB spec(A))", 2D) = "white" {}
_WeightNormal("Weight Normal", float) = 0
_WeightBold("Weight Bold", float) = 0.5
_ScaleRatioA("Scale RatioA", float) = 1
_ScaleRatioB("Scale RatioB", float) = 1
_ScaleRatioC("Scale RatioC", float) = 1
} }
SubShader SubShader
{ {
Tags { "Queue" = "Transparent" } Tags { "Queue" = "Transparent" }
@ -20,6 +27,15 @@ Shader "ConformalDecals/Text Blit"
#pragma fragment frag #pragma fragment frag
sampler2D _MainTex; sampler2D _MainTex;
// font weights to fake bold
float _WeightNormal;
float _WeightBold;
// no idea what these do
float _ScaleRatioA;
float _ScaleRatioB;
float _ScaleRatioC;
#include "UnityCG.cginc" #include "UnityCG.cginc"
#include "Lighting.cginc" #include "Lighting.cginc"
@ -27,21 +43,26 @@ Shader "ConformalDecals/Text Blit"
struct v2f { struct v2f {
float4 pos : SV_POSITION; float4 pos : SV_POSITION;
float2 uv : TEXCOORD0; float4 uv : TEXCOORD0; // u, v, bias, 0
}; };
v2f vert(float4 vertex : POSITION, float2 uv : TEXCOORD0) { v2f vert(float4 vertex : POSITION, float2 uv0 : TEXCOORD0, float2 uv1 : TEXCOORD1) {
float bold = step(uv1.y, 0);
float weight = lerp(_WeightNormal, _WeightBold, bold) * _ScaleRatioA / 8.0;
float bias = 1 - weight;
v2f o; v2f o;
o.pos = UnityObjectToClipPos(vertex); o.pos = UnityObjectToClipPos(vertex);
o.uv = uv; o.uv = float4(uv0.x, uv0.y, bias, 0);
return o; return o;
} }
fixed4 frag (v2f i) : SV_Target { fixed4 frag (v2f i) : SV_Target {
float2 uv = i.uv.xy;
float bias = i.uv.z;
fixed4 c = 0; fixed4 c = 0;
c.r = saturate(tex2D(_MainTex,(uv)).a - bias);
c.r = tex2D(_MainTex,(i.uv)).a;
return c; return c;
} }

View File

@ -1,13 +1,11 @@
float4 _DecalColor; float4 _DecalColor;
float _Weight;
float4 _OutlineColor; float4 _OutlineColor;
float _OutlineWidth; float _OutlineWidth;
void surf(DecalSurfaceInput IN, inout SurfaceOutput o) { void surf(DecalSurfaceInput IN, inout SurfaceOutput o) {
float4 color = _DecalColor; float4 color = _DecalColor;
float bias = _Cutoff - (_Weight / 4); float dist = _Cutoff - tex2D(_Decal, IN.uv_decal).r; // text distance
float dist = bias - tex2D(_Decal, IN.uv_decal).r; // text distance
float ddist = SDFdDist(dist); // distance gradient magnitude float ddist = SDFdDist(dist); // distance gradient magnitude
#ifdef DECAL_OUTLINE #ifdef DECAL_OUTLINE

View File

@ -78,7 +78,6 @@ namespace ConformalDecals {
private ColorPickerController _outlineColorPickerController; private ColorPickerController _outlineColorPickerController;
private MaterialTextureProperty _decalTextureProperty; private MaterialTextureProperty _decalTextureProperty;
private MaterialFloatProperty _decalTextWeightProperty;
private MaterialKeywordProperty _fillEnabledProperty; private MaterialKeywordProperty _fillEnabledProperty;
private MaterialColorProperty _fillColorProperty; private MaterialColorProperty _fillColorProperty;
@ -112,7 +111,6 @@ namespace ConformalDecals {
base.OnAwake(); base.OnAwake();
_decalTextureProperty = materialProperties.AddOrGetTextureProperty("_Decal", true); _decalTextureProperty = materialProperties.AddOrGetTextureProperty("_Decal", true);
_decalTextWeightProperty = materialProperties.AddOrGetProperty<MaterialFloatProperty>("_Weight");
_fillEnabledProperty = materialProperties.AddOrGetProperty<MaterialKeywordProperty>("DECAL_FILL"); _fillEnabledProperty = materialProperties.AddOrGetProperty<MaterialKeywordProperty>("DECAL_FILL");
_fillColorProperty = materialProperties.AddOrGetProperty<MaterialColorProperty>("_DecalColor"); _fillColorProperty = materialProperties.AddOrGetProperty<MaterialColorProperty>("_DecalColor");
@ -194,12 +192,12 @@ namespace ConformalDecals {
style = (int) _style.FontStyle; style = (int) _style.FontStyle;
vertical = _style.Vertical; vertical = _style.Vertical;
lineSpacing = _style.LineSpacing; lineSpacing = _style.LineSpacing;
characterSpacing = _style.CharacterSpacing; charSpacing = _style.CharSpacing;
} }
public void OnAfterDeserialize() { public void OnAfterDeserialize() {
_font = DecalConfig.GetFont(fontName); _font = DecalConfig.GetFont(fontName);
_style = new DecalTextStyle((FontStyles) style, vertical, lineSpacing, characterSpacing); _style = new DecalTextStyle((FontStyles) style, vertical, lineSpacing, charSpacing);
} }
public override void OnDestroy() { public override void OnDestroy() {
@ -210,9 +208,9 @@ namespace ConformalDecals {
protected override void OnDetach() { protected override void OnDetach() {
// close all UIs // close all UIs
if (_textEntryController != null) _textEntryController.OnClose(); if (_textEntryController != null) _textEntryController.Close();
if (_fillColorPickerController != null) _fillColorPickerController.OnClose(); if (_fillColorPickerController != null) _fillColorPickerController.Close();
if (_outlineColorPickerController != null) _outlineColorPickerController.OnClose(); if (_outlineColorPickerController != null) _outlineColorPickerController.Close();
base.OnDetach(); base.OnDetach();
} }
@ -283,7 +281,5 @@ namespace ConformalDecals {
base.UpdateTweakables(); base.UpdateTweakables();
} }
protected void UpdateCachedProperties() { }
} }
} }

View File

@ -24,7 +24,7 @@ namespace ConformalDecals.Text {
[Serializable] [Serializable]
public class TextRenderEvent : UnityEvent<TextRenderOutput> { } public class TextRenderEvent : UnityEvent<TextRenderOutput> { }
private const string BlitShader = "ConformalDecals/Text Blit"; private const string ShaderName = "ConformalDecals/Text Blit";
private const int MaxTextureSize = 4096; private const int MaxTextureSize = 4096;
private const float FontSize = 100; private const float FontSize = 100;
private const float PixelDensity = 5; private const float PixelDensity = 5;
@ -90,9 +90,8 @@ namespace ConformalDecals.Text {
_tmp = gameObject.AddComponent<TextMeshPro>(); _tmp = gameObject.AddComponent<TextMeshPro>();
_tmp.renderer.enabled = false; // dont automatically render _tmp.renderer.enabled = false; // dont automatically render
var shader = Shabby.Shabby.FindShader(BlitShader); _blitShader = Shabby.Shabby.FindShader(ShaderName);
if (shader == null) Debug.LogError($"[ConformalDecals] could not find text blit shader named '{shader}'"); if (_blitShader == null) Debug.LogError($"[ConformalDecals] could not find text blit shader named '{ShaderName}'");
_blitShader = Shabby.Shabby.FindShader(BlitShader);
_isSetup = true; _isSetup = true;
} }
@ -157,7 +156,7 @@ namespace ConformalDecals.Text {
_tmp.font = text.Font.FontAsset; _tmp.font = text.Font.FontAsset;
_tmp.fontStyle = text.Style.FontStyle | text.Font.FontStyle; _tmp.fontStyle = text.Style.FontStyle | text.Font.FontStyle;
_tmp.lineSpacing = text.Style.LineSpacing; _tmp.lineSpacing = text.Style.LineSpacing;
_tmp.characterSpacing = text.Style.CharacterSpacing; _tmp.characterSpacing = text.Style.CharSpacing;
_tmp.extraPadding = true; _tmp.extraPadding = true;
_tmp.enableKerning = true; _tmp.enableKerning = true;
@ -236,10 +235,10 @@ namespace ConformalDecals.Text {
// SETUP TEXTURE // SETUP TEXTURE
if (texture == null) { if (texture == null) {
texture = new Texture2D(textureSize.x, textureSize.y, TextTextureFormat, false); texture = new Texture2D(textureSize.x, textureSize.y, TextTextureFormat, true);
} }
else if (texture.width != textureSize.x || texture.height != textureSize.y || texture.format != TextTextureFormat) { else if (texture.width != textureSize.x || texture.height != textureSize.y || texture.format != TextTextureFormat) {
texture.Resize(textureSize.x, textureSize.y, TextTextureFormat, false); texture.Resize(textureSize.x, textureSize.y, TextTextureFormat, true);
} }
// GENERATE PROJECTION MATRIX // GENERATE PROJECTION MATRIX
@ -268,7 +267,7 @@ namespace ConformalDecals.Text {
// COPY TEXTURE BACK INTO RAM // COPY TEXTURE BACK INTO RAM
RenderTexture.active = renderTex; RenderTexture.active = renderTex;
texture.ReadPixels(new Rect(0, 0, textureSize.x, textureSize.y), 0, 0, false); texture.ReadPixels(new Rect(0, 0, textureSize.x, textureSize.y), 0, 0, true);
texture.Apply(); texture.Apply();
// RELEASE RENDERTEX // RELEASE RENDERTEX