mirror of
https://github.com/OrcaSlicer/OrcaSlicer.git
synced 2026-05-28 15:45:30 +00:00
Updated Wiki content
7
Home.md
7
Home.md
@@ -2,6 +2,7 @@ Welcome to the OrcaSlicer WIKI!
|
|||||||
|
|
||||||
We have divided it roughly into the following pages:
|
We have divided it roughly into the following pages:
|
||||||
|
|
||||||
* [Calibration](wiki/Calibration)
|
- [Calibration](./Calibration)
|
||||||
* [Print settings](wiki/Print-settings)
|
- [Print settings](./Print-settings)
|
||||||
* [How to build Orca Slicer](wiki/How-to-build)
|
- [How to build Orca Slicer](./How-to-build)
|
||||||
|
- [Developer Reference](./developer-reference/Home)
|
||||||
|
|||||||
6
developer-reference/Home.md
Normal file
6
developer-reference/Home.md
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
# For Developers
|
||||||
|
|
||||||
|
This is a documentation from someone exploring the code and is by no means complete or even completely accurate. Please edit the parts you might find inaccurate. This is probably going to be helpful nonetheless.
|
||||||
|
|
||||||
|
- [Preset, PresetBundle and PresetCollection](./Preset-and-bundle)
|
||||||
|
- [Plater, Sidebar, Tab, ComboBox](./plater-sidebar-tab-combobox)
|
||||||
43
developer-reference/Preset-and-bundle.md
Normal file
43
developer-reference/Preset-and-bundle.md
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
This page deals with the explanation for 3 classes in the code.
|
||||||
|
|
||||||
|
## [`Preset`](../../src/libslic3r/Preset.hpp)
|
||||||
|
|
||||||
|
As the name might suggest this class deals with presets for various things. It defines an enum `Type` which basically tells you what kind of data the present contains. Below are a few explained and there corresponding UI elements
|
||||||
|
|
||||||
|
#### Note: There is a lot of outdated and legacy code in the code base.
|
||||||
|
|
||||||
|
- `TYPE_PRINT`: Refers to a process preset. It's called 'Print' probably due to some legacy code.
|
||||||
|
|
||||||
|
<img src="../images/process-preset.png" alt="Example Image" width="320">
|
||||||
|
|
||||||
|
- `TYPE_FILAMENT`: As the name suggests this preset is for filaments
|
||||||
|
|
||||||
|
<img src="../images/filament-preset.png" alt="Example Image" width="320">
|
||||||
|
|
||||||
|
- `TYPE_PRINTER`: Preset for printers.
|
||||||
|
|
||||||
|
<img src="../images/printer-preset.png" alt="Example Image" width="320">
|
||||||
|
|
||||||
|
There are other preset types but some of them are for SLA. Which is legacy code, since SLA printers are no longer supported. Above 3 are the important types.
|
||||||
|
|
||||||
|
## [`PresetBundle`](../../src/libslic3r/PresetBundle.hpp)
|
||||||
|
|
||||||
|
This is a bundle containing a few types of `PresetCollection`. One bundle has presets for some printers, filaments and some processes (TYPE_PRINT).
|
||||||
|
|
||||||
|
`PresetCollection prints`\
|
||||||
|
`PresetCollection filaments`\
|
||||||
|
`PrinterPresetCollection printers`
|
||||||
|
|
||||||
|
each one of these contains a collection of processes, filaments and printers respectively.\
|
||||||
|
|
||||||
|
#### Note: Printers, filaments and processes in the bundle don't all have to be compatible with each other. In fact all the saved presets are stored in one `PresetBundle`. The `PresetBundle` is loaded on start up. The list of filaments and processes shown for a particular printer is a subset of `filaments` and `prints` `PresetCollection`s.
|
||||||
|
|
||||||
|
## [`PresetCollection`](../../src/libslic3r/Preset.hpp)
|
||||||
|
|
||||||
|
`PrinterPresetCollection` is a class derived from `PresetCollection`.
|
||||||
|
|
||||||
|
These contain a collection of presets. The presets could be of any type.\
|
||||||
|
functions of note here are:
|
||||||
|
|
||||||
|
`get_edited_preset()`: returns the current selected preset along with any modifications the user has made.\
|
||||||
|
`get_selected_preset()`: returns the current selected preset without the modifications the user has made.
|
||||||
23
developer-reference/plater-sidebar-tab-combobox.md
Normal file
23
developer-reference/plater-sidebar-tab-combobox.md
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
### !! incomplete, possibly inaccurate, being updated with new info !!
|
||||||
|
|
||||||
|
## [`Plater`](../../src/slic3r/GUI/Plater.hpp)
|
||||||
|
|
||||||
|
Refers to the entire application. The whole view, file loading, project saving and loading is all managed by this class. This class contains members for the model viewer, the sidebar, gcode viewer and everything else.
|
||||||
|
|
||||||
|
## [`Sidebar`](../../src/slic3r/GUI/Plater.hpp)
|
||||||
|
|
||||||
|
This is relating the the sidebar in the application window
|
||||||
|
|
||||||
|
<img src="../images/full-sidebar.png" alt="Example Image" width="320">
|
||||||
|
|
||||||
|
## [`ComboBox`](../../src/slic3r/GUI/Widgets/ComboBox.hpp)
|
||||||
|
|
||||||
|
The drop down menus where you can see and select presets
|
||||||
|
|
||||||
|
<img src="../images/combobox.png" alt="Example Image" width="320">
|
||||||
|
|
||||||
|
## [`Tab`](../../src/slic3r/GUI/Tab.hpp)
|
||||||
|
|
||||||
|
Refers to the various windows with settings. e.g. the Popup to edit printer or filament preset. Also the section to edit process preset and the object list. These 4 are managed by `TabPrinter`, `TabFilament`, `TabPrint` and `TabPrintModel` respectively.
|
||||||
|
|
||||||
|
<img src="../images/tab-popup.png" alt="Example Image" width="320">
|
||||||
BIN
images/combobox.png
Normal file
BIN
images/combobox.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 3.4 KiB |
BIN
images/filament-preset.png
Normal file
BIN
images/filament-preset.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 4.4 KiB |
BIN
images/full-sidebar.png
Normal file
BIN
images/full-sidebar.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 81 KiB |
BIN
images/printer-preset.png
Normal file
BIN
images/printer-preset.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 7.7 KiB |
BIN
images/process-preset.png
Normal file
BIN
images/process-preset.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 68 KiB |
BIN
images/tab-popup.png
Normal file
BIN
images/tab-popup.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 122 KiB |
23
pellet-flow-coefficient.md
Normal file
23
pellet-flow-coefficient.md
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
Large format printers with print volumes in the order of 1m^3 generally use pellets for printing.
|
||||||
|
The overall tech is very similar to FDM printing.
|
||||||
|
It is FDM printing, but instead of filaments, it uses pellets.
|
||||||
|
|
||||||
|
The difference here is that where filaments have a filament_diameter that is used to calculate
|
||||||
|
the volume of filament ingested, pellets have a particular flow_coefficient that is empirically
|
||||||
|
devised for that particular pellet.
|
||||||
|
|
||||||
|
pellet_flow_coefficient is basically a measure of the packing density of a particular pellet.
|
||||||
|
Shape, material and density of an individual pellet will determine the packing density and
|
||||||
|
the only thing that matters for 3d printing is how much of that pellet material is extruded by
|
||||||
|
one turn of whatever feeding mehcanism/gear your printer uses. You can emperically derive that
|
||||||
|
for your own pellets for a particular printer model.
|
||||||
|
|
||||||
|
We are translating the pellet_flow_coefficient into filament_diameter so that everything works just like it
|
||||||
|
does already with very minor adjustments.
|
||||||
|
|
||||||
|
filament_diameter = sqrt( (4 \* pellet_flow_coefficient) / PI )
|
||||||
|
|
||||||
|
sqrt just makes the relationship between flow_coefficient and volume linear.
|
||||||
|
|
||||||
|
higher packing density -> more material extruded by single turn -> higher pellet_flow_coefficient -> treated as if a filament of larger diameter is being used
|
||||||
|
All other calculations remain the same for slicing.
|
||||||
Reference in New Issue
Block a user