From a2508f535ec0c69e9fa3c62e5e3371a780ff42be Mon Sep 17 00:00:00 2001 From: Kevin Reid Date: Mon, 18 Dec 2023 11:46:52 -0800 Subject: [PATCH] Use `Root::push()` in export example. This way, all `Index`es are guaranteed valid and the dependencies between the glTF objects are reflected in the program's variables. I have manually tested that the output of the example is valid glTF. --- examples/export/main.rs | 58 ++++++++++++++++++----------------------- 1 file changed, 26 insertions(+), 32 deletions(-) diff --git a/examples/export/main.rs b/examples/export/main.rs index 919d67b2..d7c17ccf 100644 --- a/examples/export/main.rs +++ b/examples/export/main.rs @@ -72,8 +72,10 @@ fn export(output: Output) { let (min, max) = bounding_coords(&triangle_vertices); + let mut root = gltf_json::Root::default(); + let buffer_length = triangle_vertices.len() * mem::size_of::(); - let buffer = json::Buffer { + let buffer = root.push(json::Buffer { byte_length: USize64::from(buffer_length), extensions: Default::default(), extras: Default::default(), @@ -83,19 +85,19 @@ fn export(output: Output) { } else { None }, - }; - let buffer_view = json::buffer::View { - buffer: json::Index::new(0), - byte_length: buffer.byte_length, + }); + let buffer_view = root.push(json::buffer::View { + buffer, + byte_length: USize64::from(buffer_length), byte_offset: None, byte_stride: Some(json::buffer::Stride(mem::size_of::())), extensions: Default::default(), extras: Default::default(), name: None, target: Some(Valid(json::buffer::Target::ArrayBuffer)), - }; - let positions = json::Accessor { - buffer_view: Some(json::Index::new(0)), + }); + let positions = root.push(json::Accessor { + buffer_view: Some(buffer_view), byte_offset: Some(USize64(0)), count: USize64::from(triangle_vertices.len()), component_type: Valid(json::accessor::GenericComponentType( @@ -109,9 +111,9 @@ fn export(output: Output) { name: None, normalized: false, sparse: None, - }; - let colors = json::Accessor { - buffer_view: Some(json::Index::new(0)), + }); + let colors = root.push(json::Accessor { + buffer_view: Some(buffer_view), byte_offset: Some(USize64::from(3 * mem::size_of::())), count: USize64::from(triangle_vertices.len()), component_type: Valid(json::accessor::GenericComponentType( @@ -125,13 +127,13 @@ fn export(output: Output) { name: None, normalized: false, sparse: None, - }; + }); let primitive = json::mesh::Primitive { attributes: { let mut map = std::collections::BTreeMap::new(); - map.insert(Valid(json::mesh::Semantic::Positions), json::Index::new(0)); - map.insert(Valid(json::mesh::Semantic::Colors(0)), json::Index::new(1)); + map.insert(Valid(json::mesh::Semantic::Positions), positions); + map.insert(Valid(json::mesh::Semantic::Colors(0)), colors); map }, extensions: Default::default(), @@ -142,43 +144,35 @@ fn export(output: Output) { targets: None, }; - let mesh = json::Mesh { + let mesh = root.push(json::Mesh { extensions: Default::default(), extras: Default::default(), name: None, primitives: vec![primitive], weights: None, - }; + }); - let node = json::Node { + let node = root.push(json::Node { camera: None, children: None, extensions: Default::default(), extras: Default::default(), matrix: None, - mesh: Some(json::Index::new(0)), + mesh: Some(mesh), name: None, rotation: None, scale: None, translation: None, skin: None, weights: None, - }; + }); - let root = json::Root { - accessors: vec![positions, colors], - buffers: vec![buffer], - buffer_views: vec![buffer_view], - meshes: vec![mesh], + root.push(json::Scene { + extensions: Default::default(), + extras: Default::default(), + name: None, nodes: vec![node], - scenes: vec![json::Scene { - extensions: Default::default(), - extras: Default::default(), - name: None, - nodes: vec![json::Index::new(0)], - }], - ..Default::default() - }; + }); match output { Output::Standard => {