mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer
This commit is contained in:
		
						commit
						2f24971601
					
				
					 10 changed files with 100 additions and 30 deletions
				
			
		|  | @ -33,6 +33,8 @@ option(SLIC3R_MSVC_PDB          "Generate PDB files on MSVC in Release mode" 1) | ||||||
| option(SLIC3R_PERL_XS           "Compile XS Perl module and enable Perl unit and integration tests" 0) | option(SLIC3R_PERL_XS           "Compile XS Perl module and enable Perl unit and integration tests" 0) | ||||||
| option(SLIC3R_ASAN              "Enable ASan on Clang and GCC" 0) | option(SLIC3R_ASAN              "Enable ASan on Clang and GCC" 0) | ||||||
| 
 | 
 | ||||||
|  | set(OPENVDB_FIND_MODULE_PATH "" CACHE PATH "Path to OpenVDB installation's find modules.") | ||||||
|  | 
 | ||||||
| set(SLIC3R_GTK "2" CACHE STRING "GTK version to use with wxWidgets on Linux") | set(SLIC3R_GTK "2" CACHE STRING "GTK version to use with wxWidgets on Linux") | ||||||
| 
 | 
 | ||||||
| set(IS_CROSS_COMPILE FALSE) | set(IS_CROSS_COMPILE FALSE) | ||||||
|  | @ -494,10 +496,14 @@ if(SLIC3R_STATIC) | ||||||
|     set(USE_BLOSC TRUE) |     set(USE_BLOSC TRUE) | ||||||
| endif () | endif () | ||||||
| 
 | 
 | ||||||
| find_package(OpenVDB 5.0 REQUIRED COMPONENTS openvdb) | find_package(OpenVDB 5.0 COMPONENTS openvdb) | ||||||
| if(OpenVDB_FOUND) | if(OpenVDB_FOUND) | ||||||
|     slic3r_remap_configs(IlmBase::Half RelWithDebInfo Release) |     slic3r_remap_configs(IlmBase::Half RelWithDebInfo Release) | ||||||
|     slic3r_remap_configs(Blosc::blosc RelWithDebInfo Release) |     slic3r_remap_configs(Blosc::blosc RelWithDebInfo Release) | ||||||
|  | else () | ||||||
|  |     message(FATAL_ERROR "OpenVDB could not be found with the bundled find module. " | ||||||
|  |                    "You can try to specify the find module location of your " | ||||||
|  |                    "OpenVDB installation with the OPENVDB_FIND_MODULE_PATH cache variable.") | ||||||
| endif () | endif () | ||||||
| 
 | 
 | ||||||
| set(TOP_LEVEL_PROJECT_DIR ${PROJECT_SOURCE_DIR}) | set(TOP_LEVEL_PROJECT_DIR ${PROJECT_SOURCE_DIR}) | ||||||
|  |  | ||||||
|  | @ -102,6 +102,27 @@ may be provided to tell this module where to look. | ||||||
| 
 | 
 | ||||||
| #]=======================================================================] | #]=======================================================================] | ||||||
| 
 | 
 | ||||||
|  | # If an explicit openvdb module path was specified, that will be used | ||||||
|  | if (OPENVDB_FIND_MODULE_PATH) | ||||||
|  |   set(_module_path_bak ${CMAKE_MODULE_PATH}) | ||||||
|  |   set(CMAKE_MODULE_PATH ${OPENVDB_FIND_MODULE_PATH}) | ||||||
|  |   find_package( | ||||||
|  |     OpenVDB ${OpenVDB_FIND_VERSION} QUIET | ||||||
|  |     COMPONENTS | ||||||
|  |       ${OpenVDB_FIND_COMPONENTS} | ||||||
|  |   ) | ||||||
|  | 
 | ||||||
|  |   set(CMAKE_MODULE_PATH ${_module_path_bak}) | ||||||
|  |   if (OpenVDB_FOUND) | ||||||
|  |     return() | ||||||
|  |   endif () | ||||||
|  | 
 | ||||||
