gstreamer_gl::prelude

Trait GLFilterExt

Source
pub trait GLFilterExt: IsA<GLFilter> + 'static {
    // Provided methods
    fn draw_fullscreen_quad(&self) { ... }
    fn filter_texture(
        &self,
        input: &Buffer,
        output: &Buffer,
    ) -> Result<(), BoolError> { ... }
    fn render_to_target<P: FnMut(&GLFilter, &GLMemory) -> bool>(
        &self,
        input: &GLMemory,
        output: &GLMemory,
        func: P,
    ) -> Result<(), BoolError> { ... }
    fn render_to_target_with_shader(
        &self,
        input: &GLMemory,
        output: &GLMemory,
        shader: &GLShader,
    ) { ... }
}
Expand description

Trait containing all GLFilter methods.

§Implementors

GLFilter

Provided Methods§

Source

fn draw_fullscreen_quad(&self)

Render a fullscreen quad using the current GL state. The only GL state this modifies is the necessary vertex/index buffers and, if necessary, a Vertex Array Object for drawing a fullscreen quad. Framebuffer state, any shaders, viewport state, etc must be setup by the caller.

Source

fn filter_texture( &self, input: &Buffer, output: &Buffer, ) -> Result<(), BoolError>

Calls filter_texture vfunc with correctly mapped GstGLMemorys

§input

an input buffer

§output

an output buffer

§Returns

whether the transformation succeeded

Source

fn render_to_target<P: FnMut(&GLFilter, &GLMemory) -> bool>( &self, input: &GLMemory, output: &GLMemory, func: P, ) -> Result<(), BoolError>

Transforms input into output using func on through FBO.

§input

the input texture

§output

the output texture

§func

the function to transform input into output. called with data

§Returns

the return value of func

Source

fn render_to_target_with_shader( &self, input: &GLMemory, output: &GLMemory, shader: &GLShader, )

Transforms input into output using shader with a FBO.

See also: render_to_target()

§input

the input texture

§output

the output texture

§shader

the shader to use.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§