2025-03-06 18:01:24 -05:00
// Gridfinity Bins With A Stacking Lip
// Gridfinity is a system to help you work more efficiently. This is a system invented by Zack Freedman. There are two main components the baseplate and the bins. The components are comprised of a matrix of squares. Allowing easy stacking and expansion. This Gridfinity bins version includes a lip to allowable stacking Gridfinity bins
// Set units in millimeters (mm)
2025-05-06 08:44:03 +12:00
@settings(defaultLengthUnit = mm, kclVersion = 1.0)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Define parameters
2025-03-06 18:01:24 -05:00
binLength = 41.5
binHeight = 7.0
binBaseLength = 2.95
binTol = 0.25
binThk = 1.2
cornerRadius = 3.75
firstStep = 0.8
secondStep = 1.8
thirdStep = 2.15
magOuterDiam = 6.5
magOffset = 4.8
magDepth = 2.4
lipRadius = 0.5
lipStep1 = 1.4
lipStep2 = 1.2
lipStep3 = 0.7
lipStep4 = 1.8
lipStep5 = 1.9
// Number of bins in each direction
countBinWidth = 2
countBinLength = 3
countBinHeight = 1
// The total height of the baseplate is a summation of the vertical heights of the baseplate steps
height = firstStep + secondStep + thirdStep
lipHeight = lipStep1 + lipStep2 + lipStep3 + lipStep4 + lipStep5
2025-04-04 11:03:13 -07:00
// Define a function which builds the profile of the baseplate bin
2025-05-01 11:36:51 -05:00
fn face(@plane) {
2025-03-06 18:01:24 -05:00
faceSketch = startSketchOn(plane)
2025-04-25 16:01:35 -05:00
|> startProfile(at = [binBaseLength + binTol, 0])
2025-03-07 22:07:16 -06:00
|> yLine(length = height)
|> xLine(length = -binBaseLength)
KCL: Angled line should use keyword args (#5803)
We continue migrating KCL stdlib functions to use keyword arguments. Next up is the `angledLine` family of functions (except `angledLineThatIntersects, which will be a quick follow-up).
Before vs. after:
`angledLine({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, length = 3, tag = $edge)`
`angledLineOfXLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthX = 3, tag = $edge)`
`angledLineOfYLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthY = 3, tag = $edge)`
`angledLineToX({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteX = 3, tag = $edge)`
`angledLineToY({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteY = 3, tag = $edge)`
2025-04-09 14:55:15 -05:00
|> angledLine(angle = -45, lengthY = thirdStep)
2025-03-07 22:07:16 -06:00
|> yLine(length = -secondStep)
KCL: Angled line should use keyword args (#5803)
We continue migrating KCL stdlib functions to use keyword arguments. Next up is the `angledLine` family of functions (except `angledLineThatIntersects, which will be a quick follow-up).
Before vs. after:
`angledLine({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, length = 3, tag = $edge)`
`angledLineOfXLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthX = 3, tag = $edge)`
`angledLineOfYLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthY = 3, tag = $edge)`
`angledLineToX({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteX = 3, tag = $edge)`
`angledLineToY({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteY = 3, tag = $edge)`
2025-04-09 14:55:15 -05:00
|> angledLine(angle = -45, lengthY = firstStep)
2025-03-06 18:01:24 -05:00
|> close()
return faceSketch
}
2025-04-04 11:03:13 -07:00
// Extrude a single side of the bin
2025-03-26 08:53:34 -07:00
singleSide = extrude(face(offsetPlane(YZ, offset = cornerRadius + binTol)), length = binLength - (cornerRadius * 2))
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create the other sides of the bin by using a circular pattern
2025-03-06 18:01:24 -05:00
sides = patternCircular3d(
singleSide,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2,
(binLength + 2 * binTol) / 2,
0
],
instances = 4,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
2025-04-04 11:03:13 -07:00
// Define an axis axis000
2025-03-06 18:01:24 -05:00
axis000 = {
2025-04-03 22:44:52 +13:00
direction = [0.0, 1.0],
origin = [
cornerRadius + binTol,
cornerRadius + binTol
]
2025-03-06 18:01:24 -05:00
}
2025-04-04 11:03:13 -07:00
// Create a single corner of the bin
2025-03-26 08:53:34 -07:00
singleCorner = revolve(face(offsetPlane(YZ, offset = cornerRadius + binTol)), angle = -90, axis = axis000)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create the corners of the bin
2025-03-06 18:01:24 -05:00
corners = patternCircular3d(
singleCorner,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2,
(binLength + 2 * binTol) / 2,
0
],
instances = 4,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
2025-03-26 08:53:34 -07:00
singleBinFill = startSketchOn(XY)
2025-04-25 16:01:35 -05:00
|> startProfile(at = [
2025-03-06 18:01:24 -05:00
binBaseLength + binTol,
binBaseLength + binTol
2025-04-25 16:01:35 -05:00
])
2025-03-06 18:01:24 -05:00
|> line(end = [binLength - (binBaseLength * 2), 0], tag = $line000)
|> line(end = [0, binLength - (binBaseLength * 2)], tag = $line001)
2025-03-07 22:07:16 -06:00
|> xLine(endAbsolute = profileStartX(%), tag = $line002)
2025-03-06 18:01:24 -05:00
|> close(tag = $line003)
|> extrude(length = height)
|> fillet(
radius = firstStep,
tags = [
getNextAdjacentEdge(line000),
getPreviousAdjacentEdge(line000),
getNextAdjacentEdge(line002),
getPreviousAdjacentEdge(line002)
2025-03-26 08:53:34 -07:00
],
2025-03-06 18:01:24 -05:00
)
2025-04-14 05:58:19 -04:00
magCutout000 = startSketchOn(singleBinFill, face = START)
2025-03-06 18:01:24 -05:00
|> circle(
center = [
-magOffset - binBaseLength - binTol,
magOffset + binBaseLength + binTol
],
2025-03-26 08:53:34 -07:00
radius = magOuterDiam / 2,
2025-03-06 18:01:24 -05:00
)
|> patternCircular2d(
arcDegrees = 360,
center = [
(-binLength + 2 * binTol) / 2,
(binLength + 2 * binTol) / 2
],
instances = 4,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
|> extrude(length = -magDepth)
2025-04-04 11:03:13 -07:00
// Create the baseplate by patterning sides
2025-03-06 18:01:24 -05:00
binSides = patternLinear3d(
sides,
axis = [1.0, 0.0, 0.0],
instances = countBinWidth,
2025-03-26 08:53:34 -07:00
distance = binLength + binTol * 2,
2025-03-06 18:01:24 -05:00
)
2025-03-26 08:53:34 -07:00
|> patternLinear3d(axis = [0.0, 1.0, 0.0], instances = countBinLength, distance = binLength + binTol * 2)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create the corners of the baseplate by patterning the corners
2025-03-06 18:01:24 -05:00
binCorners = patternLinear3d(
corners,
axis = [1.0, 0.0, 0.0],
instances = countBinWidth,
2025-03-26 08:53:34 -07:00
distance = binLength + binTol * 2,
2025-03-06 18:01:24 -05:00
)
2025-03-26 08:53:34 -07:00
|> patternLinear3d(axis = [0.0, 1.0, 0.0], instances = countBinLength, distance = binLength + binTol * 2)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create the fill of the bin by patterning the corners
2025-03-06 18:01:24 -05:00
binFill = patternLinear3d(
singleBinFill,
axis = [1.0, 0.0, 0.0],
instances = countBinWidth,
2025-03-26 08:53:34 -07:00
distance = binLength + binTol * 2,
2025-03-06 18:01:24 -05:00
)
2025-03-26 08:53:34 -07:00
|> patternLinear3d(axis = [0.0, 1.0, 0.0], instances = countBinLength, distance = binLength + binTol * 2)
2025-03-06 18:01:24 -05:00
2025-03-26 08:53:34 -07:00
binTop = startSketchOn(offsetPlane(XY, offset = height))
2025-04-25 16:01:35 -05:00
|> startProfile(at = [0, 0])
2025-03-07 22:07:16 -06:00
|> xLine(length = (binLength + 2 * binTol) * countBinWidth, tag = $line010)
|> yLine(length = (binLength + 2 * binTol) * countBinLength, tag = $line011)
|> xLine(endAbsolute = profileStartX(%), tag = $line012)
2025-03-06 18:01:24 -05:00
|> close(tag = $line013)
|> extrude(length = binHeight * countBinHeight)
|> fillet(
radius = cornerRadius,
tags = [
getNextAdjacentEdge(line010),
getPreviousAdjacentEdge(line010),
getNextAdjacentEdge(line012),
getPreviousAdjacentEdge(line012)
2025-03-26 08:53:34 -07:00
],
2025-03-06 18:01:24 -05:00
)
2025-04-14 20:37:45 +12:00
|> shell(faces = [END], thickness = binThk)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Define a function which builds the profile of the baseplate bin
2025-05-01 11:36:51 -05:00
fn lipFace(@plane) {
2025-03-06 18:01:24 -05:00
faceSketch = startSketchOn(plane)
2025-04-25 16:01:35 -05:00
|> startProfile(at = [0, 0])
2025-03-07 22:07:16 -06:00
// |> yLine(length = lipHeight, tag = $line100)
2025-03-06 18:01:24 -05:00
|> line(end = [0.0, 5.792893], tag = $line000)
2025-04-18 17:40:44 -05:00
|> arc(
2025-03-06 18:01:24 -05:00
angleStart = 180.0,
angleEnd = 45.0,
2025-04-18 17:40:44 -05:00
radius = 0.500000,
tag = $arc000,
)
KCL: Angled line should use keyword args (#5803)
We continue migrating KCL stdlib functions to use keyword arguments. Next up is the `angledLine` family of functions (except `angledLineThatIntersects, which will be a quick follow-up).
Before vs. after:
`angledLine({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, length = 3, tag = $edge)`
`angledLineOfXLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthX = 3, tag = $edge)`
`angledLineOfYLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthY = 3, tag = $edge)`
`angledLineToX({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteX = 3, tag = $edge)`
`angledLineToY({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteY = 3, tag = $edge)`
2025-04-09 14:55:15 -05:00
// |> angledLine(angle = -45, lengthY = lipStep5 )
2025-03-06 18:01:24 -05:00
|> line(end = [1.046447, -1.046447], tag = $line001)
2025-03-07 22:07:16 -06:00
|> yLine(length = -lipStep4)
KCL: Angled line should use keyword args (#5803)
We continue migrating KCL stdlib functions to use keyword arguments. Next up is the `angledLine` family of functions (except `angledLineThatIntersects, which will be a quick follow-up).
Before vs. after:
`angledLine({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, length = 3, tag = $edge)`
`angledLineOfXLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthX = 3, tag = $edge)`
`angledLineOfYLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthY = 3, tag = $edge)`
`angledLineToX({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteX = 3, tag = $edge)`
`angledLineToY({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteY = 3, tag = $edge)`
2025-04-09 14:55:15 -05:00
|> angledLine(angle = -45, lengthY = lipStep3)
2025-03-07 22:07:16 -06:00
|> yLine(length = -lipStep2)
KCL: Angled line should use keyword args (#5803)
We continue migrating KCL stdlib functions to use keyword arguments. Next up is the `angledLine` family of functions (except `angledLineThatIntersects, which will be a quick follow-up).
Before vs. after:
`angledLine({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, length = 3, tag = $edge)`
`angledLineOfXLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthX = 3, tag = $edge)`
`angledLineOfYLength({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, lengthY = 3, tag = $edge)`
`angledLineToX({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteX = 3, tag = $edge)`
`angledLineToY({angle = 90, length = 3}, %, $edge)`
=> `angledLine(angle = 90, endAbsoluteY = 3, tag = $edge)`
2025-04-09 14:55:15 -05:00
|> angledLine(angle = -135, lengthY = lipStep1)
2025-03-06 18:01:24 -05:00
|> close()
return faceSketch
}
plane000 = {
2025-04-14 05:58:19 -04:00
origin = [
cornerRadius,
0.0,
height + binHeight * countBinHeight
],
xAxis = [0.0, 1.0, 0.0],
2025-04-24 22:01:27 +12:00
yAxis = [0.0, 0.0, 1.0]
2025-03-06 18:01:24 -05:00
}
plane001 = {
2025-04-14 05:58:19 -04:00
origin = [
0.0,
2025-04-24 22:01:27 +12:00
countBinLength * (binLength + 2 * binTol) - cornerRadius,
2025-04-14 05:58:19 -04:00
height + binHeight * countBinHeight
],
xAxis = [1.0, 0.0, 0.0],
2025-04-24 22:01:27 +12:00
yAxis = [0.0, 0.0, 1.0]
2025-03-06 18:01:24 -05:00
}
plane002 = {
2025-04-14 05:58:19 -04:00
origin = [
countBinWidth * (binLength + 2 * binTol) - cornerRadius,
0.0,
height + binHeight * countBinHeight
],
xAxis = [0.0, 1.0, 0.0],
2025-04-24 22:01:27 +12:00
yAxis = [0.0, 0.0, 1.0]
2025-03-06 18:01:24 -05:00
}
2025-04-04 11:03:13 -07:00
// Extrude a single side of the lip of the bin
2025-03-06 18:01:24 -05:00
lipSingleLength = extrude(lipFace(plane000), length = binLength * countBinWidth - (2 * cornerRadius) + 2 * binTol * countBinWidth)
2025-04-04 11:03:13 -07:00
// Extrude a single side of the lip of the bin
2025-03-06 18:01:24 -05:00
lipSingleWidth = extrude(lipFace(plane001), length = binLength * countBinLength - (2 * cornerRadius) + 2 * binTol * countBinLength)
2025-04-04 11:03:13 -07:00
// Create the other sides of the lips by using a circular pattern
2025-03-06 18:01:24 -05:00
lipLengths = patternCircular3d(
lipSingleLength,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2 * countBinWidth,
(binLength + 2 * binTol) / 2 * countBinLength,
0
],
instances = 2,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
2025-04-04 11:03:13 -07:00
// Create the other sides of the lips by using a circular pattern
2025-03-06 18:01:24 -05:00
lipWidths = patternCircular3d(
lipSingleWidth,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2 * countBinWidth,
(binLength + 2 * binTol) / 2 * countBinLength,
0
],
instances = 2,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
2025-04-04 11:03:13 -07:00
// Define an axis axis000
2025-03-06 18:01:24 -05:00
axis001 = {
2025-04-03 22:44:52 +13:00
direction = [0.0, 1.0],
origin = [cornerRadius, cornerRadius]
2025-03-06 18:01:24 -05:00
}
2025-04-04 11:03:13 -07:00
// Create a single corner of the bin
2025-03-18 20:34:44 -07:00
lipSingleLengthCorner = revolve(lipFace(plane000), angle = -90, axis = axis001)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create a single corner of the bin
2025-03-18 20:34:44 -07:00
lipSingleWidthCorner = revolve(lipFace(plane002), angle = 90, axis = axis001)
2025-03-06 18:01:24 -05:00
2025-04-04 11:03:13 -07:00
// Create the corners of the bin
2025-03-06 18:01:24 -05:00
lipCorners000 = patternCircular3d(
lipSingleLengthCorner,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2 * countBinWidth,
(binLength + 2 * binTol) / 2 * countBinLength,
0
],
instances = 2,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)
2025-04-04 11:03:13 -07:00
// Create the corners of the bin
2025-03-06 18:01:24 -05:00
lipCorners001 = patternCircular3d(
lipSingleWidthCorner,
arcDegrees = 360,
axis = [0, 0, 1],
center = [
(binLength + 2 * binTol) / 2 * countBinWidth,
(binLength + 2 * binTol) / 2 * countBinLength,
0
],
instances = 2,
2025-03-26 08:53:34 -07:00
rotateDuplicates = true,
2025-03-06 18:01:24 -05:00
)