|  |   if (NOT OpenVDB_FIND_QUIETLY) | ||||||
|  |     message(STATUS "Using bundled find module for OpenVDB") | ||||||
|  |   endif () | ||||||
|  | endif () | ||||||
|  | # ########################################################################### | ||||||
|  | 
 | ||||||
| cmake_minimum_required(VERSION 3.3) | cmake_minimum_required(VERSION 3.3) | ||||||
| # Monitoring <PackageName>_ROOT variables | # Monitoring <PackageName>_ROOT variables | ||||||
| if(POLICY CMP0074) | if(POLICY CMP0074) | ||||||
|  |  | ||||||
|  | @ -207,32 +207,34 @@ void SeamPlacer::init(const Print& print) | ||||||
| 
 | 
 | ||||||
|         auto merge_and_offset = [po, &temp_polygons, max_nozzle_dmr](EnforcerBlockerType type, std::vector<ExPolygons>& out) { |         auto merge_and_offset = [po, &temp_polygons, max_nozzle_dmr](EnforcerBlockerType type, std::vector<ExPolygons>& out) { | ||||||
|             // Offset the triangles out slightly.
 |             // Offset the triangles out slightly.
 | ||||||
|  |             auto offset_out = [](Polygon& input, float offset) -> ExPolygons { | ||||||
|  |                 ClipperLib::Paths out(1); | ||||||
|  |                 std::vector<float>  deltas(input.points.size(), offset); | ||||||
|  |                 input.make_counter_clockwise(); | ||||||
|  |                 out.front() = mittered_offset_path_scaled(input.points, deltas, 3.); | ||||||
|  |                 return ClipperPaths_to_Slic3rExPolygons(out); | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|             temp_polygons.clear(); |             temp_polygons.clear(); | ||||||
|             po->project_and_append_custom_facets(true, type, temp_polygons); |             po->project_and_append_custom_facets(true, type, temp_polygons); | ||||||
|             out.clear(); |             out.clear(); | ||||||
|             out.reserve(temp_polygons.size()); |             out.reserve(temp_polygons.size()); | ||||||
|             float offset = max_nozzle_dmr + po->config().elefant_foot_compensation; |             float offset = scale_(max_nozzle_dmr + po->config().elefant_foot_compensation); | ||||||
|             for (const Polygons &src : temp_polygons) { |             for (Polygons &src : temp_polygons) { | ||||||
|                 out.emplace_back(Slic3r::offset_ex(src, scale_(offset))); |                 out.emplace_back(ExPolygons()); | ||||||
|                 offset = max_nozzle_dmr; |                 for (Polygon& plg : src) { | ||||||
|  |                     ExPolygons offset_explg = offset_out(plg, offset); | ||||||
|  |                     if (! offset_explg.empty()) | ||||||
|  |                         out.back().emplace_back(std::move(offset_explg.front())); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 offset = scale_(max_nozzle_dmr); | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
|         merge_and_offset(EnforcerBlockerType::BLOCKER, temp_blk); |         merge_and_offset(EnforcerBlockerType::BLOCKER, temp_blk); | ||||||
|         merge_and_offset(EnforcerBlockerType::ENFORCER, temp_enf); |         merge_and_offset(EnforcerBlockerType::ENFORCER, temp_enf); | ||||||
| 
 | 
 | ||||||
| //     FIXME: Offsetting should be done somehow cheaper, but following does not work
 |  | ||||||
| //        for (auto* custom_per_object : {&temp_enf, &temp_blk}) {
 |  | ||||||
| //            for (ExPolygons& plgs : *custom_per_object) {
 |  | ||||||
| //                for (ExPolygon& plg : plgs) {
 |  | ||||||
| //                    auto out = Slic3r::offset_ex(plg, scale_(max_nozzle_dmr));
 |  | ||||||
| //                    plg = out.empty() ? ExPolygon() : out.front();
 |  | ||||||
| //                    assert(out.empty() || out.size() == 1);
 |  | ||||||
| //                }
 |  | ||||||
| //            }
 |  | ||||||
| //        }
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         // Remember this PrintObject and initialize a store of enforcers and blockers for it.
 |         // Remember this PrintObject and initialize a store of enforcers and blockers for it.
 | ||||||
|         m_po_list.push_back(po); |         m_po_list.push_back(po); | ||||||
|         size_t po_idx = m_po_list.size() - 1; |         size_t po_idx = m_po_list.size() - 1; | ||||||
|  |  | ||||||
|  | @ -462,6 +462,7 @@ void PrintConfigDef::init_fff_params() | ||||||
|     def->tooltip = L("Horizontal width of the brim that will be printed around each object on the first layer."); |     def->tooltip = L("Horizontal width of the brim that will be printed around each object on the first layer."); | ||||||
|     def->sidetext = L("mm"); |     def->sidetext = L("mm"); | ||||||
|     def->min = 0; |     def->min = 0; | ||||||
|  |     def->max = 200; | ||||||
|     def->mode = comSimple; |     def->mode = comSimple; | ||||||
|     def->set_default_value(new ConfigOptionFloat(0)); |     def->set_default_value(new ConfigOptionFloat(0)); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -608,7 +608,7 @@ static void generic_exception_handle() | ||||||
|         std::terminate(); |         std::terminate(); | ||||||
|         throw; |         throw; | ||||||
|     } catch (const std::exception& ex) { |     } catch (const std::exception& ex) { | ||||||
|         wxLogError("Internal error: %s", ex.what()); |         wxLogError(format_wxstr(_L("Internal error: %1%"), ex.what())); | ||||||
|         BOOST_LOG_TRIVIAL(error) << boost::format("Uncaught exception: %1%") % ex.what(); |         BOOST_LOG_TRIVIAL(error) << boost::format("Uncaught exception: %1%") % ex.what(); | ||||||
|         throw; |         throw; | ||||||
|     } |     } | ||||||
|  | @ -1138,7 +1138,7 @@ void GUI_App::UpdateDlgDarkUI(wxDialog* dlg, bool just_buttons_update/* = false* | ||||||
| void GUI_App::UpdateDVCDarkUI(wxDataViewCtrl* dvc, bool highlited/* = false*/) | void GUI_App::UpdateDVCDarkUI(wxDataViewCtrl* dvc, bool highlited/* = false*/) | ||||||
| { | { | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
|     UpdateDarkUI(dvc, highlited); |     UpdateDarkUI(dvc, highlited ? dark_mode() : false); | ||||||
|     wxItemAttr attr(dark_mode() ? m_color_highlight_default : m_color_label_default, |     wxItemAttr attr(dark_mode() ? m_color_highlight_default : m_color_label_default, | ||||||
|         m_color_window_default, |         m_color_window_default, | ||||||
|         m_normal_font); |         m_normal_font); | ||||||
|  |  | ||||||
|  | @ -433,7 +433,7 @@ wxMenu* MenuFactory::append_submenu_add_generic(wxMenu* menu, ModelVolumeType ty | ||||||
|             [type, item](wxCommandEvent&) { obj_list()->load_generic_subobject(item, type); }, "", menu); |             [type, item](wxCommandEvent&) { obj_list()->load_generic_subobject(item, type); }, "", menu); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (wxGetApp().get_mode() == comExpert && type != ModelVolumeType::INVALID) { |     if (wxGetApp().get_mode() == comExpert) { | ||||||
|         sub_menu->AppendSeparator(); |         sub_menu->AppendSeparator(); | ||||||
|         append_menu_item(sub_menu, wxID_ANY, _L("Gallery"), "", |         append_menu_item(sub_menu, wxID_ANY, _L("Gallery"), "", | ||||||
|             [type](wxCommandEvent&) { obj_list()->load_subobject(type, true); }, "", menu); |             [type](wxCommandEvent&) { obj_list()->load_subobject(type, true); }, "", menu); | ||||||
|  |  | ||||||
|  | @ -1358,6 +1358,11 @@ bool ObjectList::is_instance_or_object_selected() | ||||||
| 
 | 
 | ||||||
| void ObjectList::load_subobject(ModelVolumeType type, bool from_galery/* = false*/) | void ObjectList::load_subobject(ModelVolumeType type, bool from_galery/* = false*/) | ||||||
| { | { | ||||||
|  |     if (type == ModelVolumeType::INVALID && from_galery) { | ||||||
|  |         load_shape_object_from_gallery(); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     wxDataViewItem item = GetSelection(); |     wxDataViewItem item = GetSelection(); | ||||||
|     // we can add volumes for Object or Instance
 |     // we can add volumes for Object or Instance
 | ||||||
|     if (!item || !(m_objects_model->GetItemType(item)&(itObject|itInstance))) |     if (!item || !(m_objects_model->GetItemType(item)&(itObject|itInstance))) | ||||||
|  | @ -1663,6 +1668,39 @@ void ObjectList::load_shape_object(const std::string& type_name) | ||||||
| #endif // ENABLE_PROJECT_DIRTY_STATE
 | #endif // ENABLE_PROJECT_DIRTY_STATE
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void ObjectList::load_shape_object_from_gallery() | ||||||
|  | { | ||||||
|  |     if (wxGetApp().plater()->canvas3D()->get_selection().get_object_idx() != -1) | ||||||
|  |         return;// Add nothing if something is selected on 3DScene
 | ||||||
|  | 
 | ||||||
|  |     wxArrayString input_files; | ||||||
|  |     GalleryDialog gallery_dlg(this); | ||||||
|  |     if (gallery_dlg.ShowModal() == wxID_CANCEL) | ||||||
|  |         return; | ||||||
|  |     gallery_dlg.get_input_files(input_files); | ||||||
|  |     if (input_files.IsEmpty()) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     std::vector<boost::filesystem::path> paths; | ||||||
|  |     for (const auto& file : input_files) | ||||||
|  |         paths.push_back(into_path(file)); | ||||||
|  | 
 | ||||||
|  |     assert(!paths.empty()); | ||||||
|  |     wxString snapshot_label = (paths.size() == 1 ? _L("Add Shape") : _L("Add Shapes")) + ": " + | ||||||
|  |         wxString::FromUTF8(paths.front().filename().string().c_str()); | ||||||
|  |     for (size_t i = 1; i < paths.size(); ++i) | ||||||
|  |         snapshot_label += ", " + wxString::FromUTF8(paths[i].filename().string().c_str()); | ||||||
|  | 
 | ||||||
|  |     take_snapshot(snapshot_label); | ||||||
|  | #if ENABLE_PROJECT_DIRTY_STATE | ||||||
|  |     std::vector<size_t> res = wxGetApp().plater()->load_files(paths, true, false); | ||||||
|  |     if (!res.empty()) | ||||||
|  |         wxGetApp().mainframe->update_title(); | ||||||
|  | #else | ||||||
|  |     load_files(paths, true, false); | ||||||
|  | #endif // ENABLE_PROJECT_DIRTY_STATE
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void ObjectList::load_mesh_object(const TriangleMesh &mesh, const wxString &name, bool center) | void ObjectList::load_mesh_object(const TriangleMesh &mesh, const wxString &name, bool center) | ||||||
| {    | {    | ||||||
|     // Add mesh to model as a new object
 |     // Add mesh to model as a new object
 | ||||||
|  |  | ||||||
|  | @ -244,6 +244,7 @@ public: | ||||||
|     void                load_modifier(ModelObject& model_object, std::vector<ModelVolume*>& added_volumes, ModelVolumeType type, bool from_galery = false); |     void                load_modifier(ModelObject& model_object, std::vector<ModelVolume*>& added_volumes, ModelVolumeType type, bool from_galery = false); | ||||||
|     void                load_generic_subobject(const std::string& type_name, const ModelVolumeType type); |     void                load_generic_subobject(const std::string& type_name, const ModelVolumeType type); | ||||||
|     void                load_shape_object(const std::string &type_name); |     void                load_shape_object(const std::string &type_name); | ||||||
|  |     void                load_shape_object_from_gallery(); | ||||||
|     void                load_mesh_object(const TriangleMesh &mesh, const wxString &name, bool center = true); |     void                load_mesh_object(const TriangleMesh &mesh, const wxString &name, bool center = true); | ||||||
|     void                del_object(const int obj_idx); |     void                del_object(const int obj_idx); | ||||||
|     void                del_subobject_item(wxDataViewItem& item); |     void                del_subobject_item(wxDataViewItem& item); | ||||||
|  |  | ||||||
|  | @ -219,11 +219,6 @@ static fs::path get_dir(bool sys_dir) | ||||||
|     return fs::absolute(fs::path(data_dir()) / "shapes").make_preferred(); |     return fs::absolute(fs::path(data_dir()) / "shapes").make_preferred(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static bool custom_exists()  |  | ||||||
| { |  | ||||||
|     return fs::exists(get_dir(false)); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static std::string get_dir_path(bool sys_dir)  | static std::string get_dir_path(bool sys_dir)  | ||||||
| { | { | ||||||
|     fs::path dir = get_dir(sys_dir); |     fs::path dir = get_dir(sys_dir); | ||||||
|  | @ -299,6 +294,9 @@ void GalleryDialog::load_label_icon_list() | ||||||
|     auto add_files_from_gallery = [](std::vector<Item>& items, bool sys_dir, std::string& dir_path) |     auto add_files_from_gallery = [](std::vector<Item>& items, bool sys_dir, std::string& dir_path) | ||||||
|     { |     { | ||||||
|         fs::path dir = get_dir(sys_dir); |         fs::path dir = get_dir(sys_dir); | ||||||
|  |         if (!fs::exists(dir)) | ||||||
|  |             return; | ||||||
|  | 
 | ||||||
|         dir_path = get_dir_path(sys_dir); |         dir_path = get_dir_path(sys_dir); | ||||||
| 
 | 
 | ||||||
|         std::vector<std::string> sorted_names; |         std::vector<std::string> sorted_names; | ||||||
|  | @ -319,7 +317,6 @@ void GalleryDialog::load_label_icon_list() | ||||||
|     std::string m_sys_dir_path, m_cust_dir_path; |     std::string m_sys_dir_path, m_cust_dir_path; | ||||||
|     std::vector<Item> list_items; |     std::vector<Item> list_items; | ||||||
|     add_files_from_gallery(list_items, true, m_sys_dir_path); |     add_files_from_gallery(list_items, true, m_sys_dir_path); | ||||||
|     if (custom_exists()) |  | ||||||
|     add_files_from_gallery(list_items, false, m_cust_dir_path); |     add_files_from_gallery(list_items, false, m_cust_dir_path); | ||||||
| 
 | 
 | ||||||
|     // Make an image list containing large icons
 |     // Make an image list containing large icons
 | ||||||
|  |  | ||||||
|  | @ -3005,6 +3005,7 @@ void TabPrinter::update() | ||||||
|     m_presets->get_edited_preset().printer_technology() == ptFFF ? update_fff() : update_sla(); |     m_presets->get_edited_preset().printer_technology() == ptFFF ? update_fff() : update_sla(); | ||||||
|     m_update_cnt--; |     m_update_cnt--; | ||||||
| 
 | 
 | ||||||
|  |     update_description_lines(); | ||||||
|     Layout(); |     Layout(); | ||||||
| 
 | 
 | ||||||
|     if (m_update_cnt == 0) |     if (m_update_cnt == 0) | ||||||
|  | @ -4290,6 +4291,9 @@ void TabSLAMaterial::update() | ||||||
|     if (m_preset_bundle->printers.get_selected_preset().printer_technology() == ptFFF) |     if (m_preset_bundle->printers.get_selected_preset().printer_technology() == ptFFF) | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|  |     update_description_lines(); | ||||||
|  |     Layout(); | ||||||
|  | 
 | ||||||
| // #ys_FIXME. Just a template for this function
 | // #ys_FIXME. Just a template for this function
 | ||||||
| //     m_update_cnt++;
 | //     m_update_cnt++;
 | ||||||
| //     ! something to update
 | //     ! something to update
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966