Skip to content

A simple GCode parser & previewer with 3D printing in mind. Written in Typescript.

License

Notifications You must be signed in to change notification settings

xuzhen1994/gcode-preview

 
 

Repository files navigation

GCode Preview npm version MIT license Buy Me A Coffee

A simple G-code parser & viewer with 3D printing in mind. Written in Typescript.

Join us on discord

feature summary

  • multi-color
  • tube geometry (experimental)
  • g2/g3 arcs
  • thumbnail preview
  • build volume
  • examples for various frameworks

Demo

Click to see the interactive demo: image

Installation

npm version

npm install gcode-preview

Quick start

  import * as GCodePreview from 'gcode-preview';

  const preview = GCodePreview.init({
      canvas: document.querySelector('canvas'),
      extrusionColor: 'hotpink'
  });
  
  // draw a diagonal line
  const gcode = 'G0 X0 Y0 Z0.2\nG1 X42 Y42 E10';
  preview.processGCode(gcode);

API Docs

Check the full API documentation at https://gcode-preview.web.app/docs

Vue.js / React / Svelte integration

There's a Vue.js example that has a Vue component to wrap the library.

@Zeng95 provided a React & Typescript example that has a React component to wrap the library.

There is a Svelte example with a Svelte component.

Features

New: multi-color support

GCode files that were sliced for a multi-tool system can be previewed as such. Assign an array of colors to the extrusionColor property, where the index in the array corresponds to the index of the tool: T0..T7.

example:

extrusionColor: ['hotpink', 'indigo', 'lime']

Here, T0 is hotpink, T1 is indigo and T2 is lime.

image

Supported systems include:

  • Prusa MMU1/2/3 and XL
  • Bambulab AMS & AMS lite
  • Enraged Rabbit Carrot Feeder (ERCF)
  • IDEX machines
  • toolchangers
  • 3D Chameleon
  • Virtual tools (color mixing)
  • and possibly more

Experimental: render extrusion as tubes

renderTubes : true

G2/G3 arc support

Thanks to @Sindarius arc commands are now supported, which means gcode processed by ArcWelder should be rendered correctly.

3D WebGL + pan/zoom/rotate controls

Demo Animation

Thumbnail preview

Thumbnail previews as generated by PrusaSlicer are detected and parsed. In the gcode these are found in comments, enclosed between 'thumbnail begin' and 'thumbnail end'. The images are encoded as base64 strings but split over multiple lines. These are now parsed and patched back together, but still kept a base64. This allows easy use in the browser for us as data urls.

image

The thumbnails can be accessed like this: gcodePreview.parser.metadata.thumbnails['220x124']

Thumbnails have a .src property that will create a usable data url from the base64 string.

See an example in the demo source.

Build volume

The build volume will be rendered if the buildVolume parameter is passed. It has the following type:

buildVolume: { 
  x: number; 
  y: number; 
  z: number
}

example:

Feedback

If you have found a bug or if have an idea for a feature, don't hesitate to create an issue on GitHub or talk to us on Discord.

Contributing

It would be great if you want to help! Maybe you'd like to help out with:

  • testing GCode Preview with a variety of gcode files, from different slicers
  • making GCode Preview suitable for different printer types, like Deltas, Belt printers, IDEX, etc.
  • please report any bugs you find and add as much detail as possible, or even better, a screenshot
  • even better yet: send in a pull request :-)
  • apart from the main code, lots of improvements can still be made in:
    • documentation
    • unit tests

Contributors

  • ❤️ Thank you @sophiedeziel for rendering extrusion as tubes.
  • ❤️ Thank you @Sindarius for implementing G2/G3 arc support.
  • ❤️ Thank you @Zeng95 for providing a React & Typescript example.

Changelog

Jump to the CHANGELOG

Known issues

Preview doesn't render in Brave

This is caused by the device recognition shield in Brave. By changing the setting for "Device Recognition" in Shield settings to "Allow all device recognition attemps" or "Only block cross-site device recognition attemps" you should not get this error. mrdoob/three.js#16904

Sponsors

A big thanks to these sponsors for their contributions.

Donate

If you want to show gratitude you can always buy me beer/coffee/filament via a Paypal donation ^_^

About

A simple GCode parser & previewer with 3D printing in mind. Written in Typescript.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 97.3%
  • JavaScript 2.3%
  • CSS 0.4%