diff --git a/MANIFEST b/MANIFEST index 1568fc498..035cef1a9 100644 --- a/MANIFEST +++ b/MANIFEST @@ -29,6 +29,7 @@ lib/Slic3r/GUI.pm lib/Slic3r/GUI/Plater.pm lib/Slic3r/GUI/OptionsGroup.pm lib/Slic3r/GUI/SkeinPanel.pm +lib/Slic3r/GUI/Tab.pm lib/Slic3r/Layer.pm lib/Slic3r/Line.pm lib/Slic3r/Point.pm diff --git a/lib/Slic3r/GUI.pm b/lib/Slic3r/GUI.pm index 4059f1098..b6c4c6510 100644 --- a/lib/Slic3r/GUI.pm +++ b/lib/Slic3r/GUI.pm @@ -7,6 +7,7 @@ use FindBin; use Slic3r::GUI::Plater; use Slic3r::GUI::OptionsGroup; use Slic3r::GUI::SkeinPanel; +use Slic3r::GUI::Tab; use Wx 0.9901 qw(:sizer :frame wxID_EXIT wxID_ABOUT); use Wx::Event qw(EVT_MENU); diff --git a/lib/Slic3r/GUI/SkeinPanel.pm b/lib/Slic3r/GUI/SkeinPanel.pm index b5977ab38..d60402ad5 100644 --- a/lib/Slic3r/GUI/SkeinPanel.pm +++ b/lib/Slic3r/GUI/SkeinPanel.pm @@ -21,106 +21,25 @@ sub new { my ($parent) = @_; my $self = $class->SUPER::new($parent, -1); - my %panels = ( - printer => { - title => 'Printer', - options => [qw(nozzle_diameter bed_size print_center z_offset gcode_flavor use_relative_e_distances)], - }, - filament => { - title => 'Filament', - options => [qw(filament_diameter extrusion_multiplier temperature first_layer_temperature bed_temperature first_layer_bed_temperature)], - }, - print_speed => { - title => 'Print speed', - options => [qw(perimeter_speed small_perimeter_speed infill_speed solid_infill_speed top_solid_infill_speed bridge_speed)], - }, - speed => { - title => 'Other speed settings', - options => [qw(travel_speed first_layer_speed)], - }, - accuracy => { - title => 'Accuracy', - options => [qw(layer_height first_layer_height infill_every_layers)], - }, - print => { - title => 'Print settings', - options => [qw(perimeters solid_layers fill_density fill_angle fill_pattern solid_fill_pattern randomize_start support_material support_material_tool)], - }, - retract => { - title => 'Retraction', - options => [qw(retract_length retract_lift retract_speed retract_restart_extra retract_before_travel)], - }, - cooling => { - title => 'Cooling', - options => [qw(cooling min_fan_speed max_fan_speed bridge_fan_speed fan_below_layer_time slowdown_below_layer_time min_print_speed disable_fan_first_layers fan_always_on)], - label_width => 300, - }, - skirt => { - title => 'Skirt', - options => [qw(skirts skirt_distance skirt_height)], - }, - gcode => { - title => 'G-code', - options => [qw(start_gcode end_gcode layer_gcode gcode_comments post_process)], - label_width => 260, - }, - sequential_printing => { - title => 'Sequential printing', - options => [qw(complete_objects extruder_clearance_radius extruder_clearance_height)], - }, - extrusion => { - title => 'Extrusion', - options => [qw(extrusion_width first_layer_extrusion_width perimeters_extrusion_width infill_extrusion_width bridge_flow_ratio)], - }, - output => { - title => 'Output', - options => [qw(output_filename_format duplicate_distance)], - }, - other => { - title => 'Other', - options => [$Slic3r::have_threads ? qw(threads) : ()], - }, - notes => { - title => 'Notes', - options => [qw(notes)], - }, - ); - $self->{panels} = \%panels; - my $tabpanel = Wx::Notebook->new($self, -1, Wx::wxDefaultPosition, Wx::wxDefaultSize, &Wx::wxNB_TOP); - my $make_tab = sub { - my @cols = @_; + my $make_treebook_tab = sub { + my $class = shift; my $tab = Wx::Panel->new($tabpanel, -1); - my $sizer = Wx::BoxSizer->new(wxHORIZONTAL); - foreach my $col (@cols) { - my $vertical_sizer = Wx::BoxSizer->new(wxVERTICAL); - for my $optgroup (@$col) { - next unless @{ $panels{$optgroup}{options} }; - my $optpanel = Slic3r::GUI::OptionsGroup->new($tab, %{$panels{$optgroup}}); - $vertical_sizer->Add($optpanel, 0, wxEXPAND | wxALL, 10); - } - $sizer->Add($vertical_sizer); - } - + my $sizer = Wx::BoxSizer->new(&Wx::wxVERTICAL); + $sizer->Add($class->new($tab), 1, &Wx::wxALL | &Wx::wxEXPAND, 5); $tab->SetSizer($sizer); return $tab; }; my @tabs = ( - $make_tab->([qw(accuracy skirt retract)], [qw(print notes)]), - $make_tab->([qw(cooling)]), - $make_tab->([qw(printer filament)], [qw(print_speed speed)]), - $make_tab->([qw(gcode)]), - $make_tab->([qw(extrusion other sequential_printing)], [qw(output)]), + $make_treebook_tab->('Slic3r::GUI::Tab::Print'), + $make_treebook_tab->('Slic3r::GUI::Tab::Printer'), ); $tabpanel->AddPage(Slic3r::GUI::Plater->new($tabpanel), "Plater"); - $tabpanel->AddPage($tabs[0], "Print Settings"); - $tabpanel->AddPage($tabs[1], "Cooling"); - $tabpanel->AddPage($tabs[2], "Printer and Filament"); - $tabpanel->AddPage($tabs[3], "G-code"); - $tabpanel->AddPage($tabs[4], "Advanced"); + $tabpanel->AddPage($tabs[0], "Print settings"); + $tabpanel->AddPage($tabs[1], "Filament/printer settings"); my $buttons_sizer; { diff --git a/lib/Slic3r/GUI/Tab.pm b/lib/Slic3r/GUI/Tab.pm new file mode 100644 index 000000000..9f9e8bbc4 --- /dev/null +++ b/lib/Slic3r/GUI/Tab.pm @@ -0,0 +1,228 @@ +package Slic3r::GUI::Tab; +use strict; +use warnings; +use utf8; + +use Wx qw(:sizer :progressdialog); +use Wx::Event qw(); +use base 'Wx::Treebook'; + +sub new { + my $class = shift; + my ($parent) = @_; + my $self = $class->SUPER::new($parent, -1, [-1,-1], [-1,-1], &Wx::wxBK_LEFT); + + return $self; +} + +sub AddOptionsPage { + my $self = shift; + my $title = shift; + my $page = Slic3r::GUI::Tab::Page->new($self, @_); + $self->AddPage($page, $title); +} + +package Slic3r::GUI::Tab::Print; + +use Wx qw(:sizer :progressdialog); +use Wx::Event qw(); +use base 'Slic3r::GUI::Tab'; + +sub new { + my $class = shift; + my ($parent) = @_; + my $self = $class->SUPER::new($parent, -1); + + $self->AddOptionsPage('Layers and perimeters', optgroups => [ + { + title => 'Layer height', + options => [qw(layer_height first_layer_height)], + }, + { + title => 'Vertical shells', + options => [qw(perimeters randomize_start)], + }, + { + title => 'Horizontal shells', + options => [qw(solid_layers)], + }, + ]); + + $self->AddOptionsPage('Infill', optgroups => [ + { + title => 'Infill', + options => [qw(fill_density fill_angle fill_pattern solid_fill_pattern)], + }, + ]); + + $self->AddOptionsPage('Speed', optgroups => [ + { + title => 'Speed for print moves', + options => [qw(perimeter_speed small_perimeter_speed infill_speed solid_infill_speed top_solid_infill_speed bridge_speed)], + }, + { + title => 'Speed for non-print moves', + options => [qw(travel_speed)], + }, + { + title => 'Advanced', + options => [qw(first_layer_speed)], + }, + ]); + + $self->AddOptionsPage('Skirt', optgroups => [ + { + title => 'Skirt', + options => [qw(skirts skirt_distance skirt_height)], + }, + ]); + + $self->AddOptionsPage('Cooling', optgroups => [ + { + title => 'Enable', + options => [qw(cooling)], + }, + { + title => 'Fan settings', + options => [qw(min_fan_speed max_fan_speed bridge_fan_speed disable_fan_first_layers fan_always_on)], + }, + { + title => 'Cooling thresholds', + options => [qw(fan_below_layer_time slowdown_below_layer_time min_print_speed)], + }, + ]); + + $self->AddOptionsPage('Support material', optgroups => [ + { + title => 'Support material', + options => [qw(support_material support_material_tool)], + }, + ]); + + $self->AddOptionsPage('Notes', optgroups => [ + { + title => 'Notes', + options => [qw(notes)], + }, + ]); + + $self->AddOptionsPage('Output options', optgroups => [ + { + title => 'Sequential printing', + options => [qw(complete_objects extruder_clearance_radius extruder_clearance_height)], + }, + { + title => 'Output file', + options => [qw(gcode_comments output_filename_format)], + }, + { + title => 'Advanced', + options => [qw(post_process duplicate_distance)], # this is not the right place for duplicate_distance + }, + ]); + + $self->AddOptionsPage('Advanced', optgroups => [ + { + title => 'Extrusion width', + options => [qw(extrusion_width first_layer_extrusion_width perimeters_extrusion_width infill_extrusion_width)], + }, + { + title => 'Flow', + options => [qw(bridge_flow_ratio)], + }, + ]); + + + + + return $self; +} + +package Slic3r::GUI::Tab::Printer; + +use Wx qw(:sizer :progressdialog); +use Wx::Event qw(); +use base 'Slic3r::GUI::Tab'; + +sub new { + my $class = shift; + my ($parent) = @_; + my $self = $class->SUPER::new($parent, -1); + + $self->AddOptionsPage('General', optgroups => [ + { + title => 'Size and coordinates', + options => [qw(bed_size print_center z_offset)], + }, + { + title => 'Firmware', + options => [qw(gcode_flavor use_relative_e_distances)], + }, + ]); + + $self->AddOptionsPage('Extruder and filament', optgroups => [ + { + title => 'Size', + options => [qw(nozzle_diameter)], + }, + { + title => 'Filament', + options => [qw(filament_diameter extrusion_multiplier)], + }, + { + title => 'Temperature', + options => [qw(temperature first_layer_temperature bed_temperature first_layer_bed_temperature)], + }, + ]); + + $self->AddOptionsPage('Custom G-code', optgroups => [ + { + title => 'Custom G-code', + options => [qw(start_gcode end_gcode layer_gcode)], + }, + ]); + + $self->AddOptionsPage('Retraction', optgroups => [ + { + title => 'Retraction', + options => [qw(retract_length retract_lift retract_speed)], + }, + { + title => 'Advanced', + options => [qw(retract_restart_extra retract_before_travel)], + }, + ]); + + + return $self; +} + +package Slic3r::GUI::Tab::Page; + +use Wx qw(:sizer :progressdialog); +use Wx::Event qw(); +use base 'Wx::Panel'; + +sub new { + my $class = shift; + my ($parent, %params) = @_; + my $self = $class->SUPER::new($parent, -1); + + $self->{vsizer} = Wx::BoxSizer->new(&Wx::wxVERTICAL); + $self->SetSizer($self->{vsizer}); + + if ($params{optgroups}) { + $self->append_optgroup(%$_) for @{$params{optgroups}}; + } + + return $self; +} + +sub append_optgroup { + my $self = shift; + + my $optgroup = Slic3r::GUI::OptionsGroup->new($self, @_, label_width => 300); + $self->{vsizer}->Add($optgroup, 0, wxEXPAND | wxALL, 5); +} + +1;