| m cat |  Marked this version for translation | ||
| Line 4: | Line 4: | ||
| <translate> | <translate> | ||
| <!--T:1--> | |||
| [https://dspace.cvut.cz/bitstream/handle/10467/62770/F8-DP-2015-Chlumsky-Viktor-thesis.pdf Multi-channel signed distance fields] are how Resonite conventionally renders text. They are essentially a big lookup table of how far away a sampled point must be to be a part of some 2d object. When combined with normal image interpolation, this can result in vector-like graphics without the need for something like [https://en.wikipedia.org/wiki/SVG SVG] support nor a high-resolution texture. | [https://dspace.cvut.cz/bitstream/handle/10467/62770/F8-DP-2015-Chlumsky-Viktor-thesis.pdf Multi-channel signed distance fields] are how Resonite conventionally renders text. They are essentially a big lookup table of how far away a sampled point must be to be a part of some 2d object. When combined with normal image interpolation, this can result in vector-like graphics without the need for something like [https://en.wikipedia.org/wiki/SVG SVG] support nor a high-resolution texture. | ||
| </translate> | </translate> | ||
| <translate> | <translate> | ||
| <!--T:2--> | |||
| To render MSDFs in Resonite, one can use the [[Component:TextUnlitMaterial|TextUnlitMaterial]] or [[Component:UI_TextUnlitMaterial|UI_TextUnlitMaterial]] materials like any other matrial on a [[Component:MeshRenderer|MeshRenderer]]. The MSDF can be placed in the <code>FontAtlas</code> field of the material. <code>TintColor</code> is used to color the actual object the MSDF represents, while <code>BackgroundColor</code> can be used to color the background of the MSDF, so long as <code>AutoBackgroundColor</code> is unchecked. <code>OutlineColor</code> can be used to give an outline color to the object. <code>FaceDilate</code> dilates the boundary of the MSDF, <code>OutlineThickness</code> controls the thickness of the outline, and <code>FaceSoftness</code> controls how soft the object looks. | To render MSDFs in Resonite, one can use the [[Component:TextUnlitMaterial|TextUnlitMaterial]] or [[Component:UI_TextUnlitMaterial|UI_TextUnlitMaterial]] materials like any other matrial on a [[Component:MeshRenderer|MeshRenderer]]. The MSDF can be placed in the <code>FontAtlas</code> field of the material. <code>TintColor</code> is used to color the actual object the MSDF represents, while <code>BackgroundColor</code> can be used to color the background of the MSDF, so long as <code>AutoBackgroundColor</code> is unchecked. <code>OutlineColor</code> can be used to give an outline color to the object. <code>FaceDilate</code> dilates the boundary of the MSDF, <code>OutlineThickness</code> controls the thickness of the outline, and <code>FaceSoftness</code> controls how soft the object looks. | ||
| </translate> | </translate> | ||
| == <translate>Generating MSDFs</translate> == | == <translate><!--T:3--> Generating MSDFs</translate> == | ||
| <translate> | <translate> | ||
| <!--T:4--> | |||
| MSDFs can be created with [https://github.com/Chlumsky/msdfgen the reference implementation of the format]. This is a command line program. | MSDFs can be created with [https://github.com/Chlumsky/msdfgen the reference implementation of the format]. This is a command line program. | ||
| </translate> | </translate> | ||
| <translate> | <translate> | ||
| <!--T:5--> | |||
| For most purposes, the following command should generate a good MSDF from an SVG for rendering: | For most purposes, the following command should generate a good MSDF from an SVG for rendering: | ||
| </translate> | </translate> | ||
| Line 24: | Line 28: | ||
| <translate> | <translate> | ||
| <!--T:6--> | |||
| The SVG must contain only one path that defines the object. The program will warn you if there is more than one path in the SVG. You can use a program like [https://inkscape.org/ Inkscape] to combine multiple paths into one. | The SVG must contain only one path that defines the object. The program will warn you if there is more than one path in the SVG. You can use a program like [https://inkscape.org/ Inkscape] to combine multiple paths into one. | ||
| </translate> | </translate> | ||
| <translate> | <translate> | ||
| <!--T:7--> | |||
| If you find yourself needing a higher quality MSDF (for more complicated shapes), change the <code>dimensions</code> to 256, 512, whatever you need. If you find that 64 or even smaller works just as well for your shape, by all means, try to optimize! | If you find yourself needing a higher quality MSDF (for more complicated shapes), change the <code>dimensions</code> to 256, 512, whatever you need. If you find that 64 or even smaller works just as well for your shape, by all means, try to optimize! | ||
| </translate> | </translate> | ||
| [[Category:Tutorial]] | [[Category:Tutorial]] | ||
Revision as of 15:34, 27 April 2025

Multi-channel signed distance fields are how Resonite conventionally renders text. They are essentially a big lookup table of how far away a sampled point must be to be a part of some 2d object. When combined with normal image interpolation, this can result in vector-like graphics without the need for something like SVG support nor a high-resolution texture.
To render MSDFs in Resonite, one can use the TextUnlitMaterial or UI_TextUnlitMaterial materials like any other matrial on a MeshRenderer. The MSDF can be placed in the FontAtlas field of the material. TintColor is used to color the actual object the MSDF represents, while BackgroundColor can be used to color the background of the MSDF, so long as AutoBackgroundColor is unchecked. OutlineColor can be used to give an outline color to the object. FaceDilate dilates the boundary of the MSDF, OutlineThickness controls the thickness of the outline, and FaceSoftness controls how soft the object looks.
Generating MSDFs
MSDFs can be created with the reference implementation of the format. This is a command line program.
For most purposes, the following command should generate a good MSDF from an SVG for rendering:
msdfgen -svg input.svg -dimensions 128 128 -autoframe
The SVG must contain only one path that defines the object. The program will warn you if there is more than one path in the SVG. You can use a program like Inkscape to combine multiple paths into one.
If you find yourself needing a higher quality MSDF (for more complicated shapes), change the dimensions to 256, 512, whatever you need. If you find that 64 or even smaller works just as well for your shape, by all means, try to optimize!
