use super::{gfx_backend, mesh::Mesh, Pipeline, RenderError}; use gfx::{ buffer::Role, memory::{Bind, Usage}, traits::FactoryExt, Factory, }; use std::ops::Range; /// Represents a mesh that has been sent to the GPU. pub struct Model { pub vbuf: gfx::handle::Buffer, pub vertex_range: Range, } impl Model

{ pub fn new(factory: &mut gfx_backend::Factory, mesh: &Mesh

) -> Self { Self { vbuf: factory.create_vertex_buffer(mesh.vertices()), vertex_range: 0..mesh.vertices().len() as u32, } } pub fn vertex_range(&self) -> Range { self.vertex_range.clone() } /// Create a model with a slice of a portion of this model to send to the /// renderer. pub fn submodel(&self, vertex_range: Range) -> Model

{ Model { vbuf: self.vbuf.clone(), vertex_range, } } } /// Represents a mesh on the GPU which can be updated dynamically. pub struct DynamicModel { pub vbuf: gfx::handle::Buffer, } impl DynamicModel

{ pub fn new(factory: &mut gfx_backend::Factory, size: usize) -> Result { Ok(Self { vbuf: factory .create_buffer(size, Role::Vertex, Usage::Dynamic, Bind::empty()) .map_err(RenderError::BufferCreationError)?, }) } /// Create a model with a slice of a portion of this model to send to the /// renderer. pub fn submodel(&self, vertex_range: Range) -> Model

{ Model { vbuf: self.vbuf.clone(), vertex_range, } } pub fn update( &self, encoder: &mut gfx::Encoder, mesh: &Mesh

, offset: usize, ) -> Result<(), RenderError> { encoder .update_buffer(&self.vbuf, mesh.vertices(), offset) .map_err(RenderError::UpdateError) } }