0
0
mirror of https://github.com/Doodle3D/Doodle3D-Slicer.git synced 2025-01-06 09:53:48 +01:00
Go to file
2018-03-06 17:26:32 +01:00
img added logo 2018-01-30 00:19:05 +01:00
models Slicer now slices d3sketch files instead of stl's 2017-12-18 16:37:03 +01:00
src rename vars 2018-03-06 17:26:32 +01:00
.babelrc add transform-class-properties 2017-12-21 12:49:44 +01:00
.gitignore move example 2017-11-16 22:40:39 +01:00
.npmignore move example 2017-11-16 22:40:39 +01:00
DOCS.md remove comma 2018-02-19 18:02:57 +01:00
favicon.ico add favicon 2018-01-30 19:41:30 +01:00
index.js don't require a model for the slicer interface 2018-01-17 17:18:28 +01:00
package-lock.json lock doodle3d core version 2018-02-19 13:53:44 +01:00
package.json lock doodle3d core version 2018-02-19 13:53:44 +01:00
README.md rename base to default 2017-12-24 14:46:00 +01:00
webpack.config.js update web pack config 2018-03-06 17:17:05 +01:00

Doodle3D-Slicer

JavaScript gcode slicer, Intended to use with the Doodle3D WiFi-Box

Usage

import * as THREE from 'three';
import { defaultSettings, sliceGeometry } from 'Doodle3D/Doodle3D-Slicer';

const settings = {
  ...defaultSettings.default,
  ...defaultSettings.material.pla,
  ...defaultSettings.printer.ultimaker2go,
  ...defaultSettings.quality.high
};

const geometry = new THREE.TorusGeometry(20, 10, 30, 30).clone();

const gcode = await sliceGeometry(settings, geometry);

API

Settings

import { defaultSettings } from 'Doodle3D/Doodle3D-Slicer';

const settings = {
  ...defaultSettings.default,
  ...defaultSettings.material.pla,
  ...defaultSettings.printer.ultimaker2go,
  ...defaultSettings.quality.high
};

Create settings object to be used by the slicer

Slice Mesh

import { sliceMesh } from 'Doodle3D/Doodle3D-Slicer';

GCode: String = sliceMesh(settings: Object, mesh: THREE.Mesh, [sync: Boolean = false, onProgress: Func ])

Slice function that accepts Meshes

  • Settings: settings object (see settings)
  • Mesh: THREE.Mesh instance that contains the geometry
  • Sync: determines if the slicing progress will be sync (blocking) or async (non-blocking). A webworker is used to slice async
  • onProgress: progress callback

Slice Geometry

import { sliceGeometry } from 'Doodle3D/Doodle3D-Slicer';

GCode: String = sliceGeometry(settings: Object, geometry: THREE.Geometry | THREE.BufferGeometry, [matrix: THREE.Matrix, sync: Boolean = false, onProgress: Func ])

Slice function that accepts Geometry

  • Settings: settings object (see settings)
  • Geometry: THREE.Geometry instance
  • matrix: matrix that can control the scale, rotation and position of the model
  • Sync: determines if the slicing progress will be sync (blocking) or async (non-blocking). A webworker is used to slice async
  • onProgress: progress callback