Skip to content

Commit

Permalink
Make basis plane geometry easier to access
Browse files Browse the repository at this point in the history
  • Loading branch information
hannobraun committed Feb 28, 2024
1 parent 03d485f commit 65dffcb
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 5 deletions.
4 changes: 2 additions & 2 deletions crates/fj-core/src/algorithms/approx/curve.rs
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ mod tests {
let (surface_path, boundary) =
SurfacePath::line_from_points([[1., 1.], [2., 1.]]);
let boundary = CurveBoundary::from(boundary);
let surface = core.layers.objects.surfaces.xz_plane().geometry();
let surface = core.layers.geometry.xz_plane();

let tolerance = 1.;
let approx = (&curve, surface_path, &surface, boundary)
Expand Down Expand Up @@ -274,7 +274,7 @@ mod tests {
let surface_path =
SurfacePath::circle_from_center_and_radius([0., 0.], 1.);
let boundary = CurveBoundary::from([[0.], [TAU]]);
let surface = core.layers.objects.surfaces.xz_plane().geometry();
let surface = core.layers.geometry.xz_plane();

let tolerance = 1.;
let approx = (&curve, surface_path, &surface, boundary)
Expand Down
29 changes: 26 additions & 3 deletions crates/fj-core/src/geometry/geometry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,31 +12,39 @@ use super::{GlobalPath, SurfaceGeometry};
/// Geometric data that is associated with topological objects
pub struct Geometry {
surface: BTreeMap<HandleWrapper<Surface>, SurfaceGeometry>,

xy_plane: Handle<Surface>,
xz_plane: Handle<Surface>,
yz_plane: Handle<Surface>,
}

impl Geometry {
/// Create a new instance of `Geometry`
pub fn new(objects: &Objects) -> Self {
let mut self_ = Self {
surface: BTreeMap::new(),

xy_plane: objects.surfaces.xy_plane(),
xz_plane: objects.surfaces.xz_plane(),
yz_plane: objects.surfaces.yz_plane(),
};

self_.define_surface_inner(
objects.surfaces.xy_plane(),
self_.xy_plane.clone(),
SurfaceGeometry {
u: GlobalPath::x_axis(),
v: Vector::unit_y(),
},
);
self_.define_surface_inner(
objects.surfaces.xz_plane(),
self_.xz_plane.clone(),
SurfaceGeometry {
u: GlobalPath::x_axis(),
v: Vector::unit_z(),
},
);
self_.define_surface_inner(
objects.surfaces.yz_plane(),
self_.yz_plane.clone(),
SurfaceGeometry {
u: GlobalPath::y_axis(),
v: Vector::unit_z(),
Expand Down Expand Up @@ -65,4 +73,19 @@ impl Geometry {
.copied()
.expect("Expected geometry of surface to be defined")
}

/// Access the geometry of the xy-plane
pub fn xy_plane(&self) -> SurfaceGeometry {
self.of_surface(&self.xy_plane)
}

/// Access the geometry of the xz-plane
pub fn xz_plane(&self) -> SurfaceGeometry {
self.of_surface(&self.xz_plane)
}

/// Access the geometry of the yz-plane
pub fn yz_plane(&self) -> SurfaceGeometry {
self.of_surface(&self.yz_plane)
}
}

0 comments on commit 65dffcb

Please sign in to comment.