@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: b73ad36839d77914fb63e1e2d883f328 | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1 @@ | |||
#Allows git to track this folder even if it is empty. |
size 405 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: fed0cedb50710c846b7007e6032b8a2c | |||
NativeFormatImporter: | |||
externalObjects: {} | |||
mainObjectFileID: 0 | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 87867a93d9f2f3b4bbdbb09f1edb38c0 | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 470 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 9e0270b3080d6da47a43c001bfd38d43 | |||
NativeFormatImporter: | |||
externalObjects: {} | |||
mainObjectFileID: 0 | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 31025 |
@ -0,0 +1,7 @@ | |||
fileFormatVersion: 2 | |||
guid: b79707a426eed924a9926d85a57c24ae | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 40106 |
@ -0,0 +1,7 @@ | |||
fileFormatVersion: 2 | |||
guid: 62455bbae417074499a9bafc42cc8e9e | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 37832 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 48236b87667c0e94f93b136b9be76cda | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,47 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
public class GameManager : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private PlayerList m_PlayerList; | |||
[SerializeField] | |||
private GameObject m_playerPrefab; | |||
private Camera m_camera; | |||
// Start is called before the first frame update | |||
void Start() | |||
{ | |||
SetUpPlayers(); | |||
m_camera = Camera.main; | |||
} | |||
private void SetUpPlayers() | |||
{ | |||
foreach (PlayerData data in m_PlayerList.AllPlayers) | |||
{ | |||
GameObject newPlayer = Instantiate(m_playerPrefab); | |||
data.Input.SwitchCurrentActionMap("Gameplay"); | |||
foreach (InputBehaviour input in newPlayer.GetComponentsInChildren<InputBehaviour>()) | |||
input.Initialise(data); | |||
newPlayer.GetComponentInChildren<PlayerVisuals>().Initalise(data); | |||
newPlayer.transform.position += Vector3.ProjectOnPlane(Random.insideUnitSphere, Vector3.up); | |||
} | |||
} | |||
private void LateUpdate() | |||
{ | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: ca88e316f132da340a81ad7b750dea78 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,48 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
using NaughtyAttributes; | |||
using Variables; | |||
public class JoinManager : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private float m_JoinTime = 10; | |||
[SerializeField] | |||
private Reference<float> m_CountDown; | |||
[SerializeField] | |||
private PlayerManager m_playerManager; | |||
[SerializeField,Scene] | |||
private string m_nextScene; | |||
// Start is called before the first frame update | |||
void Start() | |||
{ | |||
m_playerManager.AllowJoin(true); | |||
StartCoroutine(DoCountDown(m_JoinTime)); | |||
} | |||
private IEnumerator DoCountDown(float totalTime) | |||
{ | |||
m_CountDown.Value = totalTime; | |||
while (m_CountDown > 0) | |||
{ | |||
m_CountDown.Value -= Time.deltaTime; | |||
yield return new WaitForEndOfFrame(); | |||
} | |||
CountDownFinished(); | |||
} | |||
private void CountDownFinished() | |||
{ | |||
m_playerManager.AllowJoin(false); | |||
UnityEngine.SceneManagement.SceneManager.LoadScene(m_nextScene); | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: a267183a1aac43748988d099f24efe06 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,27 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
using UnityEngine.InputSystem; | |||
public abstract class InputBehaviour : MonoBehaviour | |||
{ | |||
protected PlayerData m_data; | |||
public virtual void Initialise(PlayerData data) | |||
{ | |||
this.m_data = data; | |||
RegisterInput(data.Input); | |||
} | |||
protected virtual void OnDestroy() | |||
{ | |||
if (m_data != null) | |||
UnregisterInput(m_data.Input); | |||
} | |||
public abstract void RegisterInput(PlayerInput playerInput); | |||
public abstract void UnregisterInput(PlayerInput playerInput); | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 3ce47a6f551a12e45b389bbcadd60fee | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,31 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
using UnityEngine.InputSystem; | |||
[System.Serializable] | |||
public class PlayerData : ScriptableObject | |||
{ | |||
public static uint PlayerCount; | |||
public uint ID { get; private set; } | |||
public Color Color { get; private set; } | |||
public UnityEngine.InputSystem.PlayerInput Input { get; private set; } | |||
public static PlayerData Initialise(uint ID, Color color, UnityEngine.InputSystem.PlayerInput input) | |||
{ | |||
PlayerData data = ScriptableObject.CreateInstance<PlayerData>(); | |||
data.Color = color; | |||
data.ID = ID; | |||
data.Input = input; | |||
return data; | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 485593e52a1569e4e868edc474d3d345 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,16 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
public class PlayerDataHolder : MonoBehaviour | |||
{ | |||
private PlayerData m_Data; | |||
public void Initialise(PlayerData data) | |||
{ | |||
m_Data = data; | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 8fa05fb7e07cd834287b7e97ac2f7576 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,59 @@ | |||
using System; | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using System.Linq; | |||
using UnityEngine; | |||
using UnityEngine.InputSystem; | |||
using NaughtyAttributes; | |||
using Random = UnityEngine.Random; | |||
[CreateAssetMenu(menuName = "Data/PlayerList")] | |||
public class PlayerList : ScriptableObject | |||
{ | |||
[ShowNativeProperty] | |||
public int PlayerCount => Players.Count; | |||
public PlayerData[] AllPlayers => Players.Values.ToArray(); | |||
public Dictionary<PlayerInput, PlayerData> Players = new Dictionary<PlayerInput, PlayerData>(); | |||
private uint m_totalPlayerCount; | |||
public event EventHandler<PlayerData> OnPlayerJoin; | |||
public PlayerData AddPlayer(UnityEngine.InputSystem.PlayerInput input) | |||
{ | |||
uint ID = m_totalPlayerCount++; | |||
Color color = Random.ColorHSV(0, 1, 1, 1, 0.75f, 1); | |||
PlayerData data = PlayerData.Initialise(ID, color, input); | |||
Players.Add(input, data); | |||
OnPlayerJoin?.Invoke(this,data); | |||
return data; | |||
} | |||
[ContextMenu("Add Fake Player")] | |||
private void AddFakePlayer() | |||
{ | |||
uint ID = m_totalPlayerCount++; | |||
Color color = Random.ColorHSV(0, 1, 1, 1, 0.75f, 1); | |||
PlayerData data = PlayerData.Initialise(ID, color, null); | |||
//Players.Add(null, data); | |||
OnPlayerJoin?.Invoke(this, data); | |||
} | |||
private void OnEnable() | |||
{ | |||
Players = new Dictionary<UnityEngine.InputSystem.PlayerInput, PlayerData>(); | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 6fdc33589637e64429e95be33c483b8f | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,45 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
using UnityEngine.InputSystem; | |||
[RequireComponent(typeof(PlayerInputManager))] | |||
public class PlayerManager : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private PlayerList m_connectedPlayers; | |||
private PlayerInputManager m_playerManager; | |||
private void OnEnable() | |||
{ | |||
DontDestroyOnLoad(gameObject); | |||
m_playerManager = GetComponent<PlayerInputManager>(); | |||
} | |||
public void OnPlayerJoined(UnityEngine.InputSystem.PlayerInput player) | |||
{ | |||
GameObject newPlayer = player.gameObject; | |||
Debug.Log($"New Player Joined"); | |||
PlayerData data = m_connectedPlayers.AddPlayer(player); | |||
newPlayer.GetComponent<PlayerDataHolder>().Initialise(data); | |||
newPlayer.transform.SetParent(transform, false); | |||
} | |||
public void AllowJoin(bool value) | |||
{ | |||
if (value) | |||
m_playerManager.EnableJoining(); | |||
else | |||
m_playerManager.DisableJoining(); | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: b239f355fc6175e4dbe9a26698704b06 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,47 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
public class PlayerVisuals : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private SpriteRenderer m_apron; | |||
[SerializeField] | |||
private Transform m_moveingObject; | |||
private Camera m_camera; | |||
private Vector3 m_startScale; | |||
private void Awake() | |||
{ | |||
m_camera = Camera.main; | |||
m_startScale = transform.localScale; | |||
} | |||
public void Initalise(PlayerData data) | |||
{ | |||
m_apron.color = data.Color; | |||
} | |||
public void LateUpdate() | |||
{ | |||
transform.rotation = m_camera.transform.rotation; | |||
transform.Rotate(new Vector3(0, 180, 0)); | |||
float direction = Mathf.Sign(Vector3.Dot(m_moveingObject.transform.forward, -m_camera.transform.right)); | |||
transform.localScale = new Vector3(m_startScale.x * direction, m_startScale.y, m_startScale.z); | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: f1c5224ac04236e479fb805642e4f051 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: af86360b79a4a63468a257f51ff701f9 | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 4187e44d26a5d1647835f45ed66ef4ea | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,47 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
using UnityEngine.InputSystem; | |||
using UnityEngine.UI; | |||
public class PlayerJoinIcon : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private Image m_apron; | |||
private PlayerData m_data; | |||
private Vector3 m_startingScale; | |||
private void OnEnable() | |||
{ | |||
m_startingScale = transform.localScale; | |||
Debug.Log("New player awake"); | |||
if (m_data != null) | |||
{ | |||
m_data.Input.currentActionMap.FindAction("Ping").started += OnPlayerPing; | |||
m_data.Input.currentActionMap.FindAction("Ping").canceled += OnPlayerPing; | |||
} | |||
} | |||
public void Initialise(PlayerData data) | |||
{ | |||
Debug.Log("Initialised new Player"); | |||
m_data = data; | |||
m_apron.color = data.Color; | |||
} | |||
public void OnPlayerPing(InputAction.CallbackContext args) | |||
{ | |||
Debug.Log($"Ping: {args.phase}"); | |||
if (args.phase == InputActionPhase.Started) | |||
transform.localScale = m_startingScale * 1.1f; | |||
else if (args.phase == InputActionPhase.Canceled) | |||
transform.localScale = m_startingScale; | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 3c259929c41e35b42beebc0c48152528 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,80 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using UnityEngine; | |||
public class PlayerJoinUI : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private PlayerList m_ConnectedPlayers; | |||
[SerializeField] | |||
private RectTransform m_prefab; | |||
[SerializeField] | |||
private List<RectTransform> m_zones; | |||
private int count; | |||
private void OnEnable() | |||
{ | |||
m_ConnectedPlayers.OnPlayerJoin += OnPlayerJoin; | |||
} | |||
private void OnDisable() | |||
{ | |||
m_ConnectedPlayers.OnPlayerJoin -= OnPlayerJoin; | |||
} | |||
private void OnPlayerJoin(object sender, PlayerData data) | |||
{ | |||
RectTransform parent = m_zones[count++]; | |||
count = count % m_zones.Count; | |||
RectTransform newPoster = Instantiate(m_prefab); | |||
newPoster.parent = parent; | |||
RectTransform[] children = parent.GetComponentsInChildren<RectTransform>(); | |||
for (int i = 0; i < 10; i++) | |||
{ | |||
float randomX = Random.Range(parent.rect.xMin + newPoster.rect.width / 2, parent.rect.xMax - newPoster.rect.width / 2); | |||
float randomY = Random.Range(parent.rect.yMin + newPoster.rect.height / 2, parent.rect.yMax - newPoster.rect.height / 2); | |||
newPoster.localPosition = new Vector3(randomX, randomY, 0.0f); | |||
newPoster.Rotate(Vector3.forward, Random.Range(-20.0f, 20.0f)); | |||
if (Random.Range(0, 2) > 0) | |||
newPoster.transform.localScale = new Vector3(-newPoster.transform.localScale.x, newPoster.transform.localScale.y, newPoster.transform.localScale.z); | |||
bool isOverlapping = false; | |||
foreach (RectTransform child in children) | |||
{ | |||
if (child == parent) | |||
continue; | |||
if (child.rect.Overlaps(newPoster.rect)) | |||
{ | |||
isOverlapping = true; | |||
Debug.Log($"Overlapping with: {child.name} [{i}]"); | |||
} | |||
} | |||
if (!isOverlapping) | |||
break; | |||
} | |||
newPoster.GetComponent<PlayerJoinIcon>().Initialise(data); | |||
newPoster.gameObject.SetActive(true); | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: aefecf74b6329aa42a7f7be88ab870b7 | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,90 @@ | |||
using System.Collections; | |||
using System.Collections.Generic; | |||
using System.Linq; | |||
using UnityEngine; | |||
using TMPro; | |||
using Variables; | |||
public class StartScreenUI : MonoBehaviour | |||
{ | |||
[SerializeField] | |||
private Reference<float> m_StartTime; | |||
[SerializeField] | |||
private TextMeshProUGUI m_countdownText; | |||
[SerializeField] | |||
private AnimationCurve m_lerpCurve; | |||
[SerializeField] | |||
private Transform m_startPosition; | |||
[SerializeField] | |||
private Transform m_endPosition; | |||
[SerializeField] | |||
private List<NumberAlias> m_aliases; | |||
private void OnEnable() | |||
{ | |||
m_StartTime.OnValueChanged += UpdateCountDown; | |||
} | |||
private void OnDisable() | |||
{ | |||
m_StartTime.OnValueChanged -= UpdateCountDown; | |||
} | |||
private void UpdateCountDown(float value) | |||
{ | |||
int number = (int)value; | |||
if (m_aliases.Any(p => p.Number == number)) | |||
{ | |||
m_countdownText.text = m_aliases.First(p => p.Number == number).Name; | |||
} | |||
else | |||
{ | |||
m_countdownText.text = number.ToString(); | |||
} | |||
float ratio = m_lerpCurve.Evaluate(value % 1); | |||
m_countdownText.transform.position = Vector3.Lerp(m_endPosition.position, m_startPosition.position, ratio); | |||
} | |||
[ContextMenu("Do Count Down")] | |||
private void CountDown() | |||
{ | |||
StartCoroutine(CountToZero(m_StartTime)); | |||
} | |||
private IEnumerator CountToZero(float start) | |||
{ | |||
m_StartTime.Value = start; | |||
while (m_StartTime > 0) | |||
{ | |||
m_StartTime.Value -= Time.deltaTime; | |||
yield return new WaitForEndOfFrame(); | |||
} | |||
} | |||
[System.Serializable] | |||
public struct NumberAlias | |||
{ | |||
public int Number; | |||
public string Name; | |||
} | |||
} |
@ -0,0 +1,11 @@ | |||
fileFormatVersion: 2 | |||
guid: 1bc72e25d0c57444a84d27443869d7dc | |||
MonoImporter: | |||
externalObjects: {} | |||
serializedVersion: 2 | |||
defaultReferences: [] | |||
executionOrder: 0 | |||
icon: {instanceID: 0} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: f54d1bd14bd3ca042bd867b519fee8cc | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 8e7e8f5a82a3a134e91c54efd2274ea9 | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 694398 |
@ -0,0 +1,7 @@ | |||
fileFormatVersion: 2 | |||
guid: 1b8d251f9af63b746bf2f7ffe00ebb9b | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 6ab70aee4d56447429c680537fbf93ed | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,46 @@ | |||
Digitized data copyright (c) 2010 Google Corporation | |||
with Reserved Font Arimo, Tinos and Cousine. | |||
Copyright (c) 2012 Red Hat, Inc. | |||
with Reserved Font Name Liberation. | |||
This Font Software is licensed under the SIL Open Font License, Version 1.1. | |||
This license is copied below, and is also available with a FAQ at: http://scripts.sil.org/OFL | |||
----------------------------------------------------------- | |||
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 | |||
----------------------------------------------------------- | |||
PREAMBLE | |||
The goals of the Open Font License (OFL) are to stimulate worldwide development of collaborative font projects, to support the font creation efforts of academic and linguistic communities, and to provide a free and open framework in which fonts may be shared and improved in partnership with others. | |||
The OFL allows the licensed fonts to be used, studied, modified and redistributed freely as long as they are not sold by themselves. The fonts, including any derivative works, can be bundled, embedded, redistributed and/or sold with any software provided that any reserved names are not used by derivative works. The fonts and derivatives, however, cannot be released under any other type of license. The requirement for fonts to remain under this license does not apply to any document created using the fonts or their derivatives. | |||
DEFINITIONS | |||
"Font Software" refers to the set of files released by the Copyright Holder(s) under this license and clearly marked as such. This may include source files, build scripts and documentation. | |||
"Reserved Font Name" refers to any names specified as such after the copyright statement(s). | |||
"Original Version" refers to the collection of Font Software components as distributed by the Copyright Holder(s). | |||
"Modified Version" refers to any derivative made by adding to, deleting, or substituting -- in part or in whole -- any of the components of the Original Version, by changing formats or by porting the Font Software to a new environment. | |||
"Author" refers to any designer, engineer, programmer, technical writer or other person who contributed to the Font Software. | |||
PERMISSION & CONDITIONS | |||
Permission is hereby granted, free of charge, to any person obtaining a copy of the Font Software, to use, study, copy, merge, embed, modify, redistribute, and sell modified and unmodified copies of the Font Software, subject to the following conditions: | |||
1) Neither the Font Software nor any of its individual components, in Original or Modified Versions, may be sold by itself. | |||
2) Original or Modified Versions of the Font Software may be bundled, redistributed and/or sold with any software, provided that each copy contains the above copyright notice and this license. These can be included either as stand-alone text files, human-readable headers or in the appropriate machine-readable metadata fields within text or binary files as long as those fields can be easily viewed by the user. | |||
3) No Modified Version of the Font Software may use the Reserved Font Name(s) unless explicit written permission is granted by the corresponding Copyright Holder. This restriction only applies to the primary font name as presented to the users. | |||
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font Software shall not be used to promote, endorse or advertise any Modified Version, except to acknowledge the contribution(s) of the Copyright Holder(s) and the Author(s) or with their explicit written permission. | |||
5) The Font Software, modified or unmodified, in part or in whole, must be distributed entirely under this license, and must not be distributed under any other license. The requirement for fonts to remain under this license does not apply to any document created using the Font Software. | |||
TERMINATION | |||
This license becomes null and void if any of the above conditions are not met. | |||
DISCLAIMER | |||
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM OTHER DEALINGS IN THE FONT SOFTWARE. |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 6e59c59b81ab47f9b6ec5781fa725d2c | |||
timeCreated: 1484171296 | |||
licenseType: Pro | |||
TextScriptImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 350200 |
@ -0,0 +1,19 @@ | |||
fileFormatVersion: 2 | |||
guid: e3265ab4bf004d28a9537516768c1c75 | |||
timeCreated: 1484171297 | |||
licenseType: Pro | |||
TrueTypeFontImporter: | |||
serializedVersion: 2 | |||
fontSize: 16 | |||
forceTextureCase: -2 | |||
characterSpacing: 1 | |||
characterPadding: 0 | |||
includeFontData: 1 | |||
use2xBehaviour: 0 | |||
fontNames: [] | |||
fallbackFontReferences: [] | |||
customCharacters: | |||
fontRenderingMode: 0 | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 243e06394e614e5d99fab26083b707fa | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 731f1baa9d144a9897cb1d341c2092b8 | |||
folderAsset: yes | |||
timeCreated: 1442040525 | |||
licenseType: Pro | |||
DefaultImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,106 @@ | |||
%YAML 1.1 | |||
%TAG !u! tag:unity3d.com,2011: | |||
--- !u!21 &2100000 | |||
Material: | |||
serializedVersion: 6 | |||
m_ObjectHideFlags: 0 | |||
m_CorrespondingSourceObject: {fileID: 0} | |||
m_PrefabInstance: {fileID: 0} | |||
m_PrefabAsset: {fileID: 0} | |||
m_Name: LiberationSans SDF - Drop Shadow | |||
m_Shader: {fileID: 4800000, guid: fe393ace9b354375a9cb14cdbbc28be4, type: 3} | |||
m_ShaderKeywords: OUTLINE_ON UNDERLAY_ON | |||
m_LightmapFlags: 5 | |||
m_EnableInstancingVariants: 0 | |||
m_DoubleSidedGI: 0 | |||
m_CustomRenderQueue: -1 | |||
stringTagMap: {} | |||
disabledShaderPasses: [] | |||
m_SavedProperties: | |||
serializedVersion: 3 | |||
m_TexEnvs: | |||
- _BumpMap: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _Cube: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _FaceTex: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _MainTex: | |||
m_Texture: {fileID: 28684132378477856, guid: 8f586378b4e144a9851e7b34d9b748ee, | |||
type: 2} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _OutlineTex: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
m_Floats: | |||
- _Ambient: 0.5 | |||
- _Bevel: 0.5 | |||
- _BevelClamp: 0 | |||
- _BevelOffset: 0 | |||
- _BevelRoundness: 0 | |||
- _BevelWidth: 0 | |||
- _BumpFace: 0 | |||
- _BumpOutline: 0 | |||
- _ColorMask: 15 | |||
- _Diffuse: 0.5 | |||
- _DiffusePower: 1 | |||
- _FaceDilate: 0.1 | |||
- _FaceUVSpeedX: 0 | |||
- _FaceUVSpeedY: 0 | |||
- _GlowInner: 0.05 | |||
- _GlowOffset: 0 | |||
- _GlowOuter: 0.05 | |||
- _GlowPower: 0.75 | |||
- _GradientScale: 10 | |||
- _LightAngle: 3.1416 | |||
- _MaskSoftnessX: 0 | |||
- _MaskSoftnessY: 0 | |||
- _OutlineSoftness: 0 | |||
- _OutlineUVSpeedX: 0 | |||
- _OutlineUVSpeedY: 0 | |||
- _OutlineWidth: 0.1 | |||
- _PerspectiveFilter: 0.875 | |||
- _Reflectivity: 10 | |||
- _ScaleRatioA: 0.9 | |||
- _ScaleRatioB: 0.73125 | |||
- _ScaleRatioC: 0.64125 | |||
- _ScaleX: 1 | |||
- _ScaleY: 1 | |||
- _ShaderFlags: 0 | |||
- _Sharpness: 0 | |||
- _SpecularPower: 2 | |||
- _Stencil: 0 | |||
- _StencilComp: 8 | |||
- _StencilOp: 0 | |||
- _StencilReadMask: 255 | |||
- _StencilWriteMask: 255 | |||
- _TextureHeight: 1024 | |||
- _TextureWidth: 1024 | |||
- _UnderlayDilate: 0 | |||
- _UnderlayOffsetX: 0.5 | |||
- _UnderlayOffsetY: -0.5 | |||
- _UnderlaySoftness: 0.05 | |||
- _VertexOffsetX: 0 | |||
- _VertexOffsetY: 0 | |||
- _WeightBold: 0.75 | |||
- _WeightNormal: 0 | |||
m_Colors: | |||
- _ClipRect: {r: -32767, g: -32767, b: 32767, a: 32767} | |||
- _Color: {r: 1, g: 1, b: 1, a: 1} | |||
- _EnvMatrixRotation: {r: 0, g: 0, b: 0, a: 0} | |||
- _FaceColor: {r: 1, g: 1, b: 1, a: 1} | |||
- _GlowColor: {r: 0, g: 1, b: 0, a: 0.5} | |||
- _MaskCoord: {r: 0, g: 0, b: 32767, a: 32767} | |||
- _OutlineColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _ReflectFaceColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _ReflectOutlineColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _SpecularColor: {r: 1, g: 1, b: 1, a: 1} | |||
- _UnderlayColor: {r: 0, g: 0, b: 0, a: 0.5} |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: e73a58f6e2794ae7b1b7e50b7fb811b0 | |||
timeCreated: 1484172806 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 9099 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 2e498d1c8094910479dc3e1b768306a4 | |||
timeCreated: 1484171803 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,104 @@ | |||
%YAML 1.1 | |||
%TAG !u! tag:unity3d.com,2011: | |||
--- !u!21 &2100000 | |||
Material: | |||
serializedVersion: 6 | |||
m_ObjectHideFlags: 0 | |||
m_CorrespondingSourceObject: {fileID: 0} | |||
m_PrefabInstance: {fileID: 0} | |||
m_PrefabAsset: {fileID: 0} | |||
m_Name: LiberationSans SDF - Outline | |||
m_Shader: {fileID: 4800000, guid: fe393ace9b354375a9cb14cdbbc28be4, type: 3} | |||
m_ShaderKeywords: OUTLINE_ON | |||
m_LightmapFlags: 5 | |||
m_EnableInstancingVariants: 0 | |||
m_DoubleSidedGI: 0 | |||
m_CustomRenderQueue: -1 | |||
stringTagMap: {} | |||
disabledShaderPasses: [] | |||
m_SavedProperties: | |||
serializedVersion: 3 | |||
m_TexEnvs: | |||
- _BumpMap: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _Cube: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _FaceTex: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _MainTex: | |||
m_Texture: {fileID: 28684132378477856, guid: 8f586378b4e144a9851e7b34d9b748ee, | |||
type: 2} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
- _OutlineTex: | |||
m_Texture: {fileID: 0} | |||
m_Scale: {x: 1, y: 1} | |||
m_Offset: {x: 0, y: 0} | |||
m_Floats: | |||
- _Ambient: 0.5 | |||
- _Bevel: 0.5 | |||
- _BevelClamp: 0 | |||
- _BevelOffset: 0 | |||
- _BevelRoundness: 0 | |||
- _BevelWidth: 0 | |||
- _BumpFace: 0 | |||
- _BumpOutline: 0 | |||
- _ColorMask: 15 | |||
- _Diffuse: 0.5 | |||
- _FaceDilate: 0.1 | |||
- _FaceUVSpeedX: 0 | |||
- _FaceUVSpeedY: 0 | |||
- _GlowInner: 0.05 | |||
- _GlowOffset: 0 | |||
- _GlowOuter: 0.05 | |||
- _GlowPower: 0.75 | |||
- _GradientScale: 10 | |||
- _LightAngle: 3.1416 | |||
- _MaskSoftnessX: 0 | |||
- _MaskSoftnessY: 0 | |||
- _OutlineSoftness: 0 | |||
- _OutlineUVSpeedX: 0 | |||
- _OutlineUVSpeedY: 0 | |||
- _OutlineWidth: 0.1 | |||
- _PerspectiveFilter: 0.875 | |||
- _Reflectivity: 10 | |||
- _ScaleRatioA: 0.9 | |||
- _ScaleRatioB: 0.73125 | |||
- _ScaleRatioC: 0.64125 | |||
- _ScaleX: 1 | |||
- _ScaleY: 1 | |||
- _ShaderFlags: 0 | |||
- _Sharpness: 0 | |||
- _SpecularPower: 2 | |||
- _Stencil: 0 | |||
- _StencilComp: 8 | |||
- _StencilOp: 0 | |||
- _StencilReadMask: 255 | |||
- _StencilWriteMask: 255 | |||
- _TextureHeight: 1024 | |||
- _TextureWidth: 1024 | |||
- _UnderlayDilate: 0 | |||
- _UnderlayOffsetX: 0 | |||
- _UnderlayOffsetY: 0 | |||
- _UnderlaySoftness: 0 | |||
- _VertexOffsetX: 0 | |||
- _VertexOffsetY: 0 | |||
- _WeightBold: 0.75 | |||
- _WeightNormal: 0 | |||
m_Colors: | |||
- _ClipRect: {r: -32767, g: -32767, b: 32767, a: 32767} | |||
- _EnvMatrixRotation: {r: 0, g: 0, b: 0, a: 0} | |||
- _FaceColor: {r: 1, g: 1, b: 1, a: 1} | |||
- _GlowColor: {r: 0, g: 1, b: 0, a: 0.5} | |||
- _MaskCoord: {r: 0, g: 0, b: 32767, a: 32767} | |||
- _OutlineColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _ReflectFaceColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _ReflectOutlineColor: {r: 0, g: 0, b: 0, a: 1} | |||
- _SpecularColor: {r: 1, g: 1, b: 1, a: 1} | |||
- _UnderlayColor: {r: 0, g: 0, b: 0, a: 0.5} |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 79459efec17a4d00a321bdcc27bbc385 | |||
timeCreated: 1484172856 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 2256862 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 8f586378b4e144a9851e7b34d9b748ee | |||
timeCreated: 1484171803 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1 @@ | |||
)]}〕〉》」』】〙〗〟’”⦆»ヽヾーァィゥェォッャュョヮヵヶぁぃぅぇぉっゃゅょゎゕゖㇰㇱㇲㇳㇴㇵㇶㇷㇸㇹㇺㇻㇼㇽㇾㇿ々〻‐゠–〜?!‼⁇⁈⁉・、%,.:;。!?]):;=}¢°"†‡℃〆%,. |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: fade42e8bc714b018fac513c043d323b | |||
timeCreated: 1425440388 | |||
licenseType: Store | |||
TextScriptImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1 @@ | |||
([{〔〈《「『【〘〖〝‘“⦅«$—…‥〳〴〵\[({£¥"々〇$¥₩ # |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: d82c1b31c7e74239bff1220585707d2b | |||
timeCreated: 1425440388 | |||
licenseType: Store | |||
TextScriptImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 512a49d95c0c4332bdd98131869c23c9 | |||
folderAsset: yes | |||
timeCreated: 1441876896 | |||
licenseType: Pro | |||
DefaultImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 13441 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: c41005c129ba4d66911b75229fd70b45 | |||
timeCreated: 1480316912 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 4aecb92fff08436c8303b10eab8da368 | |||
folderAsset: yes | |||
timeCreated: 1441876950 | |||
licenseType: Pro | |||
DefaultImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 4953 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: f952c082cb03451daed3ee968ac6c63e | |||
timeCreated: 1432805430 | |||
licenseType: Store | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
size 1683 |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: 3f5b5dff67a942289a9defa416b206f3 | |||
timeCreated: 1436653997 | |||
licenseType: Pro | |||
NativeFormatImporter: | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,8 @@ | |||
fileFormatVersion: 2 | |||
guid: e9f693669af91aa45ad615fc681ed29f | |||
folderAsset: yes | |||
DefaultImporter: | |||
externalObjects: {} | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,143 @@ | |||
Shader "TextMeshPro/Bitmap Custom Atlas" { | |||
Properties { | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_FaceTex ("Font Texture", 2D) = "white" {} | |||
[HDR]_FaceColor ("Text Color", Color) = (1,1,1,1) | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_ClipRect("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_Padding ("Padding", float) = 0 | |||
_StencilComp("Stencil Comparison", Float) = 8 | |||
_Stencil("Stencil ID", Float) = 0 | |||
_StencilOp("Stencil Operation", Float) = 0 | |||
_StencilWriteMask("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask("Stencil Read Mask", Float) = 255 | |||
_CullMode("Cull Mode", Float) = 0 | |||
_ColorMask("Color Mask", Float) = 15 | |||
} | |||
SubShader{ | |||
Tags { "Queue" = "Transparent" "IgnoreProjector" = "True" "RenderType" = "Transparent" } | |||
Stencil | |||
{ | |||
Ref[_Stencil] | |||
Comp[_StencilComp] | |||
Pass[_StencilOp] | |||
ReadMask[_StencilReadMask] | |||
WriteMask[_StencilWriteMask] | |||
} | |||
Lighting Off | |||
Cull [_CullMode] | |||
ZTest [unity_GUIZTestMode] | |||
ZWrite Off | |||
Fog { Mode Off } | |||
Blend SrcAlpha OneMinusSrcAlpha | |||
ColorMask[_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
struct appdata_t { | |||
float4 vertex : POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct v2f { | |||
float4 vertex : SV_POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
float4 mask : TEXCOORD2; | |||
}; | |||
uniform sampler2D _MainTex; | |||
uniform sampler2D _FaceTex; | |||
uniform float4 _FaceTex_ST; | |||
uniform fixed4 _FaceColor; | |||
uniform float _VertexOffsetX; | |||
uniform float _VertexOffsetY; | |||
uniform float4 _ClipRect; | |||
uniform float _MaskSoftnessX; | |||
uniform float _MaskSoftnessY; | |||
float2 UnpackUV(float uv) | |||
{ | |||
float2 output; | |||
output.x = floor(uv / 4096); | |||
output.y = uv - 4096 * output.x; | |||
return output * 0.001953125; | |||
} | |||
v2f vert (appdata_t v) | |||
{ | |||
float4 vert = v.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
vert.xy += (vert.w * 0.5) / _ScreenParams.xy; | |||
float4 vPosition = UnityPixelSnap(UnityObjectToClipPos(vert)); | |||
fixed4 faceColor = v.color; | |||
faceColor *= _FaceColor; | |||
v2f OUT; | |||
OUT.vertex = vPosition; | |||
OUT.color = faceColor; | |||
OUT.texcoord0 = v.texcoord0; | |||
OUT.texcoord1 = TRANSFORM_TEX(UnpackUV(v.texcoord1), _FaceTex); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= abs(float2(_ScreenParams.x * UNITY_MATRIX_P[0][0], _ScreenParams.y * UNITY_MATRIX_P[1][1])); | |||
// Clamp _ClipRect to 16bit. | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
OUT.mask = float4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
return OUT; | |||
} | |||
fixed4 frag (v2f IN) : SV_Target | |||
{ | |||
fixed4 color = tex2D(_MainTex, IN.texcoord0) * tex2D(_FaceTex, IN.texcoord1) * IN.color; | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(IN.mask.xy)) * IN.mask.zw); | |||
color *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(color.a - 0.001); | |||
#endif | |||
return color; | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_BitmapShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 48bb5f55d8670e349b6e614913f9d910 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,145 @@ | |||
Shader "TextMeshPro/Mobile/Bitmap" { | |||
Properties { | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
[HDR]_Color ("Text Color", Color) = (1,1,1,1) | |||
_DiffusePower ("Diffuse Power", Range(1.0,4.0)) = 1.0 | |||
_VertexOffsetX("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY("Vertex OffsetY", float) = 0 | |||
_MaskSoftnessX("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY("Mask SoftnessY", float) = 0 | |||
_ClipRect("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_StencilComp("Stencil Comparison", Float) = 8 | |||
_Stencil("Stencil ID", Float) = 0 | |||
_StencilOp("Stencil Operation", Float) = 0 | |||
_StencilWriteMask("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask("Stencil Read Mask", Float) = 255 | |||
_CullMode("Cull Mode", Float) = 0 | |||
_ColorMask("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags { "Queue"="Transparent" "IgnoreProjector"="True" "RenderType"="Transparent" } | |||
Stencil | |||
{ | |||
Ref[_Stencil] | |||
Comp[_StencilComp] | |||
Pass[_StencilOp] | |||
ReadMask[_StencilReadMask] | |||
WriteMask[_StencilWriteMask] | |||
} | |||
Lighting Off | |||
Cull [_CullMode] | |||
ZTest [unity_GUIZTestMode] | |||
ZWrite Off | |||
Fog { Mode Off } | |||
Blend SrcAlpha OneMinusSrcAlpha | |||
ColorMask[_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#pragma fragmentoption ARB_precision_hint_fastest | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
struct appdata_t { | |||
float4 vertex : POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct v2f { | |||
float4 vertex : POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float4 mask : TEXCOORD2; | |||
}; | |||
sampler2D _MainTex; | |||
fixed4 _Color; | |||
float _DiffusePower; | |||
uniform float _VertexOffsetX; | |||
uniform float _VertexOffsetY; | |||
uniform float4 _ClipRect; | |||
uniform float _MaskSoftnessX; | |||
uniform float _MaskSoftnessY; | |||
v2f vert (appdata_t v) | |||
{ | |||
v2f OUT; | |||
float4 vert = v.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
vert.xy += (vert.w * 0.5) / _ScreenParams.xy; | |||
OUT.vertex = UnityPixelSnap(UnityObjectToClipPos(vert)); | |||
OUT.color = v.color; | |||
OUT.color *= _Color; | |||
OUT.color.rgb *= _DiffusePower; | |||
OUT.texcoord0 = v.texcoord0; | |||
float2 pixelSize = OUT.vertex.w; | |||
//pixelSize /= abs(float2(_ScreenParams.x * UNITY_MATRIX_P[0][0], _ScreenParams.y * UNITY_MATRIX_P[1][1])); | |||
// Clamp _ClipRect to 16bit. | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
OUT.mask = float4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
return OUT; | |||
} | |||
fixed4 frag (v2f IN) : COLOR | |||
{ | |||
fixed4 color = fixed4(IN.color.rgb, IN.color.a * tex2D(_MainTex, IN.texcoord0).a); | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(IN.mask.xy)) * IN.mask.zw); | |||
color *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(color.a - 0.001); | |||
#endif | |||
return color; | |||
} | |||
ENDCG | |||
} | |||
} | |||
SubShader { | |||
Tags { "Queue"="Transparent" "IgnoreProjector"="True" "RenderType"="Transparent" } | |||
Lighting Off Cull Off ZTest Always ZWrite Off Fog { Mode Off } | |||
Blend SrcAlpha OneMinusSrcAlpha | |||
BindChannels { | |||
Bind "Color", color | |||
Bind "Vertex", vertex | |||
Bind "TexCoord", texcoord0 | |||
} | |||
Pass { | |||
SetTexture [_MainTex] { | |||
constantColor [_Color] combine constant * primary, constant * texture | |||
} | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_BitmapShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 1e3b057af24249748ff873be7fafee47 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,143 @@ | |||
Shader "TextMeshPro/Bitmap" { | |||
Properties { | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_FaceTex ("Font Texture", 2D) = "white" {} | |||
[HDR]_FaceColor ("Text Color", Color) = (1,1,1,1) | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_ClipRect("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_StencilComp("Stencil Comparison", Float) = 8 | |||
_Stencil("Stencil ID", Float) = 0 | |||
_StencilOp("Stencil Operation", Float) = 0 | |||
_StencilWriteMask("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask("Stencil Read Mask", Float) = 255 | |||
_CullMode("Cull Mode", Float) = 0 | |||
_ColorMask("Color Mask", Float) = 15 | |||
} | |||
SubShader{ | |||
Tags { "Queue" = "Transparent" "IgnoreProjector" = "True" "RenderType" = "Transparent" } | |||
Stencil | |||
{ | |||
Ref[_Stencil] | |||
Comp[_StencilComp] | |||
Pass[_StencilOp] | |||
ReadMask[_StencilReadMask] | |||
WriteMask[_StencilWriteMask] | |||
} | |||
Lighting Off | |||
Cull [_CullMode] | |||
ZTest [unity_GUIZTestMode] | |||
ZWrite Off | |||
Fog { Mode Off } | |||
Blend SrcAlpha OneMinusSrcAlpha | |||
ColorMask[_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
struct appdata_t { | |||
float4 vertex : POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct v2f { | |||
float4 vertex : SV_POSITION; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
float4 mask : TEXCOORD2; | |||
}; | |||
uniform sampler2D _MainTex; | |||
uniform sampler2D _FaceTex; | |||
uniform float4 _FaceTex_ST; | |||
uniform fixed4 _FaceColor; | |||
uniform float _VertexOffsetX; | |||
uniform float _VertexOffsetY; | |||
uniform float4 _ClipRect; | |||
uniform float _MaskSoftnessX; | |||
uniform float _MaskSoftnessY; | |||
float2 UnpackUV(float uv) | |||
{ | |||
float2 output; | |||
output.x = floor(uv / 4096); | |||
output.y = uv - 4096 * output.x; | |||
return output * 0.001953125; | |||
} | |||
v2f vert (appdata_t v) | |||
{ | |||
float4 vert = v.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
vert.xy += (vert.w * 0.5) / _ScreenParams.xy; | |||
float4 vPosition = UnityPixelSnap(UnityObjectToClipPos(vert)); | |||
fixed4 faceColor = v.color; | |||
faceColor *= _FaceColor; | |||
v2f OUT; | |||
OUT.vertex = vPosition; | |||
OUT.color = faceColor; | |||
OUT.texcoord0 = v.texcoord0; | |||
OUT.texcoord1 = TRANSFORM_TEX(UnpackUV(v.texcoord1), _FaceTex); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= abs(float2(_ScreenParams.x * UNITY_MATRIX_P[0][0], _ScreenParams.y * UNITY_MATRIX_P[1][1])); | |||
// Clamp _ClipRect to 16bit. | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
OUT.mask = float4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
return OUT; | |||
} | |||
fixed4 frag (v2f IN) : SV_Target | |||
{ | |||
fixed4 color = tex2D(_MainTex, IN.texcoord0); | |||
color = fixed4 (tex2D(_FaceTex, IN.texcoord1).rgb * IN.color.rgb, IN.color.a * color.a); | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(IN.mask.xy)) * IN.mask.zw); | |||
color *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(color.a - 0.001); | |||
#endif | |||
return color; | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_BitmapShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 128e987d567d4e2c824d754223b3f3b0 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,317 @@ | |||
Shader "TextMeshPro/Distance Field Overlay" { | |||
Properties { | |||
_FaceTex ("Face Texture", 2D) = "white" {} | |||
_FaceUVSpeedX ("Face UV Speed X", Range(-5, 5)) = 0.0 | |||
_FaceUVSpeedY ("Face UV Speed Y", Range(-5, 5)) = 0.0 | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineTex ("Outline Texture", 2D) = "white" {} | |||
_OutlineUVSpeedX ("Outline UV Speed X", Range(-5, 5)) = 0.0 | |||
_OutlineUVSpeedY ("Outline UV Speed Y", Range(-5, 5)) = 0.0 | |||
_OutlineWidth ("Outline Thickness", Range(0, 1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
_Bevel ("Bevel", Range(0,1)) = 0.5 | |||
_BevelOffset ("Bevel Offset", Range(-0.5,0.5)) = 0 | |||
_BevelWidth ("Bevel Width", Range(-.5,0.5)) = 0 | |||
_BevelClamp ("Bevel Clamp", Range(0,1)) = 0 | |||
_BevelRoundness ("Bevel Roundness", Range(0,1)) = 0 | |||
_LightAngle ("Light Angle", Range(0.0, 6.2831853)) = 3.1416 | |||
[HDR]_SpecularColor ("Specular", Color) = (1,1,1,1) | |||
_SpecularPower ("Specular", Range(0,4)) = 2.0 | |||
_Reflectivity ("Reflectivity", Range(5.0,15.0)) = 10 | |||
_Diffuse ("Diffuse", Range(0,1)) = 0.5 | |||
_Ambient ("Ambient", Range(1,0)) = 0.5 | |||
_BumpMap ("Normal map", 2D) = "bump" {} | |||
_BumpOutline ("Bump Outline", Range(0,1)) = 0 | |||
_BumpFace ("Bump Face", Range(0,1)) = 0 | |||
_ReflectFaceColor ("Reflection Color", Color) = (0,0,0,1) | |||
_ReflectOutlineColor("Reflection Color", Color) = (0,0,0,1) | |||
_Cube ("Reflection Cubemap", Cube) = "black" { /* TexGen CubeReflect */ } | |||
_EnvMatrixRotation ("Texture Rotation", vector) = (0, 0, 0, 0) | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0, 0.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
[HDR]_GlowColor ("Color", Color) = (0, 1, 0, 0.5) | |||
_GlowOffset ("Offset", Range(-1,1)) = 0 | |||
_GlowInner ("Inner", Range(0,1)) = 0.05 | |||
_GlowOuter ("Outer", Range(0,1)) = 0.05 | |||
_GlowPower ("Falloff", Range(1, 0)) = 0.75 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = 0.5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5.0 | |||
_ScaleX ("Scale X", float) = 1.0 | |||
_ScaleY ("Scale Y", float) = 1.0 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_MaskCoord ("Mask Coordinates", vector) = (0, 0, 32767, 32767) | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue"="Overlay" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest Always | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma target 3.0 | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ BEVEL_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma shader_feature __ GLOW_ON | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro.cginc" | |||
struct vertex_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
float4 position : POSITION; | |||
float3 normal : NORMAL; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
UNITY_VERTEX_OUTPUT_STEREO | |||
float4 position : SV_POSITION; | |||
fixed4 color : COLOR; | |||
float2 atlas : TEXCOORD0; // Atlas | |||
float4 param : TEXCOORD1; // alphaClip, scale, bias, weight | |||
float4 mask : TEXCOORD2; // Position in object space(xy), pixel Size(zw) | |||
float3 viewDir : TEXCOORD3; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float4 texcoord2 : TEXCOORD4; // u,v, scale, bias | |||
fixed4 underlayColor : COLOR1; | |||
#endif | |||
float4 textures : TEXCOORD5; | |||
}; | |||
// Used by Unity internally to handle Texture Tiling and Offset. | |||
float4 _FaceTex_ST; | |||
float4 _OutlineTex_ST; | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
pixel_t output; | |||
UNITY_INITIALIZE_OUTPUT(pixel_t, output); | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
UNITY_TRANSFER_INSTANCE_ID(input,output); | |||
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.position; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= float2(_ScaleX, _ScaleY) * abs(mul((float2x2)UNITY_MATRIX_P, _ScreenParams.xy)); | |||
float scale = rsqrt(dot(pixelSize, pixelSize)); | |||
scale *= abs(input.texcoord1.y) * _GradientScale * (_Sharpness + 1); | |||
if (UNITY_MATRIX_P[3][3] == 0) scale = lerp(abs(scale) * (1 - _PerspectiveFilter), scale, abs(dot(UnityObjectToWorldNormal(input.normal.xyz), normalize(WorldSpaceViewDir(vert))))); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
float bias =(.5 - weight) + (.5 / scale); | |||
float alphaClip = (1.0 - _OutlineWidth*_ScaleRatioA - _OutlineSoftness*_ScaleRatioA); | |||
#if GLOW_ON | |||
alphaClip = min(alphaClip, 1.0 - _GlowOffset * _ScaleRatioB - _GlowOuter * _ScaleRatioB); | |||
#endif | |||
alphaClip = alphaClip / 2.0 - ( .5 / scale) - weight; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float4 underlayColor = _UnderlayColor; | |||
underlayColor.rgb *= underlayColor.a; | |||
float bScale = scale; | |||
bScale /= 1 + ((_UnderlaySoftness*_ScaleRatioC) * bScale); | |||
float bBias = (0.5 - weight) * bScale - 0.5 - ((_UnderlayDilate * _ScaleRatioC) * 0.5 * bScale); | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 bOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
float2 maskUV = (vert.xy - clampedRect.xy) / (clampedRect.zw - clampedRect.xy); | |||
// Support for texture tiling and offset | |||
float2 textureUV = UnpackUV(input.texcoord1.x); | |||
float2 faceUV = TRANSFORM_TEX(textureUV, _FaceTex); | |||
float2 outlineUV = TRANSFORM_TEX(textureUV, _OutlineTex); | |||
output.position = vPosition; | |||
output.color = input.color; | |||
output.atlas = input.texcoord0; | |||
output.param = float4(alphaClip, scale, bias, weight); | |||
output.mask = half4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
output.viewDir = mul((float3x3)_EnvMatrix, _WorldSpaceCameraPos.xyz - mul(unity_ObjectToWorld, vert).xyz); | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
output.texcoord2 = float4(input.texcoord0 + bOffset, bScale, bBias); | |||
output.underlayColor = underlayColor; | |||
#endif | |||
output.textures = float4(faceUV, outlineUV); | |||
return output; | |||
} | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
float c = tex2D(_MainTex, input.atlas).a; | |||
#ifndef UNDERLAY_ON | |||
clip(c - input.param.x); | |||
#endif | |||
float scale = input.param.y; | |||
float bias = input.param.z; | |||
float weight = input.param.w; | |||
float sd = (bias - c) * scale; | |||
float outline = (_OutlineWidth * _ScaleRatioA) * scale; | |||
float softness = (_OutlineSoftness * _ScaleRatioA) * scale; | |||
half4 faceColor = _FaceColor; | |||
half4 outlineColor = _OutlineColor; | |||
faceColor.rgb *= input.color.rgb; | |||
faceColor *= tex2D(_FaceTex, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y); | |||
outlineColor *= tex2D(_OutlineTex, input.textures.zw + float2(_OutlineUVSpeedX, _OutlineUVSpeedY) * _Time.y); | |||
faceColor = GetColor(sd, faceColor, outlineColor, outline, softness); | |||
#if BEVEL_ON | |||
float3 dxy = float3(0.5 / _TextureWidth, 0.5 / _TextureHeight, 0); | |||
float3 n = GetSurfaceNormal(input.atlas, weight, dxy); | |||
float3 bump = UnpackNormal(tex2D(_BumpMap, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y)).xyz; | |||
bump *= lerp(_BumpFace, _BumpOutline, saturate(sd + outline * 0.5)); | |||
n = normalize(n- bump); | |||
float3 light = normalize(float3(sin(_LightAngle), cos(_LightAngle), -1.0)); | |||
float3 col = GetSpecular(n, light); | |||
faceColor.rgb += col*faceColor.a; | |||
faceColor.rgb *= 1-(dot(n, light)*_Diffuse); | |||
faceColor.rgb *= lerp(_Ambient, 1, n.z*n.z); | |||
fixed4 reflcol = texCUBE(_Cube, reflect(input.viewDir, -n)); | |||
faceColor.rgb += reflcol.rgb * lerp(_ReflectFaceColor.rgb, _ReflectOutlineColor.rgb, saturate(sd + outline * 0.5)) * faceColor.a; | |||
#endif | |||
#if UNDERLAY_ON | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * input.texcoord2.z; | |||
faceColor += input.underlayColor * saturate(d - input.texcoord2.w) * (1 - faceColor.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * input.texcoord2.z; | |||
faceColor += input.underlayColor * (1 - saturate(d - input.texcoord2.w)) * saturate(1 - sd) * (1 - faceColor.a); | |||
#endif | |||
#if GLOW_ON | |||
float4 glowColor = GetGlowColor(sd, scale); | |||
faceColor.rgb += glowColor.rgb * glowColor.a; | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * input.mask.zw); | |||
faceColor *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(faceColor.a - 0.001); | |||
#endif | |||
return faceColor * input.color.a; | |||
} | |||
ENDCG | |||
} | |||
} | |||
Fallback "TextMeshPro/Mobile/Distance Field" | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: dd89cf5b9246416f84610a006f916af7 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,310 @@ | |||
Shader "TextMeshPro/Distance Field SSD" { | |||
Properties { | |||
_FaceTex ("Face Texture", 2D) = "white" {} | |||
_FaceUVSpeedX ("Face UV Speed X", Range(-5, 5)) = 0.0 | |||
_FaceUVSpeedY ("Face UV Speed Y", Range(-5, 5)) = 0.0 | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineTex ("Outline Texture", 2D) = "white" {} | |||
_OutlineUVSpeedX ("Outline UV Speed X", Range(-5, 5)) = 0.0 | |||
_OutlineUVSpeedY ("Outline UV Speed Y", Range(-5, 5)) = 0.0 | |||
_OutlineWidth ("Outline Thickness", Range(0, 1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
_Bevel ("Bevel", Range(0,1)) = 0.5 | |||
_BevelOffset ("Bevel Offset", Range(-0.5,0.5)) = 0 | |||
_BevelWidth ("Bevel Width", Range(-.5,0.5)) = 0 | |||
_BevelClamp ("Bevel Clamp", Range(0,1)) = 0 | |||
_BevelRoundness ("Bevel Roundness", Range(0,1)) = 0 | |||
_LightAngle ("Light Angle", Range(0.0, 6.2831853)) = 3.1416 | |||
[HDR]_SpecularColor ("Specular", Color) = (1,1,1,1) | |||
_SpecularPower ("Specular", Range(0,4)) = 2.0 | |||
_Reflectivity ("Reflectivity", Range(5.0,15.0)) = 10 | |||
_Diffuse ("Diffuse", Range(0,1)) = 0.5 | |||
_Ambient ("Ambient", Range(1,0)) = 0.5 | |||
_BumpMap ("Normal map", 2D) = "bump" {} | |||
_BumpOutline ("Bump Outline", Range(0,1)) = 0 | |||
_BumpFace ("Bump Face", Range(0,1)) = 0 | |||
_ReflectFaceColor ("Reflection Color", Color) = (0,0,0,1) | |||
_ReflectOutlineColor("Reflection Color", Color) = (0,0,0,1) | |||
_Cube ("Reflection Cubemap", Cube) = "black" { /* TexGen CubeReflect */ } | |||
_EnvMatrixRotation ("Texture Rotation", vector) = (0, 0, 0, 0) | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0, 0.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
[HDR]_GlowColor ("Color", Color) = (0, 1, 0, 0.5) | |||
_GlowOffset ("Offset", Range(-1,1)) = 0 | |||
_GlowInner ("Inner", Range(0,1)) = 0.05 | |||
_GlowOuter ("Outer", Range(0,1)) = 0.05 | |||
_GlowPower ("Falloff", Range(1, 0)) = 0.75 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = 0.5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5.0 | |||
_ScaleX ("Scale X", float) = 1.0 | |||
_ScaleY ("Scale Y", float) = 1.0 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_MaskCoord ("Mask Coordinates", vector) = (0, 0, 32767, 32767) | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue" = "Transparent" | |||
"IgnoreProjector" = "True" | |||
"RenderType" = "Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref[_Stencil] | |||
Comp[_StencilComp] | |||
Pass[_StencilOp] | |||
ReadMask[_StencilReadMask] | |||
WriteMask[_StencilWriteMask] | |||
} | |||
Cull[_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest[unity_GUIZTestMode] | |||
Blend One OneMinusSrcAlpha | |||
ColorMask[_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma target 3.0 | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ BEVEL_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma shader_feature __ GLOW_ON | |||
#pragma shader_feature __ FORCE_LINEAR | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro.cginc" | |||
struct vertex_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
float4 position : POSITION; | |||
float3 normal : NORMAL; | |||
float4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
UNITY_VERTEX_OUTPUT_STEREO | |||
float4 position : SV_POSITION; | |||
float4 color : COLOR; | |||
float2 atlas : TEXCOORD0; | |||
float weight : TEXCOORD1; | |||
float2 mask : TEXCOORD2; // Position in object space(xy) | |||
float3 viewDir : TEXCOORD3; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float2 texcoord2 : TEXCOORD4; | |||
float4 underlayColor : COLOR1; | |||
#endif | |||
float4 textures : TEXCOORD5; | |||
}; | |||
// Used by Unity internally to handle Texture Tiling and Offset. | |||
float4 _FaceTex_ST; | |||
float4 _OutlineTex_ST; | |||
float4 SRGBToLinear(float4 rgba) { | |||
return float4(lerp(rgba.rgb / 12.92f, pow((rgba.rgb + 0.055f) / 1.055f, 2.4f), step(0.04045f, rgba.rgb)), rgba.a); | |||
} | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
pixel_t output; | |||
UNITY_INITIALIZE_OUTPUT(pixel_t, output); | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
UNITY_TRANSFER_INSTANCE_ID(input,output); | |||
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.position; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float4 underlayColor = _UnderlayColor; | |||
underlayColor.rgb *= underlayColor.a; | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 bOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
// Support for texture tiling and offset | |||
float2 textureUV = UnpackUV(input.texcoord1.x); | |||
float2 faceUV = TRANSFORM_TEX(textureUV, _FaceTex); | |||
float2 outlineUV = TRANSFORM_TEX(textureUV, _OutlineTex); | |||
float4 color = input.color; | |||
#if (FORCE_LINEAR && !UNITY_COLORSPACE_GAMMA) | |||
color = SRGBToLinear(input.color); | |||
#endif | |||
output.position = vPosition; | |||
output.color = color; | |||
output.atlas = input.texcoord0; | |||
output.weight = weight; | |||
output.mask = half2(vert.xy * 2 - clampedRect.xy - clampedRect.zw); | |||
output.viewDir = mul((float3x3)_EnvMatrix, _WorldSpaceCameraPos.xyz - mul(unity_ObjectToWorld, vert).xyz); | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
output.texcoord2 = input.texcoord0 + bOffset; | |||
output.underlayColor = underlayColor; | |||
#endif | |||
output.textures = float4(faceUV, outlineUV); | |||
return output; | |||
} | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
float c = tex2D(_MainTex, input.atlas).a; | |||
float2 pixelSize = float2(ddx(input.atlas.y), ddy(input.atlas.y)); | |||
pixelSize *= _TextureWidth * .75; | |||
float scale = rsqrt(dot(pixelSize, pixelSize)) * _GradientScale * (_Sharpness + 1); | |||
float weight = input.weight; | |||
float bias = (.5 - weight) + (.5 / scale); | |||
float sd = (bias - c) * scale; | |||
float outline = (_OutlineWidth * _ScaleRatioA) * scale; | |||
float softness = (_OutlineSoftness * _ScaleRatioA) * scale; | |||
half4 faceColor = _FaceColor; | |||
half4 outlineColor = _OutlineColor; | |||
faceColor.rgb *= input.color.rgb; | |||
faceColor *= tex2D(_FaceTex, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y); | |||
outlineColor *= tex2D(_OutlineTex, input.textures.zw + float2(_OutlineUVSpeedX, _OutlineUVSpeedY) * _Time.y); | |||
faceColor = GetColor(sd, faceColor, outlineColor, outline, softness); | |||
#if BEVEL_ON | |||
float3 dxy = float3(0.5 / _TextureWidth, 0.5 / _TextureHeight, 0); | |||
float3 n = GetSurfaceNormal(input.atlas, weight, dxy); | |||
float3 bump = UnpackNormal(tex2D(_BumpMap, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y)).xyz; | |||
bump *= lerp(_BumpFace, _BumpOutline, saturate(sd + outline * 0.5)); | |||
n = normalize(n - bump); | |||
float3 light = normalize(float3(sin(_LightAngle), cos(_LightAngle), -1.0)); | |||
float3 col = GetSpecular(n, light); | |||
faceColor.rgb += col * faceColor.a; | |||
faceColor.rgb *= 1 - (dot(n, light) * _Diffuse); | |||
faceColor.rgb *= lerp(_Ambient, 1, n.z * n.z); | |||
fixed4 reflcol = texCUBE(_Cube, reflect(input.viewDir, -n)); | |||
faceColor.rgb += reflcol.rgb * lerp(_ReflectFaceColor.rgb, _ReflectOutlineColor.rgb, saturate(sd + outline * 0.5)) * faceColor.a; | |||
#endif | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float bScale = scale; | |||
bScale /= 1 + ((_UnderlaySoftness * _ScaleRatioC) * bScale); | |||
float bBias = (0.5 - weight) * bScale - 0.5 - ((_UnderlayDilate * _ScaleRatioC) * 0.5 * bScale); | |||
#endif | |||
#if UNDERLAY_ON | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * bScale; | |||
faceColor += input.underlayColor * saturate(d - bBias) * (1 - faceColor.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * bScale; | |||
faceColor += input.underlayColor * (1 - saturate(d - bBias)) * saturate(1 - sd) * (1 - faceColor.a); | |||
#endif | |||
#if GLOW_ON | |||
float4 glowColor = GetGlowColor(sd, scale); | |||
faceColor.rgb += glowColor.rgb * glowColor.a; | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
float2 maskZW = 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + (1 / scale)); | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * maskZW); | |||
faceColor *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(faceColor.a - 0.001); | |||
#endif | |||
return faceColor * input.color.a; | |||
} | |||
ENDCG | |||
} | |||
} | |||
Fallback "TextMeshPro/Mobile/Distance Field" | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 14eb328de4b8eb245bb7cea29e4ac00b | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,247 @@ | |||
// Simplified SDF shader: | |||
// - No Shading Option (bevel / bump / env map) | |||
// - No Glow Option | |||
// - Softness is applied on both side of the outline | |||
Shader "TextMeshPro/Mobile/Distance Field - Masking" { | |||
Properties { | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineWidth ("Outline Thickness", Range(0,1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0,.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = .5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5 | |||
_ScaleX ("Scale X", float) = 1 | |||
_ScaleY ("Scale Y", float) = 1 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_MaskTex ("Mask Texture", 2D) = "white" {} | |||
_MaskInverse ("Inverse", float) = 0 | |||
_MaskEdgeColor ("Edge Color", Color) = (1,1,1,1) | |||
_MaskEdgeSoftness ("Edge Softness", Range(0, 1)) = 0.01 | |||
_MaskWipeControl ("Wipe Position", Range(0, 1)) = 0.5 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest [unity_GUIZTestMode] | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ OUTLINE_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
struct vertex_t { | |||
float4 vertex : POSITION; | |||
float3 normal : NORMAL; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
float4 vertex : SV_POSITION; | |||
fixed4 faceColor : COLOR; | |||
fixed4 outlineColor : COLOR1; | |||
float4 texcoord0 : TEXCOORD0; // Texture UV, Mask UV | |||
half4 param : TEXCOORD1; // Scale(x), BiasIn(y), BiasOut(z), Bias(w) | |||
half4 mask : TEXCOORD2; // Position in clip space(xy), Softness(zw) | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
float4 texcoord1 : TEXCOORD3; // Texture UV, alpha, reserved | |||
half2 underlayParam : TEXCOORD4; // Scale(x), Bias(y) | |||
#endif | |||
}; | |||
float _MaskWipeControl; | |||
float _MaskEdgeSoftness; | |||
fixed4 _MaskEdgeColor; | |||
bool _MaskInverse; | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= float2(_ScaleX, _ScaleY) * abs(mul((float2x2)UNITY_MATRIX_P, _ScreenParams.xy)); | |||
float scale = rsqrt(dot(pixelSize, pixelSize)); | |||
scale *= abs(input.texcoord1.y) * _GradientScale * (_Sharpness + 1); | |||
if(UNITY_MATRIX_P[3][3] == 0) scale = lerp(abs(scale) * (1 - _PerspectiveFilter), scale, abs(dot(UnityObjectToWorldNormal(input.normal.xyz), normalize(WorldSpaceViewDir(vert))))); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
float layerScale = scale; | |||
scale /= 1 + (_OutlineSoftness * _ScaleRatioA * scale); | |||
float bias = (0.5 - weight) * scale - 0.5; | |||
float outline = _OutlineWidth * _ScaleRatioA * 0.5 * scale; | |||
float opacity = input.color.a; | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
opacity = 1.0; | |||
#endif | |||
fixed4 faceColor = fixed4(input.color.rgb, opacity) * _FaceColor; | |||
faceColor.rgb *= faceColor.a; | |||
fixed4 outlineColor = _OutlineColor; | |||
outlineColor.a *= opacity; | |||
outlineColor.rgb *= outlineColor.a; | |||
outlineColor = lerp(faceColor, outlineColor, sqrt(min(1.0, (outline * 2)))); | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
layerScale /= 1 + ((_UnderlaySoftness * _ScaleRatioC) * layerScale); | |||
float layerBias = (.5 - weight) * layerScale - .5 - ((_UnderlayDilate * _ScaleRatioC) * .5 * layerScale); | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 layerOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
float2 maskUV = (vert.xy - clampedRect.xy) / (clampedRect.zw - clampedRect.xy); | |||
// Structure for pixel shader | |||
pixel_t output = { | |||
vPosition, | |||
faceColor, | |||
outlineColor, | |||
float4(input.texcoord0.x, input.texcoord0.y, maskUV.x, maskUV.y), | |||
half4(scale, bias - outline, bias + outline, bias), | |||
half4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)), | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
float4(input.texcoord0 + layerOffset, input.color.a, 0), | |||
half2(layerScale, layerBias), | |||
#endif | |||
}; | |||
return output; | |||
} | |||
// PIXEL SHADER | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
half d = tex2D(_MainTex, input.texcoord0.xy).a * input.param.x; | |||
half4 c = input.faceColor * saturate(d - input.param.w); | |||
#ifdef OUTLINE_ON | |||
c = lerp(input.outlineColor, input.faceColor, saturate(d - input.param.z)); | |||
c *= saturate(d - input.param.y); | |||
#endif | |||
#if UNDERLAY_ON | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * saturate(d - input.underlayParam.y) * (1 - c.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
half sd = saturate(d - input.param.z); | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * (1 - saturate(d - input.underlayParam.y)) * sd * (1 - c.a); | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
//#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * input.mask.zw); | |||
c *= m.x * m.y; | |||
//#endif | |||
float a = abs(_MaskInverse - tex2D(_MaskTex, input.texcoord0.zw).a); | |||
float t = a + (1 - _MaskWipeControl) * _MaskEdgeSoftness - _MaskWipeControl; | |||
a = saturate(t / _MaskEdgeSoftness); | |||
c.rgb = lerp(_MaskEdgeColor.rgb*c.a, c.rgb, a); | |||
c *= a; | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
c *= input.texcoord1.z; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(c.a - 0.001); | |||
#endif | |||
return c; | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: bc1ede39bf3643ee8e493720e4259791 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,240 @@ | |||
// Simplified SDF shader: | |||
// - No Shading Option (bevel / bump / env map) | |||
// - No Glow Option | |||
// - Softness is applied on both side of the outline | |||
Shader "TextMeshPro/Mobile/Distance Field Overlay" { | |||
Properties { | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineWidth ("Outline Thickness", Range(0,1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0,.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = .5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5 | |||
_ScaleX ("Scale X", float) = 1 | |||
_ScaleY ("Scale Y", float) = 1 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue"="Overlay" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest Always | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ OUTLINE_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
struct vertex_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
float4 vertex : POSITION; | |||
float3 normal : NORMAL; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
UNITY_VERTEX_OUTPUT_STEREO | |||
float4 vertex : SV_POSITION; | |||
fixed4 faceColor : COLOR; | |||
fixed4 outlineColor : COLOR1; | |||
float4 texcoord0 : TEXCOORD0; // Texture UV, Mask UV | |||
half4 param : TEXCOORD1; // Scale(x), BiasIn(y), BiasOut(z), Bias(w) | |||
half4 mask : TEXCOORD2; // Position in clip space(xy), Softness(zw) | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
float4 texcoord1 : TEXCOORD3; // Texture UV, alpha, reserved | |||
half2 underlayParam : TEXCOORD4; // Scale(x), Bias(y) | |||
#endif | |||
}; | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
pixel_t output; | |||
UNITY_INITIALIZE_OUTPUT(pixel_t, output); | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
UNITY_TRANSFER_INSTANCE_ID(input, output); | |||
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= float2(_ScaleX, _ScaleY) * abs(mul((float2x2)UNITY_MATRIX_P, _ScreenParams.xy)); | |||
float scale = rsqrt(dot(pixelSize, pixelSize)); | |||
scale *= abs(input.texcoord1.y) * _GradientScale * (_Sharpness + 1); | |||
if(UNITY_MATRIX_P[3][3] == 0) scale = lerp(abs(scale) * (1 - _PerspectiveFilter), scale, abs(dot(UnityObjectToWorldNormal(input.normal.xyz), normalize(WorldSpaceViewDir(vert))))); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
float layerScale = scale; | |||
scale /= 1 + (_OutlineSoftness * _ScaleRatioA * scale); | |||
float bias = (0.5 - weight) * scale - 0.5; | |||
float outline = _OutlineWidth * _ScaleRatioA * 0.5 * scale; | |||
float opacity = input.color.a; | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
opacity = 1.0; | |||
#endif | |||
fixed4 faceColor = fixed4(input.color.rgb, opacity) * _FaceColor; | |||
faceColor.rgb *= faceColor.a; | |||
fixed4 outlineColor = _OutlineColor; | |||
outlineColor.a *= opacity; | |||
outlineColor.rgb *= outlineColor.a; | |||
outlineColor = lerp(faceColor, outlineColor, sqrt(min(1.0, (outline * 2)))); | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
layerScale /= 1 + ((_UnderlaySoftness * _ScaleRatioC) * layerScale); | |||
float layerBias = (.5 - weight) * layerScale - .5 - ((_UnderlayDilate * _ScaleRatioC) * .5 * layerScale); | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 layerOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
float2 maskUV = (vert.xy - clampedRect.xy) / (clampedRect.zw - clampedRect.xy); | |||
// Populate structure for pixel shader | |||
output.vertex = vPosition; | |||
output.faceColor = faceColor; | |||
output.outlineColor = outlineColor; | |||
output.texcoord0 = float4(input.texcoord0.x, input.texcoord0.y, maskUV.x, maskUV.y); | |||
output.param = half4(scale, bias - outline, bias + outline, bias); | |||
output.mask = half4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
output.texcoord1 = float4(input.texcoord0 + layerOffset, input.color.a, 0); | |||
output.underlayParam = half2(layerScale, layerBias); | |||
#endif | |||
return output; | |||
} | |||
// PIXEL SHADER | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
half d = tex2D(_MainTex, input.texcoord0.xy).a * input.param.x; | |||
half4 c = input.faceColor * saturate(d - input.param.w); | |||
#ifdef OUTLINE_ON | |||
c = lerp(input.outlineColor, input.faceColor, saturate(d - input.param.z)); | |||
c *= saturate(d - input.param.y); | |||
#endif | |||
#if UNDERLAY_ON | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * saturate(d - input.underlayParam.y) * (1 - c.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
half sd = saturate(d - input.param.z); | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * (1 - saturate(d - input.underlayParam.y)) * sd * (1 - c.a); | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * input.mask.zw); | |||
c *= m.x * m.y; | |||
#endif | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
c *= input.texcoord1.z; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(c.a - 0.001); | |||
#endif | |||
return c; | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: a02a7d8c237544f1962732b55a9aebf1 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,106 @@ | |||
// Simplified SDF shader: | |||
// - No Shading Option (bevel / bump / env map) | |||
// - No Glow Option | |||
// - Softness is applied on both side of the outline | |||
Shader "TextMeshPro/Mobile/Distance Field SSD" { | |||
Properties { | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineWidth ("Outline Thickness", Range(0,1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0,.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = .5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5 | |||
_ScaleX ("Scale X", float) = 1 | |||
_ScaleY ("Scale Y", float) = 1 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_MaskTex ("Mask Texture", 2D) = "white" {} | |||
_MaskInverse ("Inverse", float) = 0 | |||
_MaskEdgeColor ("Edge Color", Color) = (1,1,1,1) | |||
_MaskEdgeSoftness ("Edge Softness", Range(0, 1)) = 0.01 | |||
_MaskWipeControl ("Wipe Position", Range(0, 1)) = 0.5 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags { | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest [unity_GUIZTestMode] | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ OUTLINE_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro_Mobile.cginc" | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: c8d12adcee749c344b8117cf7c7eb912 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,240 @@ | |||
// Simplified SDF shader: | |||
// - No Shading Option (bevel / bump / env map) | |||
// - No Glow Option | |||
// - Softness is applied on both side of the outline | |||
Shader "TextMeshPro/Mobile/Distance Field" { | |||
Properties { | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineWidth ("Outline Thickness", Range(0,1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0,.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = .5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5 | |||
_ScaleX ("Scale X", float) = 1 | |||
_ScaleY ("Scale Y", float) = 1 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest [unity_GUIZTestMode] | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ OUTLINE_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
struct vertex_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
float4 vertex : POSITION; | |||
float3 normal : NORMAL; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
UNITY_VERTEX_OUTPUT_STEREO | |||
float4 vertex : SV_POSITION; | |||
fixed4 faceColor : COLOR; | |||
fixed4 outlineColor : COLOR1; | |||
float4 texcoord0 : TEXCOORD0; // Texture UV, Mask UV | |||
half4 param : TEXCOORD1; // Scale(x), BiasIn(y), BiasOut(z), Bias(w) | |||
half4 mask : TEXCOORD2; // Position in clip space(xy), Softness(zw) | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
float4 texcoord1 : TEXCOORD3; // Texture UV, alpha, reserved | |||
half2 underlayParam : TEXCOORD4; // Scale(x), Bias(y) | |||
#endif | |||
}; | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
pixel_t output; | |||
UNITY_INITIALIZE_OUTPUT(pixel_t, output); | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
UNITY_TRANSFER_INSTANCE_ID(input, output); | |||
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.vertex; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= float2(_ScaleX, _ScaleY) * abs(mul((float2x2)UNITY_MATRIX_P, _ScreenParams.xy)); | |||
float scale = rsqrt(dot(pixelSize, pixelSize)); | |||
scale *= abs(input.texcoord1.y) * _GradientScale * (_Sharpness + 1); | |||
if(UNITY_MATRIX_P[3][3] == 0) scale = lerp(abs(scale) * (1 - _PerspectiveFilter), scale, abs(dot(UnityObjectToWorldNormal(input.normal.xyz), normalize(WorldSpaceViewDir(vert))))); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
float layerScale = scale; | |||
scale /= 1 + (_OutlineSoftness * _ScaleRatioA * scale); | |||
float bias = (0.5 - weight) * scale - 0.5; | |||
float outline = _OutlineWidth * _ScaleRatioA * 0.5 * scale; | |||
float opacity = input.color.a; | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
opacity = 1.0; | |||
#endif | |||
fixed4 faceColor = fixed4(input.color.rgb, opacity) * _FaceColor; | |||
faceColor.rgb *= faceColor.a; | |||
fixed4 outlineColor = _OutlineColor; | |||
outlineColor.a *= opacity; | |||
outlineColor.rgb *= outlineColor.a; | |||
outlineColor = lerp(faceColor, outlineColor, sqrt(min(1.0, (outline * 2)))); | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
layerScale /= 1 + ((_UnderlaySoftness * _ScaleRatioC) * layerScale); | |||
float layerBias = (.5 - weight) * layerScale - .5 - ((_UnderlayDilate * _ScaleRatioC) * .5 * layerScale); | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 layerOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
float2 maskUV = (vert.xy - clampedRect.xy) / (clampedRect.zw - clampedRect.xy); | |||
// Populate structure for pixel shader | |||
output.vertex = vPosition; | |||
output.faceColor = faceColor; | |||
output.outlineColor = outlineColor; | |||
output.texcoord0 = float4(input.texcoord0.x, input.texcoord0.y, maskUV.x, maskUV.y); | |||
output.param = half4(scale, bias - outline, bias + outline, bias); | |||
output.mask = half4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
output.texcoord1 = float4(input.texcoord0 + layerOffset, input.color.a, 0); | |||
output.underlayParam = half2(layerScale, layerBias); | |||
#endif | |||
return output; | |||
} | |||
// PIXEL SHADER | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
half d = tex2D(_MainTex, input.texcoord0.xy).a * input.param.x; | |||
half4 c = input.faceColor * saturate(d - input.param.w); | |||
#ifdef OUTLINE_ON | |||
c = lerp(input.outlineColor, input.faceColor, saturate(d - input.param.z)); | |||
c *= saturate(d - input.param.y); | |||
#endif | |||
#if UNDERLAY_ON | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * saturate(d - input.underlayParam.y) * (1 - c.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
half sd = saturate(d - input.param.z); | |||
d = tex2D(_MainTex, input.texcoord1.xy).a * input.underlayParam.x; | |||
c += float4(_UnderlayColor.rgb * _UnderlayColor.a, _UnderlayColor.a) * (1 - saturate(d - input.underlayParam.y)) * sd * (1 - c.a); | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * input.mask.zw); | |||
c *= m.x * m.y; | |||
#endif | |||
#if (UNDERLAY_ON | UNDERLAY_INNER) | |||
c *= input.texcoord1.z; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(c.a - 0.001); | |||
#endif | |||
return c; | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: fe393ace9b354375a9cb14cdbbc28be4 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,138 @@ | |||
// Simplified version of the SDF Surface shader : | |||
// - No support for Bevel, Bump or envmap | |||
// - Diffuse only lighting | |||
// - Fully supports only 1 directional light. Other lights can affect it, but it will be per-vertex/SH. | |||
Shader "TextMeshPro/Mobile/Distance Field (Surface)" { | |||
Properties { | |||
_FaceTex ("Fill Texture", 2D) = "white" {} | |||
[HDR]_FaceColor ("Fill Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineTex ("Outline Texture", 2D) = "white" {} | |||
_OutlineWidth ("Outline Thickness", Range(0, 1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
[HDR]_GlowColor ("Color", Color) = (0, 1, 0, 0.5) | |||
_GlowOffset ("Offset", Range(-1,1)) = 0 | |||
_GlowInner ("Inner", Range(0,1)) = 0.05 | |||
_GlowOuter ("Outer", Range(0,1)) = 0.05 | |||
_GlowPower ("Falloff", Range(1, 0)) = 0.75 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = 0.5 | |||
// Should not be directly exposed to the user | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5.0 | |||
_ScaleX ("Scale X", float) = 1.0 | |||
_ScaleY ("Scale Y", float) = 1.0 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
//_MaskCoord ("Mask Coords", vector) = (0,0,0,0) | |||
//_MaskSoftness ("Mask Softness", float) = 0 | |||
} | |||
SubShader { | |||
Tags { | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
LOD 300 | |||
Cull [_CullMode] | |||
CGPROGRAM | |||
#pragma surface PixShader Lambert alpha:blend vertex:VertShader noforwardadd nolightmap nodirlightmap | |||
#pragma target 3.0 | |||
#pragma shader_feature __ GLOW_ON | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro.cginc" | |||
half _FaceShininess; | |||
half _OutlineShininess; | |||
struct Input | |||
{ | |||
fixed4 color : COLOR; | |||
float2 uv_MainTex; | |||
float2 uv2_FaceTex; | |||
float2 uv2_OutlineTex; | |||
float2 param; // Weight, Scale | |||
float3 viewDirEnv; | |||
}; | |||
#include "TMPro_Surface.cginc" | |||
ENDCG | |||
// Pass to render object as a shadow caster | |||
Pass | |||
{ | |||
Name "Caster" | |||
Tags { "LightMode" = "ShadowCaster" } | |||
Offset 1, 1 | |||
Fog {Mode Off} | |||
ZWrite On ZTest LEqual Cull Off | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#pragma multi_compile_shadowcaster | |||
#include "UnityCG.cginc" | |||
struct v2f { | |||
V2F_SHADOW_CASTER; | |||
float2 uv : TEXCOORD1; | |||
float2 uv2 : TEXCOORD3; | |||
float alphaClip : TEXCOORD2; | |||
}; | |||
uniform float4 _MainTex_ST; | |||
uniform float4 _OutlineTex_ST; | |||
float _OutlineWidth; | |||
float _FaceDilate; | |||
float _ScaleRatioA; | |||
v2f vert( appdata_base v ) | |||
{ | |||
v2f o; | |||
TRANSFER_SHADOW_CASTER(o) | |||
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex); | |||
o.uv2 = TRANSFORM_TEX(v.texcoord, _OutlineTex); | |||
o.alphaClip = o.alphaClip = (1.0 - _OutlineWidth * _ScaleRatioA - _FaceDilate * _ScaleRatioA) / 2; | |||
return o; | |||
} | |||
uniform sampler2D _MainTex; | |||
float4 frag(v2f i) : COLOR | |||
{ | |||
fixed4 texcol = tex2D(_MainTex, i.uv).a; | |||
clip(texcol.a - i.alphaClip); | |||
SHADOW_CASTER_FRAGMENT(i) | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 85187c2149c549c5b33f0cdb02836b17 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,158 @@ | |||
Shader "TextMeshPro/Distance Field (Surface)" { | |||
Properties { | |||
_FaceTex ("Fill Texture", 2D) = "white" {} | |||
_FaceUVSpeedX ("Face UV Speed X", Range(-5, 5)) = 0.0 | |||
_FaceUVSpeedY ("Face UV Speed Y", Range(-5, 5)) = 0.0 | |||
[HDR]_FaceColor ("Fill Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineTex ("Outline Texture", 2D) = "white" {} | |||
_OutlineUVSpeedX ("Outline UV Speed X", Range(-5, 5)) = 0.0 | |||
_OutlineUVSpeedY ("Outline UV Speed Y", Range(-5, 5)) = 0.0 | |||
_OutlineWidth ("Outline Thickness", Range(0, 1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
_Bevel ("Bevel", Range(0,1)) = 0.5 | |||
_BevelOffset ("Bevel Offset", Range(-0.5,0.5)) = 0 | |||
_BevelWidth ("Bevel Width", Range(-.5,0.5)) = 0 | |||
_BevelClamp ("Bevel Clamp", Range(0,1)) = 0 | |||
_BevelRoundness ("Bevel Roundness", Range(0,1)) = 0 | |||
_BumpMap ("Normalmap", 2D) = "bump" {} | |||
_BumpOutline ("Bump Outline", Range(0,1)) = 0.5 | |||
_BumpFace ("Bump Face", Range(0,1)) = 0.5 | |||
_ReflectFaceColor ("Face Color", Color) = (0,0,0,1) | |||
_ReflectOutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_Cube ("Reflection Cubemap", Cube) = "black" { /* TexGen CubeReflect */ } | |||
_EnvMatrixRotation ("Texture Rotation", vector) = (0, 0, 0, 0) | |||
[HDR]_SpecColor ("Specular Color", Color) = (0,0,0,1) | |||
_FaceShininess ("Face Shininess", Range(0,1)) = 0 | |||
_OutlineShininess ("Outline Shininess", Range(0,1)) = 0 | |||
[HDR]_GlowColor ("Color", Color) = (0, 1, 0, 0.5) | |||
_GlowOffset ("Offset", Range(-1,1)) = 0 | |||
_GlowInner ("Inner", Range(0,1)) = 0.05 | |||
_GlowOuter ("Outer", Range(0,1)) = 0.05 | |||
_GlowPower ("Falloff", Range(1, 0)) = 0.75 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = 0.5 | |||
// Should not be directly exposed to the user | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5.0 | |||
_ScaleX ("Scale X", float) = 1.0 | |||
_ScaleY ("Scale Y", float) = 1.0 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
//_MaskCoord ("Mask Coords", vector) = (0,0,0,0) | |||
//_MaskSoftness ("Mask Softness", float) = 0 | |||
} | |||
SubShader { | |||
Tags { "Queue"="Transparent" "IgnoreProjector"="True" "RenderType"="Transparent" } | |||
LOD 300 | |||
Cull [_CullMode] | |||
CGPROGRAM | |||
#pragma surface PixShader BlinnPhong alpha:blend vertex:VertShader nolightmap nodirlightmap | |||
#pragma target 3.0 | |||
#pragma shader_feature __ GLOW_ON | |||
#pragma glsl | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro.cginc" | |||
half _FaceShininess; | |||
half _OutlineShininess; | |||
struct Input | |||
{ | |||
fixed4 color : COLOR; | |||
float2 uv_MainTex; | |||
float2 uv2_FaceTex; | |||
float2 uv2_OutlineTex; | |||
float2 param; // Weight, Scale | |||
float3 viewDirEnv; | |||
}; | |||
#define BEVEL_ON 1 | |||
#include "TMPro_Surface.cginc" | |||
ENDCG | |||
// Pass to render object as a shadow caster | |||
Pass | |||
{ | |||
Name "Caster" | |||
Tags { "LightMode" = "ShadowCaster" } | |||
Offset 1, 1 | |||
Fog {Mode Off} | |||
ZWrite On | |||
ZTest LEqual | |||
Cull Off | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#pragma multi_compile_shadowcaster | |||
#include "UnityCG.cginc" | |||
struct v2f { | |||
V2F_SHADOW_CASTER; | |||
float2 uv : TEXCOORD1; | |||
float2 uv2 : TEXCOORD3; | |||
float alphaClip : TEXCOORD2; | |||
}; | |||
uniform float4 _MainTex_ST; | |||
uniform float4 _OutlineTex_ST; | |||
float _OutlineWidth; | |||
float _FaceDilate; | |||
float _ScaleRatioA; | |||
v2f vert( appdata_base v ) | |||
{ | |||
v2f o; | |||
TRANSFER_SHADOW_CASTER(o) | |||
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex); | |||
o.uv2 = TRANSFORM_TEX(v.texcoord, _OutlineTex); | |||
o.alphaClip = (1.0 - _OutlineWidth * _ScaleRatioA - _FaceDilate * _ScaleRatioA) / 2; | |||
return o; | |||
} | |||
uniform sampler2D _MainTex; | |||
float4 frag(v2f i) : COLOR | |||
{ | |||
fixed4 texcol = tex2D(_MainTex, i.uv).a; | |||
clip(texcol.a - i.alphaClip); | |||
SHADOW_CASTER_FRAGMENT(i) | |||
} | |||
ENDCG | |||
} | |||
} | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} | |||
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: f7ada0af4f174f0694ca6a487b8f543d | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,317 @@ | |||
Shader "TextMeshPro/Distance Field" { | |||
Properties { | |||
_FaceTex ("Face Texture", 2D) = "white" {} | |||
_FaceUVSpeedX ("Face UV Speed X", Range(-5, 5)) = 0.0 | |||
_FaceUVSpeedY ("Face UV Speed Y", Range(-5, 5)) = 0.0 | |||
[HDR]_FaceColor ("Face Color", Color) = (1,1,1,1) | |||
_FaceDilate ("Face Dilate", Range(-1,1)) = 0 | |||
[HDR]_OutlineColor ("Outline Color", Color) = (0,0,0,1) | |||
_OutlineTex ("Outline Texture", 2D) = "white" {} | |||
_OutlineUVSpeedX ("Outline UV Speed X", Range(-5, 5)) = 0.0 | |||
_OutlineUVSpeedY ("Outline UV Speed Y", Range(-5, 5)) = 0.0 | |||
_OutlineWidth ("Outline Thickness", Range(0, 1)) = 0 | |||
_OutlineSoftness ("Outline Softness", Range(0,1)) = 0 | |||
_Bevel ("Bevel", Range(0,1)) = 0.5 | |||
_BevelOffset ("Bevel Offset", Range(-0.5,0.5)) = 0 | |||
_BevelWidth ("Bevel Width", Range(-.5,0.5)) = 0 | |||
_BevelClamp ("Bevel Clamp", Range(0,1)) = 0 | |||
_BevelRoundness ("Bevel Roundness", Range(0,1)) = 0 | |||
_LightAngle ("Light Angle", Range(0.0, 6.2831853)) = 3.1416 | |||
[HDR]_SpecularColor ("Specular", Color) = (1,1,1,1) | |||
_SpecularPower ("Specular", Range(0,4)) = 2.0 | |||
_Reflectivity ("Reflectivity", Range(5.0,15.0)) = 10 | |||
_Diffuse ("Diffuse", Range(0,1)) = 0.5 | |||
_Ambient ("Ambient", Range(1,0)) = 0.5 | |||
_BumpMap ("Normal map", 2D) = "bump" {} | |||
_BumpOutline ("Bump Outline", Range(0,1)) = 0 | |||
_BumpFace ("Bump Face", Range(0,1)) = 0 | |||
_ReflectFaceColor ("Reflection Color", Color) = (0,0,0,1) | |||
_ReflectOutlineColor("Reflection Color", Color) = (0,0,0,1) | |||
_Cube ("Reflection Cubemap", Cube) = "black" { /* TexGen CubeReflect */ } | |||
_EnvMatrixRotation ("Texture Rotation", vector) = (0, 0, 0, 0) | |||
[HDR]_UnderlayColor ("Border Color", Color) = (0,0,0, 0.5) | |||
_UnderlayOffsetX ("Border OffsetX", Range(-1,1)) = 0 | |||
_UnderlayOffsetY ("Border OffsetY", Range(-1,1)) = 0 | |||
_UnderlayDilate ("Border Dilate", Range(-1,1)) = 0 | |||
_UnderlaySoftness ("Border Softness", Range(0,1)) = 0 | |||
[HDR]_GlowColor ("Color", Color) = (0, 1, 0, 0.5) | |||
_GlowOffset ("Offset", Range(-1,1)) = 0 | |||
_GlowInner ("Inner", Range(0,1)) = 0.05 | |||
_GlowOuter ("Outer", Range(0,1)) = 0.05 | |||
_GlowPower ("Falloff", Range(1, 0)) = 0.75 | |||
_WeightNormal ("Weight Normal", float) = 0 | |||
_WeightBold ("Weight Bold", float) = 0.5 | |||
_ShaderFlags ("Flags", float) = 0 | |||
_ScaleRatioA ("Scale RatioA", float) = 1 | |||
_ScaleRatioB ("Scale RatioB", float) = 1 | |||
_ScaleRatioC ("Scale RatioC", float) = 1 | |||
_MainTex ("Font Atlas", 2D) = "white" {} | |||
_TextureWidth ("Texture Width", float) = 512 | |||
_TextureHeight ("Texture Height", float) = 512 | |||
_GradientScale ("Gradient Scale", float) = 5.0 | |||
_ScaleX ("Scale X", float) = 1.0 | |||
_ScaleY ("Scale Y", float) = 1.0 | |||
_PerspectiveFilter ("Perspective Correction", Range(0, 1)) = 0.875 | |||
_Sharpness ("Sharpness", Range(-1,1)) = 0 | |||
_VertexOffsetX ("Vertex OffsetX", float) = 0 | |||
_VertexOffsetY ("Vertex OffsetY", float) = 0 | |||
_MaskCoord ("Mask Coordinates", vector) = (0, 0, 32767, 32767) | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
_MaskSoftnessX ("Mask SoftnessX", float) = 0 | |||
_MaskSoftnessY ("Mask SoftnessY", float) = 0 | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
} | |||
SubShader { | |||
Tags | |||
{ | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
ZWrite Off | |||
Lighting Off | |||
Fog { Mode Off } | |||
ZTest [unity_GUIZTestMode] | |||
Blend One OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass { | |||
CGPROGRAM | |||
#pragma target 3.0 | |||
#pragma vertex VertShader | |||
#pragma fragment PixShader | |||
#pragma shader_feature __ BEVEL_ON | |||
#pragma shader_feature __ UNDERLAY_ON UNDERLAY_INNER | |||
#pragma shader_feature __ GLOW_ON | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#include "TMPro_Properties.cginc" | |||
#include "TMPro.cginc" | |||
struct vertex_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
float4 position : POSITION; | |||
float3 normal : NORMAL; | |||
fixed4 color : COLOR; | |||
float2 texcoord0 : TEXCOORD0; | |||
float2 texcoord1 : TEXCOORD1; | |||
}; | |||
struct pixel_t { | |||
UNITY_VERTEX_INPUT_INSTANCE_ID | |||
UNITY_VERTEX_OUTPUT_STEREO | |||
float4 position : SV_POSITION; | |||
fixed4 color : COLOR; | |||
float2 atlas : TEXCOORD0; // Atlas | |||
float4 param : TEXCOORD1; // alphaClip, scale, bias, weight | |||
float4 mask : TEXCOORD2; // Position in object space(xy), pixel Size(zw) | |||
float3 viewDir : TEXCOORD3; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float4 texcoord2 : TEXCOORD4; // u,v, scale, bias | |||
fixed4 underlayColor : COLOR1; | |||
#endif | |||
float4 textures : TEXCOORD5; | |||
}; | |||
// Used by Unity internally to handle Texture Tiling and Offset. | |||
float4 _FaceTex_ST; | |||
float4 _OutlineTex_ST; | |||
pixel_t VertShader(vertex_t input) | |||
{ | |||
pixel_t output; | |||
UNITY_INITIALIZE_OUTPUT(pixel_t, output); | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
UNITY_TRANSFER_INSTANCE_ID(input,output); | |||
UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(output); | |||
float bold = step(input.texcoord1.y, 0); | |||
float4 vert = input.position; | |||
vert.x += _VertexOffsetX; | |||
vert.y += _VertexOffsetY; | |||
float4 vPosition = UnityObjectToClipPos(vert); | |||
float2 pixelSize = vPosition.w; | |||
pixelSize /= float2(_ScaleX, _ScaleY) * abs(mul((float2x2)UNITY_MATRIX_P, _ScreenParams.xy)); | |||
float scale = rsqrt(dot(pixelSize, pixelSize)); | |||
scale *= abs(input.texcoord1.y) * _GradientScale * (_Sharpness + 1); | |||
if (UNITY_MATRIX_P[3][3] == 0) scale = lerp(abs(scale) * (1 - _PerspectiveFilter), scale, abs(dot(UnityObjectToWorldNormal(input.normal.xyz), normalize(WorldSpaceViewDir(vert))))); | |||
float weight = lerp(_WeightNormal, _WeightBold, bold) / 4.0; | |||
weight = (weight + _FaceDilate) * _ScaleRatioA * 0.5; | |||
float bias =(.5 - weight) + (.5 / scale); | |||
float alphaClip = (1.0 - _OutlineWidth * _ScaleRatioA - _OutlineSoftness * _ScaleRatioA); | |||
#if GLOW_ON | |||
alphaClip = min(alphaClip, 1.0 - _GlowOffset * _ScaleRatioB - _GlowOuter * _ScaleRatioB); | |||
#endif | |||
alphaClip = alphaClip / 2.0 - ( .5 / scale) - weight; | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
float4 underlayColor = _UnderlayColor; | |||
underlayColor.rgb *= underlayColor.a; | |||
float bScale = scale; | |||
bScale /= 1 + ((_UnderlaySoftness*_ScaleRatioC) * bScale); | |||
float bBias = (0.5 - weight) * bScale - 0.5 - ((_UnderlayDilate * _ScaleRatioC) * 0.5 * bScale); | |||
float x = -(_UnderlayOffsetX * _ScaleRatioC) * _GradientScale / _TextureWidth; | |||
float y = -(_UnderlayOffsetY * _ScaleRatioC) * _GradientScale / _TextureHeight; | |||
float2 bOffset = float2(x, y); | |||
#endif | |||
// Generate UV for the Masking Texture | |||
float4 clampedRect = clamp(_ClipRect, -2e10, 2e10); | |||
float2 maskUV = (vert.xy - clampedRect.xy) / (clampedRect.zw - clampedRect.xy); | |||
// Support for texture tiling and offset | |||
float2 textureUV = UnpackUV(input.texcoord1.x); | |||
float2 faceUV = TRANSFORM_TEX(textureUV, _FaceTex); | |||
float2 outlineUV = TRANSFORM_TEX(textureUV, _OutlineTex); | |||
output.position = vPosition; | |||
output.color = input.color; | |||
output.atlas = input.texcoord0; | |||
output.param = float4(alphaClip, scale, bias, weight); | |||
output.mask = half4(vert.xy * 2 - clampedRect.xy - clampedRect.zw, 0.25 / (0.25 * half2(_MaskSoftnessX, _MaskSoftnessY) + pixelSize.xy)); | |||
output.viewDir = mul((float3x3)_EnvMatrix, _WorldSpaceCameraPos.xyz - mul(unity_ObjectToWorld, vert).xyz); | |||
#if (UNDERLAY_ON || UNDERLAY_INNER) | |||
output.texcoord2 = float4(input.texcoord0 + bOffset, bScale, bBias); | |||
output.underlayColor = underlayColor; | |||
#endif | |||
output.textures = float4(faceUV, outlineUV); | |||
return output; | |||
} | |||
fixed4 PixShader(pixel_t input) : SV_Target | |||
{ | |||
UNITY_SETUP_INSTANCE_ID(input); | |||
float c = tex2D(_MainTex, input.atlas).a; | |||
#ifndef UNDERLAY_ON | |||
clip(c - input.param.x); | |||
#endif | |||
float scale = input.param.y; | |||
float bias = input.param.z; | |||
float weight = input.param.w; | |||
float sd = (bias - c) * scale; | |||
float outline = (_OutlineWidth * _ScaleRatioA) * scale; | |||
float softness = (_OutlineSoftness * _ScaleRatioA) * scale; | |||
half4 faceColor = _FaceColor; | |||
half4 outlineColor = _OutlineColor; | |||
faceColor.rgb *= input.color.rgb; | |||
faceColor *= tex2D(_FaceTex, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y); | |||
outlineColor *= tex2D(_OutlineTex, input.textures.zw + float2(_OutlineUVSpeedX, _OutlineUVSpeedY) * _Time.y); | |||
faceColor = GetColor(sd, faceColor, outlineColor, outline, softness); | |||
#if BEVEL_ON | |||
float3 dxy = float3(0.5 / _TextureWidth, 0.5 / _TextureHeight, 0); | |||
float3 n = GetSurfaceNormal(input.atlas, weight, dxy); | |||
float3 bump = UnpackNormal(tex2D(_BumpMap, input.textures.xy + float2(_FaceUVSpeedX, _FaceUVSpeedY) * _Time.y)).xyz; | |||
bump *= lerp(_BumpFace, _BumpOutline, saturate(sd + outline * 0.5)); | |||
n = normalize(n- bump); | |||
float3 light = normalize(float3(sin(_LightAngle), cos(_LightAngle), -1.0)); | |||
float3 col = GetSpecular(n, light); | |||
faceColor.rgb += col*faceColor.a; | |||
faceColor.rgb *= 1-(dot(n, light)*_Diffuse); | |||
faceColor.rgb *= lerp(_Ambient, 1, n.z*n.z); | |||
fixed4 reflcol = texCUBE(_Cube, reflect(input.viewDir, -n)); | |||
faceColor.rgb += reflcol.rgb * lerp(_ReflectFaceColor.rgb, _ReflectOutlineColor.rgb, saturate(sd + outline * 0.5)) * faceColor.a; | |||
#endif | |||
#if UNDERLAY_ON | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * input.texcoord2.z; | |||
faceColor += input.underlayColor * saturate(d - input.texcoord2.w) * (1 - faceColor.a); | |||
#endif | |||
#if UNDERLAY_INNER | |||
float d = tex2D(_MainTex, input.texcoord2.xy).a * input.texcoord2.z; | |||
faceColor += input.underlayColor * (1 - saturate(d - input.texcoord2.w)) * saturate(1 - sd) * (1 - faceColor.a); | |||
#endif | |||
#if GLOW_ON | |||
float4 glowColor = GetGlowColor(sd, scale); | |||
faceColor.rgb += glowColor.rgb * glowColor.a; | |||
#endif | |||
// Alternative implementation to UnityGet2DClipping with support for softness. | |||
#if UNITY_UI_CLIP_RECT | |||
half2 m = saturate((_ClipRect.zw - _ClipRect.xy - abs(input.mask.xy)) * input.mask.zw); | |||
faceColor *= m.x * m.y; | |||
#endif | |||
#if UNITY_UI_ALPHACLIP | |||
clip(faceColor.a - 0.001); | |||
#endif | |||
return faceColor * input.color.a; | |||
} | |||
ENDCG | |||
} | |||
} | |||
Fallback "TextMeshPro/Mobile/Distance Field" | |||
CustomEditor "TMPro.EditorUtilities.TMP_SDFShaderGUI" | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 68e6db2ebdc24f95958faec2be5558d6 | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,114 @@ | |||
Shader "TextMeshPro/Sprite" | |||
{ | |||
Properties | |||
{ | |||
_MainTex ("Sprite Texture", 2D) = "white" {} | |||
_Color ("Tint", Color) = (1,1,1,1) | |||
_StencilComp ("Stencil Comparison", Float) = 8 | |||
_Stencil ("Stencil ID", Float) = 0 | |||
_StencilOp ("Stencil Operation", Float) = 0 | |||
_StencilWriteMask ("Stencil Write Mask", Float) = 255 | |||
_StencilReadMask ("Stencil Read Mask", Float) = 255 | |||
_CullMode ("Cull Mode", Float) = 0 | |||
_ColorMask ("Color Mask", Float) = 15 | |||
_ClipRect ("Clip Rect", vector) = (-32767, -32767, 32767, 32767) | |||
[Toggle(UNITY_UI_ALPHACLIP)] _UseUIAlphaClip ("Use Alpha Clip", Float) = 0 | |||
} | |||
SubShader | |||
{ | |||
Tags | |||
{ | |||
"Queue"="Transparent" | |||
"IgnoreProjector"="True" | |||
"RenderType"="Transparent" | |||
"PreviewType"="Plane" | |||
"CanUseSpriteAtlas"="True" | |||
} | |||
Stencil | |||
{ | |||
Ref [_Stencil] | |||
Comp [_StencilComp] | |||
Pass [_StencilOp] | |||
ReadMask [_StencilReadMask] | |||
WriteMask [_StencilWriteMask] | |||
} | |||
Cull [_CullMode] | |||
Lighting Off | |||
ZWrite Off | |||
ZTest [unity_GUIZTestMode] | |||
Blend SrcAlpha OneMinusSrcAlpha | |||
ColorMask [_ColorMask] | |||
Pass | |||
{ | |||
CGPROGRAM | |||
#pragma vertex vert | |||
#pragma fragment frag | |||
#include "UnityCG.cginc" | |||
#include "UnityUI.cginc" | |||
#pragma multi_compile __ UNITY_UI_CLIP_RECT | |||
#pragma multi_compile __ UNITY_UI_ALPHACLIP | |||
struct appdata_t | |||
{ | |||
float4 vertex : POSITION; | |||
float4 color : COLOR; | |||
float2 texcoord : TEXCOORD0; | |||
}; | |||
struct v2f | |||
{ | |||
float4 vertex : SV_POSITION; | |||
fixed4 color : COLOR; | |||
half2 texcoord : TEXCOORD0; | |||
float4 worldPosition : TEXCOORD1; | |||
}; | |||
fixed4 _Color; | |||
fixed4 _TextureSampleAdd; | |||
float4 _ClipRect; | |||
v2f vert(appdata_t IN) | |||
{ | |||
v2f OUT; | |||
OUT.worldPosition = IN.vertex; | |||
OUT.vertex = UnityObjectToClipPos(OUT.worldPosition); | |||
OUT.texcoord = IN.texcoord; | |||
#ifdef UNITY_HALF_TEXEL_OFFSET | |||
OUT.vertex.xy += (_ScreenParams.zw-1.0)*float2(-1,1); | |||
#endif | |||
OUT.color = IN.color * _Color; | |||
return OUT; | |||
} | |||
sampler2D _MainTex; | |||
fixed4 frag(v2f IN) : SV_Target | |||
{ | |||
half4 color = (tex2D(_MainTex, IN.texcoord) + _TextureSampleAdd) * IN.color; | |||
#if UNITY_UI_CLIP_RECT | |||
color.a *= UnityGet2DClipping(IN.worldPosition.xy, _ClipRect); | |||
#endif | |||
#ifdef UNITY_UI_ALPHACLIP | |||
clip (color.a - 0.001); | |||
#endif | |||
return color; | |||
} | |||
ENDCG | |||
} | |||
} | |||
} |
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: cf81c85f95fe47e1a27f6ae460cf182c | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |
@ -0,0 +1,84 @@ | |||
float2 UnpackUV(float uv) | |||
{ | |||
float2 output; | |||
output.x = floor(uv / 4096); | |||
output.y = uv - 4096 * output.x; | |||
return output * 0.001953125; | |||
} | |||
fixed4 GetColor(half d, fixed4 faceColor, fixed4 outlineColor, half outline, half softness) | |||
{ | |||
half faceAlpha = 1-saturate((d - outline * 0.5 + softness * 0.5) / (1.0 + softness)); | |||
half outlineAlpha = saturate((d + outline * 0.5)) * sqrt(min(1.0, outline)); | |||
faceColor.rgb *= faceColor.a; | |||
outlineColor.rgb *= outlineColor.a; | |||
faceColor = lerp(faceColor, outlineColor, outlineAlpha); | |||
faceColor *= faceAlpha; | |||
return faceColor; | |||
} | |||
float3 GetSurfaceNormal(float4 h, float bias) | |||
{ | |||
bool raisedBevel = step(1, fmod(_ShaderFlags, 2)); | |||
h += bias+_BevelOffset; | |||
float bevelWidth = max(.01, _OutlineWidth+_BevelWidth); | |||
// Track outline | |||
h -= .5; | |||
h /= bevelWidth; | |||
h = saturate(h+.5); | |||
if(raisedBevel) h = 1 - abs(h*2.0 - 1.0); | |||
h = lerp(h, sin(h*3.141592/2.0), _BevelRoundness); | |||
h = min(h, 1.0-_BevelClamp); | |||
h *= _Bevel * bevelWidth * _GradientScale * -2.0; | |||
float3 va = normalize(float3(1.0, 0.0, h.y - h.x)); | |||
float3 vb = normalize(float3(0.0, -1.0, h.w - h.z)); | |||
return cross(va, vb); | |||
} | |||
float3 GetSurfaceNormal(float2 uv, float bias, float3 delta) | |||
{ | |||
// Read "height field" | |||
float4 h = {tex2D(_MainTex, uv - delta.xz).a, | |||
tex2D(_MainTex, uv + delta.xz).a, | |||
tex2D(_MainTex, uv - delta.zy).a, | |||
tex2D(_MainTex, uv + delta.zy).a}; | |||
return GetSurfaceNormal(h, bias); | |||
} | |||
float3 GetSpecular(float3 n, float3 l) | |||
{ | |||
float spec = pow(max(0.0, dot(n, l)), _Reflectivity); | |||
return _SpecularColor.rgb * spec * _SpecularPower; | |||
} | |||
float4 GetGlowColor(float d, float scale) | |||
{ | |||
float glow = d - (_GlowOffset*_ScaleRatioB) * 0.5 * scale; | |||
float t = lerp(_GlowInner, (_GlowOuter * _ScaleRatioB), step(0.0, glow)) * 0.5 * scale; | |||
glow = saturate(abs(glow/(1.0 + t))); | |||
glow = 1.0-pow(glow, _GlowPower); | |||
glow *= sqrt(min(1.0, t)); // Fade off glow thinner than 1 screen pixel | |||
return float4(_GlowColor.rgb, saturate(_GlowColor.a * glow * 2)); | |||
} | |||
float4 BlendARGB(float4 overlying, float4 underlying) | |||
{ | |||
overlying.rgb *= overlying.a; | |||
underlying.rgb *= underlying.a; | |||
float3 blended = overlying.rgb + ((1-overlying.a)*underlying.rgb); | |||
float alpha = underlying.a + (1-underlying.a)*overlying.a; | |||
return float4(blended, alpha); | |||
} | |||
@ -0,0 +1,9 @@ | |||
fileFormatVersion: 2 | |||
guid: 407bc68d299748449bbf7f48ee690f8d | |||
ShaderImporter: | |||
externalObjects: {} | |||
defaultTextures: [] | |||
nonModifiableTextures: [] | |||
userData: | |||
assetBundleName: | |||
assetBundleVariant: |