mirror of
https://github.com/drewcassidy/KSP-Conformal-Decals.git
synced 2024-09-01 18:23:54 +00:00
More text rendering tests
This commit is contained in:
parent
7574614776
commit
f3698fc108
@ -17,11 +17,11 @@ public class TextRenderTest : MonoBehaviour {
|
|||||||
|
|
||||||
public Material _targetMaterial;
|
public Material _targetMaterial;
|
||||||
|
|
||||||
public RenderTexture renderTex;
|
public RenderTexture renderTex;
|
||||||
private float pixelDensity = 36;
|
private float pixelDensity = 5;
|
||||||
private int MaxTextureSize = 4096;
|
private int MaxTextureSize = 4096;
|
||||||
|
|
||||||
public const TextureFormat TextTextureFormat = TextureFormat.RG16;
|
public const TextureFormat TextTextureFormat = TextureFormat.RG16;
|
||||||
public const RenderTextureFormat TextRenderTextureFormat = RenderTextureFormat.R8;
|
public const RenderTextureFormat TextRenderTextureFormat = RenderTextureFormat.R8;
|
||||||
|
|
||||||
// Start is called before the first frame update
|
// Start is called before the first frame update
|
||||||
@ -32,12 +32,7 @@ public class TextRenderTest : MonoBehaviour {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update is called once per frame
|
// Update is called once per frame
|
||||||
void Update() {
|
void Update() { }
|
||||||
}
|
|
||||||
|
|
||||||
private void go() {
|
|
||||||
Debug.Log("starting...");
|
|
||||||
}
|
|
||||||
|
|
||||||
private IEnumerator OnRender() {
|
private IEnumerator OnRender() {
|
||||||
Debug.Log("starting...2");
|
Debug.Log("starting...2");
|
||||||
@ -49,40 +44,69 @@ public class TextRenderTest : MonoBehaviour {
|
|||||||
var bounds = mesh.bounds;
|
var bounds = mesh.bounds;
|
||||||
Debug.Log(bounds.size);
|
Debug.Log(bounds.size);
|
||||||
|
|
||||||
var width = Mathf.NextPowerOfTwo((int) (bounds.size.x * pixelDensity));
|
var width = bounds.size.x * pixelDensity;
|
||||||
var height = Mathf.NextPowerOfTwo((int) (bounds.size.y * pixelDensity));
|
var height = bounds.size.y * pixelDensity;
|
||||||
|
|
||||||
Debug.Log($"width = {width}");
|
var widthPoT = Mathf.NextPowerOfTwo((int) width);
|
||||||
Debug.Log($"height = {height}");
|
var heightPoT = Mathf.NextPowerOfTwo((int) height);
|
||||||
|
|
||||||
_camera.orthographicSize = height / pixelDensity / 2;
|
if (widthPoT > MaxTextureSize) {
|
||||||
_camera.aspect = (float) width / height;
|
widthPoT /= widthPoT / MaxTextureSize;
|
||||||
|
heightPoT /= widthPoT / MaxTextureSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (heightPoT > MaxTextureSize) {
|
||||||
|
widthPoT /= heightPoT / MaxTextureSize;
|
||||||
|
heightPoT /= heightPoT / MaxTextureSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
widthPoT = Mathf.Min(widthPoT, MaxTextureSize);
|
||||||
|
heightPoT = Mathf.Min(heightPoT, MaxTextureSize);
|
||||||
|
|
||||||
|
var widthRatio = widthPoT / width;
|
||||||
|
var heightRatio = heightPoT / height;
|
||||||
|
|
||||||
|
var sizeRatio = Mathf.Min(widthRatio, heightRatio);
|
||||||
|
|
||||||
|
int scaledHeight = (int) (sizeRatio * height);
|
||||||
|
int scaledWidth = (int) (sizeRatio * width);
|
||||||
|
|
||||||
|
Debug.Log($"width = {scaledWidth}");
|
||||||
|
Debug.Log($"height = {scaledHeight}");
|
||||||
|
|
||||||
|
_camera.orthographicSize = scaledHeight / pixelDensity / 2;
|
||||||
|
_camera.aspect = (float) widthPoT / heightPoT;
|
||||||
|
|
||||||
_cameraObject.transform.localPosition = new Vector3(bounds.center.x, bounds.center.y, -1);
|
_cameraObject.transform.localPosition = new Vector3(bounds.center.x, bounds.center.y, -1);
|
||||||
|
|
||||||
width = Mathf.Min(width, MaxTextureSize);
|
var halfHeight = scaledHeight / pixelDensity / 2;
|
||||||
height = Mathf.Min(height, MaxTextureSize);
|
var halfWidth = scaledWidth / pixelDensity / 2;
|
||||||
|
var matrix = Matrix4x4.Ortho(bounds.center.x - halfWidth, bounds.center.x + halfWidth,
|
||||||
|
bounds.center.y - halfHeight, bounds.center.y + halfHeight, -1, 1);
|
||||||
|
|
||||||
// setup texture
|
// setup texture
|
||||||
var texture = new Texture2D(width, height, TextTextureFormat, true);
|
var texture = new Texture2D(widthPoT, heightPoT, TextTextureFormat, true);
|
||||||
_targetMaterial.mainTexture = texture;
|
_targetMaterial.mainTexture = texture;
|
||||||
|
|
||||||
|
|
||||||
// setup render texture
|
// setup render texture
|
||||||
renderTex = RenderTexture.GetTemporary(width, height, 0, TextRenderTextureFormat, RenderTextureReadWrite.Linear, 1);
|
renderTex = RenderTexture.GetTemporary(widthPoT, heightPoT, 0, TextRenderTextureFormat, RenderTextureReadWrite.Linear, 1);
|
||||||
renderTex.autoGenerateMips = true;
|
renderTex.autoGenerateMips = false;
|
||||||
_camera.targetTexture = renderTex;
|
|
||||||
|
RenderTexture.active = renderTex;
|
||||||
|
GL.PushMatrix();
|
||||||
|
GL.LoadProjectionMatrix(matrix);
|
||||||
|
_blitMaterial.SetPass(0);
|
||||||
|
Graphics.DrawMeshNow(mesh, Matrix4x4.identity);
|
||||||
|
GL.PopMatrix();
|
||||||
|
|
||||||
// setup material
|
// setup material
|
||||||
_blitMaterial.mainTexture = _tmp.font.atlas;
|
_blitMaterial.mainTexture = _tmp.font.atlas;
|
||||||
|
|
||||||
// draw the mesh
|
|
||||||
Graphics.DrawMesh(mesh, _tmp.renderer.localToWorldMatrix, _blitMaterial, 0, _camera, 0);
|
|
||||||
_camera.Render();
|
|
||||||
|
|
||||||
yield return null;
|
yield return null;
|
||||||
|
|
||||||
RenderTexture.active = renderTex;
|
RenderTexture.active = renderTex;
|
||||||
texture.ReadPixels(new Rect(0, 0, width, height), 0, 0, true);
|
texture.ReadPixels(new Rect(0, 0, widthPoT, heightPoT), 0, 0, true);
|
||||||
texture.Apply(false, true);
|
texture.Apply(false, true);
|
||||||
|
|
||||||
RenderTexture.ReleaseTemporary(renderTex);
|
RenderTexture.ReleaseTemporary(renderTex);
|
||||||
|
Loading…
Reference in New Issue
Block a user