Move font::Source
to iced_graphics
This commit is contained in:
parent
4aed0fa4b6
commit
e0c4f1a08e
@ -13,7 +13,6 @@ euclid = "0.20"
|
|||||||
glow = "0.4"
|
glow = "0.4"
|
||||||
bytemuck = "1.2"
|
bytemuck = "1.2"
|
||||||
glam = "0.8"
|
glam = "0.8"
|
||||||
font-kit = "0.6"
|
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
glyph_brush = "0.6"
|
glyph_brush = "0.6"
|
||||||
|
|
||||||
@ -24,6 +23,7 @@ path = "../native"
|
|||||||
[dependencies.iced_graphics]
|
[dependencies.iced_graphics]
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
path = "../graphics"
|
path = "../graphics"
|
||||||
|
features = ["font-source"]
|
||||||
|
|
||||||
[dependencies.surfman]
|
[dependencies.surfman]
|
||||||
path = "../../surfman/surfman"
|
path = "../../surfman/surfman"
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
mod font;
|
|
||||||
|
|
||||||
use crate::Transformation;
|
use crate::Transformation;
|
||||||
|
use iced_graphics::font;
|
||||||
use std::{cell::RefCell, collections::HashMap};
|
use std::{cell::RefCell, collections::HashMap};
|
||||||
|
|
||||||
pub const BUILTIN_ICONS: iced_native::Font = iced_native::Font::External {
|
pub const BUILTIN_ICONS: iced_native::Font = iced_native::Font::External {
|
||||||
|
@ -6,6 +6,7 @@ edition = "2018"
|
|||||||
|
|
||||||
[features]
|
[features]
|
||||||
canvas = ["lyon"]
|
canvas = ["lyon"]
|
||||||
|
font-source = ["font-kit"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
bytemuck = "1.2"
|
bytemuck = "1.2"
|
||||||
@ -22,3 +23,7 @@ path = "../style"
|
|||||||
[dependencies.lyon]
|
[dependencies.lyon]
|
||||||
version = "0.15"
|
version = "0.15"
|
||||||
optional = true
|
optional = true
|
||||||
|
|
||||||
|
[dependencies.font-kit]
|
||||||
|
version = "0.6"
|
||||||
|
optional = true
|
||||||
|
10
graphics/src/font.rs
Normal file
10
graphics/src/font.rs
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
#[cfg(feature = "font-source")]
|
||||||
|
mod source;
|
||||||
|
|
||||||
|
#[cfg(feature = "font-source")]
|
||||||
|
pub use source::Source;
|
||||||
|
|
||||||
|
#[cfg(feature = "font-source")]
|
||||||
|
pub use font_kit::{
|
||||||
|
error::SelectionError as LoadError, family_name::FamilyName as Family,
|
||||||
|
};
|
@ -1,6 +1,4 @@
|
|||||||
pub use font_kit::{
|
use crate::font::{Family, LoadError};
|
||||||
error::SelectionError as LoadError, family_name::FamilyName as Family,
|
|
||||||
};
|
|
||||||
|
|
||||||
pub struct Source {
|
pub struct Source {
|
||||||
raw: font_kit::source::SystemSource,
|
raw: font_kit::source::SystemSource,
|
@ -6,6 +6,7 @@ mod viewport;
|
|||||||
mod widget;
|
mod widget;
|
||||||
|
|
||||||
pub mod backend;
|
pub mod backend;
|
||||||
|
pub mod font;
|
||||||
pub mod triangle;
|
pub mod triangle;
|
||||||
|
|
||||||
#[doc(no_inline)]
|
#[doc(no_inline)]
|
||||||
|
@ -19,7 +19,6 @@ bytemuck = "1.2"
|
|||||||
glyph_brush = "0.6"
|
glyph_brush = "0.6"
|
||||||
raw-window-handle = "0.3"
|
raw-window-handle = "0.3"
|
||||||
glam = "0.8"
|
glam = "0.8"
|
||||||
font-kit = "0.6"
|
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
guillotiere = "0.5"
|
guillotiere = "0.5"
|
||||||
# Pin `gfx-memory` until https://github.com/gfx-rs/wgpu-rs/issues/261 is
|
# Pin `gfx-memory` until https://github.com/gfx-rs/wgpu-rs/issues/261 is
|
||||||
@ -33,6 +32,7 @@ path = "../native"
|
|||||||
[dependencies.iced_graphics]
|
[dependencies.iced_graphics]
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
path = "../graphics"
|
path = "../graphics"
|
||||||
|
features = ["font-source"]
|
||||||
|
|
||||||
[dependencies.image]
|
[dependencies.image]
|
||||||
version = "0.23"
|
version = "0.23"
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
mod font;
|
|
||||||
|
|
||||||
use crate::Transformation;
|
use crate::Transformation;
|
||||||
|
use iced_graphics::font;
|
||||||
use std::{cell::RefCell, collections::HashMap};
|
use std::{cell::RefCell, collections::HashMap};
|
||||||
|
|
||||||
pub const BUILTIN_ICONS: iced_native::Font = iced_native::Font::External {
|
pub const BUILTIN_ICONS: iced_native::Font = iced_native::Font::External {
|
||||||
|
@ -1,37 +0,0 @@
|
|||||||
pub use font_kit::{
|
|
||||||
error::SelectionError as LoadError, family_name::FamilyName as Family,
|
|
||||||
};
|
|
||||||
|
|
||||||
pub struct Source {
|
|
||||||
raw: font_kit::source::SystemSource,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Source {
|
|
||||||
pub fn new() -> Self {
|
|
||||||
Source {
|
|
||||||
raw: font_kit::source::SystemSource::new(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn load(&self, families: &[Family]) -> Result<Vec<u8>, LoadError> {
|
|
||||||
let font = self.raw.select_best_match(
|
|
||||||
families,
|
|
||||||
&font_kit::properties::Properties::default(),
|
|
||||||
)?;
|
|
||||||
|
|
||||||
match font {
|
|
||||||
font_kit::handle::Handle::Path { path, .. } => {
|
|
||||||
use std::io::Read;
|
|
||||||
|
|
||||||
let mut buf = Vec::new();
|
|
||||||
let mut reader = std::fs::File::open(path).expect("Read font");
|
|
||||||
let _ = reader.read_to_end(&mut buf);
|
|
||||||
|
|
||||||
Ok(buf)
|
|
||||||
}
|
|
||||||
font_kit::handle::Handle::Memory { bytes, .. } => {
|
|
||||||
Ok(bytes.as_ref().clone())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user