-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Add a subtract function for faces * Add an example file for a zotac zbox PC mount
- Loading branch information
Showing
3 changed files
with
108 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
use glam::dvec3; | ||
use opencascade::{ | ||
primitives::{Direction, Shape}, | ||
workplane::Workplane, | ||
}; | ||
|
||
pub fn shape() -> Shape { | ||
// The origin of the coordinate system is the closest bottom left corner of | ||
// the PC box, when viewing its ports from behind. | ||
let case_thickness = 2.0; | ||
let case_width = 212.0; | ||
let case_height = 60.0; | ||
let case_depth = 64.0; // Not measured, arbitrary value | ||
|
||
let hook_thickness = 3.0; | ||
let wire_gap = 2.6; | ||
|
||
let case_box = Shape::box_with_dimensions(case_width, case_height, case_depth); | ||
|
||
let back_face = case_box.faces().farthest(Direction::PosY); | ||
|
||
let case_box = case_box.hollow(case_thickness, [back_face]); | ||
|
||
let port_cutout = Workplane::xz() | ||
.sketch() | ||
.move_to(10.0, 9.0) | ||
.line_to(10.0, 55.0) | ||
.line_to(200.0, 55.0) | ||
.line_to(200.0, 9.0) | ||
.close() | ||
.to_face(); | ||
|
||
let cutout = port_cutout.extrude(dvec3(0.0, -case_thickness, 0.0)).into(); | ||
|
||
let mut case_box = case_box.subtract(&cutout); | ||
|
||
// Add the back hooks | ||
let bottom_face = case_box.faces().farthest(Direction::NegZ); | ||
|
||
for x_offset in [-75.0, -25.0, 25.0, 75.0] { | ||
let mut hook: Shape = bottom_face | ||
.workplane() | ||
.translated(dvec3(x_offset, -20.0, 0.0)) | ||
.rect(40.0, 20.0) | ||
.to_face() | ||
.extrude(dvec3(0.0, 0.0, -(hook_thickness + wire_gap))) | ||
.into(); | ||
|
||
let hook_bottom = hook.faces().farthest(Direction::NegY); | ||
|
||
let hook_descent = hook_bottom | ||
.workplane() | ||
.translated(dvec3(0.0, -(hook_thickness + wire_gap) / 2.0 + hook_thickness / 2.0, 0.0)) | ||
.rect(40.0, hook_thickness) | ||
.to_face() | ||
.extrude(dvec3(0.0, -20.0, 0.0)) | ||
.into(); | ||
|
||
hook = hook.union(&hook_descent).into(); | ||
|
||
let bottom_hook_edges = | ||
hook.faces().farthest(Direction::NegY).edges().parallel_to(Direction::PosZ); | ||
hook = hook.fillet_edges(10.0, bottom_hook_edges); | ||
|
||
case_box = case_box.union(&hook); | ||
} | ||
|
||
// Punch some holes in the back for optional zipties | ||
for x_offset in [-100.0, -50.0, 0.0, 50.0, 100.0] { | ||
let ziptie_hole = bottom_face | ||
.workplane() | ||
.translated(dvec3(x_offset, -20.0, 0.0)) | ||
.circle(0.0, 0.0, 2.25) | ||
.to_face() | ||
.extrude(dvec3(0.0, 0.0, 10.0)) | ||
.into(); | ||
|
||
case_box = case_box.subtract(&ziptie_hole) | ||
} | ||
|
||
// Cut out a circle on the front | ||
let front_face = case_box | ||
.faces() | ||
.farthest(Direction::PosZ) | ||
.workplane() | ||
.translated(dvec3(0.0, 75.0, 0.0)) | ||
.circle(0.0, 0.0, 100.0) | ||
.to_face(); | ||
|
||
front_face.subtractive_extrude(&case_box, -case_thickness) | ||
} |