more rust fixes
This commit is contained in:
@ -194,18 +194,69 @@ async fn inner_circle_three_point(
|
|||||||
args: Args,
|
args: Args,
|
||||||
) -> Result<Sketch, KclError> {
|
) -> Result<Sketch, KclError> {
|
||||||
let center = calculate_circle_center(p1, p2, p3);
|
let center = calculate_circle_center(p1, p2, p3);
|
||||||
inner_circle(
|
// It can be the distance to any of the 3 points - they all lay on the circumference.
|
||||||
CircleData {
|
let radius = distance(center.into(), p2.into());
|
||||||
center,
|
|
||||||
// It can be the distance to any of the 3 points - they all lay on the circumference.
|
let sketch_surface = match sketch_surface_or_group {
|
||||||
radius: distance(center.into(), p2.into()),
|
SketchOrSurface::SketchSurface(surface) => surface,
|
||||||
},
|
SketchOrSurface::Sketch(group) => group.on,
|
||||||
sketch_surface_or_group,
|
};
|
||||||
tag,
|
let sketch = crate::std::sketch::inner_start_profile_at(
|
||||||
|
[center[0] + radius, center[1]],
|
||||||
|
sketch_surface,
|
||||||
|
None,
|
||||||
exec_state,
|
exec_state,
|
||||||
args,
|
args.clone(),
|
||||||
)
|
)
|
||||||
.await
|
.await?;
|
||||||
|
|
||||||
|
let from = [center[0] + radius, center[1]];
|
||||||
|
let angle_start = Angle::zero();
|
||||||
|
let angle_end = Angle::turn();
|
||||||
|
|
||||||
|
let id = exec_state.next_uuid();
|
||||||
|
|
||||||
|
args.batch_modeling_cmd(
|
||||||
|
id,
|
||||||
|
ModelingCmd::from(mcmd::ExtendPath {
|
||||||
|
path: sketch.id.into(),
|
||||||
|
segment: PathSegment::Arc {
|
||||||
|
start: angle_start,
|
||||||
|
end: angle_end,
|
||||||
|
center: KPoint2d::from(center).map(LengthUnit),
|
||||||
|
radius: radius.into(),
|
||||||
|
relative: false,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
let current_path = Path::CircleThreePoint {
|
||||||
|
base: BasePath {
|
||||||
|
from,
|
||||||
|
to: from,
|
||||||
|
tag: tag.clone(),
|
||||||
|
geo_meta: GeoMeta {
|
||||||
|
id,
|
||||||
|
metadata: args.source_range.into(),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
p1,
|
||||||
|
p2,
|
||||||
|
p3,
|
||||||
|
};
|
||||||
|
|
||||||
|
let mut new_sketch = sketch.clone();
|
||||||
|
if let Some(tag) = &tag {
|
||||||
|
new_sketch.add_tag(tag, ¤t_path);
|
||||||
|
}
|
||||||
|
|
||||||
|
new_sketch.paths.push(current_path);
|
||||||
|
|
||||||
|
args.batch_modeling_cmd(id, ModelingCmd::from(mcmd::ClosePath { path_id: new_sketch.id }))
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
Ok(new_sketch)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Type of the polygon
|
/// Type of the polygon
|
||||||
|
|||||||
Reference in New Issue
Block a user