Skip to content

Commit

Permalink
huge reorg of how data is structured, adds kicanvas and 3d viewer embed
Browse files Browse the repository at this point in the history
  • Loading branch information
sphawes committed Jan 12, 2024
1 parent 86c6c31 commit 5084a7d
Show file tree
Hide file tree
Showing 12 changed files with 2,088 additions and 223 deletions.
2 changes: 1 addition & 1 deletion _config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
# You can create any custom variable you would like, and they will be accessible
# in the templates via {{ site.myvariable }}.

title: Midscale Manufacturing Resources
title: Midscale Manufacturing
email: [email protected]
description: >- # this means to ignore newlines until "baseurl:"
Building hardware is difficult. This site is a collection of tools and information that make designing, collaborating on, and distributing hardware at a Midscale easier.
Expand Down
13 changes: 6 additions & 7 deletions _data/navigation.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,15 @@
main:
# - title: "Quick-Start Guide"
# url: https://mmistakes.github.io/minimal-mistakes/docs/quick-start-guide/
- title: "ECAD"
url: ecad
- title: "MCAD"
url: mcad
- title: "MFG"
- title: "Design"
url: design
- title: "Manufacturing"
url: mfg
- title: "Documentation"
url: docs
- title: "Certification"
url: certs
- title: "Communication"
url: comm


ecad:
- title: Design
Expand Down
2 changes: 2 additions & 0 deletions _includes/head.html
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@
<link rel="preload" href="https://cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5/css/all.min.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
<noscript><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5/css/all.min.css"></noscript>

<script type="module" src="/assets/js/kicanvas.js"></script>

{% if site.head_scripts %}
{% for script in site.head_scripts %}
<script src="{{ script | relative_url }}"></script>
Expand Down
1,895 changes: 1,895 additions & 0 deletions assets/js/kicanvas.js

Large diffs are not rendered by default.

Binary file added assets/wireviz.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
65 changes: 0 additions & 65 deletions comm.md

This file was deleted.

52 changes: 52 additions & 0 deletions design.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
---
# Feel free to add content and custom Front Matter to this file.
# To modify the layout, see https://jekyllrb.com/docs/themes/#overriding-theme-defaults

# <span class="badge badge-primary">Github</span><span class="badge badge-secondary">Github</span><span class="badge badge-success">Github</span><span class="badge badge-danger">Github</span><span class="badge badge-info">Github</span>

title: "Design Tools"
layout: single
header:
overlay_color: "#000"
overlay_filter: "0.65"
overlay_image: /assets/feature.jpg
caption: "Photo credit: **Tobias Netzer**"
sidebar:
nav: "design"
---

## Electrical

### [KiCAD](https://www.kicad.org/)
<span class="badge badge-success">Open Source</span>

With ECAD software, there's really only one serious option: KiCAD. KiCAD is a powerful, professional PCB design package. It has a vast plugin system, and being open source means it has a ton of automation potential. Lots of the other tools on this page rely on the fact that KiCAD is the EDA of choice.

### [WireViz](https://github.com/wireviz/WireViz)
<span class="badge badge-success">Open Source</span>

![](/assets/wireviz.png)

WireViz is a fantastic way to document your cables and wire harnesses. Using a simple YAML file, you can define complex cable harness assemblies in a git-trackable filetype, and easily export beautiful graphical output for an engineering drawing or assembly technician.

## Mechanical

### FreeCAD
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

FreeCAD is the most mature, stable, and fully-featured open source mechanical cad package. It has the traditional user experience of other desktop CAD software instead of being software-defined like most other open MCAD suites.

