Skip to content
bitli edited this page Aug 17, 2014 · 2 revisions

Internal overviews

The MatterSlice engine derives its current structure from the CuraEngine, although it is organized following dotNet practices and some effort were done for using more meaningful names in some places.

This description is based on the original CuraEngine description and some examination of the code.

The global structure is:

  1. The command line is processed to know what to do. (main.cs)
  2. The settings are loaded up. (Settings.cs)
  3. The STL is loaded (modelFile.cs)
  4. The FFF processor is run on to do the processing (fffProcessor.cs)

the fffProcessor slice the source file following these steps:

  1. Load 3D model (see ModelLoading).
  2. Analyse and fix 3D model (see ModelOptimization).
  3. Slice 3D model into 2D layers (see Slicing).
  4. Build LayerParts from sliced layers (see LayerPartsGeneration).
  5. Generate Insets (see InsetsGeneration).
  6. Generate up/down skins areas (see SkinGeneration).
  7. Generate sparse infill areas (see SkinGeneration).
  8. Generate GCode for each layer (see GCodeGeneration).

Each step has more logic in it. But this is a general overview. All data for the engine is stored in the "sliceDataStorage". It's important to remember that only the data from the previous step is valid.

Coordinates are stored in 64bit integers as microns in the code. So if you see a value of 1000 then this mean 1mm of distance. This is because Clipper works on 64bit integers and microns give a high enough resolution without limiting the size too much. Note that there are some bits and pieces of code that need to be careful about 64bit overflows, especially calculating lengths sqrt(xx+yy) can cause overflows.

Clone this wiki locally