mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Merge remote-tracking branch 'origin/master' into feature_arrange_with_libnest2d
This commit is contained in:
commit
170034dd15
15 changed files with 291 additions and 163 deletions
|
@ -194,7 +194,7 @@ sub new {
|
||||||
$self->schedule_background_process;
|
$self->schedule_background_process;
|
||||||
} else {
|
} else {
|
||||||
# Hide the print info box, it is no more valid.
|
# Hide the print info box, it is no more valid.
|
||||||
$self->{"print_info_box_show"}->(0);
|
$self->print_info_box_show(0);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -292,9 +292,9 @@ sub new {
|
||||||
$self->{right_panel} = Wx::Panel->new($self, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
|
$self->{right_panel} = Wx::Panel->new($self, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
|
||||||
|
|
||||||
### Scrolled Window for info boxes
|
### Scrolled Window for info boxes
|
||||||
my $scrolled_window_sizer = Wx::BoxSizer->new(wxVERTICAL);
|
my $scrolled_window_sizer = $self->{scrolled_window_sizer} = Wx::BoxSizer->new(wxVERTICAL);
|
||||||
$scrolled_window_sizer->SetMinSize([310, -1]);
|
$scrolled_window_sizer->SetMinSize([310, -1]);
|
||||||
my $scrolled_window_panel = Wx::ScrolledWindow->new($self->{right_panel}, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
|
my $scrolled_window_panel = $self->{scrolled_window_panel} = Wx::ScrolledWindow->new($self->{right_panel}, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
|
||||||
$scrolled_window_panel->SetSizer($scrolled_window_sizer);
|
$scrolled_window_panel->SetSizer($scrolled_window_sizer);
|
||||||
$scrolled_window_panel->SetScrollbars(1, 1, 1, 1);
|
$scrolled_window_panel->SetScrollbars(1, 1, 1, 1);
|
||||||
|
|
||||||
|
@ -520,38 +520,9 @@ sub new {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
my $print_info_sizer;
|
my $print_info_sizer = $self->{print_info_sizer} = Wx::StaticBoxSizer->new(
|
||||||
{
|
Wx::StaticBox->new($scrolled_window_panel, -1, L("Sliced Info")), wxVERTICAL);
|
||||||
my $box = Wx::StaticBox->new($scrolled_window_panel, -1, L("Sliced Info"));
|
$print_info_sizer->SetMinSize([300,-1]);
|
||||||
$print_info_sizer = Wx::StaticBoxSizer->new($box, wxVERTICAL);
|
|
||||||
$print_info_sizer->SetMinSize([300,-1]);
|
|
||||||
my $grid_sizer = Wx::FlexGridSizer->new(2, 2, 5, 5);
|
|
||||||
$grid_sizer->SetFlexibleDirection(wxHORIZONTAL);
|
|
||||||
$grid_sizer->AddGrowableCol(1, 1);
|
|
||||||
$grid_sizer->AddGrowableCol(3, 1);
|
|
||||||
$print_info_sizer->Add($grid_sizer, 0, wxEXPAND);
|
|
||||||
my @info = (
|
|
||||||
fil_m => L("Used Filament (m)"),
|
|
||||||
fil_mm3 => L("Used Filament (mm³)"),
|
|
||||||
fil_g => L("Used Filament (g)"),
|
|
||||||
cost => L("Cost"),
|
|
||||||
#==========================================================================================================================================
|
|
||||||
normal_time => L("Estimated printing time (normal mode)"),
|
|
||||||
# default_time => L("Estimated printing time (default mode)"),
|
|
||||||
#==========================================================================================================================================
|
|
||||||
silent_time => L("Estimated printing time (silent mode)"),
|
|
||||||
);
|
|
||||||
while (my $field = shift @info) {
|
|
||||||
my $label = shift @info;
|
|
||||||
my $text = Wx::StaticText->new($scrolled_window_panel, -1, "$label:", wxDefaultPosition, wxDefaultSize, wxALIGN_RIGHT);
|
|
||||||
$text->SetFont($Slic3r::GUI::small_font);
|
|
||||||
$grid_sizer->Add($text, 0);
|
|
||||||
|
|
||||||
$self->{"print_info_$field"} = Wx::StaticText->new($scrolled_window_panel, -1, "", wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT);
|
|
||||||
$self->{"print_info_$field"}->SetFont($Slic3r::GUI::small_font);
|
|
||||||
$grid_sizer->Add($self->{"print_info_$field"}, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
my $buttons_sizer = Wx::BoxSizer->new(wxHORIZONTAL);
|
my $buttons_sizer = Wx::BoxSizer->new(wxHORIZONTAL);
|
||||||
$self->{buttons_sizer} = $buttons_sizer;
|
$self->{buttons_sizer} = $buttons_sizer;
|
||||||
|
@ -572,19 +543,8 @@ sub new {
|
||||||
$right_sizer->Add($frequently_changed_parameters_sizer, 0, wxEXPAND | wxTOP, 0) if defined $frequently_changed_parameters_sizer;
|
$right_sizer->Add($frequently_changed_parameters_sizer, 0, wxEXPAND | wxTOP, 0) if defined $frequently_changed_parameters_sizer;
|
||||||
$right_sizer->Add($buttons_sizer, 0, wxEXPAND | wxBOTTOM, 5);
|
$right_sizer->Add($buttons_sizer, 0, wxEXPAND | wxBOTTOM, 5);
|
||||||
$right_sizer->Add($scrolled_window_panel, 1, wxEXPAND | wxALL, 1);
|
$right_sizer->Add($scrolled_window_panel, 1, wxEXPAND | wxALL, 1);
|
||||||
# Callback for showing / hiding the print info box.
|
|
||||||
$self->{"print_info_box_show"} = sub {
|
|
||||||
# if ($right_sizer->IsShown(5) != $_[0]) {
|
|
||||||
# $right_sizer->Show(5, $_[0]);
|
|
||||||
# $self->Layout
|
|
||||||
# }
|
|
||||||
if ($scrolled_window_sizer->IsShown(2) != $_[0]) {
|
|
||||||
$scrolled_window_sizer->Show(2, $_[0]);
|
|
||||||
$scrolled_window_panel->Layout
|
|
||||||
}
|
|
||||||
};
|
|
||||||
# Show the box initially, let it be shown after the slicing is finished.
|
# Show the box initially, let it be shown after the slicing is finished.
|
||||||
$self->{"print_info_box_show"}->(0);
|
$self->print_info_box_show(0);
|
||||||
|
|
||||||
$self->{right_panel}->SetSizer($right_sizer);
|
$self->{right_panel}->SetSizer($right_sizer);
|
||||||
|
|
||||||
|
@ -1300,7 +1260,7 @@ sub async_apply_config {
|
||||||
$self->{canvas3D}->Refresh if Slic3r::GUI::_3DScene::is_layers_editing_enabled($self->{canvas3D});
|
$self->{canvas3D}->Refresh if Slic3r::GUI::_3DScene::is_layers_editing_enabled($self->{canvas3D});
|
||||||
|
|
||||||
# Hide the slicing results if the current slicing status is no more valid.
|
# Hide the slicing results if the current slicing status is no more valid.
|
||||||
$self->{"print_info_box_show"}->(0) if $invalidated;
|
$self->print_info_box_show(0) if $invalidated;
|
||||||
|
|
||||||
if (wxTheApp->{app_config}->get("background_processing")) {
|
if (wxTheApp->{app_config}->get("background_processing")) {
|
||||||
if ($invalidated) {
|
if ($invalidated) {
|
||||||
|
@ -1618,16 +1578,7 @@ sub on_export_completed {
|
||||||
|
|
||||||
$self->{print_file} = undef;
|
$self->{print_file} = undef;
|
||||||
$self->{send_gcode_file} = undef;
|
$self->{send_gcode_file} = undef;
|
||||||
$self->{"print_info_cost"}->SetLabel(sprintf("%.2f" , $self->{print}->total_cost));
|
$self->print_info_box_show(1);
|
||||||
$self->{"print_info_fil_g"}->SetLabel(sprintf("%.2f" , $self->{print}->total_weight));
|
|
||||||
$self->{"print_info_fil_mm3"}->SetLabel(sprintf("%.2f" , $self->{print}->total_extruded_volume));
|
|
||||||
#==========================================================================================================================================
|
|
||||||
$self->{"print_info_normal_time"}->SetLabel($self->{print}->estimated_normal_print_time);
|
|
||||||
# $self->{"print_info_default_time"}->SetLabel($self->{print}->estimated_default_print_time);
|
|
||||||
#==========================================================================================================================================
|
|
||||||
$self->{"print_info_silent_time"}->SetLabel($self->{print}->estimated_silent_print_time);
|
|
||||||
$self->{"print_info_fil_m"}->SetLabel(sprintf("%.2f" , $self->{print}->total_used_filament / 1000));
|
|
||||||
$self->{"print_info_box_show"}->(1);
|
|
||||||
|
|
||||||
# this updates buttons status
|
# this updates buttons status
|
||||||
$self->object_list_changed;
|
$self->object_list_changed;
|
||||||
|
@ -1637,6 +1588,51 @@ sub on_export_completed {
|
||||||
$self->{preview3D}->reload_print if $self->{preview3D};
|
$self->{preview3D}->reload_print if $self->{preview3D};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Fill in the "Sliced info" box with the result of the G-code generator.
|
||||||
|
sub print_info_box_show {
|
||||||
|
my ($self, $show) = @_;
|
||||||
|
my $scrolled_window_panel = $self->{scrolled_window_panel};
|
||||||
|
my $scrolled_window_sizer = $self->{scrolled_window_sizer};
|
||||||
|
return if $scrolled_window_sizer->IsShown(2) == $show;
|
||||||
|
|
||||||
|
if ($show) {
|
||||||
|
my $print_info_sizer = $self->{print_info_sizer};
|
||||||
|
$print_info_sizer->Clear(1);
|
||||||
|
my $grid_sizer = Wx::FlexGridSizer->new(2, 2, 5, 5);
|
||||||
|
$grid_sizer->SetFlexibleDirection(wxHORIZONTAL);
|
||||||
|
$grid_sizer->AddGrowableCol(1, 1);
|
||||||
|
$grid_sizer->AddGrowableCol(3, 1);
|
||||||
|
$print_info_sizer->Add($grid_sizer, 0, wxEXPAND);
|
||||||
|
my @info = (
|
||||||
|
L("Used Filament (m)")
|
||||||
|
=> sprintf("%.2f" , $self->{print}->total_cost),
|
||||||
|
L("Used Filament (mm³)")
|
||||||
|
=> sprintf("%.2f" , $self->{print}->total_weight),
|
||||||
|
L("Used Filament (g)"),
|
||||||
|
=> sprintf("%.2f" , $self->{print}->total_extruded_volume),
|
||||||
|
L("Cost"),
|
||||||
|
=> $self->{print}->estimated_normal_print_time,
|
||||||
|
L("Estimated printing time (normal mode)")
|
||||||
|
=> $self->{print}->estimated_silent_print_time,
|
||||||
|
L("Estimated printing time (silent mode)")
|
||||||
|
=> sprintf("%.2f" , $self->{print}->total_used_filament / 1000)
|
||||||
|
);
|
||||||
|
while ( my $label = shift @info) {
|
||||||
|
my $value = shift @info;
|
||||||
|
next if $value eq "N/A";
|
||||||
|
my $text = Wx::StaticText->new($scrolled_window_panel, -1, "$label:", wxDefaultPosition, wxDefaultSize, wxALIGN_RIGHT);
|
||||||
|
$text->SetFont($Slic3r::GUI::small_font);
|
||||||
|
$grid_sizer->Add($text, 0);
|
||||||
|
my $field = Wx::StaticText->new($scrolled_window_panel, -1, $value, wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT);
|
||||||
|
$field->SetFont($Slic3r::GUI::small_font);
|
||||||
|
$grid_sizer->Add($field, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$scrolled_window_sizer->Show(2, $show);
|
||||||
|
$scrolled_window_panel->Layout;
|
||||||
|
}
|
||||||
|
|
||||||
sub do_print {
|
sub do_print {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
|
@ -1702,6 +1698,34 @@ sub export_object_stl {
|
||||||
$self->statusbar->SetStatusText(L("STL file exported to ").$output_file);
|
$self->statusbar->SetStatusText(L("STL file exported to ").$output_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub fix_through_netfabb {
|
||||||
|
my ($self) = @_;
|
||||||
|
my ($obj_idx, $object) = $self->selected_object;
|
||||||
|
return if !defined $obj_idx;
|
||||||
|
my $model_object = $self->{model}->objects->[$obj_idx];
|
||||||
|
my $model_fixed = Slic3r::Model->new;
|
||||||
|
Slic3r::GUI::fix_model_by_win10_sdk_gui($model_object, $self->{print}, $model_fixed);
|
||||||
|
|
||||||
|
my @new_obj_idx = $self->load_model_objects(@{$model_fixed->objects});
|
||||||
|
return if !@new_obj_idx;
|
||||||
|
|
||||||
|
foreach my $new_obj_idx (@new_obj_idx) {
|
||||||
|
my $o = $self->{model}->objects->[$new_obj_idx];
|
||||||
|
$o->clear_instances;
|
||||||
|
$o->add_instance($_) for @{$model_object->instances};
|
||||||
|
#$o->invalidate_bounding_box;
|
||||||
|
|
||||||
|
if ($o->volumes_count == $model_object->volumes_count) {
|
||||||
|
for my $i (0..($o->volumes_count-1)) {
|
||||||
|
$o->get_volume($i)->config->apply($model_object->get_volume($i)->config);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#FIXME restore volumes and their configs, layer_height_ranges, layer_height_profile, layer_height_profile_valid,
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->remove($obj_idx);
|
||||||
|
}
|
||||||
|
|
||||||
sub export_amf {
|
sub export_amf {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
return if !@{$self->{objects}};
|
return if !@{$self->{objects}};
|
||||||
|
@ -2280,6 +2304,11 @@ sub object_menu {
|
||||||
$frame->_append_menu_item($menu, L("Export object as STL…"), L('Export this single object as STL file'), sub {
|
$frame->_append_menu_item($menu, L("Export object as STL…"), L('Export this single object as STL file'), sub {
|
||||||
$self->export_object_stl;
|
$self->export_object_stl;
|
||||||
}, undef, 'brick_go.png');
|
}, undef, 'brick_go.png');
|
||||||
|
if (Slic3r::GUI::is_windows10) {
|
||||||
|
$frame->_append_menu_item($menu, L("Fix STL through Netfabb"), L('Fix the model by sending it to a Netfabb cloud service through Windows 10 API'), sub {
|
||||||
|
$self->fix_through_netfabb;
|
||||||
|
}, undef, 'brick_go.png');
|
||||||
|
}
|
||||||
|
|
||||||
return $menu;
|
return $menu;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
min_slic3r_version = 1.41.0-alpha
|
||||||
|
0.2.0-alpha
|
||||||
min_slic3r_version = 1.40.0
|
min_slic3r_version = 1.40.0
|
||||||
0.1.6 Split the MK2.5 profile from the MK2S
|
0.1.6 Split the MK2.5 profile from the MK2S
|
||||||
min_slic3r_version = 1.40.0-beta
|
min_slic3r_version = 1.40.0-beta
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
name = Prusa Research
|
name = Prusa Research
|
||||||
# Configuration version of this file. Config file will only be installed, if the config_version differs.
|
# Configuration version of this file. Config file will only be installed, if the config_version differs.
|
||||||
# This means, the server may force the Slic3r configuration to be downgraded.
|
# This means, the server may force the Slic3r configuration to be downgraded.
|
||||||
config_version = 0.1.6
|
config_version = 0.2.0-alpha
|
||||||
# Where to get the updates from?
|
# Where to get the updates from?
|
||||||
config_update_url = https://raw.githubusercontent.com/prusa3d/Slic3r-settings/master/live/PrusaResearch/
|
config_update_url = https://raw.githubusercontent.com/prusa3d/Slic3r-settings/master/live/PrusaResearch/
|
||||||
|
|
||||||
|
@ -140,7 +140,7 @@ infill_extrusion_width = 0.25
|
||||||
perimeter_extrusion_width = 0.25
|
perimeter_extrusion_width = 0.25
|
||||||
solid_infill_extrusion_width = 0.25
|
solid_infill_extrusion_width = 0.25
|
||||||
top_infill_extrusion_width = 0.25
|
top_infill_extrusion_width = 0.25
|
||||||
support_material_extrusion_width = 0.18
|
support_material_extrusion_width = 0.2
|
||||||
support_material_interface_layers = 0
|
support_material_interface_layers = 0
|
||||||
support_material_interface_spacing = 0.15
|
support_material_interface_spacing = 0.15
|
||||||
support_material_spacing = 1
|
support_material_spacing = 1
|
||||||
|
@ -155,6 +155,7 @@ infill_extrusion_width = 0.7
|
||||||
perimeter_extrusion_width = 0.65
|
perimeter_extrusion_width = 0.65
|
||||||
solid_infill_extrusion_width = 0.65
|
solid_infill_extrusion_width = 0.65
|
||||||
top_infill_extrusion_width = 0.6
|
top_infill_extrusion_width = 0.6
|
||||||
|
support_material_extrusion_width = 0.55
|
||||||
|
|
||||||
[print:*soluble_support*]
|
[print:*soluble_support*]
|
||||||
overhangs = 1
|
overhangs = 1
|
||||||
|
@ -213,26 +214,18 @@ top_infill_extrusion_width = 0.4
|
||||||
[print:0.05mm ULTRADETAIL 0.25 nozzle]
|
[print:0.05mm ULTRADETAIL 0.25 nozzle]
|
||||||
inherits = *0.05mm*; *0.25nozzle*
|
inherits = *0.05mm*; *0.25nozzle*
|
||||||
compatible_printers_condition = printer_notes=~/.*PRINTER_VENDOR_PRUSA3D.*/ and printer_notes=~/.*PRINTER_MODEL_MK2.*/ and nozzle_diameter[0]==0.25 and num_extruders==1
|
compatible_printers_condition = printer_notes=~/.*PRINTER_VENDOR_PRUSA3D.*/ and printer_notes=~/.*PRINTER_MODEL_MK2.*/ and nozzle_diameter[0]==0.25 and num_extruders==1
|
||||||
external_perimeter_extrusion_width = 0
|
|
||||||
extrusion_width = 0.28
|
|
||||||
fill_density = 20%
|
fill_density = 20%
|
||||||
first_layer_extrusion_width = 0.3
|
|
||||||
infill_extrusion_width = 0
|
|
||||||
infill_speed = 20
|
infill_speed = 20
|
||||||
max_print_speed = 100
|
max_print_speed = 100
|
||||||
perimeter_extrusion_width = 0
|
|
||||||
perimeter_speed = 20
|
perimeter_speed = 20
|
||||||
small_perimeter_speed = 15
|
small_perimeter_speed = 15
|
||||||
solid_infill_extrusion_width = 0
|
|
||||||
solid_infill_speed = 20
|
solid_infill_speed = 20
|
||||||
support_material_speed = 20
|
support_material_speed = 20
|
||||||
top_infill_extrusion_width = 0
|
|
||||||
|
|
||||||
[print:0.05mm ULTRADETAIL 0.25 nozzle MK3]
|
[print:0.05mm ULTRADETAIL 0.25 nozzle MK3]
|
||||||
inherits = *0.05mm*; *0.25nozzle*
|
inherits = *0.05mm*; *0.25nozzle*
|
||||||
compatible_printers_condition = printer_notes=~/.*PRINTER_VENDOR_PRUSA3D.*/ and printer_notes=~/.*PRINTER_MODEL_MK3.*/ and nozzle_diameter[0]==0.25 and num_extruders==1
|
compatible_printers_condition = printer_notes=~/.*PRINTER_VENDOR_PRUSA3D.*/ and printer_notes=~/.*PRINTER_MODEL_MK3.*/ and nozzle_diameter[0]==0.25 and num_extruders==1
|
||||||
fill_pattern = grid
|
fill_pattern = grid
|
||||||
top_infill_extrusion_width = 0.4
|
|
||||||
|
|
||||||
# XXXXXXXXXXXXXXXXXXXX
|
# XXXXXXXXXXXXXXXXXXXX
|
||||||
# XXX--- 0.10mm ---XXX
|
# XXX--- 0.10mm ---XXX
|
||||||
|
@ -294,7 +287,6 @@ infill_speed = 200
|
||||||
max_print_speed = 200
|
max_print_speed = 200
|
||||||
perimeter_speed = 45
|
perimeter_speed = 45
|
||||||
solid_infill_speed = 200
|
solid_infill_speed = 200
|
||||||
top_infill_extrusion_width = 0.4
|
|
||||||
top_solid_infill_speed = 50
|
top_solid_infill_speed = 50
|
||||||
|
|
||||||
[print:0.10mm DETAIL 0.6 nozzle MK3]
|
[print:0.10mm DETAIL 0.6 nozzle MK3]
|
||||||
|
@ -308,7 +300,6 @@ infill_speed = 200
|
||||||
max_print_speed = 200
|
max_print_speed = 200
|
||||||
perimeter_speed = 45
|
perimeter_speed = 45
|
||||||
solid_infill_speed = 200
|
solid_infill_speed = 200
|
||||||
top_infill_extrusion_width = 0.4
|
|
||||||
top_solid_infill_speed = 50
|
top_solid_infill_speed = 50
|
||||||
|
|
||||||
# XXXXXXXXXXXXXXXXXXXX
|
# XXXXXXXXXXXXXXXXXXXX
|
||||||
|
@ -358,7 +349,6 @@ perimeter_acceleration = 600
|
||||||
perimeter_speed = 25
|
perimeter_speed = 25
|
||||||
small_perimeter_speed = 15
|
small_perimeter_speed = 15
|
||||||
solid_infill_speed = 40
|
solid_infill_speed = 40
|
||||||
support_material_extrusion_width = 0.2
|
|
||||||
top_solid_infill_speed = 30
|
top_solid_infill_speed = 30
|
||||||
|
|
||||||
[print:0.15mm OPTIMAL 0.6 nozzle]
|
[print:0.15mm OPTIMAL 0.6 nozzle]
|
||||||
|
@ -544,7 +534,6 @@ external_perimeter_extrusion_width = 0.6
|
||||||
external_perimeter_speed = 30
|
external_perimeter_speed = 30
|
||||||
notes = Set your solluble extruder in Multiple Extruders > Support material/raft interface extruder
|
notes = Set your solluble extruder in Multiple Extruders > Support material/raft interface extruder
|
||||||
perimeter_speed = 40
|
perimeter_speed = 40
|
||||||
support_material_extrusion_width = 0.55
|
|
||||||
support_material_interface_layers = 3
|
support_material_interface_layers = 3
|
||||||
support_material_xy_spacing = 120%
|
support_material_xy_spacing = 120%
|
||||||
top_infill_extrusion_width = 0.57
|
top_infill_extrusion_width = 0.57
|
||||||
|
@ -912,6 +901,23 @@ end_gcode = G4 ; wait\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbe
|
||||||
extruder_colour = #FFFF00
|
extruder_colour = #FFFF00
|
||||||
extruder_offset = 0x0
|
extruder_offset = 0x0
|
||||||
gcode_flavor = marlin
|
gcode_flavor = marlin
|
||||||
|
silent_mode = 0
|
||||||
|
machine_max_acceleration_e = 10000
|
||||||
|
machine_max_acceleration_extruding = 1500
|
||||||
|
machine_max_acceleration_retracting = 1500
|
||||||
|
machine_max_acceleration_x = 9000
|
||||||
|
machine_max_acceleration_y = 9000
|
||||||
|
machine_max_acceleration_z = 500
|
||||||
|
machine_max_feedrate_e = 120
|
||||||
|
machine_max_feedrate_x = 500
|
||||||
|
machine_max_feedrate_y = 500
|
||||||
|
machine_max_feedrate_z = 12
|
||||||
|
machine_max_jerk_e = 2.5
|
||||||
|
machine_max_jerk_x = 10
|
||||||
|
machine_max_jerk_y = 10
|
||||||
|
machine_max_jerk_z = 0.2
|
||||||
|
machine_min_extruding_rate = 0
|
||||||
|
machine_min_travel_rate = 0
|
||||||
layer_gcode = ;AFTER_LAYER_CHANGE\n;[layer_z]
|
layer_gcode = ;AFTER_LAYER_CHANGE\n;[layer_z]
|
||||||
max_layer_height = 0.25
|
max_layer_height = 0.25
|
||||||
min_layer_height = 0.07
|
min_layer_height = 0.07
|
||||||
|
@ -935,7 +941,7 @@ retract_speed = 35
|
||||||
serial_port =
|
serial_port =
|
||||||
serial_speed = 250000
|
serial_speed = 250000
|
||||||
single_extruder_multi_material = 0
|
single_extruder_multi_material = 0
|
||||||
start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
||||||
toolchange_gcode =
|
toolchange_gcode =
|
||||||
use_firmware_retraction = 0
|
use_firmware_retraction = 0
|
||||||
use_relative_e_distances = 1
|
use_relative_e_distances = 1
|
||||||
|
@ -971,7 +977,7 @@ printer_model = MK2SMM
|
||||||
inherits = *multimaterial*
|
inherits = *multimaterial*
|
||||||
end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7 \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3 \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0 ; home X axis\nM84 ; disable motors\n\n
|
end_gcode = G1 E-4 F2100.00000\nG91\nG1 Z1 F7200.000\nG90\nG1 X245 Y1\nG1 X240 E4\nG1 F4000\nG1 X190 E2.7 \nG1 F4600\nG1 X110 E2.8\nG1 F5200\nG1 X40 E3 \nG1 E-15.0000 F5000\nG1 E-50.0000 F5400\nG1 E-15.0000 F3000\nG1 E-12.0000 F2000\nG1 F1600\nG1 X0 Y1 E3.0000\nG1 X50 Y1 E-5.0000\nG1 F2000\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-5.0000\nG1 F2400\nG1 X0 Y1 E5.0000\nG1 X50 Y1 E-3.0000\nG4 S0\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nG28 X0 ; home X axis\nM84 ; disable motors\n\n
|
||||||
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN
|
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN
|
||||||
start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0 F1000.0\nG1 X160.0 E20.0 F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0
|
start_gcode = M115 U3.1.0 ; tell printer latest fw version\n; Start G-Code sequence START\nT?\nM104 S[first_layer_temperature]\nM140 S[first_layer_bed_temperature]\nM109 S[first_layer_temperature]\nM190 S[first_layer_bed_temperature]\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100\nM92 E140\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0 F1000.0\nG1 X160.0 E20.0 F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\nG92 E0.0
|
||||||
default_print_profile = 0.15mm OPTIMAL
|
default_print_profile = 0.15mm OPTIMAL
|
||||||
default_filament_profile = Prusa PLA
|
default_filament_profile = Prusa PLA
|
||||||
|
|
||||||
|
@ -981,7 +987,7 @@ end_gcode = {if not has_wipe_tower}\n; Pull the filament into the cooling tubes.
|
||||||
extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259
|
extruder_colour = #FFAA55;#5182DB;#4ECDD3;#FB7259
|
||||||
nozzle_diameter = 0.4,0.4,0.4,0.4
|
nozzle_diameter = 0.4,0.4,0.4,0.4
|
||||||
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN
|
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK2\nPRINTER_HAS_BOWDEN
|
||||||
start_gcode = M115 U3.1.0 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0 F1000.0\nG1 X160.0 E20.0 F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0
|
start_gcode = M115 U3.1.0 ; tell printer latest fw version\n; Start G-Code sequence START\nT[initial_tool]\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG21 ; set units to millimeters\nG90 ; use absolute coordinates\nM83 ; use relative distances for extrusion\nG28 W\nG80\nG92 E0.0\nM203 E100 ; set max feedrate\nM92 E140 ; E-steps per filament milimeter\n{if not has_wipe_tower}\nG1 Z0.250 F7200.000\nG1 X50.0 E80.0 F1000.0\nG1 X160.0 E20.0 F1000.0\nG1 Z0.200 F7200.000\nG1 X220.0 E13 F1000.0\nG1 X240.0 E0 F1000.0\nG1 E-4 F1000.0\n{endif}\nG92 E0.0
|
||||||
variable_layer_height = 0
|
variable_layer_height = 0
|
||||||
default_print_profile = 0.15mm OPTIMAL
|
default_print_profile = 0.15mm OPTIMAL
|
||||||
default_filament_profile = Prusa PLA
|
default_filament_profile = Prusa PLA
|
||||||
|
@ -1005,7 +1011,7 @@ printer_variant = 0.25
|
||||||
default_print_profile = 0.10mm DETAIL 0.25 nozzle
|
default_print_profile = 0.10mm DETAIL 0.25 nozzle
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK2 0.6 nozzle]
|
[printer:Original Prusa i3 MK2 0.6 nozzle]
|
||||||
inherits = *common*; *0.6nozzle*
|
inherits = *common*
|
||||||
max_layer_height = 0.35
|
max_layer_height = 0.35
|
||||||
min_layer_height = 0.1
|
min_layer_height = 0.1
|
||||||
nozzle_diameter = 0.6
|
nozzle_diameter = 0.6
|
||||||
|
@ -1020,7 +1026,7 @@ default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
||||||
inherits = *mm-single*
|
inherits = *mm-single*
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK2 MM Single Mode 0.6 nozzle]
|
[printer:Original Prusa i3 MK2 MM Single Mode 0.6 nozzle]
|
||||||
inherits = *mm-single*; *0.6nozzle*
|
inherits = *mm-single*
|
||||||
nozzle_diameter = 0.6
|
nozzle_diameter = 0.6
|
||||||
printer_variant = 0.6
|
printer_variant = 0.6
|
||||||
default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
||||||
|
@ -1030,7 +1036,7 @@ inherits = *mm-multi*
|
||||||
nozzle_diameter = 0.4,0.4,0.4,0.4
|
nozzle_diameter = 0.4,0.4,0.4,0.4
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK2 MultiMaterial 0.6 nozzle]
|
[printer:Original Prusa i3 MK2 MultiMaterial 0.6 nozzle]
|
||||||
inherits = *mm-multi*; *0.6nozzle*
|
inherits = *mm-multi*
|
||||||
nozzle_diameter = 0.6,0.6,0.6,0.6
|
nozzle_diameter = 0.6,0.6,0.6,0.6
|
||||||
printer_variant = 0.6
|
printer_variant = 0.6
|
||||||
default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
||||||
|
@ -1042,17 +1048,17 @@ default_print_profile = 0.20mm NORMAL 0.6 nozzle
|
||||||
[printer:Original Prusa i3 MK2.5]
|
[printer:Original Prusa i3 MK2.5]
|
||||||
inherits = Original Prusa i3 MK2
|
inherits = Original Prusa i3 MK2
|
||||||
printer_model = MK2.5
|
printer_model = MK2.5
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK2.5 0.25 nozzle]
|
[printer:Original Prusa i3 MK2.5 0.25 nozzle]
|
||||||
inherits = Original Prusa i3 MK2 0.25 nozzle
|
inherits = Original Prusa i3 MK2 0.25 nozzle
|
||||||
printer_model = MK2.5
|
printer_model = MK2.5
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK2.5 0.6 nozzle]
|
[printer:Original Prusa i3 MK2.5 0.6 nozzle]
|
||||||
inherits = Original Prusa i3 MK2 0.6 nozzle
|
inherits = Original Prusa i3 MK2 0.6 nozzle
|
||||||
printer_model = MK2.5
|
printer_model = MK2.5
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X9000 Y9000 Z500 E10000 ; sets maximum accelerations, mm/sec^2\nM203 X500 Y500 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1500 T1500 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.2 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0
|
||||||
|
|
||||||
# XXXXXXXXXXXXXXXXX
|
# XXXXXXXXXXXXXXXXX
|
||||||
# XXX--- MK3 ---XXX
|
# XXX--- MK3 ---XXX
|
||||||
|
@ -1061,34 +1067,43 @@ start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X9000 Y9000 Z50
|
||||||
[printer:Original Prusa i3 MK3]
|
[printer:Original Prusa i3 MK3]
|
||||||
inherits = *common*
|
inherits = *common*
|
||||||
end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nG1 X0 Y200; home X axis\nM84 ; disable motors
|
end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nG1 X0 Y200; home X axis\nM84 ; disable motors
|
||||||
|
machine_max_acceleration_e = 9000,9000
|
||||||
|
machine_max_acceleration_extruding = 1250,960
|
||||||
|
machine_max_acceleration_retracting = 1250,1250
|
||||||
|
machine_max_acceleration_x = 1000,1000
|
||||||
|
machine_max_acceleration_y = 1000,1000
|
||||||
|
machine_max_acceleration_z = 1000,1000
|
||||||
|
machine_max_feedrate_e = 120,120
|
||||||
|
machine_max_feedrate_x = 200,172
|
||||||
|
machine_max_feedrate_y = 200,172
|
||||||
|
machine_max_feedrate_z = 12,12
|
||||||
|
machine_max_jerk_e = 1.5,1.5
|
||||||
|
machine_max_jerk_x = 8,8
|
||||||
|
machine_max_jerk_y = 8,8
|
||||||
|
machine_max_jerk_z = 0.4,0.4
|
||||||
|
machine_min_extruding_rate = 0,0
|
||||||
|
machine_min_travel_rate = 0,0
|
||||||
|
silent_mode = 1
|
||||||
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n
|
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n
|
||||||
retract_lift_below = 209
|
retract_lift_below = 209
|
||||||
max_print_height = 210
|
max_print_height = 210
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif}
|
start_gcode = M115 U3.3.0 ; tell printer latest fw version\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif}
|
||||||
printer_model = MK3
|
printer_model = MK3
|
||||||
default_print_profile = 0.15mm OPTIMAL MK3
|
default_print_profile = 0.15mm OPTIMAL MK3
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK3 0.25 nozzle]
|
[printer:Original Prusa i3 MK3 0.25 nozzle]
|
||||||
inherits = *common*
|
inherits = Original Prusa i3 MK3
|
||||||
nozzle_diameter = 0.25
|
nozzle_diameter = 0.25
|
||||||
end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nG1 X0 Y200; home X axis\nM84 ; disable motors
|
max_layer_height = 0.1
|
||||||
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n
|
min_layer_height = 0.05
|
||||||
retract_lift_below = 209
|
|
||||||
max_print_height = 210
|
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif}
|
|
||||||
printer_model = MK3
|
|
||||||
printer_variant = 0.25
|
printer_variant = 0.25
|
||||||
default_print_profile = 0.10mm DETAIL 0.25 nozzle MK3
|
default_print_profile = 0.10mm DETAIL 0.25 nozzle MK3
|
||||||
|
|
||||||
[printer:Original Prusa i3 MK3 0.6 nozzle]
|
[printer:Original Prusa i3 MK3 0.6 nozzle]
|
||||||
inherits = *common*
|
inherits = Original Prusa i3 MK3
|
||||||
nozzle_diameter = 0.6
|
nozzle_diameter = 0.6
|
||||||
end_gcode = G4 ; wait\nM221 S100\nM104 S0 ; turn off temperature\nM140 S0 ; turn off heatbed\nM107 ; turn off fan\n{if layer_z < max_print_height}G1 Z{z_offset+min(layer_z+30, max_print_height)}{endif} ; Move print head up\nG1 X0 Y200; home X axis\nM84 ; disable motors
|
max_layer_height = 0.35
|
||||||
printer_notes = Don't remove the following keywords! These keywords are used in the "compatible printer" condition of the print and filament profiles to link the particular print and filament profiles to this printer profile.\nPRINTER_VENDOR_PRUSA3D\nPRINTER_MODEL_MK3\n
|
min_layer_height = 0.1
|
||||||
retract_lift_below = 209
|
|
||||||
max_print_height = 210
|
|
||||||
start_gcode = M115 U3.2.1 ; tell printer latest fw version\nM201 X1000 Y1000 Z200 E5000 ; sets maximum accelerations, mm/sec^2\nM203 X200 Y200 Z12 E120 ; sets maximum feedrates, mm/sec\nM204 S1250 T1250 ; sets acceleration (S) and retract acceleration (T)\nM205 X10 Y10 Z0.4 E2.5 ; sets the jerk limits, mm/sec\nM205 S0 T0 ; sets the minimum extruding and travel feed rate, mm/sec\nM83 ; extruder relative mode\nM104 S[first_layer_temperature] ; set extruder temp\nM140 S[first_layer_bed_temperature] ; set bed temp\nM190 S[first_layer_bed_temperature] ; wait for bed temp\nM109 S[first_layer_temperature] ; wait for extruder temp\nG28 W ; home all without mesh bed level\nG80 ; mesh bed leveling\nG1 Y-3.0 F1000.0 ; go outside print area\nG92 E0.0\nG1 X60.0 E9.0 F1000.0 ; intro line\nG1 X100.0 E12.5 F1000.0 ; intro line\nG92 E0.0\nM221 S{if layer_height==0.05}100{else}95{endif}
|
|
||||||
printer_model = MK3
|
|
||||||
printer_variant = 0.6
|
printer_variant = 0.6
|
||||||
default_print_profile = 0.15mm OPTIMAL 0.6 nozzle MK3
|
default_print_profile = 0.15mm OPTIMAL 0.6 nozzle MK3
|
||||||
|
|
||||||
|
|
|
@ -412,45 +412,54 @@ void GCode::_do_export(Print &print, FILE *file, GCodePreviewData *preview_data)
|
||||||
// resets time estimators
|
// resets time estimators
|
||||||
m_normal_time_estimator.reset();
|
m_normal_time_estimator.reset();
|
||||||
m_normal_time_estimator.set_dialect(print.config.gcode_flavor);
|
m_normal_time_estimator.set_dialect(print.config.gcode_flavor);
|
||||||
m_normal_time_estimator.set_acceleration(print.config.machine_max_acceleration_extruding.values[0]);
|
m_silent_time_estimator_enabled = (print.config.gcode_flavor == gcfMarlin) && print.config.silent_mode;
|
||||||
m_normal_time_estimator.set_retract_acceleration(print.config.machine_max_acceleration_retracting.values[0]);
|
|
||||||
m_normal_time_estimator.set_minimum_feedrate(print.config.machine_min_extruding_rate.values[0]);
|
|
||||||
m_normal_time_estimator.set_minimum_travel_feedrate(print.config.machine_min_travel_rate.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::X, print.config.machine_max_acceleration_x.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Y, print.config.machine_max_acceleration_y.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Z, print.config.machine_max_acceleration_z.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::E, print.config.machine_max_acceleration_e.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::X, print.config.machine_max_feedrate_x.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Y, print.config.machine_max_feedrate_y.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Z, print.config.machine_max_feedrate_z.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::E, print.config.machine_max_feedrate_e.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::X, print.config.machine_max_jerk_x.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Y, print.config.machine_max_jerk_y.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Z, print.config.machine_max_jerk_z.values[0]);
|
|
||||||
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::E, print.config.machine_max_jerk_e.values[0]);
|
|
||||||
|
|
||||||
m_silent_time_estimator_enabled = (print.config.gcode_flavor == gcfMarlin) && print.config.silent_mode && boost::starts_with(print.config.printer_model.value, "MK3");
|
// Until we have a UI support for the other firmwares than the Marlin, use the hardcoded default values
|
||||||
if (m_silent_time_estimator_enabled)
|
// and let the user to enter the G-code limits into the start G-code.
|
||||||
{
|
// If the following block is enabled for other firmwares than the Marlin, then the function
|
||||||
m_silent_time_estimator.reset();
|
// this->print_machine_envelope(file, print);
|
||||||
m_silent_time_estimator.set_dialect(print.config.gcode_flavor);
|
// shall be adjusted as well to produce a G-code block compatible with the particular firmware flavor.
|
||||||
m_silent_time_estimator.set_acceleration(print.config.machine_max_acceleration_extruding.values[1]);
|
if (print.config.gcode_flavor.value == gcfMarlin) {
|
||||||
m_silent_time_estimator.set_retract_acceleration(print.config.machine_max_acceleration_retracting.values[1]);
|
m_normal_time_estimator.set_max_acceleration(print.config.machine_max_acceleration_extruding.values[0]);
|
||||||
m_silent_time_estimator.set_minimum_feedrate(print.config.machine_min_extruding_rate.values[1]);
|
m_normal_time_estimator.set_retract_acceleration(print.config.machine_max_acceleration_retracting.values[0]);
|
||||||
m_silent_time_estimator.set_minimum_travel_feedrate(print.config.machine_min_travel_rate.values[1]);
|
m_normal_time_estimator.set_minimum_feedrate(print.config.machine_min_extruding_rate.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::X, print.config.machine_max_acceleration_x.values[1]);
|
m_normal_time_estimator.set_minimum_travel_feedrate(print.config.machine_min_travel_rate.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Y, print.config.machine_max_acceleration_y.values[1]);
|
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::X, print.config.machine_max_acceleration_x.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Z, print.config.machine_max_acceleration_z.values[1]);
|
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Y, print.config.machine_max_acceleration_y.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::E, print.config.machine_max_acceleration_e.values[1]);
|
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Z, print.config.machine_max_acceleration_z.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::X, print.config.machine_max_feedrate_x.values[1]);
|
m_normal_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::E, print.config.machine_max_acceleration_e.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Y, print.config.machine_max_feedrate_y.values[1]);
|
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::X, print.config.machine_max_feedrate_x.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Z, print.config.machine_max_feedrate_z.values[1]);
|
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Y, print.config.machine_max_feedrate_y.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::E, print.config.machine_max_feedrate_e.values[1]);
|
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Z, print.config.machine_max_feedrate_z.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::X, print.config.machine_max_jerk_x.values[1]);
|
m_normal_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::E, print.config.machine_max_feedrate_e.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Y, print.config.machine_max_jerk_y.values[1]);
|
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::X, print.config.machine_max_jerk_x.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Z, print.config.machine_max_jerk_z.values[1]);
|
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Y, print.config.machine_max_jerk_y.values[0]);
|
||||||
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::E, print.config.machine_max_jerk_e.values[1]);
|
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Z, print.config.machine_max_jerk_z.values[0]);
|
||||||
|
m_normal_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::E, print.config.machine_max_jerk_e.values[0]);
|
||||||
|
|
||||||
|
if (m_silent_time_estimator_enabled)
|
||||||
|
{
|
||||||
|
m_silent_time_estimator.reset();
|
||||||
|
m_silent_time_estimator.set_dialect(print.config.gcode_flavor);
|
||||||
|
m_silent_time_estimator.set_max_acceleration(print.config.machine_max_acceleration_extruding.values[1]);
|
||||||
|
m_silent_time_estimator.set_retract_acceleration(print.config.machine_max_acceleration_retracting.values[1]);
|
||||||
|
m_silent_time_estimator.set_minimum_feedrate(print.config.machine_min_extruding_rate.values[1]);
|
||||||
|
m_silent_time_estimator.set_minimum_travel_feedrate(print.config.machine_min_travel_rate.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::X, print.config.machine_max_acceleration_x.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Y, print.config.machine_max_acceleration_y.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::Z, print.config.machine_max_acceleration_z.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_acceleration(GCodeTimeEstimator::E, print.config.machine_max_acceleration_e.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::X, print.config.machine_max_feedrate_x.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Y, print.config.machine_max_feedrate_y.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::Z, print.config.machine_max_feedrate_z.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_feedrate(GCodeTimeEstimator::E, print.config.machine_max_feedrate_e.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::X, print.config.machine_max_jerk_x.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Y, print.config.machine_max_jerk_y.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::Z, print.config.machine_max_jerk_z.values[1]);
|
||||||
|
m_silent_time_estimator.set_axis_max_jerk(GCodeTimeEstimator::E, print.config.machine_max_jerk_e.values[1]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// resets analyzer
|
// resets analyzer
|
||||||
m_analyzer.reset();
|
m_analyzer.reset();
|
||||||
m_enable_analyzer = preview_data != nullptr;
|
m_enable_analyzer = preview_data != nullptr;
|
||||||
|
@ -613,6 +622,9 @@ void GCode::_do_export(Print &print, FILE *file, GCodePreviewData *preview_data)
|
||||||
|
|
||||||
m_cooling_buffer->set_current_extruder(initial_extruder_id);
|
m_cooling_buffer->set_current_extruder(initial_extruder_id);
|
||||||
|
|
||||||
|
// Emit machine envelope limits for the Marlin firmware.
|
||||||
|
this->print_machine_envelope(file, print);
|
||||||
|
|
||||||
// Disable fan.
|
// Disable fan.
|
||||||
if (! print.config.cooling.get_at(initial_extruder_id) || print.config.disable_fan_first_layers.get_at(initial_extruder_id))
|
if (! print.config.cooling.get_at(initial_extruder_id) || print.config.disable_fan_first_layers.get_at(initial_extruder_id))
|
||||||
_write(file, m_writer.set_fan(0, true));
|
_write(file, m_writer.set_fan(0, true));
|
||||||
|
@ -968,6 +980,35 @@ static bool custom_gcode_sets_temperature(const std::string &gcode, const int mc
|
||||||
return temp_set_by_gcode;
|
return temp_set_by_gcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Print the machine envelope G-code for the Marlin firmware based on the "machine_max_xxx" parameters.
|
||||||
|
// Do not process this piece of G-code by the time estimator, it already knows the values through another sources.
|
||||||
|
void GCode::print_machine_envelope(FILE *file, Print &print)
|
||||||
|
{
|
||||||
|
if (print.config.gcode_flavor.value == gcfMarlin) {
|
||||||
|
fprintf(file, "M201 X%d Y%d Z%d E%d ; sets maximum accelerations, mm/sec^2\n",
|
||||||
|
int(print.config.machine_max_acceleration_x.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_acceleration_y.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_acceleration_z.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_acceleration_e.values.front() + 0.5));
|
||||||
|
fprintf(file, "M203 X%d Y%d Z%d E%d ; sets maximum feedrates, mm/sec\n",
|
||||||
|
int(print.config.machine_max_feedrate_x.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_feedrate_y.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_feedrate_z.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_feedrate_e.values.front() + 0.5));
|
||||||
|
fprintf(file, "M204 S%d T%d ; sets acceleration (S) and retract acceleration (T), mm/sec^2\n",
|
||||||
|
int(print.config.machine_max_acceleration_extruding.values.front() + 0.5),
|
||||||
|
int(print.config.machine_max_acceleration_retracting.values.front() + 0.5));
|
||||||
|
fprintf(file, "M205 X%.2lf Y%.2lf Z%.2lf E%.2lf ; sets the jerk limits, mm/sec\n",
|
||||||
|
print.config.machine_max_jerk_x.values.front(),
|
||||||
|
print.config.machine_max_jerk_y.values.front(),
|
||||||
|
print.config.machine_max_jerk_z.values.front(),
|
||||||
|
print.config.machine_max_jerk_e.values.front());
|
||||||
|
fprintf(file, "M205 S%d T%d ; sets the minimum extruding and travel feed rate, mm/sec\n",
|
||||||
|
int(print.config.machine_min_extruding_rate.values.front() + 0.5),
|
||||||
|
int(print.config.machine_min_travel_rate.values.front() + 0.5));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Write 1st layer bed temperatures into the G-code.
|
// Write 1st layer bed temperatures into the G-code.
|
||||||
// Only do that if the start G-code does not already contain any M-code controlling an extruder temperature.
|
// Only do that if the start G-code does not already contain any M-code controlling an extruder temperature.
|
||||||
// M140 - Set Extruder Temperature
|
// M140 - Set Extruder Temperature
|
||||||
|
|
|
@ -327,6 +327,7 @@ protected:
|
||||||
void _write_format(FILE* file, const char* format, ...);
|
void _write_format(FILE* file, const char* format, ...);
|
||||||
|
|
||||||
std::string _extrude(const ExtrusionPath &path, std::string description = "", double speed = -1);
|
std::string _extrude(const ExtrusionPath &path, std::string description = "", double speed = -1);
|
||||||
|
void print_machine_envelope(FILE *file, Print &print);
|
||||||
void _print_first_layer_bed_temperature(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait);
|
void _print_first_layer_bed_temperature(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait);
|
||||||
void _print_first_layer_extruder_temperatures(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait);
|
void _print_first_layer_extruder_temperatures(FILE *file, Print &print, const std::string &gcode, unsigned int first_printing_extruder_id, bool wait);
|
||||||
// this flag triggers first layer speeds
|
// this flag triggers first layer speeds
|
||||||
|
|
|
@ -440,13 +440,13 @@ bool WipingExtrusions::is_overriddable(const ExtrusionEntityCollection& eec, con
|
||||||
|
|
||||||
// Following function iterates through all extrusions on the layer, remembers those that could be used for wiping after toolchange
|
// Following function iterates through all extrusions on the layer, remembers those that could be used for wiping after toolchange
|
||||||
// and returns volume that is left to be wiped on the wipe tower.
|
// and returns volume that is left to be wiped on the wipe tower.
|
||||||
float WipingExtrusions::mark_wiping_extrusions(const Print& print, unsigned int new_extruder, float volume_to_wipe)
|
float WipingExtrusions::mark_wiping_extrusions(const Print& print, unsigned int old_extruder, unsigned int new_extruder, float volume_to_wipe)
|
||||||
{
|
{
|
||||||
const LayerTools& lt = *m_layer_tools;
|
const LayerTools& lt = *m_layer_tools;
|
||||||
const float min_infill_volume = 0.f; // ignore infill with smaller volume than this
|
const float min_infill_volume = 0.f; // ignore infill with smaller volume than this
|
||||||
|
|
||||||
if (print.config.filament_soluble.get_at(new_extruder))
|
if (print.config.filament_soluble.get_at(old_extruder) || print.config.filament_soluble.get_at(new_extruder))
|
||||||
return volume_to_wipe; // Soluble filament cannot be wiped in a random infill
|
return volume_to_wipe; // Soluble filament cannot be wiped in a random infill, neither the filament after it
|
||||||
|
|
||||||
// we will sort objects so that dedicated for wiping are at the beginning:
|
// we will sort objects so that dedicated for wiping are at the beginning:
|
||||||
PrintObjectPtrs object_list = print.objects;
|
PrintObjectPtrs object_list = print.objects;
|
||||||
|
|
|
@ -28,7 +28,7 @@ public:
|
||||||
|
|
||||||
// This function goes through all infill entities, decides which ones will be used for wiping and
|
// This function goes through all infill entities, decides which ones will be used for wiping and
|
||||||
// marks them by the extruder id. Returns volume that remains to be wiped on the wipe tower:
|
// marks them by the extruder id. Returns volume that remains to be wiped on the wipe tower:
|
||||||
float mark_wiping_extrusions(const Print& print, unsigned int new_extruder, float volume_to_wipe);
|
float mark_wiping_extrusions(const Print& print, unsigned int old_extruder, unsigned int new_extruder, float volume_to_wipe);
|
||||||
|
|
||||||
void ensure_perimeters_infills_order(const Print& print);
|
void ensure_perimeters_infills_order(const Print& print);
|
||||||
|
|
||||||
|
|
|
@ -414,7 +414,10 @@ namespace Slic3r {
|
||||||
|
|
||||||
void GCodeTimeEstimator::set_acceleration(float acceleration_mm_sec2)
|
void GCodeTimeEstimator::set_acceleration(float acceleration_mm_sec2)
|
||||||
{
|
{
|
||||||
_state.acceleration = acceleration_mm_sec2;
|
_state.acceleration = (_state.max_acceleration == 0) ?
|
||||||
|
acceleration_mm_sec2 :
|
||||||
|
// Clamp the acceleration with the maximum.
|
||||||
|
std::min(_state.max_acceleration, acceleration_mm_sec2);
|
||||||
}
|
}
|
||||||
|
|
||||||
float GCodeTimeEstimator::get_acceleration() const
|
float GCodeTimeEstimator::get_acceleration() const
|
||||||
|
@ -422,6 +425,18 @@ namespace Slic3r {
|
||||||
return _state.acceleration;
|
return _state.acceleration;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GCodeTimeEstimator::set_max_acceleration(float acceleration_mm_sec2)
|
||||||
|
{
|
||||||
|
_state.max_acceleration = acceleration_mm_sec2;
|
||||||
|
if (acceleration_mm_sec2 > 0)
|
||||||
|
_state.acceleration = acceleration_mm_sec2;
|
||||||
|
}
|
||||||
|
|
||||||
|
float GCodeTimeEstimator::get_max_acceleration() const
|
||||||
|
{
|
||||||
|
return _state.max_acceleration;
|
||||||
|
}
|
||||||
|
|
||||||
void GCodeTimeEstimator::set_retract_acceleration(float acceleration_mm_sec2)
|
void GCodeTimeEstimator::set_retract_acceleration(float acceleration_mm_sec2)
|
||||||
{
|
{
|
||||||
_state.retract_acceleration = acceleration_mm_sec2;
|
_state.retract_acceleration = acceleration_mm_sec2;
|
||||||
|
@ -540,6 +555,9 @@ namespace Slic3r {
|
||||||
set_e_local_positioning_type(Absolute);
|
set_e_local_positioning_type(Absolute);
|
||||||
|
|
||||||
set_feedrate(DEFAULT_FEEDRATE);
|
set_feedrate(DEFAULT_FEEDRATE);
|
||||||
|
// Setting the maximum acceleration to zero means that the there is no limit and the G-code
|
||||||
|
// is allowed to set excessive values.
|
||||||
|
set_max_acceleration(0);
|
||||||
set_acceleration(DEFAULT_ACCELERATION);
|
set_acceleration(DEFAULT_ACCELERATION);
|
||||||
set_retract_acceleration(DEFAULT_RETRACT_ACCELERATION);
|
set_retract_acceleration(DEFAULT_RETRACT_ACCELERATION);
|
||||||
set_minimum_feedrate(DEFAULT_MINIMUM_FEEDRATE);
|
set_minimum_feedrate(DEFAULT_MINIMUM_FEEDRATE);
|
||||||
|
|
|
@ -72,6 +72,8 @@ namespace Slic3r {
|
||||||
Axis axis[Num_Axis];
|
Axis axis[Num_Axis];
|
||||||
float feedrate; // mm/s
|
float feedrate; // mm/s
|
||||||
float acceleration; // mm/s^2
|
float acceleration; // mm/s^2
|
||||||
|
// hard limit for the acceleration, to which the firmware will clamp.
|
||||||
|
float max_acceleration; // mm/s^2
|
||||||
float retract_acceleration; // mm/s^2
|
float retract_acceleration; // mm/s^2
|
||||||
float additional_time; // s
|
float additional_time; // s
|
||||||
float minimum_feedrate; // mm/s
|
float minimum_feedrate; // mm/s
|
||||||
|
@ -263,6 +265,10 @@ namespace Slic3r {
|
||||||
void set_acceleration(float acceleration_mm_sec2);
|
void set_acceleration(float acceleration_mm_sec2);
|
||||||
float get_acceleration() const;
|
float get_acceleration() const;
|
||||||
|
|
||||||
|
// Maximum acceleration for the machine. The firmware simulator will clamp the M204 Sxxx to this maximum.
|
||||||
|
void set_max_acceleration(float acceleration_mm_sec2);
|
||||||
|
float get_max_acceleration() const;
|
||||||
|
|
||||||
void set_retract_acceleration(float acceleration_mm_sec2);
|
void set_retract_acceleration(float acceleration_mm_sec2);
|
||||||
float get_retract_acceleration() const;
|
float get_retract_acceleration() const;
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,9 @@ void GCodeWriter::apply_print_config(const PrintConfig &print_config)
|
||||||
{
|
{
|
||||||
this->config.apply(print_config, true);
|
this->config.apply(print_config, true);
|
||||||
m_extrusion_axis = this->config.get_extrusion_axis();
|
m_extrusion_axis = this->config.get_extrusion_axis();
|
||||||
this->m_single_extruder_multi_material = print_config.single_extruder_multi_material.value;
|
m_single_extruder_multi_material = print_config.single_extruder_multi_material.value;
|
||||||
|
m_max_acceleration = (print_config.gcode_flavor.value == gcfMarlin) ?
|
||||||
|
print_config.machine_max_acceleration_extruding.values.front() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void GCodeWriter::set_extruders(const std::vector<unsigned int> &extruder_ids)
|
void GCodeWriter::set_extruders(const std::vector<unsigned int> &extruder_ids)
|
||||||
|
@ -85,7 +87,7 @@ std::string GCodeWriter::set_temperature(unsigned int temperature, bool wait, in
|
||||||
}
|
}
|
||||||
gcode << temperature;
|
gcode << temperature;
|
||||||
if (tool != -1 &&
|
if (tool != -1 &&
|
||||||
( (this->multiple_extruders && ! this->m_single_extruder_multi_material) ||
|
( (this->multiple_extruders && ! m_single_extruder_multi_material) ||
|
||||||
FLAVOR_IS(gcfMakerWare) || FLAVOR_IS(gcfSailfish)) ) {
|
FLAVOR_IS(gcfMakerWare) || FLAVOR_IS(gcfSailfish)) ) {
|
||||||
gcode << " T" << tool;
|
gcode << " T" << tool;
|
||||||
}
|
}
|
||||||
|
@ -170,6 +172,10 @@ std::string GCodeWriter::set_fan(unsigned int speed, bool dont_save)
|
||||||
|
|
||||||
std::string GCodeWriter::set_acceleration(unsigned int acceleration)
|
std::string GCodeWriter::set_acceleration(unsigned int acceleration)
|
||||||
{
|
{
|
||||||
|
// Clamp the acceleration to the allowed maximum.
|
||||||
|
if (m_max_acceleration > 0 && acceleration > m_max_acceleration)
|
||||||
|
acceleration = m_max_acceleration;
|
||||||
|
|
||||||
if (acceleration == 0 || acceleration == m_last_acceleration)
|
if (acceleration == 0 || acceleration == m_last_acceleration)
|
||||||
return std::string();
|
return std::string();
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ public:
|
||||||
GCodeWriter() :
|
GCodeWriter() :
|
||||||
multiple_extruders(false), m_extrusion_axis("E"), m_extruder(nullptr),
|
multiple_extruders(false), m_extrusion_axis("E"), m_extruder(nullptr),
|
||||||
m_single_extruder_multi_material(false),
|
m_single_extruder_multi_material(false),
|
||||||
m_last_acceleration(0), m_last_fan_speed(0),
|
m_last_acceleration(0), m_max_acceleration(0), m_last_fan_speed(0),
|
||||||
m_last_bed_temperature(0), m_last_bed_temperature_reached(true),
|
m_last_bed_temperature(0), m_last_bed_temperature_reached(true),
|
||||||
m_lifted(0)
|
m_lifted(0)
|
||||||
{}
|
{}
|
||||||
|
@ -74,6 +74,9 @@ private:
|
||||||
bool m_single_extruder_multi_material;
|
bool m_single_extruder_multi_material;
|
||||||
Extruder* m_extruder;
|
Extruder* m_extruder;
|
||||||
unsigned int m_last_acceleration;
|
unsigned int m_last_acceleration;
|
||||||
|
// Limit for setting the acceleration, to respect the machine limits set for the Marlin firmware.
|
||||||
|
// If set to zero, the limit is not in action.
|
||||||
|
unsigned int m_max_acceleration;
|
||||||
unsigned int m_last_fan_speed;
|
unsigned int m_last_fan_speed;
|
||||||
unsigned int m_last_bed_temperature;
|
unsigned int m_last_bed_temperature;
|
||||||
bool m_last_bed_temperature_reached;
|
bool m_last_bed_temperature_reached;
|
||||||
|
|
|
@ -1132,7 +1132,7 @@ void Print::_make_wipe_tower()
|
||||||
float volume_to_wipe = wipe_volumes[current_extruder_id][extruder_id]; // total volume to wipe after this toolchange
|
float volume_to_wipe = wipe_volumes[current_extruder_id][extruder_id]; // total volume to wipe after this toolchange
|
||||||
|
|
||||||
// try to assign some infills/objects for the wiping:
|
// try to assign some infills/objects for the wiping:
|
||||||
volume_to_wipe = layer_tools.wiping_extrusions().mark_wiping_extrusions(*this, extruder_id, wipe_volumes[current_extruder_id][extruder_id]);
|
volume_to_wipe = layer_tools.wiping_extrusions().mark_wiping_extrusions(*this, current_extruder_id, extruder_id, wipe_volumes[current_extruder_id][extruder_id]);
|
||||||
|
|
||||||
wipe_tower.plan_toolchange(layer_tools.print_z, layer_tools.wipe_tower_layer_height, current_extruder_id, extruder_id, first_layer && extruder_id == m_tool_ordering.all_extruders().back(), volume_to_wipe);
|
wipe_tower.plan_toolchange(layer_tools.print_z, layer_tools.wipe_tower_layer_height, current_extruder_id, extruder_id, first_layer && extruder_id == m_tool_ordering.all_extruders().back(), volume_to_wipe);
|
||||||
current_extruder_id = extruder_id;
|
current_extruder_id = extruder_id;
|
||||||
|
|
|
@ -772,7 +772,7 @@ PrintConfigDef::PrintConfigDef()
|
||||||
def->enum_labels.push_back("Machinekit");
|
def->enum_labels.push_back("Machinekit");
|
||||||
def->enum_labels.push_back("Smoothie");
|
def->enum_labels.push_back("Smoothie");
|
||||||
def->enum_labels.push_back(L("No extrusion"));
|
def->enum_labels.push_back(L("No extrusion"));
|
||||||
def->default_value = new ConfigOptionEnum<GCodeFlavor>(gcfMarlin);
|
def->default_value = new ConfigOptionEnum<GCodeFlavor>(gcfRepRap);
|
||||||
|
|
||||||
def = this->add("infill_acceleration", coFloat);
|
def = this->add("infill_acceleration", coFloat);
|
||||||
def->label = L("Infill");
|
def->label = L("Infill");
|
||||||
|
@ -907,10 +907,10 @@ PrintConfigDef::PrintConfigDef()
|
||||||
};
|
};
|
||||||
std::vector<AxisDefault> axes {
|
std::vector<AxisDefault> axes {
|
||||||
// name, max_feedrate, max_acceleration, max_jerk
|
// name, max_feedrate, max_acceleration, max_jerk
|
||||||
{ "x", { 500., 200. }, { 9000., 1000. }, { 10., 10. } },
|
{ "x", { 500., 200. }, { 9000., 1000. }, { 10. , 10. } },
|
||||||
{ "y", { 500., 200. }, { 9000., 1000. }, { 10., 10. } },
|
{ "y", { 500., 200. }, { 9000., 1000. }, { 10. , 10. } },
|
||||||
{ "z", { 12., 12. }, { 500., 200. }, { 0.2, 0.4 } },
|
{ "z", { 12., 12. }, { 500., 200. }, { 0.2, 0.4 } },
|
||||||
{ "e", { 120., 120. }, { 10000., 5000. }, { 2.5, 2.5 } }
|
{ "e", { 120., 120. }, { 10000., 5000. }, { 2.5, 2.5 } }
|
||||||
};
|
};
|
||||||
for (const AxisDefault &axis : axes) {
|
for (const AxisDefault &axis : axes) {
|
||||||
std::string axis_upper = boost::to_upper_copy<std::string>(axis.name);
|
std::string axis_upper = boost::to_upper_copy<std::string>(axis.name);
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
|
|
||||||
#define SLIC3R_FORK_NAME "Slic3r Prusa Edition"
|
#define SLIC3R_FORK_NAME "Slic3r Prusa Edition"
|
||||||
#define SLIC3R_VERSION "1.40.1"
|
#define SLIC3R_VERSION "1.41.0-alpha"
|
||||||
#define SLIC3R_BUILD "UNKNOWN"
|
#define SLIC3R_BUILD "UNKNOWN"
|
||||||
|
|
||||||
typedef int32_t coord_t;
|
typedef int32_t coord_t;
|
||||||
|
|
|
@ -1742,27 +1742,27 @@ PageShp TabPrinter::build_kinematics_page()
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> axes{ "x", "y", "z", "e" };
|
std::vector<std::string> axes{ "x", "y", "z", "e" };
|
||||||
auto optgroup = page->new_optgroup(_(L("Maximum accelerations")));
|
auto optgroup = page->new_optgroup(_(L("Maximum feedrates")));
|
||||||
for (const std::string &axis : axes) {
|
|
||||||
append_option_line(optgroup, "machine_max_acceleration_" + axis);
|
|
||||||
}
|
|
||||||
|
|
||||||
optgroup = page->new_optgroup(_(L("Maximum feedrates")));
|
|
||||||
for (const std::string &axis : axes) {
|
for (const std::string &axis : axes) {
|
||||||
append_option_line(optgroup, "machine_max_feedrate_" + axis);
|
append_option_line(optgroup, "machine_max_feedrate_" + axis);
|
||||||
}
|
}
|
||||||
|
|
||||||
optgroup = page->new_optgroup(_(L("Starting Acceleration")));
|
optgroup = page->new_optgroup(_(L("Maximum accelerations")));
|
||||||
|
for (const std::string &axis : axes) {
|
||||||
|
append_option_line(optgroup, "machine_max_acceleration_" + axis);
|
||||||
|
}
|
||||||
append_option_line(optgroup, "machine_max_acceleration_extruding");
|
append_option_line(optgroup, "machine_max_acceleration_extruding");
|
||||||
append_option_line(optgroup, "machine_max_acceleration_retracting");
|
append_option_line(optgroup, "machine_max_acceleration_retracting");
|
||||||
|
|
||||||
optgroup = page->new_optgroup(_(L("Advanced")));
|
optgroup = page->new_optgroup(_(L("Jerk limits")));
|
||||||
append_option_line(optgroup, "machine_min_extruding_rate");
|
|
||||||
append_option_line(optgroup, "machine_min_travel_rate");
|
|
||||||
for (const std::string &axis : axes) {
|
for (const std::string &axis : axes) {
|
||||||
append_option_line(optgroup, "machine_max_jerk_" + axis);
|
append_option_line(optgroup, "machine_max_jerk_" + axis);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
optgroup = page->new_optgroup(_(L("Minimum feedrates")));
|
||||||
|
append_option_line(optgroup, "machine_min_extruding_rate");
|
||||||
|
append_option_line(optgroup, "machine_min_travel_rate");
|
||||||
|
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1900,11 +1900,18 @@ void TabPrinter::update(){
|
||||||
|
|
||||||
bool is_marlin_flavor = m_config->option<ConfigOptionEnum<GCodeFlavor>>("gcode_flavor")->value == gcfMarlin;
|
bool is_marlin_flavor = m_config->option<ConfigOptionEnum<GCodeFlavor>>("gcode_flavor")->value == gcfMarlin;
|
||||||
|
|
||||||
const std::string &printer_model = m_config->opt_string("printer_model");
|
{
|
||||||
bool can_use_silent_mode = printer_model.empty() ? false : printer_model == "MK3"; // "true" only for MK3 printers
|
Field *sm = get_field("silent_mode");
|
||||||
|
if (! is_marlin_flavor)
|
||||||
|
// Disable silent mode for non-marlin firmwares.
|
||||||
|
get_field("silent_mode")->toggle(false);
|
||||||
|
if (is_marlin_flavor)
|
||||||
|
sm->enable();
|
||||||
|
else
|
||||||
|
sm->disable();
|
||||||
|
}
|
||||||
|
|
||||||
get_field("silent_mode")->toggle(can_use_silent_mode && is_marlin_flavor);
|
if (m_use_silent_mode != m_config->opt_bool("silent_mode")) {
|
||||||
if (can_use_silent_mode && m_use_silent_mode != m_config->opt_bool("silent_mode")) {
|
|
||||||
m_rebuild_kinematics_page = true;
|
m_rebuild_kinematics_page = true;
|
||||||
m_use_silent_mode = m_config->opt_bool("silent_mode");
|
m_use_silent_mode = m_config->opt_bool("silent_mode");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue