forked from StrafesNET/strafe-project
integer types for Model
This commit is contained in:
parent
4d62042549
commit
bcd421c4dd
26
src/model.rs
26
src/model.rs
@ -1,10 +1,10 @@
|
|||||||
use crate::integer::{Unit32Vec3,Planar64,Planar64Vec3,Planar64Affine3};
|
use crate::integer::{Planar64,Planar64Vec3,Planar64Affine3};
|
||||||
pub struct TextureCoordinate([f32;2]);
|
pub type TextureCoordinate=glam::Vec2;
|
||||||
pub struct Color4(glam::Vec4);
|
pub type Color4=glam::Vec4;
|
||||||
|
|
||||||
pub struct ModelVertex {
|
pub struct ModelVertex {
|
||||||
pub pos:Planar64Vec3,
|
pub pos:Planar64Vec3,
|
||||||
pub normal:Unit32Vec3,
|
pub normal:Planar64Vec3,
|
||||||
pub tex:TextureCoordinate,
|
pub tex:TextureCoordinate,
|
||||||
pub color:Color4,
|
pub color:Color4,
|
||||||
}
|
}
|
||||||
@ -23,10 +23,10 @@ pub struct IndexedGroup{
|
|||||||
pub polys:Vec<IndexedPolygon>,
|
pub polys:Vec<IndexedPolygon>,
|
||||||
}
|
}
|
||||||
pub struct IndexedModel{
|
pub struct IndexedModel{
|
||||||
pub unique_pos:Vec<[f32; 3]>,
|
pub unique_pos:Vec<Planar64Vec3>,
|
||||||
pub unique_tex:Vec<[f32; 2]>,
|
pub unique_normal:Vec<Planar64Vec3>,
|
||||||
pub unique_normal:Vec<[f32; 3]>,
|
pub unique_tex:Vec<TextureCoordinate>,
|
||||||
pub unique_color:Vec<[f32; 4]>,
|
pub unique_color:Vec<Color4>,
|
||||||
pub unique_vertices:Vec<IndexedVertex>,
|
pub unique_vertices:Vec<IndexedVertex>,
|
||||||
pub groups: Vec<IndexedGroup>,
|
pub groups: Vec<IndexedGroup>,
|
||||||
pub instances:Vec<ModelInstance>,
|
pub instances:Vec<ModelInstance>,
|
||||||
@ -41,7 +41,7 @@ pub struct ModelInstance{
|
|||||||
impl std::default::Default for ModelInstance{
|
impl std::default::Default for ModelInstance{
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self{
|
Self{
|
||||||
color:Color4(glam::Vec4::ONE),
|
color:Color4::ONE,
|
||||||
transform:Default::default(),
|
transform:Default::default(),
|
||||||
attributes:Default::default(),
|
attributes:Default::default(),
|
||||||
temp_indexing:Default::default(),
|
temp_indexing:Default::default(),
|
||||||
@ -203,7 +203,7 @@ impl std::default::Default for CollisionAttributes{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn generate_indexed_model_list_from_obj(data:obj::ObjData,color:[f32;4]) -> Vec<IndexedModel>{
|
pub fn generate_indexed_model_list_from_obj(data:obj::ObjData,color:Color4)->Vec<IndexedModel>{
|
||||||
let mut unique_vertex_index = std::collections::HashMap::<obj::IndexTuple,u32>::new();
|
let mut unique_vertex_index = std::collections::HashMap::<obj::IndexTuple,u32>::new();
|
||||||
return data.objects.iter().map(|object|{
|
return data.objects.iter().map(|object|{
|
||||||
unique_vertex_index.clear();
|
unique_vertex_index.clear();
|
||||||
@ -233,9 +233,9 @@ pub fn generate_indexed_model_list_from_obj(data:obj::ObjData,color:[f32;4]) ->
|
|||||||
}
|
}
|
||||||
}).collect();
|
}).collect();
|
||||||
IndexedModel{
|
IndexedModel{
|
||||||
unique_pos: data.position.clone(),
|
unique_pos: data.position.iter().map(|&v|Planar64Vec3::try_from(v).unwrap()).collect(),
|
||||||
unique_tex: data.texture.clone(),
|
unique_tex: data.texture.iter().map(|&v|TextureCoordinate::from_array(v)).collect(),
|
||||||
unique_normal: data.normal.clone(),
|
unique_normal: data.normal.iter().map(|&v|Planar64Vec3::try_from(v).unwrap()).collect(),
|
||||||
unique_color: vec![color],
|
unique_color: vec![color],
|
||||||
unique_vertices,
|
unique_vertices,
|
||||||
groups,
|
groups,
|
||||||
|
Loading…
Reference in New Issue
Block a user