mirror of
https://git.mirrors.martin98.com/https://github.com/prusa3d/PrusaSlicer.git
synced 2025-05-21 20:18:17 +08:00
Some improvements to the Simple Mode
This commit is contained in:
parent
2e88b088e6
commit
98417f77f0
@ -22,6 +22,7 @@ sub new {
|
|||||||
$self->{vsizer} = Wx::BoxSizer->new(wxVERTICAL);
|
$self->{vsizer} = Wx::BoxSizer->new(wxVERTICAL);
|
||||||
$self->SetSizer($self->{vsizer});
|
$self->SetSizer($self->{vsizer});
|
||||||
$self->build;
|
$self->build;
|
||||||
|
$self->_update;
|
||||||
|
|
||||||
{
|
{
|
||||||
my $label = Wx::StaticText->new($self, -1, "Want more options? Switch to the Expert Mode.", wxDefaultPosition, wxDefaultSize);
|
my $label = Wx::StaticText->new($self, -1, "Want more options? Switch to the Expert Mode.", wxDefaultPosition, wxDefaultSize);
|
||||||
@ -71,12 +72,14 @@ sub load_config {
|
|||||||
$self->{config}->set($opt_key, $config->get($opt_key));
|
$self->{config}->set($opt_key, $config->get($opt_key));
|
||||||
}
|
}
|
||||||
$_->reload_config for @{$self->{optgroups}};
|
$_->reload_config for @{$self->{optgroups}};
|
||||||
|
$self->_update;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub load_presets {}
|
sub load_presets {}
|
||||||
|
|
||||||
sub is_dirty { 0 }
|
sub is_dirty { 0 }
|
||||||
sub config { $_[0]->{config}->clone }
|
sub config { $_[0]->{config}->clone }
|
||||||
|
sub _update {}
|
||||||
|
|
||||||
sub on_value_change {
|
sub on_value_change {
|
||||||
my ($self, $cb) = @_;
|
my ($self, $cb) = @_;
|
||||||
@ -88,7 +91,19 @@ sub on_presets_changed {}
|
|||||||
# propagate event to the parent
|
# propagate event to the parent
|
||||||
sub _on_value_change {
|
sub _on_value_change {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
|
|
||||||
$self->{on_value_change}->(@_) if $self->{on_value_change};
|
$self->{on_value_change}->(@_) if $self->{on_value_change};
|
||||||
|
$self->_update;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_field {
|
||||||
|
my ($self, $opt_key, $opt_index) = @_;
|
||||||
|
|
||||||
|
foreach my $optgroup (@{ $self->{optgroups} }) {
|
||||||
|
my $field = $optgroup->get_fieldc($opt_key, $opt_index);
|
||||||
|
return $field if defined $field;
|
||||||
|
}
|
||||||
|
return undef;
|
||||||
}
|
}
|
||||||
|
|
||||||
package Slic3r::GUI::SimpleTab::Print;
|
package Slic3r::GUI::SimpleTab::Print;
|
||||||
@ -104,10 +119,12 @@ sub build {
|
|||||||
|
|
||||||
$self->init_config_options(qw(
|
$self->init_config_options(qw(
|
||||||
layer_height perimeters top_solid_layers bottom_solid_layers
|
layer_height perimeters top_solid_layers bottom_solid_layers
|
||||||
fill_density fill_pattern support_material support_material_spacing raft_layers
|
fill_density fill_pattern external_fill_pattern
|
||||||
|
support_material support_material_spacing raft_layers
|
||||||
|
support_material_contact_distance dont_support_bridges
|
||||||
perimeter_speed infill_speed travel_speed
|
perimeter_speed infill_speed travel_speed
|
||||||
brim_width
|
brim_width
|
||||||
complete_objects extruder_clearance_radius extruder_clearance_height
|
xy_size_compensation
|
||||||
));
|
));
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -127,12 +144,15 @@ sub build {
|
|||||||
my $optgroup = $self->new_optgroup('Infill');
|
my $optgroup = $self->new_optgroup('Infill');
|
||||||
$optgroup->append_single_option_line('fill_density');
|
$optgroup->append_single_option_line('fill_density');
|
||||||
$optgroup->append_single_option_line('fill_pattern');
|
$optgroup->append_single_option_line('fill_pattern');
|
||||||
|
$optgroup->append_single_option_line('external_fill_pattern');
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
my $optgroup = $self->new_optgroup('Support material');
|
my $optgroup = $self->new_optgroup('Support material');
|
||||||
$optgroup->append_single_option_line('support_material');
|
$optgroup->append_single_option_line('support_material');
|
||||||
$optgroup->append_single_option_line('support_material_spacing');
|
$optgroup->append_single_option_line('support_material_spacing');
|
||||||
|
$optgroup->append_single_option_line('support_material_contact_distance');
|
||||||
|
$optgroup->append_single_option_line('dont_support_bridges');
|
||||||
$optgroup->append_single_option_line('raft_layers');
|
$optgroup->append_single_option_line('raft_layers');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,18 +169,35 @@ sub build {
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
my $optgroup = $self->new_optgroup('Sequential printing');
|
my $optgroup = $self->new_optgroup('Other');
|
||||||
$optgroup->append_single_option_line('complete_objects');
|
$optgroup->append_single_option_line('xy_size_compensation');
|
||||||
|
|
||||||
my $line = Slic3r::GUI::OptionsGroup::Line->new(
|
|
||||||
label => 'Extruder clearance (mm)',
|
|
||||||
);
|
|
||||||
$line->append_option($optgroup->get_option('extruder_clearance_radius'));
|
|
||||||
$line->append_option($optgroup->get_option('extruder_clearance_height'));
|
|
||||||
$optgroup->append_line($line);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub _update {
|
||||||
|
my ($self) = @_;
|
||||||
|
|
||||||
|
my $config = $self->{config};
|
||||||
|
|
||||||
|
my $have_perimeters = $config->perimeters > 0;
|
||||||
|
$self->get_field($_)->toggle($have_perimeters)
|
||||||
|
for qw(perimeter_speed);
|
||||||
|
|
||||||
|
my $have_infill = $config->fill_density > 0;
|
||||||
|
my $have_solid_infill = $config->top_solid_layers > 0 || $config->bottom_solid_layers > 0;
|
||||||
|
$self->get_field($_)->toggle($have_infill)
|
||||||
|
for qw(fill_pattern);
|
||||||
|
$self->get_field($_)->toggle($have_solid_infill)
|
||||||
|
for qw(external_fill_pattern);
|
||||||
|
$self->get_field($_)->toggle($have_infill || $have_solid_infill)
|
||||||
|
for qw(infill_speed);
|
||||||
|
|
||||||
|
my $have_support_material = $config->support_material || $config->raft_layers > 0;
|
||||||
|
$self->get_field($_)->toggle($have_support_material)
|
||||||
|
for qw(support_material_spacing dont_support_bridges
|
||||||
|
support_material_contact_distance);
|
||||||
|
}
|
||||||
|
|
||||||
package Slic3r::GUI::SimpleTab::Filament;
|
package Slic3r::GUI::SimpleTab::Filament;
|
||||||
use base 'Slic3r::GUI::SimpleTab';
|
use base 'Slic3r::GUI::SimpleTab';
|
||||||
|
|
||||||
@ -220,7 +257,7 @@ sub build {
|
|||||||
z_offset
|
z_offset
|
||||||
gcode_flavor
|
gcode_flavor
|
||||||
nozzle_diameter
|
nozzle_diameter
|
||||||
retract_length retract_lift
|
retract_length retract_lift wipe
|
||||||
start_gcode
|
start_gcode
|
||||||
end_gcode
|
end_gcode
|
||||||
));
|
));
|
||||||
@ -273,6 +310,7 @@ sub build {
|
|||||||
my $optgroup = $self->new_optgroup('Retraction');
|
my $optgroup = $self->new_optgroup('Retraction');
|
||||||
$optgroup->append_single_option_line('retract_length', 0);
|
$optgroup->append_single_option_line('retract_length', 0);
|
||||||
$optgroup->append_single_option_line('retract_lift', 0);
|
$optgroup->append_single_option_line('retract_lift', 0);
|
||||||
|
$optgroup->append_single_option_line('wipe', 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -296,4 +334,14 @@ sub build {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub _update {
|
||||||
|
my ($self) = @_;
|
||||||
|
|
||||||
|
my $config = $self->{config};
|
||||||
|
|
||||||
|
my $have_retraction = $config->retract_length->[0] > 0;
|
||||||
|
$self->get_field($_, 0)->toggle($have_retraction)
|
||||||
|
for qw(retract_lift wipe);
|
||||||
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user