Blog

Rendering STL in Markdown on GitHub

07 Sep, 2022
Xebia Background Header Wave

A few months ago, GitHub announced some new features when it comes to Markdown rendering. In the announcement they announce support for geoJSON and topoJSON, and to my delight, STL. I use STLs a lot for 3D printing and this is that little nudge I needed to start storing my own designs in GitHub instead of only having them on Thingiverse. There is just one issue though, to use the new Markdown features you need an ACII STL, but that’s not what you’ll find online most of the time, we like sharing our STLs in binary!

How to convert binary STL to ASCII STL

When you download, or even create an STL, chances are that you’ll create a binary file. These are compact and make them perfect for sharing. But for Markdown, we need something called ASCII STL. Luckily we can convert between the two, for free! These are the steps I took: Download FreeCAD. This free CAD software supports many different formats.

1. Import your binary STL

Go to File > Open and open your STL. I’m using my Azure Percept Stand as an example:

Opening a file in FreeCAD

2. Export ASCII STL

To export your model, select it (or hit ctrl-a) and go to File > Export. Here you want to select STL as the file type. Note that behind the file type you’ll see two file extensions (<em>.stl </em>ast). If you save it as an .stl, you’ll just end up with another binary format. Instead, name your model <model name>.ast

Opening a file in FreeCAD

3. Open the ASCII STL file

When you open your newly created file in a text editor, you can view the ASCII STL definition.

solid Mesh
  facet normal -0.000000 1.000000 0.000000
    outer loop
      vertex 15.337000 15.000000 109.000000
      vertex 15.337000 15.000000 139.000000
      vertex 99.000000 15.000000 0.000000
    endloop
  endfacet
  ...

Copy and paste this in any place where you can write markdown, make certain to wrap it in a code block like so:

```stl
[your ascii stl here]
```

Here are just a few examples of what you can do with the new STL Markdown features. I’m sure we’ll see some great examples in the community soon!

Screenshot of a GitHub Issue with STL markdown Example

Include a preview in your README files

Screenshot of a rendered README file with STL markdown Example

Matthijs van der Veer
Matthijs is a consultant at Xebia, with a strong focus on Generative AI. He loves helping people achieve more in the cloud.
Questions?

Get in touch with us to learn more about the subject and related solutions

Explore related posts