Struct citro3d::Instance

source ·
#[non_exhaustive]
pub struct Instance { /* private fields */ }
Expand description

The single instance for using citro3d. This is the base type that an application should instantiate to use this library.

Implementations§

source§

impl Instance

source

pub fn new() -> Result<Self>

Initialize the default citro3d instance.

§Errors

Fails if citro3d cannot be initialized.

source

pub fn with_cmdbuf_size(size: usize) -> Result<Self>

Initialize the instance with a specified command buffer size.

§Errors

Fails if citro3d cannot be initialized.

source

pub fn render_target<'screen>( &self, width: usize, height: usize, screen: RefMut<'screen, dyn Screen>, depth_format: Option<DepthFormat> ) -> Result<Target<'screen>>

Create a new render target with the specified size, color format, and depth format.

§Errors

Fails if the target could not be created with the given parameters.

source

pub fn select_render_target(&mut self, target: &Target<'_>) -> Result<()>

Select the given render target for drawing the frame. This must be called as pare of a render call (i.e. within the call to render_frame_with).

§Errors

Fails if the given target cannot be used for drawing, or called outside the context of a frame render.

source

pub fn render_frame_with(&mut self, f: impl FnOnce(&mut Self))

Render a frame. The passed in function/closure can mutate the instance, such as to select a render target or bind a new shader program.

source

pub fn buffer_info(&self) -> Option<Info>

Get the buffer info being used, if it exists. Note that the resulting buffer::Info is copied from the one currently in use.

source

pub fn set_buffer_info(&mut self, buffer_info: &Info)

Set the buffer info to use for any following draw calls.

source

pub fn attr_info(&self) -> Option<Info>

Get the attribute info being used, if it exists. Note that the resulting attrib::Info is copied from the one currently in use.

source

pub fn set_attr_info(&mut self, attr_info: &Info)

Set the attribute info to use for any following draw calls.

source

pub fn draw_arrays(&mut self, primitive: Primitive, vbo_data: Slice<'_>)

Render primitives from the current vertex array buffer.

source

pub fn bind_program(&mut self, program: &Program)

Use the given shader::Program for subsequent draw calls.

source

pub fn bind_vertex_uniform(&mut self, index: Index, uniform: impl Into<Uniform>)

Bind a uniform to the given index in the vertex shader for the next draw call.

§Example
let idx = uniform::Index::from(0);
let mtx = Matrix4::identity();
instance.bind_vertex_uniform(idx, &mtx);
source

pub fn bind_geometry_uniform( &mut self, index: Index, uniform: impl Into<Uniform> )

Bind a uniform to the given index in the geometry shader for the next draw call.

§Example
let idx = uniform::Index::from(0);
let mtx = Matrix4::identity();
instance.bind_geometry_uniform(idx, &mtx);
source

pub fn texenv(&mut self, stage: Stage) -> &mut TexEnv

Retrieve the TexEnv for the given stage, initializing it first if necessary.

§Example
let stage0 = texenv::Stage::new(0).unwrap();
let texenv0 = instance.texenv(stage0);

Trait Implementations§

source§

impl Debug for Instance

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Drop for Instance

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl !RefUnwindSafe for Instance

§

impl !Send for Instance

§

impl !Sync for Instance

§

impl Unpin for Instance

§

impl UnwindSafe for Instance

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.