mirror of
https://github.com/kennetek/gridfinity-rebuilt-openscad.git
synced 2025-01-08 15:19:43 +00:00
318 lines
13 KiB
HTML
Executable file
318 lines
13 KiB
HTML
Executable file
<!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>size of 3D printer nozzle</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>
|