diff options
Diffstat (limited to 'graphics/src/viewport.rs')
| -rw-r--r-- | graphics/src/viewport.rs | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/graphics/src/viewport.rs b/graphics/src/viewport.rs new file mode 100644 index 00000000..66122e6d --- /dev/null +++ b/graphics/src/viewport.rs @@ -0,0 +1,70 @@ +use crate::{Size, Transformation}; + +/// A viewing region for displaying computer graphics. +#[derive(Debug)] +pub struct Viewport { +    physical_size: Size<u32>, +    logical_size: Size<f32>, +    scale_factor: f64, +    projection: Transformation, +} + +impl Viewport { +    /// Creates a new [`Viewport`] with the given physical dimensions and scale +    /// factor. +    /// +    /// [`Viewport`]: struct.Viewport.html +    pub fn with_physical_size(size: Size<u32>, scale_factor: f64) -> Viewport { +        Viewport { +            physical_size: size, +            logical_size: Size::new( +                (size.width as f64 / scale_factor) as f32, +                (size.height as f64 / scale_factor) as f32, +            ), +            scale_factor, +            projection: Transformation::orthographic(size.width, size.height), +        } +    } + +    /// Returns the physical size of the [`Viewport`]. +    /// +    /// [`Viewport`]: struct.Viewport.html +    pub fn physical_size(&self) -> Size<u32> { +        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 { +        self.physical_size.height +    } + +    /// Returns the logical size of the [`Viewport`]. +    /// +    /// [`Viewport`]: struct.Viewport.html +    pub fn logical_size(&self) -> Size<f32> { +        self.logical_size +    } + +    /// Returns the scale factor of the [`Viewport`]. +    /// +    /// [`Viewport`]: struct.Viewport.html +    pub fn scale_factor(&self) -> f64 { +        self.scale_factor +    } + +    /// Returns the projection transformation of the [`Viewport`]. +    /// +    /// [`Viewport`]: struct.Viewport.html +    pub fn projection(&self) -> Transformation { +        self.projection +    } +} | 
