summaryrefslogblamecommitdiffstats
path: root/graphics/src/backend.rs
blob: 7abc42c5fcef731d9431c74dcd8781503b756b5a (plain) (tree)
1
2
3
4
5
6
7
8
                             


                       
                                        
 

                     


                                           
                          
                                                                
                                                        


                                                           

 
                                                    
                
                                    
                                                      

 
                                                     
                 
                                                     
                                                              

 
                                                   
               
                                                            
                                                                     
 
//! Write a graphics backend.
use crate::core::image;
use crate::core::svg;
use crate::core::Size;
use crate::{Compositor, Mesh, Renderer};

use std::borrow::Cow;

/// The graphics backend of a [`Renderer`].
///
/// [`Renderer`]: crate::Renderer
pub trait Backend: Sized {
    /// The custom kind of primitives this [`Backend`] supports.
    type Primitive: TryFrom<Mesh, Error = &'static str>;

    /// The default compositor of this [`Backend`].
    type Compositor: Compositor<Renderer = Renderer<Self>>;
}

/// A graphics backend that supports text rendering.
pub trait Text {
    /// Loads a font from its bytes.
    fn load_font(&mut self, font: Cow<'static, [u8]>);
}

/// A graphics backend that supports image rendering.
pub trait Image {
    /// Returns the dimensions of the provided image.
    fn dimensions(&self, handle: &image::Handle) -> Size<u32>;
}

/// A graphics backend that supports SVG rendering.
pub trait Svg {
    /// Returns the viewport dimensions of the provided SVG.
    fn viewport_dimensions(&self, handle: &svg::Handle) -> Size<u32>;
}