mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer
This commit is contained in:
		
						commit
						52538b93c2
					
				
					 10 changed files with 14 additions and 17 deletions
				
			
		|  | @ -88,7 +88,6 @@ void LayerRegion::make_perimeters(const SurfaceCollection &slices, SurfaceCollec | ||||||
| 
 | 
 | ||||||
| void LayerRegion::process_external_surfaces(const Layer *lower_layer, const Polygons *lower_layer_covered) | void LayerRegion::process_external_surfaces(const Layer *lower_layer, const Polygons *lower_layer_covered) | ||||||
| { | { | ||||||
|     const Surfaces &surfaces   = this->fill_surfaces.surfaces; |  | ||||||
|     const bool      has_infill = this->region()->config().fill_density.value > 0.; |     const bool      has_infill = this->region()->config().fill_density.value > 0.; | ||||||
|     const float		margin 	   = float(scale_(EXTERNAL_INFILL_MARGIN)); |     const float		margin 	   = float(scale_(EXTERNAL_INFILL_MARGIN)); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -12,7 +12,6 @@ TrimmedLoop trim_loop(const Polygon &loop, const EdgeGrid::Grid &grid) | ||||||
| 	TrimmedLoop out; | 	TrimmedLoop out; | ||||||
| 
 | 
 | ||||||
| 	if (loop.size() >= 2) { | 	if (loop.size() >= 2) { | ||||||
| 		size_t cnt = loop.points.size(); |  | ||||||
| 
 | 
 | ||||||
| 		struct Visitor { | 		struct Visitor { | ||||||
| 			Visitor(const EdgeGrid::Grid &grid, const Slic3r::Point *pt_prev, const Slic3r::Point *pt_this) : grid(grid), pt_prev(pt_prev), pt_this(pt_this) {} | 			Visitor(const EdgeGrid::Grid &grid, const Slic3r::Point *pt_prev, const Slic3r::Point *pt_this) : grid(grid), pt_prev(pt_prev), pt_this(pt_this) {} | ||||||
|  |  | ||||||
|  | @ -235,9 +235,9 @@ size_t Index::load(const boost::filesystem::path &path) | ||||||
| 			value = left_trim(value + 1); | 			value = left_trim(value + 1); | ||||||
| 		*key_end = 0; | 		*key_end = 0; | ||||||
|     	boost::optional<Semver> semver; |     	boost::optional<Semver> semver; | ||||||
|     	if (maybe_semver) |         if (maybe_semver) | ||||||
|     		semver = Semver::parse(key); |     		semver = Semver::parse(key); | ||||||
| 		if (key_value_pair) { |         if (key_value_pair) { | ||||||
|     		if (semver) |     		if (semver) | ||||||
|     			throw file_parser_error("Key cannot be a semantic version", path, idx_line);\ |     			throw file_parser_error("Key cannot be a semantic version", path, idx_line);\ | ||||||
|     		// Verify validity of the key / value pair.
 |     		// Verify validity of the key / value pair.
 | ||||||
|  | @ -288,7 +288,6 @@ Index::const_iterator Index::find(const Semver &ver) const | ||||||
| 
 | 
 | ||||||
| Index::const_iterator Index::recommended() const | Index::const_iterator Index::recommended() const | ||||||
| { | { | ||||||
| 	int idx = -1; |  | ||||||
| 	const_iterator highest = this->end(); | 	const_iterator highest = this->end(); | ||||||
| 	for (const_iterator it = this->begin(); it != this->end(); ++ it) | 	for (const_iterator it = this->begin(); it != this->end(); ++ it) | ||||||
| 		if (it->is_current_slic3r_supported() && | 		if (it->is_current_slic3r_supported() && | ||||||
|  |  | ||||||
|  | @ -55,6 +55,7 @@ bool BackgroundSlicingProcess::select_technology(PrinterTechnology tech) | ||||||
| 		switch (tech) { | 		switch (tech) { | ||||||
| 		case ptFFF: m_print = m_fff_print; break; | 		case ptFFF: m_print = m_fff_print; break; | ||||||
| 		case ptSLA: m_print = m_sla_print; break; | 		case ptSLA: m_print = m_sla_print; break; | ||||||
|  |         default: assert(false); break; | ||||||
| 		} | 		} | ||||||
| 		changed = true; | 		changed = true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -1926,7 +1926,7 @@ void GLCanvas3D::reload_scene(bool refresh_immediately, bool force_full_scene_re | ||||||
|                 if (it->new_geometry()) { |                 if (it->new_geometry()) { | ||||||
|                     // New volume.
 |                     // New volume.
 | ||||||
|                     unsigned int old_id = find_old_volume_id(it->composite_id); |                     unsigned int old_id = find_old_volume_id(it->composite_id); | ||||||
|                     if (old_id != -1) |                     if (old_id != (unsigned int)-1) | ||||||
|                         map_glvolume_old_to_new[old_id] = m_volumes.volumes.size(); |                         map_glvolume_old_to_new[old_id] = m_volumes.volumes.size(); | ||||||
|                     m_volumes.load_object_volume(&model_object, obj_idx, volume_idx, instance_idx, m_color_by, m_initialized); |                     m_volumes.load_object_volume(&model_object, obj_idx, volume_idx, instance_idx, m_color_by, m_initialized); | ||||||
|                     m_volumes.volumes.back()->geometry_id = key.geometry_id; |                     m_volumes.volumes.back()->geometry_id = key.geometry_id; | ||||||
|  |  | ||||||
|  | @ -87,7 +87,7 @@ class GUI_App : public wxApp | ||||||
|     wxFont		    m_bold_font; |     wxFont		    m_bold_font; | ||||||
| 	wxFont			m_normal_font; | 	wxFont			m_normal_font; | ||||||
| 
 | 
 | ||||||
|     size_t          m_em_unit; // width of a "m"-symbol in pixels for current system font 
 |     int          m_em_unit; // width of a "m"-symbol in pixels for current system font
 | ||||||
|                                // Note: for 100% Scale m_em_unit = 10 -> it's a good enough coefficient for a size setting of controls
 |                                // Note: for 100% Scale m_em_unit = 10 -> it's a good enough coefficient for a size setting of controls
 | ||||||
| 
 | 
 | ||||||
|     std::unique_ptr<wxLocale> 	  m_wxLocale; |     std::unique_ptr<wxLocale> 	  m_wxLocale; | ||||||
|  | @ -105,7 +105,7 @@ public: | ||||||
|     bool            initialized() const { return m_initialized; } |     bool            initialized() const { return m_initialized; } | ||||||
| 
 | 
 | ||||||
|     GUI_App(); |     GUI_App(); | ||||||
|     ~GUI_App(); |     ~GUI_App() override; | ||||||
| 
 | 
 | ||||||
|     static unsigned get_colour_approx_luma(const wxColour &colour); |     static unsigned get_colour_approx_luma(const wxColour &colour); | ||||||
|     static bool     dark_mode(); |     static bool     dark_mode(); | ||||||
|  | @ -124,8 +124,7 @@ public: | ||||||
|     const wxFont&   small_font()            { return m_small_font; } |     const wxFont&   small_font()            { return m_small_font; } | ||||||
|     const wxFont&   bold_font()             { return m_bold_font; } |     const wxFont&   bold_font()             { return m_bold_font; } | ||||||
|     const wxFont&   normal_font()           { return m_normal_font; } |     const wxFont&   normal_font()           { return m_normal_font; } | ||||||
|     size_t          em_unit() const         { return m_em_unit; } |     int             em_unit() const         { return m_em_unit; } | ||||||
|     void            set_em_unit(const size_t em_unit)    { m_em_unit = em_unit; } |  | ||||||
|     float           toolbar_icon_scale(const bool is_limited = false) const; |     float           toolbar_icon_scale(const bool is_limited = false) const; | ||||||
| 
 | 
 | ||||||
|     void            recreate_GUI(); |     void            recreate_GUI(); | ||||||
|  | @ -155,7 +154,7 @@ public: | ||||||
| 	// Translate the language code to a code, for which Prusa Research maintains translations. Defaults to "en_US".
 | 	// Translate the language code to a code, for which Prusa Research maintains translations. Defaults to "en_US".
 | ||||||
|     wxString 		current_language_code_safe() const; |     wxString 		current_language_code_safe() const; | ||||||
| 
 | 
 | ||||||
|     virtual bool OnExceptionInMainLoop(); |     virtual bool OnExceptionInMainLoop() override; | ||||||
| 
 | 
 | ||||||
| #ifdef __APPLE__ | #ifdef __APPLE__ | ||||||
|     // wxWidgets override to get an event on open files.
 |     // wxWidgets override to get an event on open files.
 | ||||||
|  |  | ||||||
|  | @ -445,7 +445,7 @@ void ObjectList::update_extruder_values_for_items(const size_t max_extruder) | ||||||
|         auto object = (*m_objects)[i]; |         auto object = (*m_objects)[i]; | ||||||
|         wxString extruder; |         wxString extruder; | ||||||
|         if (!object->config.has("extruder") || |         if (!object->config.has("extruder") || | ||||||
|             object->config.option<ConfigOptionInt>("extruder")->value > max_extruder) |             size_t(object->config.option<ConfigOptionInt>("extruder")->value) > max_extruder) | ||||||
|             extruder = _(L("default")); |             extruder = _(L("default")); | ||||||
|         else |         else | ||||||
|             extruder = wxString::Format("%d", object->config.option<ConfigOptionInt>("extruder")->value); |             extruder = wxString::Format("%d", object->config.option<ConfigOptionInt>("extruder")->value); | ||||||
|  | @ -457,7 +457,7 @@ void ObjectList::update_extruder_values_for_items(const size_t max_extruder) | ||||||
|                 item = m_objects_model->GetItemByVolumeId(i, id); |                 item = m_objects_model->GetItemByVolumeId(i, id); | ||||||
|                 if (!item) continue; |                 if (!item) continue; | ||||||
|                 if (!object->volumes[id]->config.has("extruder") || |                 if (!object->volumes[id]->config.has("extruder") || | ||||||
|                     object->volumes[id]->config.option<ConfigOptionInt>("extruder")->value > max_extruder) |                     size_t(object->volumes[id]->config.option<ConfigOptionInt>("extruder")->value) > max_extruder) | ||||||
|                     extruder = _(L("default")); |                     extruder = _(L("default")); | ||||||
|                 else |                 else | ||||||
|                     extruder = wxString::Format("%d", object->volumes[id]->config.option<ConfigOptionInt>("extruder")->value);  |                     extruder = wxString::Format("%d", object->volumes[id]->config.option<ConfigOptionInt>("extruder")->value);  | ||||||
|  |  | ||||||
|  | @ -233,7 +233,7 @@ void OptionsGroup::append_line(const Line& line, wxStaticText**	full_Label/* = n | ||||||
| 
 | 
 | ||||||
| 		add_undo_buttuns_to_sizer(sizer, field); | 		add_undo_buttuns_to_sizer(sizer, field); | ||||||
| 		if (is_window_field(field))  | 		if (is_window_field(field))  | ||||||
| 			sizer->Add(field->getWindow(), option.opt.full_width ? 1 : 0, //(option.opt.full_width ? wxEXPAND : 0) |
 |             sizer->Add(field->getWindow(), option.opt.full_width ? 1 : 0, //(option.opt.full_width ? wxEXPAND : 0) |
 | ||||||
|             wxBOTTOM | wxTOP | (option.opt.full_width ? wxEXPAND : wxALIGN_CENTER_VERTICAL), (wxOSX || !staticbox) ? 0 : 2); |             wxBOTTOM | wxTOP | (option.opt.full_width ? wxEXPAND : wxALIGN_CENTER_VERTICAL), (wxOSX || !staticbox) ? 0 : 2); | ||||||
| 		if (is_sizer_field(field))  | 		if (is_sizer_field(field))  | ||||||
| 			sizer->Add(field->getSizer(), 1, /*(*/option.opt.full_width ? wxEXPAND : /*0) |*/ wxALIGN_CENTER_VERTICAL, 0); | 			sizer->Add(field->getSizer(), 1, /*(*/option.opt.full_width ? wxEXPAND : /*0) |*/ wxALIGN_CENTER_VERTICAL, 0); | ||||||
|  |  | ||||||
|  | @ -4791,7 +4791,7 @@ bool Plater::undo_redo_string_getter(const bool is_undo, int idx, const char** o | ||||||
|     const std::vector<UndoRedo::Snapshot>& ss_stack = p->undo_redo_stack().snapshots(); |     const std::vector<UndoRedo::Snapshot>& ss_stack = p->undo_redo_stack().snapshots(); | ||||||
|     const int idx_in_ss_stack = p->get_active_snapshot_index() + (is_undo ? -(++idx) : idx); |     const int idx_in_ss_stack = p->get_active_snapshot_index() + (is_undo ? -(++idx) : idx); | ||||||
| 
 | 
 | ||||||
|     if (0 < idx_in_ss_stack && idx_in_ss_stack < ss_stack.size() - 1) { |     if (0 < idx_in_ss_stack && (size_t)idx_in_ss_stack < ss_stack.size() - 1) { | ||||||
|         *out_text = ss_stack[idx_in_ss_stack].name.c_str(); |         *out_text = ss_stack[idx_in_ss_stack].name.c_str(); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  | @ -4804,7 +4804,7 @@ void Plater::undo_redo_topmost_string_getter(const bool is_undo, std::string& ou | ||||||
|     const std::vector<UndoRedo::Snapshot>& ss_stack = p->undo_redo_stack().snapshots(); |     const std::vector<UndoRedo::Snapshot>& ss_stack = p->undo_redo_stack().snapshots(); | ||||||
|     const int idx_in_ss_stack = p->get_active_snapshot_index() + (is_undo ? -1 : 0); |     const int idx_in_ss_stack = p->get_active_snapshot_index() + (is_undo ? -1 : 0); | ||||||
| 
 | 
 | ||||||
|     if (0 < idx_in_ss_stack && idx_in_ss_stack < ss_stack.size() - 1) { |     if (0 < idx_in_ss_stack && (size_t)idx_in_ss_stack < ss_stack.size() - 1) { | ||||||
|         out_text = ss_stack[idx_in_ss_stack].name; |         out_text = ss_stack[idx_in_ss_stack].name; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -1020,7 +1020,7 @@ wxDataViewItem ObjectDataViewModel::Delete(const wxDataViewItem &item) | ||||||
| 		node_parent->GetChildren().Remove(node); | 		node_parent->GetChildren().Remove(node); | ||||||
| 
 | 
 | ||||||
| 		if (id > 0) {  | 		if (id > 0) {  | ||||||
| 			if(id == node_parent->GetChildCount()) id--; |             if (size_t(id) == node_parent->GetChildCount()) id--; | ||||||
| 			ret_item = wxDataViewItem(node_parent->GetChildren().Item(id)); | 			ret_item = wxDataViewItem(node_parent->GetChildren().Item(id)); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka