mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Some incomplete work for per-region config
This commit is contained in:
parent
2e7b29fbdd
commit
691db31da0
9 changed files with 151 additions and 92 deletions
|
@ -1,6 +1,8 @@
|
||||||
package Slic3r::Format::STL;
|
package Slic3r::Format::STL;
|
||||||
use Moo;
|
use Moo;
|
||||||
|
|
||||||
|
use File::Basename qw(basename);
|
||||||
|
|
||||||
sub read_file {
|
sub read_file {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($file) = @_;
|
my ($file) = @_;
|
||||||
|
@ -10,8 +12,11 @@ sub read_file {
|
||||||
$mesh->repair;
|
$mesh->repair;
|
||||||
|
|
||||||
my $model = Slic3r::Model->new;
|
my $model = Slic3r::Model->new;
|
||||||
|
|
||||||
|
my $material_id = basename($file);
|
||||||
|
$model->set_material($material_id);
|
||||||
my $object = $model->add_object;
|
my $object = $model->add_object;
|
||||||
my $volume = $object->add_volume(mesh => $mesh);
|
my $volume = $object->add_volume(mesh => $mesh, material_id => $material_id);
|
||||||
return $model;
|
return $model;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ use Slic3r::GUI::Plater;
|
||||||
use Slic3r::GUI::Plater::ObjectPartsPanel;
|
use Slic3r::GUI::Plater::ObjectPartsPanel;
|
||||||
use Slic3r::GUI::Plater::ObjectPreviewDialog;
|
use Slic3r::GUI::Plater::ObjectPreviewDialog;
|
||||||
use Slic3r::GUI::Plater::ObjectSettingsDialog;
|
use Slic3r::GUI::Plater::ObjectSettingsDialog;
|
||||||
|
use Slic3r::GUI::Plater::OverrideSettingsPanel;
|
||||||
use Slic3r::GUI::Preferences;
|
use Slic3r::GUI::Preferences;
|
||||||
use Slic3r::GUI::OptionsGroup;
|
use Slic3r::GUI::OptionsGroup;
|
||||||
use Slic3r::GUI::SkeinPanel;
|
use Slic3r::GUI::SkeinPanel;
|
||||||
|
|
|
@ -53,10 +53,19 @@ sub new {
|
||||||
$self->{btn_load_modifier}->SetFont($Slic3r::GUI::small_font);
|
$self->{btn_load_modifier}->SetFont($Slic3r::GUI::small_font);
|
||||||
$self->{btn_delete}->SetFont($Slic3r::GUI::small_font);
|
$self->{btn_delete}->SetFont($Slic3r::GUI::small_font);
|
||||||
|
|
||||||
|
# part settings panel
|
||||||
|
$self->{settings_panel} = Slic3r::GUI::Plater::OverrideSettingsPanel->new(
|
||||||
|
$self,
|
||||||
|
opt_keys => Slic3r::Config::PrintRegion->new->get_keys,
|
||||||
|
);
|
||||||
|
my $settings_sizer = Wx::StaticBoxSizer->new(Wx::StaticBox->new($self, -1, "Part Settings"), wxVERTICAL);
|
||||||
|
$settings_sizer->Add($self->{settings_panel}, 1, wxEXPAND | wxALL, 0);
|
||||||
|
|
||||||
# left pane with tree
|
# left pane with tree
|
||||||
my $left_sizer = Wx::BoxSizer->new(wxVERTICAL);
|
my $left_sizer = Wx::BoxSizer->new(wxVERTICAL);
|
||||||
$left_sizer->Add($tree, 0, wxEXPAND | wxLEFT | wxRIGHT | wxBOTTOM, 10);
|
$left_sizer->Add($tree, 0, wxEXPAND | wxLEFT | wxRIGHT | wxBOTTOM, 10);
|
||||||
$left_sizer->Add($buttons_sizer, 0, wxEXPAND | wxLEFT | wxRIGHT | wxBOTTOM, 10);
|
$left_sizer->Add($buttons_sizer, 0, wxEXPAND | wxLEFT | wxRIGHT | wxBOTTOM, 10);
|
||||||
|
$left_sizer->Add($settings_sizer, 1, wxEXPAND | wxALL, 0);
|
||||||
|
|
||||||
# right pane with preview canvas
|
# right pane with preview canvas
|
||||||
my $canvas;
|
my $canvas;
|
||||||
|
@ -134,8 +143,9 @@ sub selection_changed {
|
||||||
$_->{selected} = 0 for @{$self->{canvas}->volumes};
|
$_->{selected} = 0 for @{$self->{canvas}->volumes};
|
||||||
}
|
}
|
||||||
|
|
||||||
# disable buttons
|
# disable things as if nothing is selected
|
||||||
$self->{btn_delete}->Disable;
|
$self->{btn_delete}->Disable;
|
||||||
|
$self->{settings_panel}->Disable;
|
||||||
|
|
||||||
my $itemData = $self->get_selection;
|
my $itemData = $self->get_selection;
|
||||||
if ($itemData && $itemData->{type} eq 'volume') {
|
if ($itemData && $itemData->{type} eq 'volume') {
|
||||||
|
@ -143,6 +153,12 @@ sub selection_changed {
|
||||||
$self->{canvas}->volumes->[ $itemData->{volume_id} ]{selected} = 1;
|
$self->{canvas}->volumes->[ $itemData->{volume_id} ]{selected} = 1;
|
||||||
}
|
}
|
||||||
$self->{btn_delete}->Enable;
|
$self->{btn_delete}->Enable;
|
||||||
|
|
||||||
|
my $volume = $self->{model_object}->volumes->[ $itemData->{volume_id} ];
|
||||||
|
my $material = $self->{model_object}->model->materials->{ $volume->material_id // '_' };
|
||||||
|
$material //= $volume->assign_unique_material;
|
||||||
|
$self->{settings_panel}->Enable;
|
||||||
|
$self->{settings_panel}->set_config($material->config);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{canvas}->Render if $self->{canvas};
|
$self->{canvas}->Render if $self->{canvas};
|
||||||
|
|
|
@ -72,35 +72,12 @@ sub new {
|
||||||
$self->{sizer}->Add($label, 0, wxEXPAND | wxTOP | wxLEFT | wxRIGHT, 10);
|
$self->{sizer}->Add($label, 0, wxEXPAND | wxTOP | wxLEFT | wxRIGHT, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
# option selector
|
$self->{settings_panel} = Slic3r::GUI::Plater::OverrideSettingsPanel->new(
|
||||||
{
|
$self,
|
||||||
# get all options with object scope and sort them by category+label
|
config => $self->model_object->config,
|
||||||
my %settings = map { $_ => sprintf('%s > %s', $Slic3r::Config::Options->{$_}{category}, $Slic3r::Config::Options->{$_}{full_label} // $Slic3r::Config::Options->{$_}{label}) }
|
opt_keys => [ map @{$_->get_keys}, Slic3r::Config::PrintObject->new, Slic3r::Config::PrintRegion->new ],
|
||||||
grep { ($Slic3r::Config::Options->{$_}{scope} // '') eq 'object' }
|
);
|
||||||
keys %$Slic3r::Config::Options;
|
$self->{sizer}->Add($self->{settings_panel}, 1, wxEXPAND | wxLEFT | wxRIGHT, 10);
|
||||||
$self->{options} = [ sort { $settings{$a} cmp $settings{$b} } keys %settings ];
|
|
||||||
my $choice = Wx::Choice->new($self, -1, wxDefaultPosition, [150, -1], [ map $settings{$_}, @{$self->{options}} ]);
|
|
||||||
|
|
||||||
# create the button
|
|
||||||
my $btn = Wx::BitmapButton->new($self, -1, Wx::Bitmap->new("$Slic3r::var/add.png", wxBITMAP_TYPE_PNG));
|
|
||||||
EVT_BUTTON($self, $btn, sub {
|
|
||||||
my $idx = $choice->GetSelection;
|
|
||||||
return if $idx == -1; # lack of selected item, can happen on Windows
|
|
||||||
my $opt_key = $self->{options}[$idx];
|
|
||||||
$self->model_object->config->apply(Slic3r::Config->new_from_defaults($opt_key));
|
|
||||||
$self->update_optgroup;
|
|
||||||
});
|
|
||||||
|
|
||||||
my $h_sizer = Wx::BoxSizer->new(wxHORIZONTAL);
|
|
||||||
$h_sizer->Add($choice, 1, wxEXPAND | wxALL, 0);
|
|
||||||
$h_sizer->Add($btn, 0, wxEXPAND | wxLEFT, 10);
|
|
||||||
$self->{sizer}->Add($h_sizer, 0, wxEXPAND | wxALL, 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->{options_sizer} = Wx::BoxSizer->new(wxVERTICAL);
|
|
||||||
$self->{sizer}->Add($self->{options_sizer}, 0, wxEXPAND | wxALL, 10);
|
|
||||||
|
|
||||||
$self->update_optgroup;
|
|
||||||
|
|
||||||
$self->SetSizer($self->{sizer});
|
$self->SetSizer($self->{sizer});
|
||||||
$self->{sizer}->SetSizeHints($self);
|
$self->{sizer}->SetSizeHints($self);
|
||||||
|
@ -108,41 +85,6 @@ sub new {
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub update_optgroup {
|
|
||||||
my $self = shift;
|
|
||||||
|
|
||||||
$self->{options_sizer}->Clear(1);
|
|
||||||
|
|
||||||
my $config = $self->model_object->config;
|
|
||||||
my %categories = ();
|
|
||||||
foreach my $opt_key (@{$config->get_keys}) {
|
|
||||||
my $category = $Slic3r::Config::Options->{$opt_key}{category};
|
|
||||||
$categories{$category} ||= [];
|
|
||||||
push @{$categories{$category}}, $opt_key;
|
|
||||||
}
|
|
||||||
foreach my $category (sort keys %categories) {
|
|
||||||
my $optgroup = Slic3r::GUI::ConfigOptionsGroup->new(
|
|
||||||
parent => $self,
|
|
||||||
title => $category,
|
|
||||||
config => $config,
|
|
||||||
options => [ sort @{$categories{$category}} ],
|
|
||||||
full_labels => 1,
|
|
||||||
extra_column => sub {
|
|
||||||
my ($line) = @_;
|
|
||||||
my ($opt_key) = @{$line->{options}}; # we assume that we have one option per line
|
|
||||||
my $btn = Wx::BitmapButton->new($self, -1, Wx::Bitmap->new("$Slic3r::var/delete.png", wxBITMAP_TYPE_PNG));
|
|
||||||
EVT_BUTTON($self, $btn, sub {
|
|
||||||
$self->model_object->config->erase($opt_key);
|
|
||||||
Slic3r::GUI->CallAfter(sub { $self->update_optgroup });
|
|
||||||
});
|
|
||||||
return $btn;
|
|
||||||
},
|
|
||||||
);
|
|
||||||
$self->{options_sizer}->Add($optgroup->sizer, 0, wxEXPAND | wxBOTTOM, 10);
|
|
||||||
}
|
|
||||||
$self->Layout;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub CanClose {
|
sub CanClose {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
|
|
||||||
|
|
98
lib/Slic3r/GUI/Plater/OverrideSettingsPanel.pm
Normal file
98
lib/Slic3r/GUI/Plater/OverrideSettingsPanel.pm
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
package Slic3r::GUI::Plater::OverrideSettingsPanel;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use utf8;
|
||||||
|
|
||||||
|
use File::Basename qw(basename);
|
||||||
|
use Wx qw(:misc :sizer :button wxTAB_TRAVERSAL wxSUNKEN_BORDER wxBITMAP_TYPE_PNG);
|
||||||
|
use Wx::Event qw(EVT_BUTTON);
|
||||||
|
use base 'Wx::ScrolledWindow';
|
||||||
|
|
||||||
|
use constant ICON_MATERIAL => 0;
|
||||||
|
use constant ICON_SOLIDMESH => 1;
|
||||||
|
use constant ICON_MODIFIERMESH => 2;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my $class = shift;
|
||||||
|
my ($parent, %params) = @_;
|
||||||
|
my $self = $class->SUPER::new($parent, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
|
||||||
|
$self->{config} = $params{config}; # may be passed as undef
|
||||||
|
my @opt_keys = @{$params{opt_keys}};
|
||||||
|
|
||||||
|
$self->{sizer} = Wx::BoxSizer->new(wxVERTICAL);
|
||||||
|
|
||||||
|
# option selector
|
||||||
|
{
|
||||||
|
# get all options with object scope and sort them by category+label
|
||||||
|
my %settings = map { $_ => sprintf('%s > %s', $Slic3r::Config::Options->{$_}{category}, $Slic3r::Config::Options->{$_}{full_label} // $Slic3r::Config::Options->{$_}{label}) } @opt_keys;
|
||||||
|
$self->{options} = [ sort { $settings{$a} cmp $settings{$b} } keys %settings ];
|
||||||
|
my $choice = Wx::Choice->new($self, -1, wxDefaultPosition, [150, -1], [ map $settings{$_}, @{$self->{options}} ]);
|
||||||
|
|
||||||
|
# create the button
|
||||||
|
my $btn = Wx::BitmapButton->new($self, -1, Wx::Bitmap->new("$Slic3r::var/add.png", wxBITMAP_TYPE_PNG));
|
||||||
|
EVT_BUTTON($self, $btn, sub {
|
||||||
|
my $idx = $choice->GetSelection;
|
||||||
|
return if $idx == -1; # lack of selected item, can happen on Windows
|
||||||
|
my $opt_key = $self->{options}[$idx];
|
||||||
|
$self->{config}->apply(Slic3r::Config->new_from_defaults($opt_key));
|
||||||
|
$self->update_optgroup;
|
||||||
|
});
|
||||||
|
|
||||||
|
my $h_sizer = Wx::BoxSizer->new(wxHORIZONTAL);
|
||||||
|
$h_sizer->Add($choice, 1, wxEXPAND | wxALL, 0);
|
||||||
|
$h_sizer->Add($btn, 0, wxEXPAND | wxLEFT, 10);
|
||||||
|
$self->{sizer}->Add($h_sizer, 0, wxEXPAND | wxBOTTOM, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{options_sizer} = Wx::BoxSizer->new(wxVERTICAL);
|
||||||
|
$self->{sizer}->Add($self->{options_sizer}, 0, wxEXPAND | wxALL, 0);
|
||||||
|
|
||||||
|
$self->SetSizer($self->{sizer});
|
||||||
|
$self->SetScrollbars(0, 1, 0, 1);
|
||||||
|
|
||||||
|
$self->update_optgroup;
|
||||||
|
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_config {
|
||||||
|
my ($self, $config) = @_;
|
||||||
|
$self->{config} = $config;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub update_optgroup {
|
||||||
|
my $self = shift;
|
||||||
|
|
||||||
|
$self->{options_sizer}->Clear(1);
|
||||||
|
return if !defined $self->{config};
|
||||||
|
|
||||||
|
my %categories = ();
|
||||||
|
foreach my $opt_key (@{$self->{config}->get_keys}) {
|
||||||
|
my $category = $Slic3r::Config::Options->{$opt_key}{category};
|
||||||
|
$categories{$category} ||= [];
|
||||||
|
push @{$categories{$category}}, $opt_key;
|
||||||
|
}
|
||||||
|
foreach my $category (sort keys %categories) {
|
||||||
|
my $optgroup = Slic3r::GUI::ConfigOptionsGroup->new(
|
||||||
|
parent => $self,
|
||||||
|
title => $category,
|
||||||
|
config => $self->{config},
|
||||||
|
options => [ sort @{$categories{$category}} ],
|
||||||
|
full_labels => 1,
|
||||||
|
extra_column => sub {
|
||||||
|
my ($line) = @_;
|
||||||
|
my ($opt_key) = @{$line->{options}}; # we assume that we have one option per line
|
||||||
|
my $btn = Wx::BitmapButton->new($self, -1, Wx::Bitmap->new("$Slic3r::var/delete.png", wxBITMAP_TYPE_PNG));
|
||||||
|
EVT_BUTTON($self, $btn, sub {
|
||||||
|
$self->{config}->erase($opt_key);
|
||||||
|
Slic3r::GUI->CallAfter(sub { $self->update_optgroup });
|
||||||
|
});
|
||||||
|
return $btn;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
$self->{options_sizer}->Add($optgroup->sizer, 0, wxEXPAND | wxBOTTOM, 10);
|
||||||
|
}
|
||||||
|
$self->Layout;
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
|
@ -531,6 +531,15 @@ has 'material_id' => (is => 'rw');
|
||||||
has 'mesh' => (is => 'rw', required => 1);
|
has 'mesh' => (is => 'rw', required => 1);
|
||||||
has 'modifier' => (is => 'rw', defualt => sub { 0 });
|
has 'modifier' => (is => 'rw', defualt => sub { 0 });
|
||||||
|
|
||||||
|
sub assign_unique_material {
|
||||||
|
my ($self) = @_;
|
||||||
|
|
||||||
|
my $model = $self->object->model;
|
||||||
|
my $material_id = 1 + scalar keys %{$model->materials};
|
||||||
|
$self->material_id($material_id);
|
||||||
|
return $model->set_material($material_id);
|
||||||
|
}
|
||||||
|
|
||||||
package Slic3r::Model::Instance;
|
package Slic3r::Model::Instance;
|
||||||
use Moo;
|
use Moo;
|
||||||
|
|
||||||
|
|
|
@ -378,7 +378,6 @@ class ConfigOptionDef
|
||||||
std::string tooltip;
|
std::string tooltip;
|
||||||
std::string sidetext;
|
std::string sidetext;
|
||||||
std::string cli;
|
std::string cli;
|
||||||
std::string scope;
|
|
||||||
t_config_option_key ratio_over;
|
t_config_option_key ratio_over;
|
||||||
bool multiline;
|
bool multiline;
|
||||||
bool full_width;
|
bool full_width;
|
||||||
|
|
|
@ -82,7 +82,6 @@ class PrintConfigDef
|
||||||
Options["bottom_solid_layers"].category = "Layers and Perimeters";
|
Options["bottom_solid_layers"].category = "Layers and Perimeters";
|
||||||
Options["bottom_solid_layers"].tooltip = "Number of solid layers to generate on bottom surfaces.";
|
Options["bottom_solid_layers"].tooltip = "Number of solid layers to generate on bottom surfaces.";
|
||||||
Options["bottom_solid_layers"].cli = "bottom-solid-layers=i";
|
Options["bottom_solid_layers"].cli = "bottom-solid-layers=i";
|
||||||
Options["bottom_solid_layers"].scope = "object";
|
|
||||||
Options["bottom_solid_layers"].full_label = "Bottom solid layers";
|
Options["bottom_solid_layers"].full_label = "Bottom solid layers";
|
||||||
|
|
||||||
Options["bridge_acceleration"].type = coFloat;
|
Options["bridge_acceleration"].type = coFloat;
|
||||||
|
@ -171,7 +170,6 @@ class PrintConfigDef
|
||||||
Options["extra_perimeters"].category = "Layers and Perimeters";
|
Options["extra_perimeters"].category = "Layers and Perimeters";
|
||||||
Options["extra_perimeters"].tooltip = "Add more perimeters when needed for avoiding gaps in sloping walls.";
|
Options["extra_perimeters"].tooltip = "Add more perimeters when needed for avoiding gaps in sloping walls.";
|
||||||
Options["extra_perimeters"].cli = "extra-perimeters!";
|
Options["extra_perimeters"].cli = "extra-perimeters!";
|
||||||
Options["extra_perimeters"].scope = "object";
|
|
||||||
|
|
||||||
Options["extruder"].type = coInt;
|
Options["extruder"].type = coInt;
|
||||||
Options["extruder"].label = "Extruder";
|
Options["extruder"].label = "Extruder";
|
||||||
|
@ -211,6 +209,7 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["extrusion_width"].type = coFloatOrPercent;
|
Options["extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["extrusion_width"].label = "Default extrusion width";
|
Options["extrusion_width"].label = "Default extrusion width";
|
||||||
|
Options["extrusion_width"].category = "Extrusion Width";
|
||||||
Options["extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width. If left to zero, Slic3r calculates a width automatically. If expressed as percentage (for example: 230%) it will be computed over layer height.";
|
Options["extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width. If left to zero, Slic3r calculates a width automatically. If expressed as percentage (for example: 230%) it will be computed over layer height.";
|
||||||
Options["extrusion_width"].sidetext = "mm or % (leave 0 for auto)";
|
Options["extrusion_width"].sidetext = "mm or % (leave 0 for auto)";
|
||||||
Options["extrusion_width"].cli = "extrusion-width=s";
|
Options["extrusion_width"].cli = "extrusion-width=s";
|
||||||
|
@ -236,6 +235,7 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["fill_angle"].type = coInt;
|
Options["fill_angle"].type = coInt;
|
||||||
Options["fill_angle"].label = "Fill angle";
|
Options["fill_angle"].label = "Fill angle";
|
||||||
|
Options["fill_angle"].category = "Infill";
|
||||||
Options["fill_angle"].tooltip = "Default base angle for infill orientation. Cross-hatching will be applied to this. Bridges will be infilled using the best direction Slic3r can detect, so this setting does not affect them.";
|
Options["fill_angle"].tooltip = "Default base angle for infill orientation. Cross-hatching will be applied to this. Bridges will be infilled using the best direction Slic3r can detect, so this setting does not affect them.";
|
||||||
Options["fill_angle"].sidetext = "°";
|
Options["fill_angle"].sidetext = "°";
|
||||||
Options["fill_angle"].cli = "fill-angle=i";
|
Options["fill_angle"].cli = "fill-angle=i";
|
||||||
|
@ -246,14 +246,12 @@ class PrintConfigDef
|
||||||
Options["fill_density"].category = "Infill";
|
Options["fill_density"].category = "Infill";
|
||||||
Options["fill_density"].tooltip = "Density of internal infill, expressed in the range 0 - 1.";
|
Options["fill_density"].tooltip = "Density of internal infill, expressed in the range 0 - 1.";
|
||||||
Options["fill_density"].cli = "fill-density=f";
|
Options["fill_density"].cli = "fill-density=f";
|
||||||
Options["fill_density"].scope = "object";
|
|
||||||
|
|
||||||
Options["fill_pattern"].type = coEnum;
|
Options["fill_pattern"].type = coEnum;
|
||||||
Options["fill_pattern"].label = "Fill pattern";
|
Options["fill_pattern"].label = "Fill pattern";
|
||||||
Options["fill_pattern"].category = "Infill";
|
Options["fill_pattern"].category = "Infill";
|
||||||
Options["fill_pattern"].tooltip = "Fill pattern for general low-density infill.";
|
Options["fill_pattern"].tooltip = "Fill pattern for general low-density infill.";
|
||||||
Options["fill_pattern"].cli = "fill-pattern=s";
|
Options["fill_pattern"].cli = "fill-pattern=s";
|
||||||
Options["fill_pattern"].scope = "object";
|
|
||||||
Options["fill_pattern"].enum_keys_map = ConfigOptionEnum<InfillPattern>::get_enum_values();
|
Options["fill_pattern"].enum_keys_map = ConfigOptionEnum<InfillPattern>::get_enum_values();
|
||||||
Options["fill_pattern"].enum_values.push_back("rectilinear");
|
Options["fill_pattern"].enum_values.push_back("rectilinear");
|
||||||
Options["fill_pattern"].enum_values.push_back("line");
|
Options["fill_pattern"].enum_values.push_back("line");
|
||||||
|
@ -292,6 +290,7 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["first_layer_height"].type = coFloatOrPercent;
|
Options["first_layer_height"].type = coFloatOrPercent;
|
||||||
Options["first_layer_height"].label = "First layer height";
|
Options["first_layer_height"].label = "First layer height";
|
||||||
|
Options["first_layer_height"].category = "Layers and Perimeters";
|
||||||
Options["first_layer_height"].tooltip = "When printing with very low layer heights, you might still want to print a thicker bottom layer to improve adhesion and tolerance for non perfect build plates. This can be expressed as an absolute value or as a percentage (for example: 150%) over the default layer height.";
|
Options["first_layer_height"].tooltip = "When printing with very low layer heights, you might still want to print a thicker bottom layer to improve adhesion and tolerance for non perfect build plates. This can be expressed as an absolute value or as a percentage (for example: 150%) over the default layer height.";
|
||||||
Options["first_layer_height"].sidetext = "mm or %";
|
Options["first_layer_height"].sidetext = "mm or %";
|
||||||
Options["first_layer_height"].cli = "first-layer-height=s";
|
Options["first_layer_height"].cli = "first-layer-height=s";
|
||||||
|
@ -361,17 +360,18 @@ class PrintConfigDef
|
||||||
Options["infill_every_layers"].tooltip = "This feature allows to combine infill and speed up your print by extruding thicker infill layers while preserving thin perimeters, thus accuracy.";
|
Options["infill_every_layers"].tooltip = "This feature allows to combine infill and speed up your print by extruding thicker infill layers while preserving thin perimeters, thus accuracy.";
|
||||||
Options["infill_every_layers"].sidetext = "layers";
|
Options["infill_every_layers"].sidetext = "layers";
|
||||||
Options["infill_every_layers"].cli = "infill-every-layers=i";
|
Options["infill_every_layers"].cli = "infill-every-layers=i";
|
||||||
Options["infill_every_layers"].scope = "object";
|
|
||||||
Options["infill_every_layers"].full_label = "Combine infill every n layers";
|
Options["infill_every_layers"].full_label = "Combine infill every n layers";
|
||||||
Options["infill_every_layers"].min = 1;
|
Options["infill_every_layers"].min = 1;
|
||||||
|
|
||||||
Options["infill_extruder"].type = coInt;
|
Options["infill_extruder"].type = coInt;
|
||||||
Options["infill_extruder"].label = "Infill extruder";
|
Options["infill_extruder"].label = "Infill extruder";
|
||||||
|
Options["infill_extruder"].category = "Extruders";
|
||||||
Options["infill_extruder"].tooltip = "The extruder to use when printing infill.";
|
Options["infill_extruder"].tooltip = "The extruder to use when printing infill.";
|
||||||
Options["infill_extruder"].cli = "infill-extruder=i";
|
Options["infill_extruder"].cli = "infill-extruder=i";
|
||||||
|
|
||||||
Options["infill_extrusion_width"].type = coFloatOrPercent;
|
Options["infill_extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["infill_extrusion_width"].label = "Infill";
|
Options["infill_extrusion_width"].label = "Infill";
|
||||||
|
Options["infill_extrusion_width"].category = "Extrusion Width";
|
||||||
Options["infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill. You may want to use fatter extrudates to speed up the infill and make your parts stronger. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
Options["infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill. You may want to use fatter extrudates to speed up the infill and make your parts stronger. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
||||||
Options["infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
Options["infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
||||||
Options["infill_extrusion_width"].cli = "infill-extrusion-width=s";
|
Options["infill_extrusion_width"].cli = "infill-extrusion-width=s";
|
||||||
|
@ -386,7 +386,6 @@ class PrintConfigDef
|
||||||
Options["infill_only_where_needed"].category = "Infill";
|
Options["infill_only_where_needed"].category = "Infill";
|
||||||
Options["infill_only_where_needed"].tooltip = "This option will limit infill to the areas actually needed for supporting ceilings (it will act as internal support material).";
|
Options["infill_only_where_needed"].tooltip = "This option will limit infill to the areas actually needed for supporting ceilings (it will act as internal support material).";
|
||||||
Options["infill_only_where_needed"].cli = "infill-only-where-needed!";
|
Options["infill_only_where_needed"].cli = "infill-only-where-needed!";
|
||||||
Options["infill_only_where_needed"].scope = "object";
|
|
||||||
|
|
||||||
Options["infill_speed"].type = coFloat;
|
Options["infill_speed"].type = coFloat;
|
||||||
Options["infill_speed"].label = "Infill";
|
Options["infill_speed"].label = "Infill";
|
||||||
|
@ -406,6 +405,7 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["layer_height"].type = coFloat;
|
Options["layer_height"].type = coFloat;
|
||||||
Options["layer_height"].label = "Layer height";
|
Options["layer_height"].label = "Layer height";
|
||||||
|
Options["layer_height"].category = "Layers and Perimeters";
|
||||||
Options["layer_height"].tooltip = "This setting controls the height (and thus the total number) of the slices/layers. Thinner layers give better accuracy but take more time to print.";
|
Options["layer_height"].tooltip = "This setting controls the height (and thus the total number) of the slices/layers. Thinner layers give better accuracy but take more time to print.";
|
||||||
Options["layer_height"].sidetext = "mm";
|
Options["layer_height"].sidetext = "mm";
|
||||||
Options["layer_height"].cli = "layer-height=f";
|
Options["layer_height"].cli = "layer-height=f";
|
||||||
|
@ -473,7 +473,6 @@ class PrintConfigDef
|
||||||
Options["overhangs"].category = "Layers and Perimeters";
|
Options["overhangs"].category = "Layers and Perimeters";
|
||||||
Options["overhangs"].tooltip = "Experimental option to adjust flow for overhangs (bridge flow will be used), to apply bridge speed to them and enable fan.";
|
Options["overhangs"].tooltip = "Experimental option to adjust flow for overhangs (bridge flow will be used), to apply bridge speed to them and enable fan.";
|
||||||
Options["overhangs"].cli = "overhangs!";
|
Options["overhangs"].cli = "overhangs!";
|
||||||
Options["overhangs"].scope = "object";
|
|
||||||
|
|
||||||
Options["perimeter_acceleration"].type = coFloat;
|
Options["perimeter_acceleration"].type = coFloat;
|
||||||
Options["perimeter_acceleration"].label = "Perimeters";
|
Options["perimeter_acceleration"].label = "Perimeters";
|
||||||
|
@ -483,12 +482,14 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["perimeter_extruder"].type = coInt;
|
Options["perimeter_extruder"].type = coInt;
|
||||||
Options["perimeter_extruder"].label = "Perimeter extruder";
|
Options["perimeter_extruder"].label = "Perimeter extruder";
|
||||||
|
Options["perimeter_extruder"].category = "Extruders";
|
||||||
Options["perimeter_extruder"].tooltip = "The extruder to use when printing perimeters.";
|
Options["perimeter_extruder"].tooltip = "The extruder to use when printing perimeters.";
|
||||||
Options["perimeter_extruder"].cli = "perimeter-extruder=i";
|
Options["perimeter_extruder"].cli = "perimeter-extruder=i";
|
||||||
Options["perimeter_extruder"].aliases.push_back("perimeters_extruder");
|
Options["perimeter_extruder"].aliases.push_back("perimeters_extruder");
|
||||||
|
|
||||||
Options["perimeter_extrusion_width"].type = coFloatOrPercent;
|
Options["perimeter_extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["perimeter_extrusion_width"].label = "Perimeters";
|
Options["perimeter_extrusion_width"].label = "Perimeters";
|
||||||
|
Options["perimeter_extrusion_width"].category = "Extrusion Width";
|
||||||
Options["perimeter_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for perimeters. You may want to use thinner extrudates to get more accurate surfaces. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
Options["perimeter_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for perimeters. You may want to use thinner extrudates to get more accurate surfaces. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
||||||
Options["perimeter_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
Options["perimeter_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
||||||
Options["perimeter_extrusion_width"].cli = "perimeter-extrusion-width=s";
|
Options["perimeter_extrusion_width"].cli = "perimeter-extrusion-width=s";
|
||||||
|
@ -506,7 +507,6 @@ class PrintConfigDef
|
||||||
Options["perimeters"].category = "Layers and Perimeters";
|
Options["perimeters"].category = "Layers and Perimeters";
|
||||||
Options["perimeters"].tooltip = "This option sets the number of perimeters to generate for each layer. Note that Slic3r may increase this number automatically when it detects sloping surfaces which benefit from a higher number of perimeters if the Extra Perimeters option is enabled.";
|
Options["perimeters"].tooltip = "This option sets the number of perimeters to generate for each layer. Note that Slic3r may increase this number automatically when it detects sloping surfaces which benefit from a higher number of perimeters if the Extra Perimeters option is enabled.";
|
||||||
Options["perimeters"].cli = "perimeters=i";
|
Options["perimeters"].cli = "perimeters=i";
|
||||||
Options["perimeters"].scope = "object";
|
|
||||||
Options["perimeters"].aliases.push_back("perimeter_offsets");
|
Options["perimeters"].aliases.push_back("perimeter_offsets");
|
||||||
|
|
||||||
Options["post_process"].type = coStrings;
|
Options["post_process"].type = coStrings;
|
||||||
|
@ -529,7 +529,6 @@ class PrintConfigDef
|
||||||
Options["raft_layers"].tooltip = "The object will be raised by this number of layers, and support material will be generated under it.";
|
Options["raft_layers"].tooltip = "The object will be raised by this number of layers, and support material will be generated under it.";
|
||||||
Options["raft_layers"].sidetext = "layers";
|
Options["raft_layers"].sidetext = "layers";
|
||||||
Options["raft_layers"].cli = "raft-layers=i";
|
Options["raft_layers"].cli = "raft-layers=i";
|
||||||
Options["raft_layers"].scope = "object";
|
|
||||||
|
|
||||||
Options["randomize_start"].type = coBool;
|
Options["randomize_start"].type = coBool;
|
||||||
Options["randomize_start"].label = "Randomize starting points";
|
Options["randomize_start"].label = "Randomize starting points";
|
||||||
|
@ -628,7 +627,6 @@ class PrintConfigDef
|
||||||
Options["solid_fill_pattern"].category = "Infill";
|
Options["solid_fill_pattern"].category = "Infill";
|
||||||
Options["solid_fill_pattern"].tooltip = "Fill pattern for top/bottom infill.";
|
Options["solid_fill_pattern"].tooltip = "Fill pattern for top/bottom infill.";
|
||||||
Options["solid_fill_pattern"].cli = "solid-fill-pattern=s";
|
Options["solid_fill_pattern"].cli = "solid-fill-pattern=s";
|
||||||
Options["solid_fill_pattern"].scope = "object";
|
|
||||||
Options["solid_fill_pattern"].enum_keys_map = ConfigOptionEnum<InfillPattern>::get_enum_values();
|
Options["solid_fill_pattern"].enum_keys_map = ConfigOptionEnum<InfillPattern>::get_enum_values();
|
||||||
Options["solid_fill_pattern"].enum_values.push_back("rectilinear");
|
Options["solid_fill_pattern"].enum_values.push_back("rectilinear");
|
||||||
Options["solid_fill_pattern"].enum_values.push_back("concentric");
|
Options["solid_fill_pattern"].enum_values.push_back("concentric");
|
||||||
|
@ -647,7 +645,6 @@ class PrintConfigDef
|
||||||
Options["solid_infill_below_area"].tooltip = "Force solid infill for regions having a smaller area than the specified threshold.";
|
Options["solid_infill_below_area"].tooltip = "Force solid infill for regions having a smaller area than the specified threshold.";
|
||||||
Options["solid_infill_below_area"].sidetext = "mm²";
|
Options["solid_infill_below_area"].sidetext = "mm²";
|
||||||
Options["solid_infill_below_area"].cli = "solid-infill-below-area=f";
|
Options["solid_infill_below_area"].cli = "solid-infill-below-area=f";
|
||||||
Options["solid_infill_below_area"].scope = "object";
|
|
||||||
|
|
||||||
Options["solid_infill_every_layers"].type = coInt;
|
Options["solid_infill_every_layers"].type = coInt;
|
||||||
Options["solid_infill_every_layers"].label = "Solid infill every";
|
Options["solid_infill_every_layers"].label = "Solid infill every";
|
||||||
|
@ -655,11 +652,11 @@ class PrintConfigDef
|
||||||
Options["solid_infill_every_layers"].tooltip = "This feature allows to force a solid layer every given number of layers. Zero to disable.";
|
Options["solid_infill_every_layers"].tooltip = "This feature allows to force a solid layer every given number of layers. Zero to disable.";
|
||||||
Options["solid_infill_every_layers"].sidetext = "layers";
|
Options["solid_infill_every_layers"].sidetext = "layers";
|
||||||
Options["solid_infill_every_layers"].cli = "solid-infill-every-layers=i";
|
Options["solid_infill_every_layers"].cli = "solid-infill-every-layers=i";
|
||||||
Options["solid_infill_every_layers"].scope = "object";
|
|
||||||
Options["solid_infill_every_layers"].min = 0;
|
Options["solid_infill_every_layers"].min = 0;
|
||||||
|
|
||||||
Options["solid_infill_extrusion_width"].type = coFloatOrPercent;
|
Options["solid_infill_extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["solid_infill_extrusion_width"].label = "Solid infill";
|
Options["solid_infill_extrusion_width"].label = "Solid infill";
|
||||||
|
Options["solid_infill_extrusion_width"].category = "Extrusion Width";
|
||||||
Options["solid_infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill for solid surfaces. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
Options["solid_infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill for solid surfaces. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
||||||
Options["solid_infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
Options["solid_infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
||||||
Options["solid_infill_extrusion_width"].cli = "solid-infill-extrusion-width=s";
|
Options["solid_infill_extrusion_width"].cli = "solid-infill-extrusion-width=s";
|
||||||
|
@ -715,7 +712,6 @@ class PrintConfigDef
|
||||||
Options["support_material"].category = "Support material";
|
Options["support_material"].category = "Support material";
|
||||||
Options["support_material"].tooltip = "Enable support material generation.";
|
Options["support_material"].tooltip = "Enable support material generation.";
|
||||||
Options["support_material"].cli = "support-material!";
|
Options["support_material"].cli = "support-material!";
|
||||||
Options["support_material"].scope = "object";
|
|
||||||
|
|
||||||
Options["support_material_angle"].type = coInt;
|
Options["support_material_angle"].type = coInt;
|
||||||
Options["support_material_angle"].label = "Pattern angle";
|
Options["support_material_angle"].label = "Pattern angle";
|
||||||
|
@ -723,7 +719,6 @@ class PrintConfigDef
|
||||||
Options["support_material_angle"].tooltip = "Use this setting to rotate the support material pattern on the horizontal plane.";
|
Options["support_material_angle"].tooltip = "Use this setting to rotate the support material pattern on the horizontal plane.";
|
||||||
Options["support_material_angle"].sidetext = "°";
|
Options["support_material_angle"].sidetext = "°";
|
||||||
Options["support_material_angle"].cli = "support-material-angle=i";
|
Options["support_material_angle"].cli = "support-material-angle=i";
|
||||||
Options["support_material_angle"].scope = "object";
|
|
||||||
|
|
||||||
Options["support_material_enforce_layers"].type = coInt;
|
Options["support_material_enforce_layers"].type = coInt;
|
||||||
Options["support_material_enforce_layers"].label = "Enforce support for the first";
|
Options["support_material_enforce_layers"].label = "Enforce support for the first";
|
||||||
|
@ -731,22 +726,24 @@ class PrintConfigDef
|
||||||
Options["support_material_enforce_layers"].tooltip = "Generate support material for the specified number of layers counting from bottom, regardless of whether normal support material is enabled or not and regardless of any angle threshold. This is useful for getting more adhesion of objects having a very thin or poor footprint on the build plate.";
|
Options["support_material_enforce_layers"].tooltip = "Generate support material for the specified number of layers counting from bottom, regardless of whether normal support material is enabled or not and regardless of any angle threshold. This is useful for getting more adhesion of objects having a very thin or poor footprint on the build plate.";
|
||||||
Options["support_material_enforce_layers"].sidetext = "layers";
|
Options["support_material_enforce_layers"].sidetext = "layers";
|
||||||
Options["support_material_enforce_layers"].cli = "support-material-enforce-layers=f";
|
Options["support_material_enforce_layers"].cli = "support-material-enforce-layers=f";
|
||||||
Options["support_material_enforce_layers"].scope = "object";
|
|
||||||
Options["support_material_enforce_layers"].full_label = "Enforce support for the first n layers";
|
Options["support_material_enforce_layers"].full_label = "Enforce support for the first n layers";
|
||||||
|
|
||||||
Options["support_material_extruder"].type = coInt;
|
Options["support_material_extruder"].type = coInt;
|
||||||
Options["support_material_extruder"].label = "Support material extruder";
|
Options["support_material_extruder"].label = "Support material extruder";
|
||||||
|
Options["support_material_extruder"].category = "Extruders";
|
||||||
Options["support_material_extruder"].tooltip = "The extruder to use when printing support material. This affects brim and raft too.";
|
Options["support_material_extruder"].tooltip = "The extruder to use when printing support material. This affects brim and raft too.";
|
||||||
Options["support_material_extruder"].cli = "support-material-extruder=i";
|
Options["support_material_extruder"].cli = "support-material-extruder=i";
|
||||||
|
|
||||||
Options["support_material_extrusion_width"].type = coFloatOrPercent;
|
Options["support_material_extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["support_material_extrusion_width"].label = "Support material";
|
Options["support_material_extrusion_width"].label = "Support material";
|
||||||
|
Options["support_material_extrusion_width"].category = "Extrusion Width";
|
||||||
Options["support_material_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for support material. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
Options["support_material_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for support material. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
||||||
Options["support_material_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
Options["support_material_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
||||||
Options["support_material_extrusion_width"].cli = "support-material-extrusion-width=s";
|
Options["support_material_extrusion_width"].cli = "support-material-extrusion-width=s";
|
||||||
|
|
||||||
Options["support_material_interface_extruder"].type = coInt;
|
Options["support_material_interface_extruder"].type = coInt;
|
||||||
Options["support_material_interface_extruder"].label = "Support material interface extruder";
|
Options["support_material_interface_extruder"].label = "Support material interface extruder";
|
||||||
|
Options["support_material_interface_extruder"].category = "Extruders";
|
||||||
Options["support_material_interface_extruder"].tooltip = "The extruder to use when printing support material interface. This affects raft too.";
|
Options["support_material_interface_extruder"].tooltip = "The extruder to use when printing support material interface. This affects raft too.";
|
||||||
Options["support_material_interface_extruder"].cli = "support-material-interface-extruder=i";
|
Options["support_material_interface_extruder"].cli = "support-material-interface-extruder=i";
|
||||||
|
|
||||||
|
@ -756,7 +753,6 @@ class PrintConfigDef
|
||||||
Options["support_material_interface_layers"].tooltip = "Number of interface layers to insert between the object(s) and support material.";
|
Options["support_material_interface_layers"].tooltip = "Number of interface layers to insert between the object(s) and support material.";
|
||||||
Options["support_material_interface_layers"].sidetext = "layers";
|
Options["support_material_interface_layers"].sidetext = "layers";
|
||||||
Options["support_material_interface_layers"].cli = "support-material-interface-layers=i";
|
Options["support_material_interface_layers"].cli = "support-material-interface-layers=i";
|
||||||
Options["support_material_interface_layers"].scope = "object";
|
|
||||||
|
|
||||||
Options["support_material_interface_spacing"].type = coFloat;
|
Options["support_material_interface_spacing"].type = coFloat;
|
||||||
Options["support_material_interface_spacing"].label = "Interface pattern spacing";
|
Options["support_material_interface_spacing"].label = "Interface pattern spacing";
|
||||||
|
@ -764,14 +760,12 @@ class PrintConfigDef
|
||||||
Options["support_material_interface_spacing"].tooltip = "Spacing between interface lines. Set zero to get a solid interface.";
|
Options["support_material_interface_spacing"].tooltip = "Spacing between interface lines. Set zero to get a solid interface.";
|
||||||
Options["support_material_interface_spacing"].sidetext = "mm";
|
Options["support_material_interface_spacing"].sidetext = "mm";
|
||||||
Options["support_material_interface_spacing"].cli = "support-material-interface-spacing=f";
|
Options["support_material_interface_spacing"].cli = "support-material-interface-spacing=f";
|
||||||
Options["support_material_interface_spacing"].scope = "object";
|
|
||||||
|
|
||||||
Options["support_material_pattern"].type = coEnum;
|
Options["support_material_pattern"].type = coEnum;
|
||||||
Options["support_material_pattern"].label = "Pattern";
|
Options["support_material_pattern"].label = "Pattern";
|
||||||
Options["support_material_pattern"].category = "Support material";
|
Options["support_material_pattern"].category = "Support material";
|
||||||
Options["support_material_pattern"].tooltip = "Pattern used to generate support material.";
|
Options["support_material_pattern"].tooltip = "Pattern used to generate support material.";
|
||||||
Options["support_material_pattern"].cli = "support-material-pattern=s";
|
Options["support_material_pattern"].cli = "support-material-pattern=s";
|
||||||
Options["support_material_pattern"].scope = "object";
|
|
||||||
Options["support_material_pattern"].enum_keys_map = ConfigOptionEnum<SupportMaterialPattern>::get_enum_values();
|
Options["support_material_pattern"].enum_keys_map = ConfigOptionEnum<SupportMaterialPattern>::get_enum_values();
|
||||||
Options["support_material_pattern"].enum_values.push_back("rectilinear");
|
Options["support_material_pattern"].enum_values.push_back("rectilinear");
|
||||||
Options["support_material_pattern"].enum_values.push_back("rectilinear-grid");
|
Options["support_material_pattern"].enum_values.push_back("rectilinear-grid");
|
||||||
|
@ -788,10 +782,10 @@ class PrintConfigDef
|
||||||
Options["support_material_spacing"].tooltip = "Spacing between support material lines.";
|
Options["support_material_spacing"].tooltip = "Spacing between support material lines.";
|
||||||
Options["support_material_spacing"].sidetext = "mm";
|
Options["support_material_spacing"].sidetext = "mm";
|
||||||
Options["support_material_spacing"].cli = "support-material-spacing=f";
|
Options["support_material_spacing"].cli = "support-material-spacing=f";
|
||||||
Options["support_material_spacing"].scope = "object";
|
|
||||||
|
|
||||||
Options["support_material_speed"].type = coFloat;
|
Options["support_material_speed"].type = coFloat;
|
||||||
Options["support_material_speed"].label = "Support material";
|
Options["support_material_speed"].label = "Support material";
|
||||||
|
Options["support_material_speed"].category = "Support material";
|
||||||
Options["support_material_speed"].tooltip = "Speed for printing support material.";
|
Options["support_material_speed"].tooltip = "Speed for printing support material.";
|
||||||
Options["support_material_speed"].sidetext = "mm/s";
|
Options["support_material_speed"].sidetext = "mm/s";
|
||||||
Options["support_material_speed"].cli = "support-material-speed=f";
|
Options["support_material_speed"].cli = "support-material-speed=f";
|
||||||
|
@ -802,7 +796,6 @@ class PrintConfigDef
|
||||||
Options["support_material_threshold"].tooltip = "Support material will not be generated for overhangs whose slope angle (90° = vertical) is above the given threshold. In other words, this value represent the most horizontal slope (measured from the horizontal plane) that you can print without support material. Set to zero for automatic detection (recommended).";
|
Options["support_material_threshold"].tooltip = "Support material will not be generated for overhangs whose slope angle (90° = vertical) is above the given threshold. In other words, this value represent the most horizontal slope (measured from the horizontal plane) that you can print without support material. Set to zero for automatic detection (recommended).";
|
||||||
Options["support_material_threshold"].sidetext = "°";
|
Options["support_material_threshold"].sidetext = "°";
|
||||||
Options["support_material_threshold"].cli = "support-material-threshold=i";
|
Options["support_material_threshold"].cli = "support-material-threshold=i";
|
||||||
Options["support_material_threshold"].scope = "object";
|
|
||||||
|
|
||||||
Options["temperature"].type = coInts;
|
Options["temperature"].type = coInts;
|
||||||
Options["temperature"].label = "Other layers";
|
Options["temperature"].label = "Other layers";
|
||||||
|
@ -817,7 +810,6 @@ class PrintConfigDef
|
||||||
Options["thin_walls"].category = "Layers and Perimeters";
|
Options["thin_walls"].category = "Layers and Perimeters";
|
||||||
Options["thin_walls"].tooltip = "Detect single-width walls (parts where two extrusions don't fit and we need to collapse them into a single trace).";
|
Options["thin_walls"].tooltip = "Detect single-width walls (parts where two extrusions don't fit and we need to collapse them into a single trace).";
|
||||||
Options["thin_walls"].cli = "thin-walls!";
|
Options["thin_walls"].cli = "thin-walls!";
|
||||||
Options["thin_walls"].scope = "object";
|
|
||||||
|
|
||||||
Options["threads"].type = coInt;
|
Options["threads"].type = coInt;
|
||||||
Options["threads"].label = "Threads";
|
Options["threads"].label = "Threads";
|
||||||
|
@ -838,6 +830,7 @@ class PrintConfigDef
|
||||||
|
|
||||||
Options["top_infill_extrusion_width"].type = coFloatOrPercent;
|
Options["top_infill_extrusion_width"].type = coFloatOrPercent;
|
||||||
Options["top_infill_extrusion_width"].label = "Top solid infill";
|
Options["top_infill_extrusion_width"].label = "Top solid infill";
|
||||||
|
Options["top_infill_extrusion_width"].category = "Extrusion Width";
|
||||||
Options["top_infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill for top surfaces. You may want to use thinner extrudates to fill all narrow regions and get a smoother finish. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
Options["top_infill_extrusion_width"].tooltip = "Set this to a non-zero value to set a manual extrusion width for infill for top surfaces. You may want to use thinner extrudates to fill all narrow regions and get a smoother finish. If expressed as percentage (for example 90%) if will be computed over layer height.";
|
||||||
Options["top_infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
Options["top_infill_extrusion_width"].sidetext = "mm or % (leave 0 for default)";
|
||||||
Options["top_infill_extrusion_width"].cli = "top-infill-extrusion-width=s";
|
Options["top_infill_extrusion_width"].cli = "top-infill-extrusion-width=s";
|
||||||
|
@ -854,7 +847,6 @@ class PrintConfigDef
|
||||||
Options["top_solid_layers"].category = "Layers and Perimeters";
|
Options["top_solid_layers"].category = "Layers and Perimeters";
|
||||||
Options["top_solid_layers"].tooltip = "Number of solid layers to generate on top surfaces.";
|
Options["top_solid_layers"].tooltip = "Number of solid layers to generate on top surfaces.";
|
||||||
Options["top_solid_layers"].cli = "top-solid-layers=i";
|
Options["top_solid_layers"].cli = "top-solid-layers=i";
|
||||||
Options["top_solid_layers"].scope = "object";
|
|
||||||
Options["top_solid_layers"].full_label = "Top solid layers";
|
Options["top_solid_layers"].full_label = "Top solid layers";
|
||||||
|
|
||||||
Options["travel_speed"].type = coFloat;
|
Options["travel_speed"].type = coFloat;
|
||||||
|
@ -982,7 +974,6 @@ class PrintRegionConfig : public virtual StaticConfig
|
||||||
ConfigOptionFloat solid_infill_below_area;
|
ConfigOptionFloat solid_infill_below_area;
|
||||||
ConfigOptionFloatOrPercent solid_infill_extrusion_width;
|
ConfigOptionFloatOrPercent solid_infill_extrusion_width;
|
||||||
ConfigOptionInt solid_infill_every_layers;
|
ConfigOptionInt solid_infill_every_layers;
|
||||||
ConfigOptionInt solid_layers;
|
|
||||||
ConfigOptionBool thin_walls;
|
ConfigOptionBool thin_walls;
|
||||||
ConfigOptionFloatOrPercent top_infill_extrusion_width;
|
ConfigOptionFloatOrPercent top_infill_extrusion_width;
|
||||||
ConfigOptionInt top_solid_layers;
|
ConfigOptionInt top_solid_layers;
|
||||||
|
@ -1030,7 +1021,6 @@ class PrintRegionConfig : public virtual StaticConfig
|
||||||
if (opt_key == "solid_infill_below_area") return &this->solid_infill_below_area;
|
if (opt_key == "solid_infill_below_area") return &this->solid_infill_below_area;
|
||||||
if (opt_key == "solid_infill_extrusion_width") return &this->solid_infill_extrusion_width;
|
if (opt_key == "solid_infill_extrusion_width") return &this->solid_infill_extrusion_width;
|
||||||
if (opt_key == "solid_infill_every_layers") return &this->solid_infill_every_layers;
|
if (opt_key == "solid_infill_every_layers") return &this->solid_infill_every_layers;
|
||||||
if (opt_key == "solid_layers") return &this->solid_layers;
|
|
||||||
if (opt_key == "thin_walls") return &this->thin_walls;
|
if (opt_key == "thin_walls") return &this->thin_walls;
|
||||||
if (opt_key == "top_infill_extrusion_width") return &this->top_infill_extrusion_width;
|
if (opt_key == "top_infill_extrusion_width") return &this->top_infill_extrusion_width;
|
||||||
if (opt_key == "top_solid_layers") return &this->top_solid_layers;
|
if (opt_key == "top_solid_layers") return &this->top_solid_layers;
|
||||||
|
|
|
@ -154,7 +154,6 @@ print_config_def()
|
||||||
(void)hv_stores( hv, "tooltip", newSVpvn_utf8(optdef->tooltip.c_str(), optdef->tooltip.length(), true) );
|
(void)hv_stores( hv, "tooltip", newSVpvn_utf8(optdef->tooltip.c_str(), optdef->tooltip.length(), true) );
|
||||||
(void)hv_stores( hv, "sidetext", newSVpvn_utf8(optdef->sidetext.c_str(), optdef->sidetext.length(), true) );
|
(void)hv_stores( hv, "sidetext", newSVpvn_utf8(optdef->sidetext.c_str(), optdef->sidetext.length(), true) );
|
||||||
(void)hv_stores( hv, "cli", newSVpvn(optdef->cli.c_str(), optdef->cli.length()) );
|
(void)hv_stores( hv, "cli", newSVpvn(optdef->cli.c_str(), optdef->cli.length()) );
|
||||||
(void)hv_stores( hv, "scope", newSVpvn(optdef->scope.c_str(), optdef->scope.length()) );
|
|
||||||
(void)hv_stores( hv, "ratio_over", newSVpvn(optdef->ratio_over.c_str(), optdef->ratio_over.length()) );
|
(void)hv_stores( hv, "ratio_over", newSVpvn(optdef->ratio_over.c_str(), optdef->ratio_over.length()) );
|
||||||
(void)hv_stores( hv, "multiline", newSViv(optdef->multiline ? 1 : 0) );
|
(void)hv_stores( hv, "multiline", newSViv(optdef->multiline ? 1 : 0) );
|
||||||
(void)hv_stores( hv, "full_width", newSViv(optdef->full_width ? 1 : 0) );
|
(void)hv_stores( hv, "full_width", newSViv(optdef->full_width ? 1 : 0) );
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue