Struct ascii_forge::window::Window  
source · pub struct Window { /* private fields */ }Expand description
The main window behind the application. Represents the terminal window, allowing it to be used similar to a buffer, but has extra event handling.
use ascii_forge::prelude::*;
let mut window = Window::init()?;
render!(
    window,
    [
        (10, 10) => "Element Here!"
    ]
)Implementations§
source§impl Window
 
impl Window
sourcepub fn new(io: Stdout) -> Result<Self>
 
pub fn new(io: Stdout) -> Result<Self>
Creates a new window from the given stdout. Please prefer to use init as it will do all of the terminal init stuff.
sourcepub fn new_inline(io: Stdout, height: u16) -> Result<Self>
 
pub fn new_inline(io: Stdout, height: u16) -> Result<Self>
Creates a new window built for inline using the given Stdout and height.
sourcepub fn init_inline(height: u16) -> Result<Self>
 
pub fn init_inline(height: u16) -> Result<Self>
Initializes a window that is prepared for inline rendering. Height is the number of columns that your terminal will need.
pub fn keyboard(&mut self) -> Result<()>
sourcepub fn buffer_mut(&mut self) -> &mut Buffer
 
pub fn buffer_mut(&mut self) -> &mut Buffer
Returns the active Buffer, as a mutable reference.
sourcepub fn swap_buffers(&mut self)
 
pub fn swap_buffers(&mut self)
Swaps the buffers, clearing the old buffer. Used automatically by the window’s update method.
sourcepub fn restore(&mut self) -> Result<()>
 
pub fn restore(&mut self) -> Result<()>
Restores the window to it’s previous state from before the window’s init method. If the window is inline, restore the inline render
sourcepub fn render(&mut self) -> Result<()>
 
pub fn render(&mut self) -> Result<()>
Renders the window to the screen. should really only be used by the update method, but if you need a custom system, you can use this.
sourcepub fn handle_event(&mut self, poll: Duration) -> Result<()>
 
pub fn handle_event(&mut self, poll: Duration) -> Result<()>
Handles events. Used automatically by the update method, so no need to use it unless update is being used.
pub fn mouse_pos(&self) -> Vec2
sourcepub fn hover<V: Into<Vec2>>(&self, loc: V, size: V) -> Result<bool>
 
pub fn hover<V: Into<Vec2>>(&self, loc: V, size: V) -> Result<bool>
Returns true if the mouse cursor is hovering the given rect.