parry3d/transformation/to_trimesh/
cylinder_to_trimesh.rsuse crate::math::Real;
use crate::shape::Cylinder;
use crate::transformation::utils;
use na::{self, Point3, RealField, Vector3};
impl Cylinder {
pub fn to_trimesh(&self, nsubdiv: u32) -> (Vec<Point3<Real>>, Vec<[u32; 3]>) {
let diameter = self.radius * 2.0;
let height = self.half_height * 2.0;
let scale = Vector3::new(diameter, height, diameter);
let (vtx, idx) = unit_cylinder(nsubdiv);
(utils::scaled(vtx, scale), idx)
}
}
fn unit_cylinder(nsubdiv: u32) -> (Vec<Point3<Real>>, Vec<[u32; 3]>) {
let two_pi = Real::two_pi();
let invsubdiv = 1.0 / (nsubdiv as Real);
let dtheta = two_pi * invsubdiv;
let mut coords = Vec::new();
let mut indices = Vec::new();
utils::push_circle(
na::convert(0.5),
nsubdiv,
dtheta,
na::convert(-0.5),
&mut coords,
);
utils::push_circle(
na::convert(0.5),
nsubdiv,
dtheta,
na::convert(0.5),
&mut coords,
);
utils::push_ring_indices(0, nsubdiv, nsubdiv, &mut indices);
utils::push_filled_circle_indices(0, nsubdiv, &mut indices);
utils::push_filled_circle_indices(nsubdiv, nsubdiv, &mut indices);
let len = indices.len();
let bottom_start_id = len - (nsubdiv as usize - 2);
utils::reverse_clockwising(&mut indices[bottom_start_id..]);
(coords, indices)
}