Struct glin::Context[][src]

pub struct Context<'c, R: RenderSurface + 'c = Screen> { /* fields omitted */ }
[]

Used to issue draw calls

Implementations

impl Context<'static>[src]

pub fn new<W: GlWindow>(window: &mut W) -> Result<Context<'static>>[src][]

Create a new context from any window implementing GLWindow

pub fn from_properties<'a, P, W>(
    window: &mut W,
    properties: P
) -> Result<Context<'static>> where
    P: IntoIterator<Item = &'a Property>,
    W: GlWindow
[src][]

Create a new context from any window implmenting GLWindow and a set of default properties

impl<'c> Context<'c>[src]

pub unsafe fn reset_default_state(&mut self, state: State<'static>)[src][]

Sets the current state to the one passed as parameter.

Used to reset the current state, for example, after altering it doing external gl calls

impl<'c, R: RenderSurface + 'c> Context<'c, R>[src]

pub unsafe fn gl(&self) -> &Gl[src]

pub fn draw_with_properties<'a, V, U, I, P>(
    &self,
    vao_range: V,
    program: &Program,
    uniforms: I,
    properties: P
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    P: IntoIterator<Item = &'a Property>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw<V, U, I>(
    &self,
    vao_range: V,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw_instanced_with_opt_properties<'a, V, U, I, P>(
    &self,
    vao_range: V,
    num_instances: usize,
    program: &Program,
    uniforms: I,
    properties: Option<P>
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    P: IntoIterator<Item = &'a Property>, 
[src][]

Instanced drawing, draws num_instances times the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw_instanced<V, U, I>(
    &self,
    vao_range: V,
    num_instances: usize,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>, 
[src][]

Instanced drawing, draws num_instances times the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw_instanced_with_properties<'a, V, U, I, P>(
    &self,
    vao_range: V,
    num_instances: usize,
    program: &Program,
    uniforms: I,
    properties: P
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    P: IntoIterator<Item = &'a Property>, 
[src][]

Instanced drawing, draws num_instances times the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw_elements_command<V, T, B, U, I>(
    &self,
    vao_range: V,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn draw_arrays_command<V, T, U, I, B>(
    &self,
    vao_range: V,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn multi_draw_elements_command<V, T, B, U, I>(
    &self,
    vao_range: V,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn multi_draw_arrays_command<V, T, B, U, I>(
    &self,
    vao_range: V,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub unsafe fn multi_draw_elements_command_vao_id<T, B, U, I>(
    &self,
    vao_id: u32,
    mode: GLenum,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub unsafe fn multi_draw_arrays_command_vao_id<T, B, U, I>(
    &self,
    vao_id: u32,
    mode: GLenum,
    command_buffer: B,
    program: &Program,
    uniforms: I
) -> Result<()> where
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>,
    B: BufferRange<T>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode) using a draw command

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub unsafe fn draw_with_program_id<V, U, I>(
    &self,
    vao_range: V,
    program: u32,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>, 
[src][]

Draw the passed VaoDraw (VAO range + a mode)

The call will use the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub unsafe fn draw_instanced_with_program_id<V, U, I>(
    &self,
    vao_range: V,
    num_instances: usize,
    program: u32,
    uniforms: I
) -> Result<()> where
    V: VaoDraw,
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>, 
[src][]

Instanced drawing, draws num_instances times the passed VaoDraw (VAO range + a mode)

The call will used the passed properties to set the GL state if it’s not the same already the passed glsl program and the set of uniforms

pub fn with<'a, P: IntoIterator<Item = &'a Property>>(
    &self,
    properties: P
) -> Context<'_, R>
[src][]

Pass a set of properties to get a copy of this context with those properties

Every draw call issued over the new context will use the passed properties.

use std::mem;
struct Vertex{
    position: [f32; 4]
}

let gl: glin::Context = unsafe{ mem::uninitialized() };
let vao: glin::SimpleVao<Vertex> = unsafe{ mem::uninitialized() };
let program: glin::Program = unsafe{ mem::uninitialized() };

{
    let gl = gl.with(&[glin::Property::DepthTest(true)]);
    // All calls in this scope will have depth testing enabled
    gl.draw(&vao, &program, &[]);
    gl.draw(&vao, &program, &[]);
    gl.draw(&vao, &program, &[]);
}

pub fn set_properties<'a, P: IntoIterator<Item = &'a Property>>(
    &mut self,
    properties: P
)
[src]

pub fn with_fbo<F: UntypedOffscreenBuffer + Clone>(
    &self,
    fbo: F
) -> Context<'_, F>
[src][]

Pass an fbo get a copy of this context that renders to the fbo

This call is mut to forbid the caller from using the original context while the new one is in scoepe for performance reasons

struct Vertex {
    position: [f32; 4]
}

let fbo = gl.new_fbo().create(1920, 1080, glin::fbo::ColorFormat::RGBA8).unwrap();

{
    let gl = gl.with_fbo(&fbo);
    // All calls in this scope will render to the passed fbo
    gl.draw(&vao, &program, &[]);
    gl.draw(&vao, &program, &[]);
    gl.draw(&vao, &program, &[]);
}

pub fn into_with_fbo<F: UntypedOffscreenBuffer + Clone>(
    self,
    fbo: F
) -> Context<'c, F>
[src]

pub fn capture_state(&self) -> State<'static>[src][]

Get a copy of the context State

pub fn clear_color<C: Color<T> + ?Sized, T: ?Sized>(&self, color: &C) where
    Self: Sized
[src][]

Clear the draw buffer with the passed color

pub fn clear_depth(&self, depth: f64)[src][]

Clear the depth buffer

pub fn clear_stencil(&self, stencil: i32)[src][]

Clear the stencil buffer

pub fn clear<C>(
    &self,
    color: Option<C>,
    depth: Option<f64>,
    stencil: Option<i32>
) where
    C: Borrow<[f32; 4]>, 
[src]

pub fn new_texture(&self) -> Builder<'_>[src]

pub fn new_cubemap(&self) -> Builder<'_>[src]

pub fn new_fbo(&self) -> Builder<'_>[src]

pub fn new_fbo_color_attachment(&self) -> ColorAttachmentBuilder<'_>[src]

pub fn new_fbo_depth_attachment(&self) -> DepthAttachmentBuilder<'_>[src]

pub fn new_render_buffer(&self) -> RenderBufferBuilder<'_>[src]

pub fn new_buffer(&self) -> Builder<'_>[src]

pub fn new_shared_buffer(&self) -> SharedBuilder<'_>[src]

pub fn new_vao(&self) -> Builder[src]

pub fn new_simple_vao(&self) -> Builder<'_>[src]

pub fn new_program(&self) -> Builder<'_>[src]

pub fn new_sampler(&self) -> Sampler[src]

pub fn new_timestamp_query(&self) -> TimeStamp[src]

pub fn new_duration_query(&self) -> Duration[src]

pub fn new_fence(&self) -> Fence[src]

pub fn new_debug_group(&self, id: u32, message: &str) -> DebugGroup[src]

pub fn creation_proxy(&self) -> &Rc<CreationProxy>[src]

pub fn state(&self) -> &State<'static>[src]

pub fn shallow_clone(&self) -> Context<'_, R>[src]

pub fn blit<C1, D1, C2, D2>(
    &self,
    fbo_src: &Fbo<C1, D1>,
    fbo_dst: &mut Fbo<C2, D2>,
    src_rect: &Rect,
    dst_rect: &Rect
)
[src][]

Copy the contents of the first color attachment of this Fbo to dst

From the src_rect rectangle to dst_rect.

If scissor test is enabled in this context it’ll also modify the blited area

pub fn blit_color_attachment<C1, D1, C2, D2>(
    &self,
    fbo_src: &Fbo<C1, D1>,
    fbo_dst: &mut Fbo<C2, D2>,
    attachment: u32,
    src_rect: &Rect,
    dst_rect: &Rect
)
[src][]

Copy the contents of the color specified attachment of this Fbo to dst

From the src_rect rectangle to dst_rect

If scissor test is enabled in this context it’ll also modify the blited area

pub fn blit_depth<C1, D1, C2, D2>(
    &self,
    fbo_src: &Fbo<C1, D1>,
    fbo_dst: &mut Fbo<C2, D2>,
    src_rect: &Rect,
    dst_rect: &Rect
)
[src][]

Copy the contents of the depth attachments of this Fbo to dst

From the src_rect rectangle to dst_rect

If scissor test is enabled in this context it’ll also modify the blited area

pub fn dispatch_compute<U, I>(
    &self,
    program: &Program,
    x: u32,
    y: u32,
    z: u32,
    uniforms: I
) -> Result<()> where
    U: Borrow<Uniform>,
    I: IntoIterator<Item = U>, 
[src]

impl<'c, R: RenderSurface> Context<'c, R>[src]

pub fn surface(&self) -> &R[src]

Trait Implementations

impl<'c, R: RenderSurface> Clone for Context<'c, R>[src]

impl<'c, R: RenderSurface> CreationContext for Context<'c, R>[src]

impl<'c, R: RenderSurface> CreationContextMut for Context<'c, R>[src]

impl<'c> SurfaceCreationContext for Context<'c>[src]

Auto Trait Implementations

impl<'c, R = Screen> !RefUnwindSafe for Context<'c, R>

impl<'c, R = Screen> !Send for Context<'c, R>

impl<'c, R = Screen> !Sync for Context<'c, R>

impl<'c, R> Unpin for Context<'c, R> where
    R: Unpin

impl<'c, R = Screen> !UnwindSafe for Context<'c, R>

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Any for T where
    T: Any
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Pointable for T[src]

type Init = T

The type for initializers.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.