Merge pull request #72100 from bruvzg/sysf_msdf
[SystemFont] Add missing MSDF properties.
This commit is contained in:
commit
886c0dbef9
3 changed files with 52 additions and 0 deletions
|
@ -43,6 +43,12 @@
|
|||
<member name="hinting" type="int" setter="set_hinting" getter="get_hinting" enum="TextServer.Hinting" default="1">
|
||||
Font hinting mode.
|
||||
</member>
|
||||
<member name="msdf_pixel_range" type="int" setter="set_msdf_pixel_range" getter="get_msdf_pixel_range" default="16">
|
||||
The width of the range around the shape between the minimum and maximum representable signed distance. If using font outlines, [member msdf_pixel_range] must be set to at least [i]twice[/i] the size of the largest font outline. The default [member msdf_pixel_range] value of [code]16[/code] allows outline sizes up to [code]8[/code] to look correct.
|
||||
</member>
|
||||
<member name="msdf_size" type="int" setter="set_msdf_size" getter="get_msdf_size" default="48">
|
||||
Source font size used to generate MSDF textures. Higher values allow for more precision, but are slower to render and require more memory. Only increase this value if you notice a visible lack of precision in glyph rendering.
|
||||
</member>
|
||||
<member name="multichannel_signed_distance_field" type="bool" setter="set_multichannel_signed_distance_field" getter="is_multichannel_signed_distance_field" default="false">
|
||||
If set to [code]true[/code], glyphs of all sizes are rendered using single multichannel signed distance field generated from the dynamic font vector data.
|
||||
</member>
|
||||
|
|
|
@ -2868,6 +2868,12 @@ void SystemFont::_bind_methods() {
|
|||
ClassDB::bind_method(D_METHOD("set_multichannel_signed_distance_field", "msdf"), &SystemFont::set_multichannel_signed_distance_field);
|
||||
ClassDB::bind_method(D_METHOD("is_multichannel_signed_distance_field"), &SystemFont::is_multichannel_signed_distance_field);
|
||||
|
||||
ClassDB::bind_method(D_METHOD("set_msdf_pixel_range", "msdf_pixel_range"), &SystemFont::set_msdf_pixel_range);
|
||||
ClassDB::bind_method(D_METHOD("get_msdf_pixel_range"), &SystemFont::get_msdf_pixel_range);
|
||||
|
||||
ClassDB::bind_method(D_METHOD("set_msdf_size", "msdf_size"), &SystemFont::set_msdf_size);
|
||||
ClassDB::bind_method(D_METHOD("get_msdf_size"), &SystemFont::get_msdf_size);
|
||||
|
||||
ClassDB::bind_method(D_METHOD("set_oversampling", "oversampling"), &SystemFont::set_oversampling);
|
||||
ClassDB::bind_method(D_METHOD("get_oversampling"), &SystemFont::get_oversampling);
|
||||
|
||||
|
@ -2890,6 +2896,8 @@ void SystemFont::_bind_methods() {
|
|||
ADD_PROPERTY(PropertyInfo(Variant::INT, "hinting", PROPERTY_HINT_ENUM, "None,Light,Normal"), "set_hinting", "get_hinting");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::INT, "subpixel_positioning", PROPERTY_HINT_ENUM, "Disabled,Auto,One Half of a Pixel,One Quarter of a Pixel"), "set_subpixel_positioning", "get_subpixel_positioning");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "multichannel_signed_distance_field"), "set_multichannel_signed_distance_field", "is_multichannel_signed_distance_field");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::INT, "msdf_pixel_range"), "set_msdf_pixel_range", "get_msdf_pixel_range");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::INT, "msdf_size"), "set_msdf_size", "get_msdf_size");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::FLOAT, "oversampling", PROPERTY_HINT_RANGE, "0,10,0.1"), "set_oversampling", "get_oversampling");
|
||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "fallbacks", PROPERTY_HINT_ARRAY_TYPE, MAKE_RESOURCE_TYPE_HINT("Font")), "set_fallbacks", "get_fallbacks");
|
||||
}
|
||||
|
@ -2987,6 +2995,8 @@ void SystemFont::_update_base_font() {
|
|||
file->set_hinting(hinting);
|
||||
file->set_subpixel_positioning(subpixel_positioning);
|
||||
file->set_multichannel_signed_distance_field(msdf);
|
||||
file->set_msdf_pixel_range(msdf_pixel_range);
|
||||
file->set_msdf_size(msdf_size);
|
||||
file->set_oversampling(oversampling);
|
||||
|
||||
base_font = file;
|
||||
|
@ -3186,6 +3196,34 @@ bool SystemFont::is_multichannel_signed_distance_field() const {
|
|||
return msdf;
|
||||
}
|
||||
|
||||
void SystemFont::set_msdf_pixel_range(int p_msdf_pixel_range) {
|
||||
if (msdf_pixel_range != p_msdf_pixel_range) {
|
||||
msdf_pixel_range = p_msdf_pixel_range;
|
||||
if (base_font.is_valid()) {
|
||||
base_font->set_msdf_pixel_range(msdf_pixel_range);
|
||||
}
|
||||
emit_changed();
|
||||
}
|
||||
}
|
||||
|
||||
int SystemFont::get_msdf_pixel_range() const {
|
||||
return msdf_pixel_range;
|
||||
}
|
||||
|
||||
void SystemFont::set_msdf_size(int p_msdf_size) {
|
||||
if (msdf_size != p_msdf_size) {
|
||||
msdf_size = p_msdf_size;
|
||||
if (base_font.is_valid()) {
|
||||
base_font->set_msdf_size(msdf_size);
|
||||
}
|
||||
emit_changed();
|
||||
}
|
||||
}
|
||||
|
||||
int SystemFont::get_msdf_size() const {
|
||||
return msdf_size;
|
||||
}
|
||||
|
||||
void SystemFont::set_oversampling(real_t p_oversampling) {
|
||||
if (oversampling != p_oversampling) {
|
||||
oversampling = p_oversampling;
|
||||
|
|
|
@ -452,6 +452,8 @@ class SystemFont : public Font {
|
|||
TextServer::SubpixelPositioning subpixel_positioning = TextServer::SUBPIXEL_POSITIONING_AUTO;
|
||||
real_t oversampling = 0.f;
|
||||
bool msdf = false;
|
||||
int msdf_pixel_range = 16;
|
||||
int msdf_size = 48;
|
||||
|
||||
protected:
|
||||
static void _bind_methods();
|
||||
|
@ -488,6 +490,12 @@ public:
|
|||
virtual void set_multichannel_signed_distance_field(bool p_msdf);
|
||||
virtual bool is_multichannel_signed_distance_field() const;
|
||||
|
||||
virtual void set_msdf_pixel_range(int p_msdf_pixel_range);
|
||||
virtual int get_msdf_pixel_range() const;
|
||||
|
||||
virtual void set_msdf_size(int p_msdf_size);
|
||||
virtual int get_msdf_size() const;
|
||||
|
||||
virtual void set_font_names(const PackedStringArray &p_names);
|
||||
virtual PackedStringArray get_font_names() const;
|
||||
|
||||
|
|
Loading…
Reference in a new issue