Write documentation for iced_graphics
This commit is contained in:
parent
45511a442f
commit
2ca7e3c4b0
@ -12,6 +12,9 @@ pub enum Antialiasing {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Antialiasing {
|
impl Antialiasing {
|
||||||
|
/// Returns the amount of samples of the [`Antialiasing`].
|
||||||
|
///
|
||||||
|
/// [`Antialiasing`]: enum.Antialiasing.html
|
||||||
pub fn sample_count(self) -> u32 {
|
pub fn sample_count(self) -> u32 {
|
||||||
match self {
|
match self {
|
||||||
Antialiasing::MSAAx2 => 2,
|
Antialiasing::MSAAx2 => 2,
|
||||||
|
@ -1,15 +1,33 @@
|
|||||||
|
//! Write a graphics backend.
|
||||||
use iced_native::image;
|
use iced_native::image;
|
||||||
use iced_native::svg;
|
use iced_native::svg;
|
||||||
use iced_native::{Font, Size};
|
use iced_native::{Font, Size};
|
||||||
|
|
||||||
|
/// The graphics backend of a [`Renderer`].
|
||||||
|
///
|
||||||
|
/// [`Renderer`]: ../struct.Renderer.html
|
||||||
pub trait Backend {
|
pub trait Backend {
|
||||||
|
/// Trims the measurements cache.
|
||||||
|
///
|
||||||
|
/// This method is currently necessary to properly trim the text cache in
|
||||||
|
/// `iced_wgpu` and `iced_glow` because of limitations in the text rendering
|
||||||
|
/// pipeline. It will be removed in the future.
|
||||||
fn trim_measurements(&mut self) {}
|
fn trim_measurements(&mut self) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A graphics backend that supports text rendering.
|
||||||
pub trait Text {
|
pub trait Text {
|
||||||
|
/// The icon font of the backend.
|
||||||
const ICON_FONT: Font;
|
const ICON_FONT: Font;
|
||||||
|
|
||||||
|
/// The `char` representing a ✔ icon in the [`ICON_FONT`].
|
||||||
|
///
|
||||||
|
/// [`ICON_FONT`]: #associatedconst.ICON_FONt
|
||||||
const CHECKMARK_ICON: char;
|
const CHECKMARK_ICON: char;
|
||||||
|
|
||||||
|
/// Measures the text contents with the given size and font,
|
||||||
|
/// returning the size of a laid out paragraph that fits in the provided
|
||||||
|
/// bounds.
|
||||||
fn measure(
|
fn measure(
|
||||||
&self,
|
&self,
|
||||||
contents: &str,
|
contents: &str,
|
||||||
@ -19,10 +37,14 @@ pub trait Text {
|
|||||||
) -> (f32, f32);
|
) -> (f32, f32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A graphics backend that supports image rendering.
|
||||||
pub trait Image {
|
pub trait Image {
|
||||||
|
/// Returns the dimensions of the provided image.
|
||||||
fn dimensions(&self, handle: &image::Handle) -> (u32, u32);
|
fn dimensions(&self, handle: &image::Handle) -> (u32, u32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A graphics backend that supports SVG rendering.
|
||||||
pub trait Svg {
|
pub trait Svg {
|
||||||
|
/// Returns the viewport dimensions of the provided SVG.
|
||||||
fn viewport_dimensions(&self, handle: &svg::Handle) -> (u32, u32);
|
fn viewport_dimensions(&self, handle: &svg::Handle) -> (u32, u32);
|
||||||
}
|
}
|
||||||
|
@ -1,22 +1,33 @@
|
|||||||
|
//! Find system fonts or use the built-in ones.
|
||||||
#[cfg(feature = "font-source")]
|
#[cfg(feature = "font-source")]
|
||||||
mod source;
|
mod source;
|
||||||
|
|
||||||
#[cfg(feature = "font-source")]
|
#[cfg(feature = "font-source")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "font-source")))]
|
||||||
pub use source::Source;
|
pub use source::Source;
|
||||||
|
|
||||||
#[cfg(feature = "font-source")]
|
#[cfg(feature = "font-source")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "font-source")))]
|
||||||
pub use font_kit::{
|
pub use font_kit::{
|
||||||
error::SelectionError as LoadError, family_name::FamilyName as Family,
|
error::SelectionError as LoadError, family_name::FamilyName as Family,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// A built-in fallback font, for convenience.
|
||||||
#[cfg(feature = "font-fallback")]
|
#[cfg(feature = "font-fallback")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "font-fallback")))]
|
||||||
pub const FALLBACK: &[u8] = include_bytes!("../fonts/Lato-Regular.ttf");
|
pub const FALLBACK: &[u8] = include_bytes!("../fonts/Lato-Regular.ttf");
|
||||||
|
|
||||||
|
/// A built-in icon font, for convenience.
|
||||||
#[cfg(feature = "font-icons")]
|
#[cfg(feature = "font-icons")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "font-icons")))]
|
||||||
pub const ICONS: iced_native::Font = iced_native::Font::External {
|
pub const ICONS: iced_native::Font = iced_native::Font::External {
|
||||||
name: "iced_wgpu icons",
|
name: "iced_wgpu icons",
|
||||||
bytes: include_bytes!("../fonts/Icons.ttf"),
|
bytes: include_bytes!("../fonts/Icons.ttf"),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// The `char` representing a ✔ icon in the built-in [`ICONS`] font.
|
||||||
|
///
|
||||||
|
/// [`ICONS`]: const.ICONS.html
|
||||||
#[cfg(feature = "font-icons")]
|
#[cfg(feature = "font-icons")]
|
||||||
|
#[cfg_attr(docsrs, doc(cfg(feature = "font-icons")))]
|
||||||
pub const CHECKMARK_ICON: char = '\u{F00C}';
|
pub const CHECKMARK_ICON: char = '\u{F00C}';
|
||||||
|
@ -1,16 +1,24 @@
|
|||||||
use crate::font::{Family, LoadError};
|
use crate::font::{Family, LoadError};
|
||||||
|
|
||||||
|
/// A font source that can find and load system fonts.
|
||||||
|
#[allow(missing_debug_implementations)]
|
||||||
pub struct Source {
|
pub struct Source {
|
||||||
raw: font_kit::source::SystemSource,
|
raw: font_kit::source::SystemSource,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Source {
|
impl Source {
|
||||||
|
/// Creates a new [`Source`].
|
||||||
|
///
|
||||||
|
/// [`Source`]: struct.Source.html
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
Source {
|
Source {
|
||||||
raw: font_kit::source::SystemSource::new(),
|
raw: font_kit::source::SystemSource::new(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Finds and loads a font matching the set of provided family priorities.
|
||||||
|
///
|
||||||
|
/// [`Source`]: struct.Source.html
|
||||||
pub fn load(&self, families: &[Family]) -> Result<Vec<u8>, LoadError> {
|
pub fn load(&self, families: &[Family]) -> Result<Vec<u8>, LoadError> {
|
||||||
let font = self.raw.select_best_match(
|
let font = self.raw.select_best_match(
|
||||||
families,
|
families,
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
//! Organize rendering primitives into a flattened list of layers.
|
||||||
use crate::image;
|
use crate::image;
|
||||||
use crate::svg;
|
use crate::svg;
|
||||||
use crate::triangle;
|
use crate::triangle;
|
||||||
@ -6,16 +7,39 @@ use crate::{
|
|||||||
Vector, VerticalAlignment, Viewport,
|
Vector, VerticalAlignment, Viewport,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// A group of primitives that should be clipped together.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Layer<'a> {
|
pub struct Layer<'a> {
|
||||||
|
/// The clipping bounds of the [`Layer`].
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub bounds: Rectangle,
|
pub bounds: Rectangle,
|
||||||
|
|
||||||
|
/// The quads of the [`Layer`].
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub quads: Vec<Quad>,
|
pub quads: Vec<Quad>,
|
||||||
|
|
||||||
|
/// The triangle meshes of the [`Layer`].
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub meshes: Vec<Mesh<'a>>,
|
pub meshes: Vec<Mesh<'a>>,
|
||||||
|
|
||||||
|
/// The text of the [`Layer`].
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub text: Vec<Text<'a>>,
|
pub text: Vec<Text<'a>>,
|
||||||
|
|
||||||
|
/// The images of the [`Layer`].
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub images: Vec<Image>,
|
pub images: Vec<Image>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Layer<'a> {
|
impl<'a> Layer<'a> {
|
||||||
|
/// Creates a new [`Layer`] with the given clipping bounds.
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub fn new(bounds: Rectangle) -> Self {
|
pub fn new(bounds: Rectangle) -> Self {
|
||||||
Self {
|
Self {
|
||||||
bounds,
|
bounds,
|
||||||
@ -26,6 +50,11 @@ impl<'a> Layer<'a> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Creates a new [`Layer`] for the provided overlay text.
|
||||||
|
///
|
||||||
|
/// This can be useful for displaying debug information.
|
||||||
|
///
|
||||||
|
/// [`Layer`]: struct.Layer.html
|
||||||
pub fn overlay(lines: &'a [impl AsRef<str>], viewport: &Viewport) -> Self {
|
pub fn overlay(lines: &'a [impl AsRef<str>], viewport: &Viewport) -> Self {
|
||||||
let mut overlay =
|
let mut overlay =
|
||||||
Layer::new(Rectangle::with_size(viewport.logical_size()));
|
Layer::new(Rectangle::with_size(viewport.logical_size()));
|
||||||
@ -56,6 +85,10 @@ impl<'a> Layer<'a> {
|
|||||||
overlay
|
overlay
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Distributes the given [`Primitive`] and generates a list of layers based
|
||||||
|
/// on its contents.
|
||||||
|
///
|
||||||
|
/// [`Primitive`]: ../enum.Primitive.html
|
||||||
pub fn generate(
|
pub fn generate(
|
||||||
primitive: &'a Primitive,
|
primitive: &'a Primitive,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
@ -119,7 +152,7 @@ impl<'a> Layer<'a> {
|
|||||||
bounds.x + translation.x,
|
bounds.x + translation.x,
|
||||||
bounds.y + translation.y,
|
bounds.y + translation.y,
|
||||||
],
|
],
|
||||||
scale: [bounds.width, bounds.height],
|
size: [bounds.width, bounds.height],
|
||||||
color: match background {
|
color: match background {
|
||||||
Background::Color(color) => color.into_linear(),
|
Background::Color(color) => color.into_linear(),
|
||||||
},
|
},
|
||||||
@ -203,46 +236,124 @@ impl<'a> Layer<'a> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A colored rectangle with a border.
|
||||||
|
///
|
||||||
|
/// This type can be directly uploaded to GPU memory.
|
||||||
#[derive(Debug, Clone, Copy)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Quad {
|
pub struct Quad {
|
||||||
|
/// The position of the [`Quad`].
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
pub position: [f32; 2],
|
pub position: [f32; 2],
|
||||||
pub scale: [f32; 2],
|
|
||||||
|
/// The size of the [`Quad`].
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
|
pub size: [f32; 2],
|
||||||
|
|
||||||
|
/// The color of the [`Quad`], in __linear RGB__.
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
pub color: [f32; 4],
|
pub color: [f32; 4],
|
||||||
|
|
||||||
|
/// The border color of the [`Quad`], in __linear RGB__.
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
pub border_color: [f32; 4],
|
pub border_color: [f32; 4],
|
||||||
|
|
||||||
|
/// The border radius of the [`Quad`].
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
pub border_radius: f32,
|
pub border_radius: f32,
|
||||||
|
|
||||||
|
/// The border width of the [`Quad`].
|
||||||
|
///
|
||||||
|
/// [`Quad`]: struct.Quad.html
|
||||||
pub border_width: f32,
|
pub border_width: f32,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A mesh of triangles.
|
||||||
#[derive(Debug, Clone, Copy)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
pub struct Mesh<'a> {
|
pub struct Mesh<'a> {
|
||||||
|
/// The origin of the vertices of the [`Mesh`].
|
||||||
|
///
|
||||||
|
/// [`Mesh`]: struct.Mesh.html
|
||||||
pub origin: Point,
|
pub origin: Point,
|
||||||
|
|
||||||
|
/// The vertex and index buffers of the [`Mesh`].
|
||||||
|
///
|
||||||
|
/// [`Mesh`]: struct.Mesh.html
|
||||||
pub buffers: &'a triangle::Mesh2D,
|
pub buffers: &'a triangle::Mesh2D,
|
||||||
|
|
||||||
|
/// The clipping bounds of the [`Mesh`].
|
||||||
|
///
|
||||||
|
/// [`Mesh`]: struct.Mesh.html
|
||||||
pub clip_bounds: Rectangle<f32>,
|
pub clip_bounds: Rectangle<f32>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A paragraph of text.
|
||||||
#[derive(Debug, Clone, Copy)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
pub struct Text<'a> {
|
pub struct Text<'a> {
|
||||||
|
/// The content of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub content: &'a str,
|
pub content: &'a str,
|
||||||
|
|
||||||
|
/// The layout bounds of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub bounds: Rectangle,
|
pub bounds: Rectangle,
|
||||||
|
|
||||||
|
/// The color of the [`Text`], in __linear RGB_.
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub color: [f32; 4],
|
pub color: [f32; 4],
|
||||||
|
|
||||||
|
/// The size of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub size: f32,
|
pub size: f32,
|
||||||
|
|
||||||
|
/// The font of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub font: Font,
|
pub font: Font,
|
||||||
|
|
||||||
|
/// The horizontal alignment of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub horizontal_alignment: HorizontalAlignment,
|
pub horizontal_alignment: HorizontalAlignment,
|
||||||
|
|
||||||
|
/// The vertical alignment of the [`Text`].
|
||||||
|
///
|
||||||
|
/// [`Text`]: struct.Text.html
|
||||||
pub vertical_alignment: VerticalAlignment,
|
pub vertical_alignment: VerticalAlignment,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// A raster or vector image.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub enum Image {
|
pub enum Image {
|
||||||
|
/// A raster image.
|
||||||
Raster {
|
Raster {
|
||||||
|
/// The handle of a raster image.
|
||||||
handle: image::Handle,
|
handle: image::Handle,
|
||||||
|
|
||||||
|
/// The bounds of the image.
|
||||||
bounds: Rectangle,
|
bounds: Rectangle,
|
||||||
},
|
},
|
||||||
|
/// A vector image.
|
||||||
Vector {
|
Vector {
|
||||||
|
/// The handle of a vector image.
|
||||||
handle: svg::Handle,
|
handle: svg::Handle,
|
||||||
|
|
||||||
|
/// The bounds of the image.
|
||||||
bounds: Rectangle,
|
bounds: Rectangle,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
unsafe impl bytemuck::Zeroable for Quad {}
|
unsafe impl bytemuck::Zeroable for Quad {}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
unsafe impl bytemuck::Pod for Quad {}
|
unsafe impl bytemuck::Pod for Quad {}
|
||||||
|
@ -1,3 +1,13 @@
|
|||||||
|
//! A bunch of backend-agnostic types that can be leveraged to build a renderer
|
||||||
|
//! for [`iced`].
|
||||||
|
//!
|
||||||
|
//! [`iced`]: https://github.com/hecrj/iced
|
||||||
|
#![deny(missing_docs)]
|
||||||
|
#![deny(missing_debug_implementations)]
|
||||||
|
#![deny(unused_results)]
|
||||||
|
#![deny(unsafe_code)]
|
||||||
|
#![forbid(rust_2018_idioms)]
|
||||||
|
#![cfg_attr(docsrs, feature(doc_cfg))]
|
||||||
mod antialiasing;
|
mod antialiasing;
|
||||||
mod defaults;
|
mod defaults;
|
||||||
mod primitive;
|
mod primitive;
|
||||||
|
@ -3,19 +3,33 @@ use iced_native::layout::{self, Layout};
|
|||||||
use iced_native::mouse;
|
use iced_native::mouse;
|
||||||
use iced_native::{Background, Color, Element, Point, Widget};
|
use iced_native::{Background, Color, Element, Point, Widget};
|
||||||
|
|
||||||
pub struct Renderer<B> {
|
/// A backend-agnostic renderer that supports all the built-in widgets.
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct Renderer<B: Backend> {
|
||||||
backend: B,
|
backend: B,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<B> Renderer<B> {
|
impl<B: Backend> Renderer<B> {
|
||||||
|
/// Creates a new [`Renderer`] from the given [`Backend`].
|
||||||
|
///
|
||||||
|
/// [`Renderer`]: struct.Renderer.html
|
||||||
|
/// [`Backend`]: backend/trait.Backend.html
|
||||||
pub fn new(backend: B) -> Self {
|
pub fn new(backend: B) -> Self {
|
||||||
Self { backend }
|
Self { backend }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns a reference to the [`Backend`] of the [`Renderer`].
|
||||||
|
///
|
||||||
|
/// [`Renderer`]: struct.Renderer.html
|
||||||
|
/// [`Backend`]: backend/trait.Backend.html
|
||||||
pub fn backend(&self) -> &B {
|
pub fn backend(&self) -> &B {
|
||||||
&self.backend
|
&self.backend
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns a mutable reference to the [`Backend`] of the [`Renderer`].
|
||||||
|
///
|
||||||
|
/// [`Renderer`]: struct.Renderer.html
|
||||||
|
/// [`Backend`]: backend/trait.Backend.html
|
||||||
pub fn backend_mut(&mut self) -> &mut B {
|
pub fn backend_mut(&mut self) -> &mut B {
|
||||||
&mut self.backend
|
&mut self.backend
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
//! Draw geometry using meshes of triangles.
|
||||||
|
|
||||||
/// A set of [`Vertex2D`] and indices representing a list of triangles.
|
/// A set of [`Vertex2D`] and indices representing a list of triangles.
|
||||||
///
|
///
|
||||||
/// [`Vertex2D`]: struct.Vertex2D.html
|
/// [`Vertex2D`]: struct.Vertex2D.html
|
||||||
@ -23,5 +25,8 @@ pub struct Vertex2D {
|
|||||||
pub color: [f32; 4],
|
pub color: [f32; 4],
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
unsafe impl bytemuck::Zeroable for Vertex2D {}
|
unsafe impl bytemuck::Zeroable for Vertex2D {}
|
||||||
|
|
||||||
|
#[allow(unsafe_code)]
|
||||||
unsafe impl bytemuck::Pod for Vertex2D {}
|
unsafe impl bytemuck::Pod for Vertex2D {}
|
||||||
|
@ -26,22 +26,44 @@ impl Viewport {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the physical size of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
pub fn physical_size(&self) -> Size<u32> {
|
pub fn physical_size(&self) -> Size<u32> {
|
||||||
self.physical_size
|
self.physical_size
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the physical width of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
|
pub fn physical_width(&self) -> u32 {
|
||||||
|
self.physical_size.height
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Returns the physical height of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
pub fn physical_height(&self) -> u32 {
|
pub fn physical_height(&self) -> u32 {
|
||||||
self.physical_size.height
|
self.physical_size.height
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the logical size of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
pub fn logical_size(&self) -> Size<f32> {
|
pub fn logical_size(&self) -> Size<f32> {
|
||||||
self.logical_size
|
self.logical_size
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the scale factor of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
pub fn scale_factor(&self) -> f64 {
|
pub fn scale_factor(&self) -> f64 {
|
||||||
self.scale_factor
|
self.scale_factor
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the projection transformation of the [`Viewport`].
|
||||||
|
///
|
||||||
|
/// [`Viewport`]: struct.Viewport.html
|
||||||
pub fn projection(&self) -> Transformation {
|
pub fn projection(&self) -> Transformation {
|
||||||
self.projection
|
self.projection
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ use iced_native::column;
|
|||||||
use iced_native::mouse;
|
use iced_native::mouse;
|
||||||
use iced_native::{Element, Layout, Point};
|
use iced_native::{Element, Layout, Point};
|
||||||
|
|
||||||
|
/// A container that distributes its contents vertically.
|
||||||
pub type Column<'a, Message, Backend> =
|
pub type Column<'a, Message, Backend> =
|
||||||
iced_native::Column<'a, Message, Renderer<Backend>>;
|
iced_native::Column<'a, Message, Renderer<Backend>>;
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
//! Display images in your user interface.
|
||||||
use crate::backend::{self, Backend};
|
use crate::backend::{self, Backend};
|
||||||
use crate::{Primitive, Renderer};
|
use crate::{Primitive, Renderer};
|
||||||
use iced_native::image;
|
use iced_native::image;
|
||||||
|
@ -3,6 +3,7 @@ use iced_native::mouse;
|
|||||||
use iced_native::row;
|
use iced_native::row;
|
||||||
use iced_native::{Element, Layout, Point};
|
use iced_native::{Element, Layout, Point};
|
||||||
|
|
||||||
|
/// A container that distributes its contents horizontally.
|
||||||
pub type Row<'a, Message, Backend> =
|
pub type Row<'a, Message, Backend> =
|
||||||
iced_native::Row<'a, Message, Renderer<Backend>>;
|
iced_native::Row<'a, Message, Renderer<Backend>>;
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
//! Display vector graphics in your application.
|
||||||
use crate::backend::{self, Backend};
|
use crate::backend::{self, Backend};
|
||||||
use crate::{Primitive, Renderer};
|
use crate::{Primitive, Renderer};
|
||||||
use iced_native::{mouse, svg, Layout};
|
use iced_native::{mouse, svg, Layout};
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
//! Draw graphics to window surfaces.
|
||||||
mod compositor;
|
mod compositor;
|
||||||
|
|
||||||
#[cfg(feature = "opengl")]
|
#[cfg(feature = "opengl")]
|
||||||
|
@ -3,19 +3,60 @@ use iced_native::mouse;
|
|||||||
|
|
||||||
use core::ffi::c_void;
|
use core::ffi::c_void;
|
||||||
|
|
||||||
|
/// A basic OpenGL compositor.
|
||||||
|
///
|
||||||
|
/// A compositor is responsible for initializing a renderer and managing window
|
||||||
|
/// surfaces.
|
||||||
|
///
|
||||||
|
/// For now, this compositor only deals with a single global surface
|
||||||
|
/// for drawing. However, the trait will most likely change in the near future
|
||||||
|
/// to handle multiple surfaces at once.
|
||||||
|
///
|
||||||
|
/// If you implement an OpenGL renderer, you can implement this trait to ease
|
||||||
|
/// integration with existing windowing shells, like `iced_glutin`.
|
||||||
pub trait GLCompositor: Sized {
|
pub trait GLCompositor: Sized {
|
||||||
|
/// The renderer of the [`Compositor`].
|
||||||
|
///
|
||||||
|
/// This should point to your renderer type, which could be a type alias
|
||||||
|
/// of the [`Renderer`] provided in this crate with with a specific
|
||||||
|
/// [`Backend`].
|
||||||
|
///
|
||||||
|
/// [`Compositor`]: trait.Compositor.html
|
||||||
|
/// [`Renderer`]: ../struct.Renderer.html
|
||||||
|
/// [`Backend`]: ../backend/trait.Backend.html
|
||||||
type Renderer: iced_native::Renderer;
|
type Renderer: iced_native::Renderer;
|
||||||
|
|
||||||
|
/// The settings of the [`Compositor`].
|
||||||
|
///
|
||||||
|
/// It's up to you to decide the configuration supported by your renderer!
|
||||||
type Settings: Default;
|
type Settings: Default;
|
||||||
|
|
||||||
|
/// Creates a new [`Compositor`] and [`Renderer`] with the given
|
||||||
|
/// [`Settings`] and an OpenGL address loader function.
|
||||||
|
///
|
||||||
|
/// [`Compositor`]: trait.Compositor.html
|
||||||
|
/// [`Renderer`]: #associatedtype.Renderer
|
||||||
|
/// [`Backend`]: ../backend/trait.Backend.html
|
||||||
|
#[allow(unsafe_code)]
|
||||||
unsafe fn new(
|
unsafe fn new(
|
||||||
settings: Self::Settings,
|
settings: Self::Settings,
|
||||||
loader_function: impl FnMut(&str) -> *const c_void,
|
loader_function: impl FnMut(&str) -> *const c_void,
|
||||||
) -> (Self, Self::Renderer);
|
) -> (Self, Self::Renderer);
|
||||||
|
|
||||||
|
/// Returns the amount of samples that should be used when configuring
|
||||||
|
/// an OpenGL context for this [`Compositor`].
|
||||||
|
///
|
||||||
|
/// [`Compositor`]: trait.Compositor.html
|
||||||
fn sample_count(settings: &Self::Settings) -> u32;
|
fn sample_count(settings: &Self::Settings) -> u32;
|
||||||
|
|
||||||
|
/// Resizes the viewport of the [`Compositor`].
|
||||||
|
///
|
||||||
|
/// [`Compositor`]: trait.Compositor.html
|
||||||
fn resize_viewport(&mut self, physical_size: Size<u32>);
|
fn resize_viewport(&mut self, physical_size: Size<u32>);
|
||||||
|
|
||||||
|
/// Draws the provided output with the given [`Renderer`].
|
||||||
|
///
|
||||||
|
/// [`Compositor`]: trait.Compositor.html
|
||||||
fn draw<T: AsRef<str>>(
|
fn draw<T: AsRef<str>>(
|
||||||
&mut self,
|
&mut self,
|
||||||
renderer: &mut Self::Renderer,
|
renderer: &mut Self::Renderer,
|
||||||
|
@ -12,9 +12,10 @@ use iced_native::{Font, HorizontalAlignment, Size, VerticalAlignment};
|
|||||||
#[cfg(any(feature = "image", feature = "svg"))]
|
#[cfg(any(feature = "image", feature = "svg"))]
|
||||||
use crate::image;
|
use crate::image;
|
||||||
|
|
||||||
/// A [`wgpu`] renderer.
|
/// A [`wgpu`] graphics backend for [`iced`].
|
||||||
///
|
///
|
||||||
/// [`wgpu`]: https://github.com/gfx-rs/wgpu-rs
|
/// [`wgpu`]: https://github.com/gfx-rs/wgpu-rs
|
||||||
|
/// [`iced`]: https://github.com/hecrj/iced
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Backend {
|
pub struct Backend {
|
||||||
quad_pipeline: quad::Pipeline,
|
quad_pipeline: quad::Pipeline,
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
//! [`wgpu`]: https://github.com/gfx-rs/wgpu-rs
|
//! [`wgpu`]: https://github.com/gfx-rs/wgpu-rs
|
||||||
//! [WebGPU API]: https://gpuweb.github.io/gpuweb/
|
//! [WebGPU API]: https://gpuweb.github.io/gpuweb/
|
||||||
//! [`wgpu_glyph`]: https://github.com/hecrj/wgpu_glyph
|
//! [`wgpu_glyph`]: https://github.com/hecrj/wgpu_glyph
|
||||||
//#![deny(missing_docs)]
|
#![deny(missing_docs)]
|
||||||
#![deny(missing_debug_implementations)]
|
#![deny(missing_debug_implementations)]
|
||||||
#![deny(unused_results)]
|
#![deny(unused_results)]
|
||||||
#![forbid(unsafe_code)]
|
#![forbid(unsafe_code)]
|
||||||
@ -47,7 +47,11 @@ pub use widget::*;
|
|||||||
|
|
||||||
pub(crate) use iced_graphics::Transformation;
|
pub(crate) use iced_graphics::Transformation;
|
||||||
|
|
||||||
pub type Renderer = iced_graphics::Renderer<Backend>;
|
|
||||||
|
|
||||||
#[cfg(any(feature = "image", feature = "svg"))]
|
#[cfg(any(feature = "image", feature = "svg"))]
|
||||||
mod image;
|
mod image;
|
||||||
|
|
||||||
|
/// A [`wgpu`] graphics renderer for [`iced`].
|
||||||
|
///
|
||||||
|
/// [`wgpu`]: https://github.com/gfx-rs/wgpu-rs
|
||||||
|
/// [`iced`]: https://github.com/hecrj/iced
|
||||||
|
pub type Renderer = iced_graphics::Renderer<Backend>;
|
||||||
|
@ -19,8 +19,6 @@ pub mod scrollable;
|
|||||||
pub mod slider;
|
pub mod slider;
|
||||||
pub mod text_input;
|
pub mod text_input;
|
||||||
|
|
||||||
mod text;
|
|
||||||
|
|
||||||
#[doc(no_inline)]
|
#[doc(no_inline)]
|
||||||
pub use button::Button;
|
pub use button::Button;
|
||||||
#[doc(no_inline)]
|
#[doc(no_inline)]
|
||||||
@ -40,8 +38,6 @@ pub use slider::Slider;
|
|||||||
#[doc(no_inline)]
|
#[doc(no_inline)]
|
||||||
pub use text_input::TextInput;
|
pub use text_input::TextInput;
|
||||||
|
|
||||||
pub use text::Text;
|
|
||||||
|
|
||||||
#[cfg(feature = "canvas")]
|
#[cfg(feature = "canvas")]
|
||||||
#[cfg_attr(docsrs, doc(cfg(feature = "canvas")))]
|
#[cfg_attr(docsrs, doc(cfg(feature = "canvas")))]
|
||||||
pub mod canvas;
|
pub mod canvas;
|
||||||
@ -52,5 +48,11 @@ pub use canvas::Canvas;
|
|||||||
|
|
||||||
pub use iced_native::Space;
|
pub use iced_native::Space;
|
||||||
|
|
||||||
|
/// A container that distributes its contents vertically.
|
||||||
pub type Column<'a, Message> = iced_native::Column<'a, Message, Renderer>;
|
pub type Column<'a, Message> = iced_native::Column<'a, Message, Renderer>;
|
||||||
|
|
||||||
|
/// A container that distributes its contents horizontally.
|
||||||
pub type Row<'a, Message> = iced_native::Row<'a, Message, Renderer>;
|
pub type Row<'a, Message> = iced_native::Row<'a, Message, Renderer>;
|
||||||
|
|
||||||
|
/// A paragraph of text.
|
||||||
|
pub type Text = iced_native::Text<Renderer>;
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
//! Write some text for your users to read.
|
|
||||||
use crate::Renderer;
|
|
||||||
|
|
||||||
/// A paragraph of text.
|
|
||||||
///
|
|
||||||
/// This is an alias of an `iced_native` text with an `iced_wgpu::Renderer`.
|
|
||||||
pub type Text = iced_native::Text<Renderer>;
|
|
Loading…
Reference in New Issue
Block a user