Feature gate font-kit
behind "default_system_font"
feature.
This commit is contained in:
parent
05750bf186
commit
ae9521e500
@ -12,7 +12,7 @@ keywords = ["gui", "ui", "graphics", "interface", "widgets"]
|
|||||||
categories = ["gui"]
|
categories = ["gui"]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["wgpu"]
|
default = ["wgpu", "default_system_font"]
|
||||||
# Enables the `iced_wgpu` renderer
|
# Enables the `iced_wgpu` renderer
|
||||||
wgpu = ["iced_wgpu"]
|
wgpu = ["iced_wgpu"]
|
||||||
# Enables the `Image` widget
|
# Enables the `Image` widget
|
||||||
@ -21,10 +21,14 @@ image = ["iced_wgpu/image"]
|
|||||||
svg = ["iced_wgpu/svg"]
|
svg = ["iced_wgpu/svg"]
|
||||||
# Enables the `Canvas` widget
|
# Enables the `Canvas` widget
|
||||||
canvas = ["iced_wgpu/canvas"]
|
canvas = ["iced_wgpu/canvas"]
|
||||||
|
# Enables using system fonts.
|
||||||
|
default_system_font = ["iced_wgpu/default_system_font"]
|
||||||
# Enables the `iced_glow` renderer. Overrides `iced_wgpu`
|
# Enables the `iced_glow` renderer. Overrides `iced_wgpu`
|
||||||
glow = ["iced_glow", "iced_glutin"]
|
glow = ["iced_glow", "iced_glutin"]
|
||||||
# Enables the `Canvas` widget for `iced_glow`
|
# Enables the `Canvas` widget for `iced_glow`
|
||||||
glow_canvas = ["iced_glow/canvas"]
|
glow_canvas = ["iced_glow/canvas"]
|
||||||
|
# Enables using system fonts for `iced_glow`.
|
||||||
|
glow_default_system_font = ["iced_glow/default_system_font"]
|
||||||
# Enables a debug view in native platforms (press F12)
|
# Enables a debug view in native platforms (press F12)
|
||||||
debug = ["iced_winit/debug"]
|
debug = ["iced_winit/debug"]
|
||||||
# Enables `tokio` as the `executor::Default` on native platforms
|
# Enables `tokio` as the `executor::Default` on native platforms
|
||||||
|
@ -9,6 +9,7 @@ repository = "https://github.com/hecrj/iced"
|
|||||||
|
|
||||||
[features]
|
[features]
|
||||||
canvas = ["iced_graphics/canvas"]
|
canvas = ["iced_graphics/canvas"]
|
||||||
|
default_system_font = ["iced_graphics/font-source"]
|
||||||
# Not supported yet!
|
# Not supported yet!
|
||||||
image = []
|
image = []
|
||||||
svg = []
|
svg = []
|
||||||
@ -29,7 +30,7 @@ path = "../native"
|
|||||||
[dependencies.iced_graphics]
|
[dependencies.iced_graphics]
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
path = "../graphics"
|
path = "../graphics"
|
||||||
features = ["font-source", "font-fallback", "font-icons", "opengl"]
|
features = ["font-fallback", "font-icons", "opengl"]
|
||||||
|
|
||||||
[package.metadata.docs.rs]
|
[package.metadata.docs.rs]
|
||||||
rustdoc-args = ["--cfg", "docsrs"]
|
rustdoc-args = ["--cfg", "docsrs"]
|
||||||
|
@ -12,15 +12,20 @@ pub struct Pipeline {
|
|||||||
|
|
||||||
impl Pipeline {
|
impl Pipeline {
|
||||||
pub fn new(gl: &glow::Context, default_font: Option<&[u8]>) -> Self {
|
pub fn new(gl: &glow::Context, default_font: Option<&[u8]>) -> Self {
|
||||||
|
let default_font = default_font.map(|slice| slice.to_vec());
|
||||||
|
|
||||||
// TODO: Font customization
|
// TODO: Font customization
|
||||||
let font_source = font::Source::new();
|
#[cfg(feature = "default_system_font")]
|
||||||
|
let default_font = {
|
||||||
|
default_font.or_else(|| {
|
||||||
|
font::Source::new()
|
||||||
|
.load(&[font::Family::SansSerif, font::Family::Serif])
|
||||||
|
.ok()
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
let default_font =
|
let default_font =
|
||||||
default_font.map(|slice| slice.to_vec()).unwrap_or_else(|| {
|
default_font.unwrap_or_else(|| font::FALLBACK.to_vec());
|
||||||
font_source
|
|
||||||
.load(&[font::Family::SansSerif, font::Family::Serif])
|
|
||||||
.unwrap_or_else(|_| font::FALLBACK.to_vec())
|
|
||||||
});
|
|
||||||
|
|
||||||
let font = ab_glyph::FontArc::try_from_vec(default_font)
|
let font = ab_glyph::FontArc::try_from_vec(default_font)
|
||||||
.unwrap_or_else(|_| {
|
.unwrap_or_else(|_| {
|
||||||
|
@ -10,6 +10,7 @@ repository = "https://github.com/hecrj/iced"
|
|||||||
[features]
|
[features]
|
||||||
svg = ["resvg"]
|
svg = ["resvg"]
|
||||||
canvas = ["iced_graphics/canvas"]
|
canvas = ["iced_graphics/canvas"]
|
||||||
|
default_system_font = ["iced_graphics/font-source"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
wgpu = "0.5"
|
wgpu = "0.5"
|
||||||
@ -32,7 +33,7 @@ path = "../native"
|
|||||||
[dependencies.iced_graphics]
|
[dependencies.iced_graphics]
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
path = "../graphics"
|
path = "../graphics"
|
||||||
features = ["font-source", "font-fallback", "font-icons"]
|
features = ["font-fallback", "font-icons"]
|
||||||
|
|
||||||
[dependencies.image]
|
[dependencies.image]
|
||||||
version = "0.23"
|
version = "0.23"
|
||||||
|
@ -16,15 +16,20 @@ impl Pipeline {
|
|||||||
format: wgpu::TextureFormat,
|
format: wgpu::TextureFormat,
|
||||||
default_font: Option<&[u8]>,
|
default_font: Option<&[u8]>,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
|
let default_font = default_font.map(|slice| slice.to_vec());
|
||||||
|
|
||||||
// TODO: Font customization
|
// TODO: Font customization
|
||||||
let font_source = font::Source::new();
|
#[cfg(feature = "default_system_font")]
|
||||||
|
let default_font = {
|
||||||
|
default_font.or_else(|| {
|
||||||
|
font::Source::new()
|
||||||
|
.load(&[font::Family::SansSerif, font::Family::Serif])
|
||||||
|
.ok()
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
let default_font =
|
let default_font =
|
||||||
default_font.map(|slice| slice.to_vec()).unwrap_or_else(|| {
|
default_font.unwrap_or_else(|| font::FALLBACK.to_vec());
|
||||||
font_source
|
|
||||||
.load(&[font::Family::SansSerif, font::Family::Serif])
|
|
||||||
.unwrap_or_else(|_| font::FALLBACK.to_vec())
|
|
||||||
});
|
|
||||||
|
|
||||||
let font = ab_glyph::FontArc::try_from_vec(default_font)
|
let font = ab_glyph::FontArc::try_from_vec(default_font)
|
||||||
.unwrap_or_else(|_| {
|
.unwrap_or_else(|_| {
|
||||||
|
Loading…
Reference in New Issue
Block a user