FreeCAD can be easy to learn, but feature trees are notoriously fragile due to the [Topological Naming Problem](https://wiki.freecad.org/Topological_naming_problem). The most consistent way to deal with this issue is to use a Direct Modeling methodology, as opposed to a Parametric one. The main [difference between the two](https://3space.com/parametric-vs-direct-modeling/) is that Direct Modeling does not go back in the feature tree, only ever adding on new cuts and extrudes. It is also possible to have parametric designs in FreeCAD with [careful use of datum planes](https://wiki.freecad.org/Topological_naming_problem#Solution).

This being said, this issue is actively being addressed by the FreeCAD community, and the [open-core](https://en.wikipedia.org/wiki/Open-core_model) company [Ondsel](https://ondsel.com/blog) based on the FreeCAD project.

### [OpenSCAD](https://openscad.org/)
<span class="badge badge-success">Open Source</span>

### [CADQuery](https://cadquery.readthedocs.io/en/latest/)
<span class="badge badge-success">Open Source</span>

### Blender
<span class="badge badge-success">Open Source</span>

can only run CI in the way that it can render an existing .blend file, doesnt seem to be able to edit that .blend file at all
114 changes: 114 additions & 0 deletions docs.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
---
# Feel free to add content and custom Front Matter to this file.
# To modify the layout, see https://jekyllrb.com/docs/themes/#overriding-theme-defaults

# <span class="badge badge-primary">Github CI</span>
#<span class="badge badge-secondary">Web Service</span>
#<span class="badge badge-success">Open Source</span>
#<span class="badge badge-danger">Paid Service</span>
#<span class="badge badge-info">Free Service</span>

title: "Documentation Tools"
layout: single
header:
overlay_color: "#000"
overlay_filter: "0.65"
overlay_image: /assets/feature.jpg
caption: "Photo credit: **Tobias Netzer**"
sidebar:
nav: "docs"
---

## Docs Site

### [Github Pages](https://pages.github.com/)
<span class="badge badge-primary">Github CI</span><span class="badge badge-info">Free Service</span>

Regardless of the static site generator you choose, using Github Pages as the hosting service for your documentation is a great choice. It is free to deploy, completely automatic after your CI script is set, and there's tons of documentation around getting started. Plus, managing your documentation in git means it's incredibly easy to manage docs release alongside product updates.

### MKDocs
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

MKDocs is by far the easiest and most straightforward to get beautiful documentation on the web. Accepting garden-variety Markdown as the copy format, it's dead simple to write for, and the results look spectacular. MKDocs also is [very easily deployable](https://github.com/opulo-inc/docs/blob/main/.github/workflows/ci.yaml) using Github Pages, so a simple `git push origin main` will deploy your doc instructions to production. Fixing a bug on the site can literally be a less than a minute ordeal.

## Community

### [Discord](https://discord.com/)
<span class="badge badge-info">Free Service</span>

Discord is effectively a nice UI wrapped around the basics of IRC. Many communities have flocked to Discord as a place for conversation over the past 5 years, and in response Discord recently released a number of community-specific features that make this even easier. Some pithy features are gated behind a paywall, but the basic communication functionality is fantastic for building an engaged community. Given that it's real-time text communication, discussions can happen much faster than in something like a forum.

### [Discourse](https://www.discourse.org/)
<span class="badge badge-success">Open Source</span><span class="badge badge-info">Free Service</span>

Discourse is the best way to build your own forum. Although conversation might happen a bit slower in a forum rather than a Discord server, the results of discussions are highly searchable, and a forum setting is more familiar to some folks than a real-time chat app.


MCAD automation tools are mostly geared towards exporting as STLs or STEPs for 3D printing, or rendering an image for viewing/BOM usage. Open CAD packages like FreeCAD, OpenSCAD, and CADQuery take the most advantage of this, handling all exports using their CLI interfaces. Proprietary tools can take advantage of automatic rendering by first exporting to an interchange format. See bulk exporting for [Fusion360](https://www.autodesk.com/support/technical/article/caas/sfdcarticles/sfdcarticles/How-to-export-specific-bodies-in-a-file-to-a-STEP-file-from-Fusion-360.html) and [Solidworks](https://help.solidworks.com/2023/english/WhatsNew/c_wn2023_import_export_assembly_step.htm?id=4dca041efcda481ca1e9f214d4725333#:~:text=You%20can%20export%20large%20SOLIDWORKS,assemblies%20as%20atomic%20STEP%20files.).


## Export/Render

### [AutoBOM](https://github.com/opulo-inc/lumenpnp/blob/main/.github/workflows/export-bom.yaml) (Opulo's BOM Generator)
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

AutoBOM is a series of Python scripts and CI builds developed by Opulo that automatically exports a standalone downloadable webpage Bill of Materials based on a GitHub repo. AutoBOM expects to find an up-to-date `bom.csv` file in the repo's root directory, and that source files are made with FreeCAD and KiCAD. The BOM will even include rendered images of all FreeCAD files and KiCAD PCBs included in the `bom.csv`. You can see an example by downloading the BOM.zip file attached to the most recent release [here](https://github.com/opulo-inc/feeder/releases/).

### FreeCAD STL Export
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

### OpenSCAD STL Rendering
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

[OpenSCAD CLI Manual](https://en.wikibooks.org/wiki/OpenSCAD_User_Manual/Using_OpenSCAD_in_a_command_line_environment)

```
openscad
-o part.png
--colorscheme BeforeDawn
--imgsize 512,512
--quiet --render --projection=o --viewall --hardwarnings
./part.scad
```

### Blender .blend Rendering

[CLI rendering in Blender](https://docs.blender.org/manual/en/latest/advanced/command_line/render.html)

### [KiBot](https://github.com/INTI-CMNB/KiBot)
<span class="badge badge-success">Open Source</span><span class="badge badge-primary">Github CI</span>

KiBot is an export tool for KiCAD designs. KiBot is capable of exporting gerbers of your board, 3D models, images, stencils, and even run ERC/DRC a final time before export.

KiBot is great for automating the export of gerber files on release, or when run manually in GitHub. It can also help with exporting images of PCBs for documentation purposes. For example, Opulo feeders have a [CI workflow](https://github.com/opulo-inc/feeder/blob/main/.github/workflows/export-ecad.yaml) that automatically exports all feeder PCBs for easy community use and reference.

### [pcb2blender](https://github.com/30350n/pcb2blender)
<span class="badge badge-success">Open Source</span>

Turn KiCad designs into Blender files to create beautiful renders for your PCBs!

![pcb2blender example](assets/pcb2blender_example.webp)

## Web Viewers

### [3dviewer.net](https://3dviewer.net/)
<span class="badge badge-success">Open Source</span><span class="badge badge-info">Free Service</span>

<iframe width="640" height="480" style="border:1px solid #eeeeee;" src="https://3dviewer.net/embed.html#model=https://raw.githubusercontent.com/opulo-inc/lumenpnp/main/pnp/cad/FDM/back-leg.FCStd$camera=-217.09205,134.93892,8.02837,-34.00000,0.00000,-85.00000,0.00000,1.00000,0.00000,45.00000$projectionmode=perspective$envsettings=fishermans_bastion,off$backgroundcolor=255,255,255,255$defaultcolor=200,200,200$defaultlinecolor=100,100,100$edgesettings=off,0,0,0,1"></iframe>

3D Viewer is a fantastic tool for sharing and viewing FreeCAD source files (among many others). You can easily share links to view a FreeCAD file that's hosted on Github. [Example](https://3dviewer.net/#model=https://github.com/opulo-inc/lumenpnp/blob/main/pnp/cad/FDM/back-leg.FCStd) It also has embedding support, allowing you to put a KiCanvas viewer on your own site, which you can see above.




### [KiCanvas](https://kicanvas.org/)
<span class="badge badge-success">Open Source</span><span class="badge badge-info">Free Service</span>

KiCanvas is a fantastic tool for sharing and viewing KiCAD source files. You can paste a GitHub link into [KiCanvas.org](https://kicanvas.org/) to immediately view in-browser. You can also easily share [links](https://kicanvas.org/?github=https%3A%2F%2Fgithub.com%2Fopulo-inc%2Ffeeder%2Ftree%2Fmain%2Fpcb%2Fmobo) to view a FreeCAD file that's hosted on Github. KiCanvas also has embedding support, allowing you to put a KiCanvas viewer on your own site.

<kicanvas-embed src="https://raw.githubusercontent.com/opulo-inc/lumenpnp/main/pnp/pcb/mobo/mobo.kicad_pcb" controls="basic"> </kicanvas-embed>


### [Tracespace](https://tracespace.io/view/)
<span class="badge badge-info">Free Service</span>

69 changes: 0 additions & 69 deletions ecad.md

This file was deleted.

Loading

0 comments on commit 5084a7d

Please sign in to comment.