Extrusion width change
37
docs/baseplates.md
Normal file
|
@ -0,0 +1,37 @@
|
|||
# gridfinity-rebuilt-baseplate
|
||||
|
||||
To round out the rebuilt catalog, we have baseplates. Originally, baseplates were not included as there was not anything really interesting to parameterize, unlike with bins. However, upon closer inspection, there is a couple things that would make peoples' lives easier. For instance, what is called here the "skeletonized" style, in that the baseplate is still thick to allow for magnets, but the center portion is removed. Additionally, being able to generate spacers for the sides of the bases, so that they fit perfectly inside your drawers.
|
||||
|
||||
![Bin](images/baseplate.gif)
|
||||
|
||||
## Script Parameters
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>=0 \| n∈R } | number of bases along the x-axis<br> If set to zero, will fill with as many <br>bases that fit within `distancex`
|
||||
gridy | { n>=0 \| n∈R } | number of bases along the y-axis<br> If set to zero, will fill with as many <br>bases that fit within `distancey`
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
distancex | { n>0 \| n∈R } | minimum length of baseplate along x <br>alternatively, how large is the drawer along x <br>(leave zero to ignore)
|
||||
distancey | { n>0 \| n∈R } | minimum length of baseplate along y <br>alternatively, how large is the drawer along y <br>(leave zero to ignore)
|
||||
style_plate | { 0, 1, 2 } | the style of baseplate <br> • (0) thin (minimum material, only outline) <br> • (1) weighted (thick with space for tire iron) <br> • (2) skeletonized (thick, center hollowed)
|
||||
enable_magnet | boolean | toggle hole for magnet on top
|
||||
style_hole | { 0, 1, 2 } | the style of holes underneath the baseplate, if applicable <br> • (0) none <br> • (1) countersink <br> • (2) counterbore
|
||||
|
||||
## Modules
|
||||
|
||||
### gridfinityBaseplate
|
||||
|
||||
Generates a baseplate to use with gridfinity bins.
|
||||
|
||||
** `gridfinityBaseplate(gridx, gridy, length, distancex, distancey, style_plate, enable_magnet, style_hole)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>=0 \| n∈R } | number of bases along the x-axis<br> If set to zero, will fill with as many <br>bases that fit within `distancex`
|
||||
gridy | { n>=0 \| n∈R } | number of bases along the y-axis<br> If set to zero, will fill with as many <br>bases that fit within `distancey`
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
distancex | { n>0 \| n∈R } | minimum length of baseplate along x <br>alternatively, how large is the drawer along x <br>(leave zero to ignore)
|
||||
distancey | { n>0 \| n∈R } | minimum length of baseplate along y <br>alternatively, how large is the drawer along y <br>(leave zero to ignore)
|
||||
style_plate | { 0, 1, 2 } | the style of baseplate <br> • (0) thin (minimum material, only outline) <br> • (1) weighted (thick with space for tire iron) <br> • (2) skeletonized (thick, center hollowed)
|
||||
enable_magnet | boolean | toggle hole for magnet on top
|
||||
style_hole | { 0, 1, 2 } | the style of holes underneath the baseplate, if applicable <br> • (0) none <br> • (1) countersink <br> • (2) counterbore
|
172
docs/bins.md
Normal file
|
@ -0,0 +1,172 @@
|
|||
# gridfinity-rebuilt-bins
|
||||
|
||||
Generates stock bins, with a great number of variations.
|
||||
|
||||
![Bin](images/custom_dimension.gif)
|
||||
|
||||
## Script Parameters
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
gridz | { n>0 \| n∈R } | bin height. See bin height information and "gridz_define" below.
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
divx | { n>0 \| n∈Z } | number of compartments along X
|
||||
divy | { n>0 \| n∈Z } | number of compartments along Y
|
||||
enable_scoop | boolean | toggles the fillet on bottom edge for easy removal of items
|
||||
enable_zsnap | boolean | automatically snap the bin size to the nearest 7mm increment. <br> default: true
|
||||
enable_lip | boolean | if you are not stacking the bin, you can disable the top lip <br> to save space. default: true
|
||||
gridz_define | { n>0 \| n∈R } | determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters
|
||||
height_internal | { n>0 \| n∈R } | height of the internal block. <br> Can be lower than bin height to save filament on custom bins. <br> default of 0 means use the calculated height.
|
||||
style_tab | { 0, 1, 2, 3, 4, 5 } | how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs
|
||||
style_hole | { 0, 1, 2, 3 } | the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit
|
||||
div_base_x | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
div_base_y | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
|
||||
<br>
|
||||
|
||||
## Modules
|
||||
|
||||
---
|
||||
|
||||
### gridfinityInit
|
||||
|
||||
Initializes the top part of the bin (walls and solid section). All bins have to use this module, and have the compartments cut out from it.
|
||||
|
||||
** `gridfinityInit (gridx, gridy, height, height_internal, length)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
height | { n>0 \| n∈R } | height of the bin, in millimeters (but not exactly). <br> See the `height()` function for more info.
|
||||
height_internal | { n>0 \| n∈R } | height of the internal block. <br> Can be lower than bin height to save filament on custom bins. <br> default of 0 means use the calculated height.
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
|
||||
```
|
||||
// Example: generate a 3x3x6 bin with a 42mm unit size
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cutEqual(n_divx = 3, n_divy = 3, style_tab = 0, enable_scoop = true);
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### height
|
||||
|
||||
Calculates the proper height for bins.
|
||||
|
||||
** `height (gridz, gridz_define, enable_lip, enable_zsnap)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridz | { n>0 \| n∈R } | bin height. See bin height information and "gridz_define" below.
|
||||
gridz_define | { n>0 \| n∈R } | determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters
|
||||
enable_lip | boolean | if you are not stacking the bin, you can disable the top lip <br> to save space. default: true
|
||||
enable_zsnap | boolean | automatically snap the bin size to the nearest 7mm increment. <br> default: true
|
||||
|
||||
```
|
||||
// Example: height for a 6 unit high bin
|
||||
height(6);
|
||||
|
||||
// Example: height for a bin that can fit (at maximum) a 30mm high object inside
|
||||
height(30, 1, true, false);
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### gridfinityBase
|
||||
|
||||
Generates the bases for bins. Has various different hole styles, and can be subdivided.
|
||||
|
||||
** `gridfinityBase (gridx, gridy, length, div_base_x, div_base_y, style_hole)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. default: 42
|
||||
div_base_x | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. 0 means automatically guess the division)
|
||||
div_base_y | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. 0 means automatically guess the division)
|
||||
style_hole | { 0, 1, 2, 3 } | the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit
|
||||
|
||||
```
|
||||
// Example: generate a 3x3 base with a 42mm unit size and clean magnet holes
|
||||
gridfinityBase(3, 3, 42, 0, 0, 1);
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### cutEqual
|
||||
|
||||
Generates the "traditional" bin cutters. It is a utility function that creates evenly distributed compartments.
|
||||
|
||||
** `cutEqual (n_divx, n_divy, style_tab, enable_scoop)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
n_divx | { n>0 \| n∈Z } | number of compartments along X
|
||||
n_divy | { n>0 \| n∈Z } | number of compartments along Y
|
||||
style_tab | { 0, 1, 2, 3, 4, 5 } | how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs
|
||||
enable_scoop | boolean | toggles the fillet on bottom edge for easy removal of items
|
||||
|
||||
```
|
||||
// Example: this generates 9 compartments in a 3x3 grid, and all compartments have a full tab and a scoop
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cutEqual(n_divx = 3, n_divy = 3, style_tab = 0, enable_scoop = true);
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### cut
|
||||
|
||||
Cuts a single compartment into the bin at the provided location with the provided attributes. The coordinate system for compartments originates (0,0) at the bottom left corner of the bin, where 1 unit is the length of 1 base. Positive X and positive Y are in the same direction as the global coordinate system.
|
||||
|
||||
** `cut (x, y, w, h, t, s)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
x | { n>=0 \| n∈R } | X coordinate of the compartment <br>(position of left edge of compartment)
|
||||
y | { n>=0 \| n∈R } | Y coordinate of the compartment <br>(position of bottom edge of compartment)
|
||||
w | { n>0 \| n∈R } | Width of the compartment, in base units <br>(1 unit = 1 `length`)
|
||||
h | { n>0 \| n∈R } | Height of the compartment, in base units <br>(1 unit = 1 `length`)
|
||||
style_tab | { 0, 1, 2, 3, 4, 5 } | how the tabs for labels are generated for this compartment. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs
|
||||
s | boolean | toggles the fillet on bottom edge for easy removal of items, <br> only for this specific compartment
|
||||
|
||||
```
|
||||
// Example:
|
||||
// this cuts two compartments that are both 1 wide and 2 high.
|
||||
// One is on the bottom left, and the other is at the top right.
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cut(0, 0, 1, 2, 0, true);
|
||||
cut(2, 1, 1, 2, 0, true);
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### cut_move
|
||||
|
||||
Moves all of its children from the global origin to the center of the area that a compartment would normally fill, and uses them to cut from the bin. This allows you to easily make custom cutouts in the bin.
|
||||
|
||||
** `cut_move (x, y, w, h)` **
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
x | { n>=0 \| n∈R } | X coordinate of the area (position of left edge)
|
||||
y | { n>=0 \| n∈R } | Y coordinate of the area (position of bottom edge)
|
||||
w | { n>0 \| n∈R } | Width of the area, in base units (1 unit = 1 `length`)
|
||||
h | { n>0 \| n∈R } | Height of the area, in base units (1 unit = 1 `length`)
|
||||
|
||||
```
|
||||
// Example:
|
||||
// cuts a cylindrical hole of radius 5
|
||||
// hole center is located 1/2 units from the right edge of the bin, and 1 unit from the top
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cut_move(x=2, y=1, w=1, h=2) {
|
||||
cylinder(r=5, h=100, center=true);
|
||||
}
|
||||
}
|
||||
```
|
38
docs/constants.md
Normal file
|
@ -0,0 +1,38 @@
|
|||
# gridfinity-rebuilt-constants
|
||||
|
||||
This file contains dimensions that are critical to the constructiuon of the other models, but are not values that often need to be changed. Thus, they were outsourced to this file such that the rest of the files would retain parity. All values here have the same range, this is positive real numbers. Some can be zero, but that may result in strange or invalid geometry,
|
||||
|
||||
Parameter | Description
|
||||
--- | ------
|
||||
h_base | height of the base
|
||||
r_base| outside rounded radius of bin
|
||||
r_c1 | lower base chamfer "radius"
|
||||
r_c2 | upper base chamfer "radius"
|
||||
h_bot| bottom thiccness of bin
|
||||
r_fo1| outside radii 1
|
||||
r_fo2| outside radii 2
|
||||
r_fo3 | outside radii 3
|
||||
r_hole1| screw hole radius
|
||||
r_hole2| magnet hole radius
|
||||
d_hole| center-to-center distance between holes
|
||||
h_hole| magnet hole depth
|
||||
h_slit| slit depth (printer layer height)
|
||||
r_f1| top edge fillet radius
|
||||
r_f2 | internal fillet radius
|
||||
d_div | width of divider between compartments
|
||||
d_wall| minimum wall thickness
|
||||
d_clear| tolerance fit factor
|
||||
d_tabh| height of tab (yaxis, measured from inner wall)
|
||||
d_tabw| maximum width of tab
|
||||
a_tab| angle of tab
|
||||
bp_h_bot| Baseplate bottom part height (part added with weigthed=true)
|
||||
bp_cut_size| Baseplate bottom cutout rectangle size
|
||||
bp_cut_depth| Baseplate bottom cutout rectangle depth
|
||||
bp_rcut_width| Baseplate bottom cutout finger gap width
|
||||
bp_rcut_length| Baseplate bottom cutout finger gap left
|
||||
bp_rcut_depth| Baseplate bottom cutout finger gap depth
|
||||
d_cs | countersink diameter for baseplate
|
||||
r_skel| radius of cutout for skeletonized baseplate
|
||||
r_cb| baseplate counterbore radius
|
||||
h_cb| baseplate counterbore depth
|
||||
h_skel | minimum baseplate thickness (when skeletonized)
|
BIN
docs/images/base_dimension.gif
Normal file
After Width: | Height: | Size: 674 KiB |
BIN
docs/images/baseplate.gif
Normal file
After Width: | Height: | Size: 121 KiB |
BIN
docs/images/compartment_dimension.gif
Normal file
After Width: | Height: | Size: 1.3 MiB |
BIN
docs/images/custom_dimension.gif
Normal file
After Width: | Height: | Size: 166 KiB |
BIN
docs/images/height_dimension.gif
Normal file
After Width: | Height: | Size: 1,013 KiB |
BIN
docs/images/holes_dimension.gif
Normal file
After Width: | Height: | Size: 295 KiB |
BIN
docs/images/lite.gif
Normal file
After Width: | Height: | Size: 177 KiB |
BIN
docs/images/slicer_base.png
Normal file
After Width: | Height: | Size: 205 KiB |
BIN
docs/images/slicer_bin.png
Normal file
After Width: | Height: | Size: 256 KiB |
BIN
docs/images/slicer_holes.png
Normal file
After Width: | Height: | Size: 367 KiB |
BIN
docs/images/slicer_holes_top.png
Normal file
After Width: | Height: | Size: 335 KiB |
BIN
docs/images/spin.gif
Normal file
After Width: | Height: | Size: 460 KiB |
BIN
docs/images/tab_dimension.gif
Normal file
After Width: | Height: | Size: 1.2 MiB |
BIN
docs/images/vase_base.gif
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
docs/images/vase_bottom.gif
Normal file
After Width: | Height: | Size: 21 KiB |
BIN
docs/images/vase_dividers.gif
Normal file
After Width: | Height: | Size: 118 KiB |
BIN
docs/images/vase_features_back.gif
Normal file
After Width: | Height: | Size: 53 KiB |
BIN
docs/images/vase_features_front.gif
Normal file
After Width: | Height: | Size: 43 KiB |
BIN
docs/images/vase_tabs.gif
Normal file
After Width: | Height: | Size: 137 KiB |
22
docs/index.md
Normal file
|
@ -0,0 +1,22 @@
|
|||
## Introduction
|
||||
Gridfinity rebuilt aims to remake the brilliant Gridfinity project from [Zack Freedman](https://www.youtube.com/c/ZackFreedman/about) in a more robust and open-source way than the original Fusion 360 files. Many major CAD suites struggle with making parametric models constructed from linear patterns, due to changing fillet edges and seams. Thus, a pure mathematical approach using OpenSCAD can allow a single solution for all possible bin variants.
|
||||
|
||||
The project has expanded into more eccentric models that use modules from the original generator. This wiki aims to document these modules in great detail.
|
||||
|
||||
Models are generated subtractively. First, the solid bin and bases are constructed, and then the compartments and holes are removed. This allows for internal fillets that nearly match the originals. However, they are not exactly perfect. There are some fillets that are too small and too difficult to be worth implementing, as most printers do not have a high enough resolution for it to matter.
|
||||
|
||||
## Getting Started
|
||||
For best results, use a version of OpenSCAD with the fast-csg feature. As of writing, this feature is only implemented in the [development snapshots](https://openscad.org/downloads.html). To enable the feature, go to Edit > Preferences > Features > fast-csg. This can speed up rendering from 10 minutes down to a couple of seconds, even for comically large bins. It is not a requirement to use development versions of OpenSCAD.
|
||||
|
||||
Most files will come ready-to-run, so parameters can be changed using OpenSCAD's built-in customizer window, and the bins will automatically generate. However, all modules are packed up nicely, so any module can be imported into other files or have more custom modifications beyond tweaking the parameters.
|
||||
|
||||
## Script Structure
|
||||
* Information (Imports / Script Details)
|
||||
* Parameters (Shown in Customizer)
|
||||
* Implementation (Executing the Parameters)
|
||||
* Construction (Script-Specific Modules and Constants)
|
||||
* Examples
|
||||
|
||||
The two files which do not follow these conventions are `gridfinity-rebuilt-utility` and `gridfinity-rebuilt-constants`. These files are not meant to be exposed to the user, except for special requirements that the normal parameters cannot handle. Their respective wiki pages go into more depth.
|
||||
|
||||
**NOTE: This documentation is a work in progress, just like the rest of the repository, so parts may still be under construction.**
|
55
docs/lite.md
Normal file
|
@ -0,0 +1,55 @@
|
|||
# gridfinity-rebuilt-lite
|
||||
|
||||
Generates stock bins, but with a twist: the bases are hollow. This is unable to be implemented directly into `gridfinity-rebuilt-bins` due to its surprisingly complex construction. It couldn't be a toggle without causing the structure of the script to fundamentally change (and become more complex) so it was moved to a separate file. Notably, there are some parameters missing, as they are incompatible with the lite variation. Additionally, the complex geometry means rendering is fairly slow, and currently causes many CSG errors.
|
||||
|
||||
![Bin](images/lite.gif)
|
||||
|
||||
## Script Parameters
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
gridz | { n>0 \| n∈R } | bin height. See bin height information and "gridz_define" below.
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
divx | { n>0 \| n∈Z } | number of compartments along X
|
||||
divy | { n>0 \| n∈Z } | number of compartments along Y
|
||||
enable_zsnap | boolean | automatically snap the bin size to the nearest 7mm increment. <br> default: true
|
||||
enable_lip | boolean | if you are not stacking the bin, you can disable the top lip <br> to save space. default: true
|
||||
gridz_define | { n>0 \| n∈R } | determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters
|
||||
style_tab | { 0, 1, 2, 3, 4, 5 } | how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs
|
||||
style_hole | { 0, 1, 2, 3 } | the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit
|
||||
div_base_x | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
div_base_y | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
|
||||
<br>
|
||||
|
||||
## Modules
|
||||
|
||||
---
|
||||
|
||||
### gridfinityLite
|
||||
|
||||
Wrapper function that calls [`gridfinityInit`](bins.md#gridfinityInit) and [`gridfinityBase`](bins.md#gridfinityBase) functions (hence the sheer quantity of parameters). Like [`gridfinityInit`](bins.md#gridfinityInit), it uses its children as cutters for the compartments.
|
||||
|
||||
**`gridfinityLite(gridx, gridy, gridz, gridz_define, enable_lip, enable_zsnap, length, div_base_x, div_base_y, style_hole)`**
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
gridz | { n>0 \| n∈R } | bin height. See bin height information and "gridz_define" below.
|
||||
gridz_define | { n>0 \| n∈R } | determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters
|
||||
enable_lip | boolean | if you are not stacking the bin, you can disable the top lip <br> to save space. default: true
|
||||
enable_zsnap | boolean | automatically snap the bin size to the nearest 7mm increment. <br> default: true
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)
|
||||
div_base_x | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
div_base_y | { n>=0 \| n∈Z } | number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)
|
||||
style_hole | { 0, 1, 2, 3 } | the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit
|
||||
|
||||
```
|
||||
// Example: generate a 3x3x6 bin with 2x2 compartments, that is hollow
|
||||
gridfinityLite(gridx=3, gridy=3, gridz=6, gridz_define=0, enable_lip=true, enable_zsnap=false, length=42, div_base_x=0, div_base_y=0, style_hole=1) {
|
||||
cutEqual(n_divx=2, n_divy=2, style_tab=1, enable_scoop = false);
|
||||
}
|
||||
```
|
75
docs/vase.md
Normal file
|
@ -0,0 +1,75 @@
|
|||
# gridfinity-spiral-vase
|
||||
|
||||
Some assembly required!
|
||||
Adaptation of Gridfinity bins to work with spiral vase mode, as to save filament and print time. A big drawback of using vase mode for Gridfinity bins was that they would be very flimsy, and would lack the features that make Gridfinity such a good organizational tool. The goal of this implementation was to maintain the design philosophy while working under the constraints of vase mode.
|
||||
|
||||
![Bin](images/vase_dividers.gif)
|
||||
![Bin](images/vase_base.gif)
|
||||
|
||||
## Instructions
|
||||
Normal Gridfinity is impossible to convert to vase mode due to the geometry of the bases, meaning most existing vase mode Gridfinity models are limited to 1x1 bins. How this script gets around the impossible is to use two separate pieces. **The bin and bases must be printed separately, and then glued together to form the final bin.** While this is slightly more work, there is an added bonus to this method, as for larger bins you may not need every single grid slot to have a base, you only really need them on the corners, or the edges, with some in the middle for support. Using less bases saves filament and print time.
|
||||
|
||||
All parameters are global. The customizer has descriptions for all parameters. It is **essential** that the section *Printer Settings* matches your preferred slicer's settings, otherwise the model will not slice correctly. Additionally, you have to turn on the spiral vase parameter in your slicer. If you do not know what vase mode is, [this](https://www.youtube.com/watch?v=HZSFoFYpBaA) is a helpful video.
|
||||
|
||||
1. Change the *Printer Settings* parameters to match your slicer and printer settings.
|
||||
2. Run the `gridfinityVaseBase()` module. This will generate a single spiral-capable base. Export as an STL file. You will need to print multiple of these, so it recommended to fill a base plate with them using the "complete individual objects" option (or equivilant) in your slicer. You only need to do this step initially, and then each time your printer settings change afterwards.
|
||||
3. Change the bin parameters and run `gridfinityVase()` module to generate the main bin.
|
||||
4. Glue bases to the bottom of the bin. I recommend superglue on the corners and the top of the magnet holes.
|
||||
|
||||
How your sliced files should look (cross section shown for 1x1 bin):
|
||||
|
||||
![Bin](images/slicer_bin.png)
|
||||
![Bin](images/slicer_base.png)
|
||||
|
||||
Example sliced files can be found on the [Printables](https://www.printables.com/model/284371-spiral-vase-gridfinity-in-openscad) page.
|
||||
|
||||
## Statistics
|
||||
Given how it has become a bit of a [challenge](https://www.printables.com/model/265271-gridfinity-lite-economical-plain-storage-bins) to reduce the weight and print time for these bins, here is a comparison for a large bin:
|
||||
|
||||
| Type | Weight | Time |
|
||||
|--------------|-----------|------------|
|
||||
Plain 4x2x6 Bin | 114.66g | 3h58m
|
||||
Vase 4x2x6 Bin with 8 Bases | 68.31g | 2h27m
|
||||
Vase 4x2x6 Bin with 4 Bases (only corners) | 56.43g | 1h59m
|
||||
|
||||
Clearly, vase mode is very quick and quite lightweight. However, this fundamentally means the bins will be weaker, so keep that in mind.
|
||||
|
||||
## Script Parameters
|
||||
|
||||
Parameter | Range | Description
|
||||
--- | ----- | ---
|
||||
type | { 0 , 1 } | generate the bin (0) or base (1)
|
||||
nozzle | { n>0 \| n∈R } | extrusion width in slicer
|
||||
layer | { n>0 \| n∈R } | size of layers in slicer
|
||||
bottom_layer | { n>0 \| n∈Z } | number of layers on the bottom of the print
|
||||
gridx | { n>0 \| n∈R } | number of bases along the x-axis
|
||||
gridy | { n>0 \| n∈R } | number of bases along the y-axis
|
||||
gridz | { n>0 \| n∈R } | bin height. See bin height information and <br> "gridz_define" below.
|
||||
length | { n>0 \| n∈R } | length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of <br>Life, the Universe, and Everything.)
|
||||
n_divx | { n>0 \| n∈Z } | number of compartments along X
|
||||
enable_holes | boolean | toggle holes inside the base
|
||||
enable_zsnap | boolean | automatically snap the bin size to the nearest <br> 7mm increment. default: true
|
||||
enable_lip | boolean | if you are not stacking the bin, you can disable the <br>top lip to save space. default: true
|
||||
enable_scoop_chamfer | boolean | toggles the chamfer on bottom edge <br> for easy removal of items
|
||||
enable_funnel | boolean | toggles funnel on back of tab. <br> acts as a finger grip and pour spout for small parts.
|
||||
enable_inset | boolean | toggles an inset on the front of the bin. <br> adds strength when using scoop.
|
||||
enable_pinch | boolean | toggles an outside pinch at the top lip of the bin. <br> adds strength.
|
||||
gridz_define | { n>0 \| n∈R } | determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in mm <br> • (2) gridz is the overall external height of the bin in mm
|
||||
style_tab | { 0, 1, 2, 3, 4, 5 } | how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs
|
||||
style_base | { 0, 1, 2, 3, 4} | specifies the locations for the "X" cutouts for bases. <br> • (0) all <br> • (1) corners <br> • (2) edges <br> • (3) automatic <br> • (4) none
|
||||
a_tab | { n>0 \| n∈R } | angle of the tab
|
||||
|
||||
## Modules
|
||||
|
||||
### gridfinityVase
|
||||
|
||||
Generates the compartment section of the bin. No parameters as it uses the global parameters for construction.
|
||||
|
||||
**`gridfinityVase()`**
|
||||
|
||||
|
||||
### gridfinityVaseBase
|
||||
|
||||
Generates the base section of the bin. No parameters as it uses the global parameters for construction. It only generates a single base, as all of them are the same. Use your slicer with the "outpuit individual objects" option to print a full sheet of these, or as many as you need to fit your bins.
|
||||
|
||||
**`gridfinityVaseBase()`**
|
51
ignore/README-VASE.md
Normal file
|
@ -0,0 +1,51 @@
|
|||
# Gridfinity Spiral Vase
|
||||
|
||||
Some assembly required!
|
||||
Adaptation of Gridfinity bins to work with spiral vase mode, as to save filament and print time. A big drawback of using vase mode for Gridfinity bins was that they would be very flimsy, and would lack the features that make Gridfinity such a good organizational tool. The goal of this implementation was to maintain the design philosophy while working under the constraints of vase mode.
|
||||
|
||||
[<img src="../images/vase_features_front.gif" width="320">]()
|
||||
[<img src="../images/vase_features_back.gif" width="320">]()
|
||||
[<img src="../images/vase_dividers.gif" width="320">]()
|
||||
[<img src="../images/vase_bottom.gif" width="320">]()
|
||||
[<img src="../images/vase_base.gif" width="320">]()
|
||||
[<img src="../images/vase_tabs.gif" width="320">]()
|
||||
|
||||
## Features
|
||||
As this script is a child of the `gridfinity-rebuilt-base.scad` script, it has most of the same features. Of course, vase mode does have some limitations (it can only do compartments along the X-axis, not the Y-axis). This script is not stand-alone, you must download the full repository for it to work. See the full list of features [here](https://github.com/kennetek/gridfinity-rebuilt-openscad).
|
||||
|
||||
## Instructions
|
||||
Normal Gridfinity is impossible to convert to vase mode due to the geometry of the bases, meaning most existing vase mode Gridfinity models are limited to 1x1 bins. How this script gets around the impossible is to use two separate pieces. **The bin and bases must be printed separately, and then glued together to form the final bin.** While this is slightly more work, there is an added bonus to this method, as for larger bins you may not need every single grid slot to have a base, you only really need them on the corners, or the edges, with some in the middle for support. Using less bases saves filament and print time.
|
||||
|
||||
All parameters are global. The customizer has descriptions for all parameters. It is **essential** that the section *Printer Settings* matches your preferred slicer's settings, otherwise the model will not slice correctly. Additionally, you have to turn on the spiral vase parameter in your slicer. If you do not know what vase mode is, [this](https://www.youtube.com/watch?v=HZSFoFYpBaA) is a helpful video.
|
||||
|
||||
1. Change the *Printer Settings* parameters to match your slicer and printer settings.
|
||||
2. Run the `gridfinityVaseBase()` module. This will generate a single spiral-capable base. Export as an STL file. You will need to print multiple of these, so it recommended to fill a base plate with them using the "complete individual objects" option (or equivilant) in your slicer. You only need to do this step initially, and then each time your printer settings change afterwards.
|
||||
3. Change the bin parameters and run `gridfinityVase()` module to generate the main bin.
|
||||
4. Glue bases to the bottom of the bin. I recommend superglue on the corners and the top of the magnet holes.
|
||||
|
||||
How your sliced files should look (cross section shown for 1x1 bin):
|
||||
|
||||
[<img src="../images/slicer_bin.png" height="200">]()
|
||||
[<img src="../images/slicer_base.png" height="200">]()
|
||||
|
||||
Example sliced files can be found on the [Printables](https://www.printables.com/model/284371-spiral-vase-gridfinity-in-openscad) page.
|
||||
|
||||
## Statistics
|
||||
Given how it has become a bit of a [challenge](https://www.printables.com/model/265271-gridfinity-lite-economical-plain-storage-bins) to reduce the weight and print time for these bins, here is a comparison for a large bin:
|
||||
|
||||
| Type | Weight | Time |
|
||||
|--------------|-----------|------------|
|
||||
Plain 4x2x6 Bin | 114.66g | 3h58m
|
||||
Vase 4x2x6 Bin with 8 Bases | 68.31g | 2h27m
|
||||
Vase 4x2x6 Bin with 4 Bases (only corners) | 56.43g | 1h59m
|
||||
|
||||
Clearly, vase mode is very quick and quite lightweight. However, this fundamentally means the bins will be weaker, so keep that in mind.
|
||||
|
||||
## Recommendations
|
||||
For best results, use a version of OpenSCAD with the fast-csg feature. As of writing, this feature is only implemented in the [development snapshots](https://openscad.org/downloads.html). To enable the feature, go to Edit > Preferences > Features > fast-csg. On my computer, this sped up rendering from 10 minutes down to a couple of seconds, even for comically large bins.
|
||||
|
||||
## Enjoy!
|
||||
|
||||
[<img src="../images/spin.gif" width="160">]()
|
||||
|
||||
[Gridfinity](https://www.youtube.com/watch?v=ra_9zU-mnl8) by [Zack Freedman](https://www.youtube.com/c/ZackFreedman/about)
|
BIN
ignore/gridfinity-spiral-vase.stl
Normal file
12
mkdocs.yml
Normal file
|
@ -0,0 +1,12 @@
|
|||
site_name: Gridfinity Rebuilt
|
||||
theme: readthedocs
|
||||
nav:
|
||||
- Home: index.md
|
||||
- Bins: bins.md
|
||||
- Baseplates: baseplates.md
|
||||
- Lite: lite.md
|
||||
- Vase: vase.md
|
||||
- Constants: constants.md
|
||||
plugins:
|
||||
- search
|
||||
- autorefs
|
125
site/404.html
Normal file
|
@ -0,0 +1,125 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="/img/favicon.ico" />
|
||||
<title>Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="/css/theme.css" />
|
||||
<link rel="stylesheet" href="/css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script src="/js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="/js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href="/." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="//search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/.">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="/constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="/.">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href="/." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
|
||||
<h1 id="404-page-not-found">404</h1>
|
||||
|
||||
<p><strong>Page not found</strong></p>
|
||||
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '/';</script>
|
||||
<script src="/js/theme_extra.js" defer></script>
|
||||
<script src="/js/theme.js" defer></script>
|
||||
<script src="/search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
256
site/baseplates/index.html
Normal file
|
@ -0,0 +1,256 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="../img/favicon.ico" />
|
||||
<title>Baseplates - Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="../css/theme.css" />
|
||||
<link rel="stylesheet" href="../css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Baseplates";
|
||||
var mkdocs_page_input_path = "baseplates.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="../js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="../js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href=".." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="..">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href="./">Baseplates</a>
|
||||
<ul class="current">
|
||||
<li class="toctree-l2"><a class="reference internal" href="#script-parameters">Script Parameters</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#modules">Modules</a>
|
||||
<ul>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinitybaseplate">gridfinityBaseplate</a>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="..">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href=".." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Baseplates</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h1 id="gridfinity-rebuilt-baseplate">gridfinity-rebuilt-baseplate</h1>
|
||||
<p>To round out the rebuilt catalog, we have baseplates. Originally, baseplates were not included as there was not anything really interesting to parameterize, unlike with bins. However, upon closer inspection, there is a couple things that would make peoples' lives easier. For instance, what is called here the "skeletonized" style, in that the baseplate is still thick to allow for magnets, but the center portion is removed. Additionally, being able to generate spacers for the sides of the bases, so that they fit perfectly inside your drawers.</p>
|
||||
<p><img alt="Bin" src="../images/baseplate.gif" /></p>
|
||||
<h2 id="script-parameters">Script Parameters</h2>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis<br> If set to zero, will fill with as many <br>bases that fit within <code>distancex</code></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis<br> If set to zero, will fill with as many <br>bases that fit within <code>distancey</code></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>distancex</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>minimum length of baseplate along x <br>alternatively, how large is the drawer along x <br>(leave zero to ignore)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>distancey</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>minimum length of baseplate along y <br>alternatively, how large is the drawer along y <br>(leave zero to ignore)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_plate</td>
|
||||
<td>{ 0, 1, 2 }</td>
|
||||
<td>the style of baseplate <br> • (0) thin (minimum material, only outline) <br> • (1) weighted (thick with space for tire iron) <br> • (2) skeletonized (thick, center hollowed)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_magnet</td>
|
||||
<td>boolean</td>
|
||||
<td>toggle hole for magnet on top</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2 }</td>
|
||||
<td>the style of holes underneath the baseplate, if applicable <br> • (0) none <br> • (1) countersink <br> • (2) counterbore</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<h2 id="modules">Modules</h2>
|
||||
<h3 id="gridfinitybaseplate">gridfinityBaseplate</h3>
|
||||
<p>Generates a baseplate to use with gridfinity bins. </p>
|
||||
<p><strong> <code>gridfinityBaseplate(gridx, gridy, length, distancex, distancey, style_plate, enable_magnet, style_hole)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis<br> If set to zero, will fill with as many <br>bases that fit within <code>distancex</code></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis<br> If set to zero, will fill with as many <br>bases that fit within <code>distancey</code></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>distancex</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>minimum length of baseplate along x <br>alternatively, how large is the drawer along x <br>(leave zero to ignore)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>distancey</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>minimum length of baseplate along y <br>alternatively, how large is the drawer along y <br>(leave zero to ignore)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_plate</td>
|
||||
<td>{ 0, 1, 2 }</td>
|
||||
<td>the style of baseplate <br> • (0) thin (minimum material, only outline) <br> • (1) weighted (thick with space for tire iron) <br> • (2) skeletonized (thick, center hollowed)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_magnet</td>
|
||||
<td>boolean</td>
|
||||
<td>toggle hole for magnet on top</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2 }</td>
|
||||
<td>the style of holes underneath the baseplate, if applicable <br> • (0) none <br> • (1) countersink <br> • (2) counterbore</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href="../bins/" class="btn btn-neutral float-left" title="Bins"><span class="icon icon-circle-arrow-left"></span> Previous</a>
|
||||
<a href="../lite/" class="btn btn-neutral float-right" title="Lite">Next <span class="icon icon-circle-arrow-right"></span></a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
<span><a href="../bins/" style="color: #fcfcfc">« Previous</a></span>
|
||||
|
||||
|
||||
<span><a href="../lite/" style="color: #fcfcfc">Next »</a></span>
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '..';</script>
|
||||
<script src="../js/theme_extra.js" defer></script>
|
||||
<script src="../js/theme.js" defer></script>
|
||||
<script src="../search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
519
site/bins/index.html
Normal file
|
@ -0,0 +1,519 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="../img/favicon.ico" />
|
||||
<title>Bins - Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="../css/theme.css" />
|
||||
<link rel="stylesheet" href="../css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Bins";
|
||||
var mkdocs_page_input_path = "bins.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="../js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="../js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href=".." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="..">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href="./">Bins</a>
|
||||
<ul class="current">
|
||||
<li class="toctree-l2"><a class="reference internal" href="#script-parameters">Script Parameters</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#modules">Modules</a>
|
||||
<ul>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinityinit">gridfinityInit</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#height">height</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinitybase">gridfinityBase</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#cutequal">cutEqual</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#cut">cut</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#cut_move">cut_move</a>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="..">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href=".." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Bins</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h1 id="gridfinity-rebuilt-bins">gridfinity-rebuilt-bins</h1>
|
||||
<p>Generates stock bins, with a great number of variations. </p>
|
||||
<p><img alt="Bin" src="../images/custom_dimension.gif" /></p>
|
||||
<h2 id="script-parameters">Script Parameters</h2>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>bin height. See bin height information and "gridz_define" below.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>divx</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along X</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>divy</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along Y</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_scoop</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles the fillet on bottom edge for easy removal of items</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_zsnap</td>
|
||||
<td>boolean</td>
|
||||
<td>automatically snap the bin size to the nearest 7mm increment. <br> default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_lip</td>
|
||||
<td>boolean</td>
|
||||
<td>if you are not stacking the bin, you can disable the top lip <br> to save space. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz_define</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>height_internal</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>height of the internal block. <br> Can be lower than bin height to save filament on custom bins. <br> default of 0 means use the calculated height.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_tab</td>
|
||||
<td>{ 0, 1, 2, 3, 4, 5 }</td>
|
||||
<td>how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2, 3 }</td>
|
||||
<td>the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_x</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_y</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<p><br></p>
|
||||
<h2 id="modules">Modules</h2>
|
||||
<hr />
|
||||
<h3 id="gridfinityinit">gridfinityInit</h3>
|
||||
<p>Initializes the top part of the bin (walls and solid section). All bins have to use this module, and have the compartments cut out from it. </p>
|
||||
<p><strong> <code>gridfinityInit (gridx, gridy, height, height_internal, length)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>height</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>height of the bin, in millimeters (but not exactly). <br> See the <code>height()</code> function for more info.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>height_internal</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>height of the internal block. <br> Can be lower than bin height to save filament on custom bins. <br> default of 0 means use the calculated height.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example: generate a 3x3x6 bin with a 42mm unit size
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cutEqual(n_divx = 3, n_divy = 3, style_tab = 0, enable_scoop = true);
|
||||
}
|
||||
</code></pre>
|
||||
<hr />
|
||||
<h3 id="height">height</h3>
|
||||
<p>Calculates the proper height for bins. </p>
|
||||
<p><strong> <code>height (gridz, gridz_define, enable_lip, enable_zsnap)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridz</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>bin height. See bin height information and "gridz_define" below.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz_define</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_lip</td>
|
||||
<td>boolean</td>
|
||||
<td>if you are not stacking the bin, you can disable the top lip <br> to save space. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_zsnap</td>
|
||||
<td>boolean</td>
|
||||
<td>automatically snap the bin size to the nearest 7mm increment. <br> default: true</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example: height for a 6 unit high bin
|
||||
height(6);
|
||||
|
||||
// Example: height for a bin that can fit (at maximum) a 30mm high object inside
|
||||
height(30, 1, true, false);
|
||||
</code></pre>
|
||||
<hr />
|
||||
<h3 id="gridfinitybase">gridfinityBase</h3>
|
||||
<p>Generates the bases for bins. Has various different hole styles, and can be subdivided.</p>
|
||||
<p><strong> <code>gridfinityBase (gridx, gridy, length, div_base_x, div_base_y, style_hole)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. default: 42</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_x</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. 0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_y</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. 0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2, 3 }</td>
|
||||
<td>the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example: generate a 3x3 base with a 42mm unit size and clean magnet holes
|
||||
gridfinityBase(3, 3, 42, 0, 0, 1);
|
||||
</code></pre>
|
||||
<hr />
|
||||
<h3 id="cutequal">cutEqual</h3>
|
||||
<p>Generates the "traditional" bin cutters. It is a utility function that creates evenly distributed compartments. </p>
|
||||
<p><strong> <code>cutEqual (n_divx, n_divy, style_tab, enable_scoop)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>n_divx</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along X</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>n_divy</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along Y</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_tab</td>
|
||||
<td>{ 0, 1, 2, 3, 4, 5 }</td>
|
||||
<td>how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_scoop</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles the fillet on bottom edge for easy removal of items</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example: this generates 9 compartments in a 3x3 grid, and all compartments have a full tab and a scoop
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cutEqual(n_divx = 3, n_divy = 3, style_tab = 0, enable_scoop = true);
|
||||
}
|
||||
</code></pre>
|
||||
<hr />
|
||||
<h3 id="cut">cut</h3>
|
||||
<p>Cuts a single compartment into the bin at the provided location with the provided attributes. The coordinate system for compartments originates (0,0) at the bottom left corner of the bin, where 1 unit is the length of 1 base. Positive X and positive Y are in the same direction as the global coordinate system.</p>
|
||||
<p><strong> <code>cut (x, y, w, h, t, s)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>x</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>X coordinate of the compartment <br>(position of left edge of compartment)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>y</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>Y coordinate of the compartment <br>(position of bottom edge of compartment)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>w</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>Width of the compartment, in base units <br>(1 unit = 1 <code>length</code>)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>Height of the compartment, in base units <br>(1 unit = 1 <code>length</code>)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_tab</td>
|
||||
<td>{ 0, 1, 2, 3, 4, 5 }</td>
|
||||
<td>how the tabs for labels are generated for this compartment. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>s</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles the fillet on bottom edge for easy removal of items, <br> only for this specific compartment</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example:
|
||||
// this cuts two compartments that are both 1 wide and 2 high.
|
||||
// One is on the bottom left, and the other is at the top right.
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cut(0, 0, 1, 2, 0, true);
|
||||
cut(2, 1, 1, 2, 0, true);
|
||||
}
|
||||
</code></pre>
|
||||
<hr />
|
||||
<h3 id="cut_move">cut_move</h3>
|
||||
<p>Moves all of its children from the global origin to the center of the area that a compartment would normally fill, and uses them to cut from the bin. This allows you to easily make custom cutouts in the bin.</p>
|
||||
<p><strong> <code>cut_move (x, y, w, h)</code> </strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>x</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>X coordinate of the area (position of left edge)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>y</td>
|
||||
<td>{ n>=0 | n∈R }</td>
|
||||
<td>Y coordinate of the area (position of bottom edge)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>w</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>Width of the area, in base units (1 unit = 1 <code>length</code>)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>Height of the area, in base units (1 unit = 1 <code>length</code>)</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example:
|
||||
// cuts a cylindrical hole of radius 5
|
||||
// hole center is located 1/2 units from the right edge of the bin, and 1 unit from the top
|
||||
gridfinityInit(3, 3, height(6), 0, 42) {
|
||||
cut_move(x=2, y=1, w=1, h=2) {
|
||||
cylinder(r=5, h=100, center=true);
|
||||
}
|
||||
}
|
||||
</code></pre>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href=".." class="btn btn-neutral float-left" title="Home"><span class="icon icon-circle-arrow-left"></span> Previous</a>
|
||||
<a href="../baseplates/" class="btn btn-neutral float-right" title="Baseplates">Next <span class="icon icon-circle-arrow-right"></span></a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
<span><a href=".." style="color: #fcfcfc">« Previous</a></span>
|
||||
|
||||
|
||||
<span><a href="../baseplates/" style="color: #fcfcfc">Next »</a></span>
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '..';</script>
|
||||
<script src="../js/theme_extra.js" defer></script>
|
||||
<script src="../js/theme.js" defer></script>
|
||||
<script src="../search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
275
site/constants/index.html
Normal file
|
@ -0,0 +1,275 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="../img/favicon.ico" />
|
||||
<title>Constants - Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="../css/theme.css" />
|
||||
<link rel="stylesheet" href="../css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Constants";
|
||||
var mkdocs_page_input_path = "constants.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="../js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="../js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href=".." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="..">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href="./">Constants</a>
|
||||
<ul class="current">
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="..">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href=".." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Constants</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h1 id="gridfinity-rebuilt-constants">gridfinity-rebuilt-constants</h1>
|
||||
<p>This file contains dimensions that are critical to the constructiuon of the other models, but are not values that often need to be changed. Thus, they were outsourced to this file such that the rest of the files would retain parity. All values here have the same range, this is positive real numbers. Some can be zero, but that may result in strange or invalid geometry, </p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>h_base</td>
|
||||
<td>height of the base</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_base</td>
|
||||
<td>outside rounded radius of bin</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_c1</td>
|
||||
<td>lower base chamfer "radius"</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_c2</td>
|
||||
<td>upper base chamfer "radius"</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h_bot</td>
|
||||
<td>bottom thiccness of bin</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_fo1</td>
|
||||
<td>outside radii 1</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_fo2</td>
|
||||
<td>outside radii 2</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_fo3</td>
|
||||
<td>outside radii 3</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_hole1</td>
|
||||
<td>screw hole radius</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_hole2</td>
|
||||
<td>magnet hole radius</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_hole</td>
|
||||
<td>center-to-center distance between holes</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h_hole</td>
|
||||
<td>magnet hole depth</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h_slit</td>
|
||||
<td>slit depth (printer layer height)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_f1</td>
|
||||
<td>top edge fillet radius</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_f2</td>
|
||||
<td>internal fillet radius</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_div</td>
|
||||
<td>width of divider between compartments</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_wall</td>
|
||||
<td>minimum wall thickness</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_clear</td>
|
||||
<td>tolerance fit factor</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_tabh</td>
|
||||
<td>height of tab (yaxis, measured from inner wall)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_tabw</td>
|
||||
<td>maximum width of tab</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>a_tab</td>
|
||||
<td>angle of tab</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_h_bot</td>
|
||||
<td>Baseplate bottom part height (part added with weigthed=true)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_cut_size</td>
|
||||
<td>Baseplate bottom cutout rectangle size</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_cut_depth</td>
|
||||
<td>Baseplate bottom cutout rectangle depth</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_rcut_width</td>
|
||||
<td>Baseplate bottom cutout finger gap width</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_rcut_length</td>
|
||||
<td>Baseplate bottom cutout finger gap left</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bp_rcut_depth</td>
|
||||
<td>Baseplate bottom cutout finger gap depth</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>d_cs</td>
|
||||
<td>countersink diameter for baseplate</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_skel</td>
|
||||
<td>radius of cutout for skeletonized baseplate</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>r_cb</td>
|
||||
<td>baseplate counterbore radius</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h_cb</td>
|
||||
<td>baseplate counterbore depth</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>h_skel</td>
|
||||
<td>minimum baseplate thickness (when skeletonized)</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href="../vase/" class="btn btn-neutral float-left" title="Vase"><span class="icon icon-circle-arrow-left"></span> Previous</a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
<span><a href="../vase/" style="color: #fcfcfc">« Previous</a></span>
|
||||
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '..';</script>
|
||||
<script src="../js/theme_extra.js" defer></script>
|
||||
<script src="../js/theme.js" defer></script>
|
||||
<script src="../search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
BIN
site/css/fonts/Roboto-Slab-Bold.woff
Normal file
BIN
site/css/fonts/Roboto-Slab-Bold.woff2
Normal file
BIN
site/css/fonts/Roboto-Slab-Regular.woff
Normal file
BIN
site/css/fonts/Roboto-Slab-Regular.woff2
Normal file
BIN
site/css/fonts/fontawesome-webfont.eot
Normal file
2671
site/css/fonts/fontawesome-webfont.svg
Normal file
After Width: | Height: | Size: 434 KiB |
BIN
site/css/fonts/fontawesome-webfont.ttf
Normal file
BIN
site/css/fonts/fontawesome-webfont.woff
Normal file
BIN
site/css/fonts/fontawesome-webfont.woff2
Normal file
BIN
site/css/fonts/lato-bold-italic.woff
Normal file
BIN
site/css/fonts/lato-bold-italic.woff2
Normal file
BIN
site/css/fonts/lato-bold.woff
Normal file
BIN
site/css/fonts/lato-bold.woff2
Normal file
BIN
site/css/fonts/lato-normal-italic.woff
Normal file
BIN
site/css/fonts/lato-normal-italic.woff2
Normal file
BIN
site/css/fonts/lato-normal.woff
Normal file
BIN
site/css/fonts/lato-normal.woff2
Normal file
13
site/css/theme.css
Normal file
191
site/css/theme_extra.css
Normal file
|
@ -0,0 +1,191 @@
|
|||
/*
|
||||
* Wrap inline code samples otherwise they shoot of the side and
|
||||
* can't be read at all.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/313
|
||||
* https://github.com/mkdocs/mkdocs/issues/233
|
||||
* https://github.com/mkdocs/mkdocs/issues/834
|
||||
*/
|
||||
.rst-content code {
|
||||
white-space: pre-wrap;
|
||||
word-wrap: break-word;
|
||||
padding: 2px 5px;
|
||||
}
|
||||
|
||||
/**
|
||||
* Make code blocks display as blocks and give them the appropriate
|
||||
* font size and padding.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/855
|
||||
* https://github.com/mkdocs/mkdocs/issues/834
|
||||
* https://github.com/mkdocs/mkdocs/issues/233
|
||||
*/
|
||||
.rst-content pre code {
|
||||
white-space: pre;
|
||||
word-wrap: normal;
|
||||
display: block;
|
||||
padding: 12px;
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
/**
|
||||
* Fix code colors
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/2027
|
||||
*/
|
||||
.rst-content code {
|
||||
color: #E74C3C;
|
||||
}
|
||||
|
||||
.rst-content pre code {
|
||||
color: #000;
|
||||
background: #f8f8f8;
|
||||
}
|
||||
|
||||
/*
|
||||
* Fix link colors when the link text is inline code.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/718
|
||||
*/
|
||||
a code {
|
||||
color: #2980B9;
|
||||
}
|
||||
a:hover code {
|
||||
color: #3091d1;
|
||||
}
|
||||
a:visited code {
|
||||
color: #9B59B6;
|
||||
}
|
||||
|
||||
/*
|
||||
* The CSS classes from highlight.js seem to clash with the
|
||||
* ReadTheDocs theme causing some code to be incorrectly made
|
||||
* bold and italic.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/411
|
||||
*/
|
||||
pre .cs, pre .c {
|
||||
font-weight: inherit;
|
||||
font-style: inherit;
|
||||
}
|
||||
|
||||
/*
|
||||
* Fix some issues with the theme and non-highlighted code
|
||||
* samples. Without and highlighting styles attached the
|
||||
* formatting is broken.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/319
|
||||
*/
|
||||
.rst-content .no-highlight {
|
||||
display: block;
|
||||
padding: 0.5em;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Additions specific to the search functionality provided by MkDocs
|
||||
*/
|
||||
|
||||
.search-results {
|
||||
margin-top: 23px;
|
||||
}
|
||||
|
||||
.search-results article {
|
||||
border-top: 1px solid #E1E4E5;
|
||||
padding-top: 24px;
|
||||
}
|
||||
|
||||
.search-results article:first-child {
|
||||
border-top: none;
|
||||
}
|
||||
|
||||
form .search-query {
|
||||
width: 100%;
|
||||
border-radius: 50px;
|
||||
padding: 6px 12px; /* csslint allow: box-model */
|
||||
border-color: #D1D4D5;
|
||||
}
|
||||
|
||||
/*
|
||||
* Improve inline code blocks within admonitions.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/656
|
||||
*/
|
||||
.rst-content .admonition code {
|
||||
color: #404040;
|
||||
border: 1px solid #c7c9cb;
|
||||
border: 1px solid rgba(0, 0, 0, 0.2);
|
||||
background: #f8fbfd;
|
||||
background: rgba(255, 255, 255, 0.7);
|
||||
}
|
||||
|
||||
/*
|
||||
* Account for wide tables which go off the side.
|
||||
* Override borders to avoid weirdness on narrow tables.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/834
|
||||
* https://github.com/mkdocs/mkdocs/pull/1034
|
||||
*/
|
||||
.rst-content .section .docutils {
|
||||
width: 100%;
|
||||
overflow: auto;
|
||||
display: block;
|
||||
border: none;
|
||||
}
|
||||
|
||||
td, th {
|
||||
border: 1px solid #e1e4e5 !important; /* csslint allow: important */
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
/*
|
||||
* Without the following amendments, the navigation in the theme will be
|
||||
* slightly cut off. This is due to the fact that the .wy-nav-side has a
|
||||
* padding-bottom of 2em, which must not necessarily align with the font-size of
|
||||
* 90 % on the .rst-current-version container, combined with the padding of 12px
|
||||
* above and below. These amendments fix this in two steps: First, make sure the
|
||||
* .rst-current-version container has a fixed height of 40px, achieved using
|
||||
* line-height, and then applying a padding-bottom of 40px to this container. In
|
||||
* a second step, the items within that container are re-aligned using flexbox.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/2012
|
||||
*/
|
||||
.wy-nav-side {
|
||||
padding-bottom: 40px;
|
||||
}
|
||||
|
||||
/*
|
||||
* The second step of above amendment: Here we make sure the items are aligned
|
||||
* correctly within the .rst-current-version container. Using flexbox, we
|
||||
* achieve it in such a way that it will look like the following:
|
||||
*
|
||||
* [No repo_name]
|
||||
* Next >> // On the first page
|
||||
* << Previous Next >> // On all subsequent pages
|
||||
*
|
||||
* [With repo_name]
|
||||
* <repo_name> Next >> // On the first page
|
||||
* <repo_name> << Previous Next >> // On all subsequent pages
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/2012
|
||||
*/
|
||||
.rst-versions .rst-current-version {
|
||||
padding: 0 12px;
|
||||
display: flex;
|
||||
font-size: initial;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
line-height: 40px;
|
||||
}
|
||||
|
||||
/*
|
||||
* Please note that this amendment also involves removing certain inline-styles
|
||||
* from the file ./mkdocs/themes/readthedocs/versions.html.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/2012
|
||||
*/
|
||||
.rst-current-version span {
|
||||
flex: 1;
|
||||
text-align: center;
|
||||
}
|
BIN
site/images/base_dimension.gif
Normal file
After Width: | Height: | Size: 674 KiB |
BIN
site/images/baseplate.gif
Normal file
After Width: | Height: | Size: 121 KiB |
BIN
site/images/compartment_dimension.gif
Normal file
After Width: | Height: | Size: 1.3 MiB |
BIN
site/images/custom_dimension.gif
Normal file
After Width: | Height: | Size: 166 KiB |
BIN
site/images/height_dimension.gif
Normal file
After Width: | Height: | Size: 1,013 KiB |
BIN
site/images/holes_dimension.gif
Normal file
After Width: | Height: | Size: 295 KiB |
BIN
site/images/lite.gif
Normal file
After Width: | Height: | Size: 177 KiB |
BIN
site/images/slicer_base.png
Normal file
After Width: | Height: | Size: 205 KiB |
BIN
site/images/slicer_bin.png
Normal file
After Width: | Height: | Size: 256 KiB |
BIN
site/images/slicer_holes.png
Normal file
After Width: | Height: | Size: 367 KiB |
BIN
site/images/slicer_holes_top.png
Normal file
After Width: | Height: | Size: 335 KiB |
BIN
site/images/spin.gif
Normal file
After Width: | Height: | Size: 460 KiB |
BIN
site/images/tab_dimension.gif
Normal file
After Width: | Height: | Size: 1.2 MiB |
BIN
site/images/vase_base.gif
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
site/images/vase_bottom.gif
Normal file
After Width: | Height: | Size: 21 KiB |
BIN
site/images/vase_dividers.gif
Normal file
After Width: | Height: | Size: 118 KiB |
BIN
site/images/vase_features_back.gif
Normal file
After Width: | Height: | Size: 53 KiB |
BIN
site/images/vase_features_front.gif
Normal file
After Width: | Height: | Size: 43 KiB |
BIN
site/images/vase_tabs.gif
Normal file
After Width: | Height: | Size: 137 KiB |
BIN
site/img/favicon.ico
Normal file
After Width: | Height: | Size: 1.1 KiB |
157
site/index.html
Normal file
|
@ -0,0 +1,157 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="description" content="None" />
|
||||
<link rel="shortcut icon" href="img/favicon.ico" />
|
||||
<title>Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="css/theme.css" />
|
||||
<link rel="stylesheet" href="css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Home";
|
||||
var mkdocs_page_input_path = "index.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href="." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="./search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href=".">Home</a>
|
||||
<ul class="current">
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href=".">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href="." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Home</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h2 id="introduction">Introduction</h2>
|
||||
<p>Gridfinity rebuilt aims to remake the brilliant Gridfinity project from <a href="https://www.youtube.com/c/ZackFreedman/about">Zack Freedman</a> in a more robust and open-source way than the original Fusion 360 files. Many major CAD suites struggle with making parametric models constructed from linear patterns, due to changing fillet edges and seams. Thus, a pure mathematical approach using OpenSCAD can allow a single solution for all possible bin variants. </p>
|
||||
<p>The project has expanded into more eccentric models that use modules from the original generator. This wiki aims to document these modules in great detail. </p>
|
||||
<p>Models are generated subtractively. First, the solid bin and bases are constructed, and then the compartments and holes are removed. This allows for internal fillets that nearly match the originals. However, they are not exactly perfect. There are some fillets that are too small and too difficult to be worth implementing, as most printers do not have a high enough resolution for it to matter. </p>
|
||||
<h2 id="getting-started">Getting Started</h2>
|
||||
<p>For best results, use a version of OpenSCAD with the fast-csg feature. As of writing, this feature is only implemented in the <a href="https://openscad.org/downloads.html">development snapshots</a>. To enable the feature, go to Edit > Preferences > Features > fast-csg. This can speed up rendering from 10 minutes down to a couple of seconds, even for comically large bins. It is not a requirement to use development versions of OpenSCAD. </p>
|
||||
<p>Most files will come ready-to-run, so parameters can be changed using OpenSCAD's built-in customizer window, and the bins will automatically generate. However, all modules are packed up nicely, so any module can be imported into other files or have more custom modifications beyond tweaking the parameters. </p>
|
||||
<h2 id="script-structure">Script Structure</h2>
|
||||
<ul>
|
||||
<li>Information (Imports / Script Details)</li>
|
||||
<li>Parameters (Shown in Customizer)</li>
|
||||
<li>Implementation (Executing the Parameters)</li>
|
||||
<li>Construction (Script-Specific Modules and Constants)</li>
|
||||
<li>Examples</li>
|
||||
</ul>
|
||||
<p>The two files which do not follow these conventions are <code>gridfinity-rebuilt-utility</code> and <code>gridfinity-rebuilt-constants</code>. These files are not meant to be exposed to the user, except for special requirements that the normal parameters cannot handle. Their respective wiki pages go into more depth. </p>
|
||||
<p><strong>NOTE: This documentation is a work in progress, just like the rest of the repository, so parts may still be under construction.</strong></p>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href="bins/" class="btn btn-neutral float-right" title="Bins">Next <span class="icon icon-circle-arrow-right"></span></a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
|
||||
<span><a href="bins/" style="color: #fcfcfc">Next »</a></span>
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '.';</script>
|
||||
<script src="js/theme_extra.js" defer></script>
|
||||
<script src="js/theme.js" defer></script>
|
||||
<script src="search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
|
||||
<!--
|
||||
MkDocs version : 1.4.2
|
||||
Build Date UTC : 2023-02-06 06:28:43.124984+00:00
|
||||
-->
|
4
site/js/html5shiv.min.js
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
/**
|
||||
* @preserve HTML5 Shiv 3.7.3 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
|
||||
*/
|
||||
!function(a,b){function c(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function d(){var a=t.elements;return"string"==typeof a?a.split(" "):a}function e(a,b){var c=t.elements;"string"!=typeof c&&(c=c.join(" ")),"string"!=typeof a&&(a=a.join(" ")),t.elements=c+" "+a,j(b)}function f(a){var b=s[a[q]];return b||(b={},r++,a[q]=r,s[r]=b),b}function g(a,c,d){if(c||(c=b),l)return c.createElement(a);d||(d=f(c));var e;return e=d.cache[a]?d.cache[a].cloneNode():p.test(a)?(d.cache[a]=d.createElem(a)).cloneNode():d.createElem(a),!e.canHaveChildren||o.test(a)||e.tagUrn?e:d.frag.appendChild(e)}function h(a,c){if(a||(a=b),l)return a.createDocumentFragment();c=c||f(a);for(var e=c.frag.cloneNode(),g=0,h=d(),i=h.length;i>g;g++)e.createElement(h[g]);return e}function i(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return t.shivMethods?g(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+d().join().replace(/[\w\-:]+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(t,b.frag)}function j(a){a||(a=b);var d=f(a);return!t.shivCSS||k||d.hasCSS||(d.hasCSS=!!c(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}")),l||i(a,d),a}var k,l,m="3.7.3",n=a.html5||{},o=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,p=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,q="_html5shiv",r=0,s={};!function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",k="hidden"in a,l=1==a.childNodes.length||function(){b.createElement("a");var a=b.createDocumentFragment();return"undefined"==typeof a.cloneNode||"undefined"==typeof a.createDocumentFragment||"undefined"==typeof a.createElement}()}catch(c){k=!0,l=!0}}();var t={elements:n.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output picture progress section summary template time video",version:m,shivCSS:n.shivCSS!==!1,supportsUnknownElements:l,shivMethods:n.shivMethods!==!1,type:"default",shivDocument:j,createElement:g,createDocumentFragment:h,addElements:e};a.html5=t,j(b),"object"==typeof module&&module.exports&&(module.exports=t)}("undefined"!=typeof window?window:this,document);
|
2
site/js/jquery-3.6.0.min.js
vendored
Normal file
2
site/js/theme.js
Normal file
8
site/js/theme_extra.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
/*
|
||||
* Assign 'docutils' class to tables so styling and
|
||||
* JavaScript behavior is applied.
|
||||
*
|
||||
* https://github.com/mkdocs/mkdocs/issues/2028
|
||||
*/
|
||||
|
||||
$('div.rst-content table').addClass('docutils');
|
298
site/lite/index.html
Normal file
|
@ -0,0 +1,298 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="../img/favicon.ico" />
|
||||
<title>Lite - Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="../css/theme.css" />
|
||||
<link rel="stylesheet" href="../css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Lite";
|
||||
var mkdocs_page_input_path = "lite.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="../js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="../js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href=".." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="..">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href="./">Lite</a>
|
||||
<ul class="current">
|
||||
<li class="toctree-l2"><a class="reference internal" href="#script-parameters">Script Parameters</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#modules">Modules</a>
|
||||
<ul>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinitylite">gridfinityLite</a>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="..">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href=".." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Lite</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h1 id="gridfinity-rebuilt-lite">gridfinity-rebuilt-lite</h1>
|
||||
<p>Generates stock bins, but with a twist: the bases are hollow. This is unable to be implemented directly into <code>gridfinity-rebuilt-bins</code> due to its surprisingly complex construction. It couldn't be a toggle without causing the structure of the script to fundamentally change (and become more complex) so it was moved to a separate file. Notably, there are some parameters missing, as they are incompatible with the lite variation. Additionally, the complex geometry means rendering is fairly slow, and currently causes many CSG errors. </p>
|
||||
<p><img alt="Bin" src="../images/lite.gif" /></p>
|
||||
<h2 id="script-parameters">Script Parameters</h2>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>bin height. See bin height information and "gridz_define" below.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>divx</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along X</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>divy</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along Y</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_zsnap</td>
|
||||
<td>boolean</td>
|
||||
<td>automatically snap the bin size to the nearest 7mm increment. <br> default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_lip</td>
|
||||
<td>boolean</td>
|
||||
<td>if you are not stacking the bin, you can disable the top lip <br> to save space. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz_define</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_tab</td>
|
||||
<td>{ 0, 1, 2, 3, 4, 5 }</td>
|
||||
<td>how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2, 3 }</td>
|
||||
<td>the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_x</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_y</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<p><br></p>
|
||||
<h2 id="modules">Modules</h2>
|
||||
<hr />
|
||||
<h3 id="gridfinitylite">gridfinityLite</h3>
|
||||
<p>Wrapper function that calls <a href="../bins/#gridfinityInit"><code>gridfinityInit</code></a> and <a href="../bins/#gridfinityBase"><code>gridfinityBase</code></a> functions (hence the sheer quantity of parameters). Like <a href="../bins/#gridfinityInit"><code>gridfinityInit</code></a>, it uses its children as cutters for the compartments. </p>
|
||||
<p><strong><code>gridfinityLite(gridx, gridy, gridz, gridz_define, enable_lip, enable_zsnap, length, div_base_x, div_base_y, style_hole)</code></strong></p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>bin height. See bin height information and "gridz_define" below.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz_define</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in millimeters <br> • (2) gridz is the overall external height of the bin in millimeters</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_lip</td>
|
||||
<td>boolean</td>
|
||||
<td>if you are not stacking the bin, you can disable the top lip <br> to save space. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_zsnap</td>
|
||||
<td>boolean</td>
|
||||
<td>automatically snap the bin size to the nearest 7mm increment. <br> default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of Life, <br>the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_x</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the X axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>div_base_y</td>
|
||||
<td>{ n>=0 | n∈Z }</td>
|
||||
<td>number of divisions per 1 unit of base along the Y axis. <br>(default 1, only use integers. <br>0 means automatically guess the division)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_hole</td>
|
||||
<td>{ 0, 1, 2, 3 }</td>
|
||||
<td>the style of holes in the bases <br> • (0) No holes <br> • (1) Magnet holes only <br> • (2) Magnet and screw holes - no printable slit <br> • (3) Magnet and screw holes - with printable slit</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<pre><code>// Example: generate a 3x3x6 bin with 2x2 compartments, that is hollow
|
||||
gridfinityLite(gridx=3, gridy=3, gridz=6, gridz_define=0, enable_lip=true, enable_zsnap=false, length=42, div_base_x=0, div_base_y=0, style_hole=1) {
|
||||
cutEqual(n_divx=2, n_divy=2, style_tab=1, enable_scoop = false);
|
||||
}
|
||||
</code></pre>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href="../baseplates/" class="btn btn-neutral float-left" title="Baseplates"><span class="icon icon-circle-arrow-left"></span> Previous</a>
|
||||
<a href="../vase/" class="btn btn-neutral float-right" title="Vase">Next <span class="icon icon-circle-arrow-right"></span></a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
<span><a href="../baseplates/" style="color: #fcfcfc">« Previous</a></span>
|
||||
|
||||
|
||||
<span><a href="../vase/" style="color: #fcfcfc">Next »</a></span>
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '..';</script>
|
||||
<script src="../js/theme_extra.js" defer></script>
|
||||
<script src="../js/theme.js" defer></script>
|
||||
<script src="../search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
132
site/search.html
Normal file
|
@ -0,0 +1,132 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="./img/favicon.ico" />
|
||||
<title>Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="./css/theme.css" />
|
||||
<link rel="stylesheet" href="./css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script src="./js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="./js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href="./." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="./search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./.">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./vase/">Vase</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="./constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="./.">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href="./." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
|
||||
<h1 id="search">Search Results</h1>
|
||||
|
||||
<form id="content_search" action="search.html">
|
||||
<span role="status" aria-live="polite" class="ui-helper-hidden-accessible"></span>
|
||||
<input name="q" id="mkdocs-search-query" type="text" class="search_input search-query ui-autocomplete-input" placeholder="Search the Docs" autocomplete="off" autofocus title="Type search term here">
|
||||
</form>
|
||||
|
||||
<div id="mkdocs-search-results" class="search-results" data-no-results-text="No results found">
|
||||
Searching...
|
||||
</div>
|
||||
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '.';</script>
|
||||
<script src="./js/theme_extra.js" defer></script>
|
||||
<script src="./js/theme.js" defer></script>
|
||||
<script src="./search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
3475
site/search/lunr.js
Normal file
109
site/search/main.js
Normal file
|
@ -0,0 +1,109 @@
|
|||
function getSearchTermFromLocation() {
|
||||
var sPageURL = window.location.search.substring(1);
|
||||
var sURLVariables = sPageURL.split('&');
|
||||
for (var i = 0; i < sURLVariables.length; i++) {
|
||||
var sParameterName = sURLVariables[i].split('=');
|
||||
if (sParameterName[0] == 'q') {
|
||||
return decodeURIComponent(sParameterName[1].replace(/\+/g, '%20'));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function joinUrl (base, path) {
|
||||
if (path.substring(0, 1) === "/") {
|
||||
// path starts with `/`. Thus it is absolute.
|
||||
return path;
|
||||
}
|
||||
if (base.substring(base.length-1) === "/") {
|
||||
// base ends with `/`
|
||||
return base + path;
|
||||
}
|
||||
return base + "/" + path;
|
||||
}
|
||||
|
||||
function escapeHtml (value) {
|
||||
return value.replace(/&/g, '&')
|
||||
.replace(/"/g, '"')
|
||||
.replace(/</g, '<')
|
||||
.replace(/>/g, '>');
|
||||
}
|
||||
|
||||
function formatResult (location, title, summary) {
|
||||
return '<article><h3><a href="' + joinUrl(base_url, location) + '">'+ escapeHtml(title) + '</a></h3><p>' + escapeHtml(summary) +'</p></article>';
|
||||
}
|
||||
|
||||
function displayResults (results) {
|
||||
var search_results = document.getElementById("mkdocs-search-results");
|
||||
while (search_results.firstChild) {
|
||||
search_results.removeChild(search_results.firstChild);
|
||||
}
|
||||
if (results.length > 0){
|
||||
for (var i=0; i < results.length; i++){
|
||||
var result = results[i];
|
||||
var html = formatResult(result.location, result.title, result.summary);
|
||||
search_results.insertAdjacentHTML('beforeend', html);
|
||||
}
|
||||
} else {
|
||||
var noResultsText = search_results.getAttribute('data-no-results-text');
|
||||
if (!noResultsText) {
|
||||
noResultsText = "No results found";
|
||||
}
|
||||
search_results.insertAdjacentHTML('beforeend', '<p>' + noResultsText + '</p>');
|
||||
}
|
||||
}
|
||||
|
||||
function doSearch () {
|
||||
var query = document.getElementById('mkdocs-search-query').value;
|
||||
if (query.length > min_search_length) {
|
||||
if (!window.Worker) {
|
||||
displayResults(search(query));
|
||||
} else {
|
||||
searchWorker.postMessage({query: query});
|
||||
}
|
||||
} else {
|
||||
// Clear results for short queries
|
||||
displayResults([]);
|
||||
}
|
||||
}
|
||||
|
||||
function initSearch () {
|
||||
var search_input = document.getElementById('mkdocs-search-query');
|
||||
if (search_input) {
|
||||
search_input.addEventListener("keyup", doSearch);
|
||||
}
|
||||
var term = getSearchTermFromLocation();
|
||||
if (term) {
|
||||
search_input.value = term;
|
||||
doSearch();
|
||||
}
|
||||
}
|
||||
|
||||
function onWorkerMessage (e) {
|
||||
if (e.data.allowSearch) {
|
||||
initSearch();
|
||||
} else if (e.data.results) {
|
||||
var results = e.data.results;
|
||||
displayResults(results);
|
||||
} else if (e.data.config) {
|
||||
min_search_length = e.data.config.min_search_length-1;
|
||||
}
|
||||
}
|
||||
|
||||
if (!window.Worker) {
|
||||
console.log('Web Worker API not supported');
|
||||
// load index in main thread
|
||||
$.getScript(joinUrl(base_url, "search/worker.js")).done(function () {
|
||||
console.log('Loaded worker');
|
||||
init();
|
||||
window.postMessage = function (msg) {
|
||||
onWorkerMessage({data: msg});
|
||||
};
|
||||
}).fail(function (jqxhr, settings, exception) {
|
||||
console.error('Could not load worker.js');
|
||||
});
|
||||
} else {
|
||||
// Wrap search in a web worker
|
||||
var searchWorker = new Worker(joinUrl(base_url, "search/worker.js"));
|
||||
searchWorker.postMessage({init: true});
|
||||
searchWorker.onmessage = onWorkerMessage;
|
||||
}
|
1
site/search/search_index.json
Normal file
133
site/search/worker.js
Normal file
|
@ -0,0 +1,133 @@
|
|||
var base_path = 'function' === typeof importScripts ? '.' : '/search/';
|
||||
var allowSearch = false;
|
||||
var index;
|
||||
var documents = {};
|
||||
var lang = ['en'];
|
||||
var data;
|
||||
|
||||
function getScript(script, callback) {
|
||||
console.log('Loading script: ' + script);
|
||||
$.getScript(base_path + script).done(function () {
|
||||
callback();
|
||||
}).fail(function (jqxhr, settings, exception) {
|
||||
console.log('Error: ' + exception);
|
||||
});
|
||||
}
|
||||
|
||||
function getScriptsInOrder(scripts, callback) {
|
||||
if (scripts.length === 0) {
|
||||
callback();
|
||||
return;
|
||||
}
|
||||
getScript(scripts[0], function() {
|
||||
getScriptsInOrder(scripts.slice(1), callback);
|
||||
});
|
||||
}
|
||||
|
||||
function loadScripts(urls, callback) {
|
||||
if( 'function' === typeof importScripts ) {
|
||||
importScripts.apply(null, urls);
|
||||
callback();
|
||||
} else {
|
||||
getScriptsInOrder(urls, callback);
|
||||
}
|
||||
}
|
||||
|
||||
function onJSONLoaded () {
|
||||
data = JSON.parse(this.responseText);
|
||||
var scriptsToLoad = ['lunr.js'];
|
||||
if (data.config && data.config.lang && data.config.lang.length) {
|
||||
lang = data.config.lang;
|
||||
}
|
||||
if (lang.length > 1 || lang[0] !== "en") {
|
||||
scriptsToLoad.push('lunr.stemmer.support.js');
|
||||
if (lang.length > 1) {
|
||||
scriptsToLoad.push('lunr.multi.js');
|
||||
}
|
||||
if (lang.includes("ja") || lang.includes("jp")) {
|
||||
scriptsToLoad.push('tinyseg.js');
|
||||
}
|
||||
for (var i=0; i < lang.length; i++) {
|
||||
if (lang[i] != 'en') {
|
||||
scriptsToLoad.push(['lunr', lang[i], 'js'].join('.'));
|
||||
}
|
||||
}
|
||||
}
|
||||
loadScripts(scriptsToLoad, onScriptsLoaded);
|
||||
}
|
||||
|
||||
function onScriptsLoaded () {
|
||||
console.log('All search scripts loaded, building Lunr index...');
|
||||
if (data.config && data.config.separator && data.config.separator.length) {
|
||||
lunr.tokenizer.separator = new RegExp(data.config.separator);
|
||||
}
|
||||
|
||||
if (data.index) {
|
||||
index = lunr.Index.load(data.index);
|
||||
data.docs.forEach(function (doc) {
|
||||
documents[doc.location] = doc;
|
||||
});
|
||||
console.log('Lunr pre-built index loaded, search ready');
|
||||
} else {
|
||||
index = lunr(function () {
|
||||
if (lang.length === 1 && lang[0] !== "en" && lunr[lang[0]]) {
|
||||
this.use(lunr[lang[0]]);
|
||||
} else if (lang.length > 1) {
|
||||
this.use(lunr.multiLanguage.apply(null, lang)); // spread operator not supported in all browsers: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_operator#Browser_compatibility
|
||||
}
|
||||
this.field('title');
|
||||
this.field('text');
|
||||
this.ref('location');
|
||||
|
||||
for (var i=0; i < data.docs.length; i++) {
|
||||
var doc = data.docs[i];
|
||||
this.add(doc);
|
||||
documents[doc.location] = doc;
|
||||
}
|
||||
});
|
||||
console.log('Lunr index built, search ready');
|
||||
}
|
||||
allowSearch = true;
|
||||
postMessage({config: data.config});
|
||||
postMessage({allowSearch: allowSearch});
|
||||
}
|
||||
|
||||
function init () {
|
||||
var oReq = new XMLHttpRequest();
|
||||
oReq.addEventListener("load", onJSONLoaded);
|
||||
var index_path = base_path + '/search_index.json';
|
||||
if( 'function' === typeof importScripts ){
|
||||
index_path = 'search_index.json';
|
||||
}
|
||||
oReq.open("GET", index_path);
|
||||
oReq.send();
|
||||
}
|
||||
|
||||
function search (query) {
|
||||
if (!allowSearch) {
|
||||
console.error('Assets for search still loading');
|
||||
return;
|
||||
}
|
||||
|
||||
var resultDocuments = [];
|
||||
var results = index.search(query);
|
||||
for (var i=0; i < results.length; i++){
|
||||
var result = results[i];
|
||||
doc = documents[result.ref];
|
||||
doc.summary = doc.text.substring(0, 200);
|
||||
resultDocuments.push(doc);
|
||||
}
|
||||
return resultDocuments;
|
||||
}
|
||||
|
||||
if( 'function' === typeof importScripts ) {
|
||||
onmessage = function (e) {
|
||||
if (e.data.init) {
|
||||
init();
|
||||
} else if (e.data.query) {
|
||||
postMessage({ results: search(e.data.query) });
|
||||
} else {
|
||||
console.error("Worker - Unrecognized message: " + e);
|
||||
}
|
||||
};
|
||||
}
|
33
site/sitemap.xml
Normal file
|
@ -0,0 +1,33 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
<url>
|
||||
<loc>None</loc>
|
||||
<lastmod>2023-02-06</lastmod>
|
||||
<changefreq>daily</changefreq>
|
||||
</url>
|
||||
</urlset>
|
BIN
site/sitemap.xml.gz
Normal file
318
site/vase/index.html
Normal file
|
@ -0,0 +1,318 @@
|
|||
<!DOCTYPE html>
|
||||
<html class="writer-html5" lang="en" >
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<link rel="shortcut icon" href="../img/favicon.ico" />
|
||||
<title>Vase - Gridfinity Rebuilt</title>
|
||||
<link rel="stylesheet" href="../css/theme.css" />
|
||||
<link rel="stylesheet" href="../css/theme_extra.css" />
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" />
|
||||
|
||||
<script>
|
||||
// Current page data
|
||||
var mkdocs_page_name = "Vase";
|
||||
var mkdocs_page_input_path = "vase.md";
|
||||
var mkdocs_page_url = null;
|
||||
</script>
|
||||
|
||||
<script src="../js/jquery-3.6.0.min.js" defer></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="../js/html5shiv.min.js"></script>
|
||||
<![endif]-->
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js"></script>
|
||||
<script>hljs.initHighlightingOnLoad();</script>
|
||||
</head>
|
||||
|
||||
<body class="wy-body-for-nav" role="document">
|
||||
|
||||
<div class="wy-grid-for-nav">
|
||||
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
|
||||
<div class="wy-side-scroll">
|
||||
<div class="wy-side-nav-search">
|
||||
<a href=".." class="icon icon-home"> Gridfinity Rebuilt
|
||||
</a><div role="search">
|
||||
<form id ="rtd-search-form" class="wy-form" action="../search.html" method="get">
|
||||
<input type="text" name="q" placeholder="Search docs" title="Type search term here" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="..">Home</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../bins/">Bins</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../baseplates/">Baseplates</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../lite/">Lite</a>
|
||||
</li>
|
||||
</ul>
|
||||
<ul class="current">
|
||||
<li class="toctree-l1 current"><a class="reference internal current" href="./">Vase</a>
|
||||
<ul class="current">
|
||||
<li class="toctree-l2"><a class="reference internal" href="#instructions">Instructions</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#statistics">Statistics</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#script-parameters">Script Parameters</a>
|
||||
</li>
|
||||
<li class="toctree-l2"><a class="reference internal" href="#modules">Modules</a>
|
||||
<ul>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinityvase">gridfinityVase</a>
|
||||
</li>
|
||||
<li class="toctree-l3"><a class="reference internal" href="#gridfinityvasebase">gridfinityVaseBase</a>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<ul>
|
||||
<li class="toctree-l1"><a class="reference internal" href="../constants/">Constants</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||||
<nav class="wy-nav-top" role="navigation" aria-label="Mobile navigation menu">
|
||||
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||||
<a href="..">Gridfinity Rebuilt</a>
|
||||
|
||||
</nav>
|
||||
<div class="wy-nav-content">
|
||||
<div class="rst-content"><div role="navigation" aria-label="breadcrumbs navigation">
|
||||
<ul class="wy-breadcrumbs">
|
||||
<li><a href=".." class="icon icon-home" alt="Docs"></a> »</li>
|
||||
<li>Vase</li>
|
||||
<li class="wy-breadcrumbs-aside">
|
||||
</li>
|
||||
</ul>
|
||||
<hr/>
|
||||
</div>
|
||||
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||||
<div class="section" itemprop="articleBody">
|
||||
|
||||
<h1 id="gridfinity-spiral-vase">gridfinity-spiral-vase</h1>
|
||||
<p>Some assembly required!
|
||||
Adaptation of Gridfinity bins to work with spiral vase mode, as to save filament and print time. A big drawback of using vase mode for Gridfinity bins was that they would be very flimsy, and would lack the features that make Gridfinity such a good organizational tool. The goal of this implementation was to maintain the design philosophy while working under the constraints of vase mode. </p>
|
||||
<p><img alt="Bin" src="../images/vase_dividers.gif" />
|
||||
<img alt="Bin" src="../images/vase_base.gif" /></p>
|
||||
<h2 id="instructions">Instructions</h2>
|
||||
<p>Normal Gridfinity is impossible to convert to vase mode due to the geometry of the bases, meaning most existing vase mode Gridfinity models are limited to 1x1 bins. How this script gets around the impossible is to use two separate pieces. <strong>The bin and bases must be printed separately, and then glued together to form the final bin.</strong> While this is slightly more work, there is an added bonus to this method, as for larger bins you may not need every single grid slot to have a base, you only really need them on the corners, or the edges, with some in the middle for support. Using less bases saves filament and print time.</p>
|
||||
<p>All parameters are global. The customizer has descriptions for all parameters. It is <strong>essential</strong> that the section <em>Printer Settings</em> matches your preferred slicer's settings, otherwise the model will not slice correctly. Additionally, you have to turn on the spiral vase parameter in your slicer. If you do not know what vase mode is, <a href="https://www.youtube.com/watch?v=HZSFoFYpBaA">this</a> is a helpful video. </p>
|
||||
<ol>
|
||||
<li>Change the <em>Printer Settings</em> parameters to match your slicer and printer settings.</li>
|
||||
<li>Run the <code>gridfinityVaseBase()</code> module. This will generate a single spiral-capable base. Export as an STL file. You will need to print multiple of these, so it recommended to fill a base plate with them using the "complete individual objects" option (or equivilant) in your slicer. You only need to do this step initially, and then each time your printer settings change afterwards. </li>
|
||||
<li>Change the bin parameters and run <code>gridfinityVase()</code> module to generate the main bin. </li>
|
||||
<li>Glue bases to the bottom of the bin. I recommend superglue on the corners and the top of the magnet holes. </li>
|
||||
</ol>
|
||||
<p>How your sliced files should look (cross section shown for 1x1 bin):</p>
|
||||
<p><img alt="Bin" src="../images/slicer_bin.png" />
|
||||
<img alt="Bin" src="../images/slicer_base.png" /></p>
|
||||
<p>Example sliced files can be found on the <a href="https://www.printables.com/model/284371-spiral-vase-gridfinity-in-openscad">Printables</a> page. </p>
|
||||
<h2 id="statistics">Statistics</h2>
|
||||
<p>Given how it has become a bit of a <a href="https://www.printables.com/model/265271-gridfinity-lite-economical-plain-storage-bins">challenge</a> to reduce the weight and print time for these bins, here is a comparison for a large bin:</p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Type</th>
|
||||
<th>Weight</th>
|
||||
<th>Time</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>Plain 4x2x6 Bin</td>
|
||||
<td>114.66g</td>
|
||||
<td>3h58m</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Vase 4x2x6 Bin with 8 Bases</td>
|
||||
<td>68.31g</td>
|
||||
<td>2h27m</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Vase 4x2x6 Bin with 4 Bases (only corners)</td>
|
||||
<td>56.43g</td>
|
||||
<td>1h59m</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<p>Clearly, vase mode is very quick and quite lightweight. However, this fundamentally means the bins will be weaker, so keep that in mind. </p>
|
||||
<h2 id="script-parameters">Script Parameters</h2>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Parameter</th>
|
||||
<th>Range</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>type</td>
|
||||
<td>{ 0 , 1 }</td>
|
||||
<td>generate the bin (0) or base (1)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>nozzle</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>extrusion width in slicer</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>layer</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>size of layers in slicer</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>bottom_layer</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of layers on the bottom of the print</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridx</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the x-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridy</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>number of bases along the y-axis</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>bin height. See bin height information and <br> "gridz_define" below.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>length</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>length of one unit of the base. <br> default: 42 (The Answer to the Ultimate Question of <br>Life, the Universe, and Everything.)</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>n_divx</td>
|
||||
<td>{ n>0 | n∈Z }</td>
|
||||
<td>number of compartments along X</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_holes</td>
|
||||
<td>boolean</td>
|
||||
<td>toggle holes inside the base</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_zsnap</td>
|
||||
<td>boolean</td>
|
||||
<td>automatically snap the bin size to the nearest <br> 7mm increment. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_lip</td>
|
||||
<td>boolean</td>
|
||||
<td>if you are not stacking the bin, you can disable the <br>top lip to save space. default: true</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_scoop_chamfer</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles the chamfer on bottom edge <br> for easy removal of items</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_funnel</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles funnel on back of tab. <br> acts as a finger grip and pour spout for small parts.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_inset</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles an inset on the front of the bin. <br> adds strength when using scoop.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>enable_pinch</td>
|
||||
<td>boolean</td>
|
||||
<td>toggles an outside pinch at the top lip of the bin. <br> adds strength.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>gridz_define</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>determine what the variable "gridz" applies to based on <br> your use case. default: 0. <br> • (0) gridz is the height in # of 7mm increments (Zack) <br> • (1) gridz is the internal height in mm <br> • (2) gridz is the overall external height of the bin in mm</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_tab</td>
|
||||
<td>{ 0, 1, 2, 3, 4, 5 }</td>
|
||||
<td>how the tabs for labels are generated. <br> • (0) Full tabs across the entire compartment <br> • (1) automatic tabs <br> - left aligned tabs on the left edge<br> - right aligned tabs on right edge<br> - center tabs otherwise <br> • (2) left aligned tabs <br> • (3) center aligned tabs <br> • (4) right aligned tabs <br> • (5) no tabs</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>style_base</td>
|
||||
<td>{ 0, 1, 2, 3, 4}</td>
|
||||
<td>specifies the locations for the "X" cutouts for bases. <br> • (0) all <br> • (1) corners <br> • (2) edges <br> • (3) automatic <br> • (4) none</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>a_tab</td>
|
||||
<td>{ n>0 | n∈R }</td>
|
||||
<td>angle of the tab</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<h2 id="modules">Modules</h2>
|
||||
<h3 id="gridfinityvase">gridfinityVase</h3>
|
||||
<p>Generates the compartment section of the bin. No parameters as it uses the global parameters for construction. </p>
|
||||
<p><strong><code>gridfinityVase()</code></strong></p>
|
||||
<h3 id="gridfinityvasebase">gridfinityVaseBase</h3>
|
||||
<p>Generates the base section of the bin. No parameters as it uses the global parameters for construction. It only generates a single base, as all of them are the same. Use your slicer with the "outpuit individual objects" option to print a full sheet of these, or as many as you need to fit your bins. </p>
|
||||
<p><strong><code>gridfinityVaseBase()</code></strong></p>
|
||||
|
||||
</div>
|
||||
</div><footer>
|
||||
<div class="rst-footer-buttons" role="navigation" aria-label="Footer Navigation">
|
||||
<a href="../lite/" class="btn btn-neutral float-left" title="Lite"><span class="icon icon-circle-arrow-left"></span> Previous</a>
|
||||
<a href="../constants/" class="btn btn-neutral float-right" title="Constants">Next <span class="icon icon-circle-arrow-right"></span></a>
|
||||
</div>
|
||||
|
||||
<hr/>
|
||||
|
||||
<div role="contentinfo">
|
||||
<!-- Copyright etc -->
|
||||
</div>
|
||||
|
||||
Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||||
</footer>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="rst-versions" role="note" aria-label="Versions">
|
||||
<span class="rst-current-version" data-toggle="rst-current-version">
|
||||
|
||||
|
||||
<span><a href="../lite/" style="color: #fcfcfc">« Previous</a></span>
|
||||
|
||||
|
||||
<span><a href="../constants/" style="color: #fcfcfc">Next »</a></span>
|
||||
|
||||
</span>
|
||||
</div>
|
||||
<script>var base_url = '..';</script>
|
||||
<script src="../js/theme_extra.js" defer></script>
|
||||
<script src="../js/theme.js" defer></script>
|
||||
<script src="../search/main.js" defer></script>
|
||||
<script defer>
|
||||
window.onload = function () {
|
||||
SphinxRtdTheme.Navigation.enable(true);
|
||||
};
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|