mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 16:21:24 -06:00 
			
		
		
		
	Load presets into the new C++ class.
This commit is contained in:
		
							parent
							
								
									b1e3b0cdf9
								
							
						
					
					
						commit
						84d4bf8fdb
					
				
					 6 changed files with 57 additions and 3 deletions
				
			
		|  | @ -1,11 +1,20 @@ | |||
| #include "Preset.hpp" | ||||
| 
 | ||||
| #include <fstream> | ||||
| #include <boost/filesystem.hpp> | ||||
| #include <boost/algorithm/string/predicate.hpp> | ||||
| 
 | ||||
| #include <wx/image.h> | ||||
| #include <wx/bmpcbox.h> | ||||
| 
 | ||||
| #if 0 | ||||
| #define DEBUG | ||||
| #define _DEBUG | ||||
| #undef NDEBUG | ||||
| #endif | ||||
| 
 | ||||
| #include <assert.h> | ||||
| 
 | ||||
| namespace Slic3r { | ||||
| 
 | ||||
| // Load a config file, return a C++ class Slic3r::DynamicPrintConfig with $keys initialized from the config file.
 | ||||
|  | @ -67,6 +76,28 @@ PresetCollection::PresetCollection(Preset::Type type, const std::vector<std::str | |||
|     m_presets.front().load(keys); | ||||
| } | ||||
| 
 | ||||
| // Load all presets found in dir_path.
 | ||||
| // Throws an exception on error.
 | ||||
| void PresetCollection::load_presets(const std::string &dir_path, const std::string &subdir) | ||||
| { | ||||
|     m_presets.erase(m_presets.begin()+1, m_presets.end()); | ||||
|     t_config_option_keys keys = this->default_preset().config.keys(); | ||||
| 	for (auto &file : boost::filesystem::directory_iterator(boost::filesystem::canonical(boost::filesystem::path(dir_path) / subdir).make_preferred())) | ||||
|         if (boost::filesystem::is_regular_file(file.status()) && boost::algorithm::iends_with(file.path().filename().string(), ".ini")) { | ||||
|             std::string name = file.path().filename().string(); | ||||
|             // Remove the .ini suffix.
 | ||||
|             name.erase(name.size() - 4); | ||||
|             try { | ||||
|                 Preset preset(m_type, name, false); | ||||
|                 preset.file = file.path().string(); | ||||
|                 preset.load(keys); | ||||
|                 m_presets.emplace_back(preset); | ||||
|             } catch (const boost::filesystem::filesystem_error &err) { | ||||
| 
 | ||||
|             } | ||||
|         } | ||||
| } | ||||
| 
 | ||||
| void PresetCollection::set_default_suppressed(bool default_suppressed) | ||||
| { | ||||
|     if (m_default_suppressed != default_suppressed) { | ||||
|  | @ -162,12 +193,23 @@ PresetBundle::PresetBundle() : | |||
| 
 | ||||
| PresetBundle::~PresetBundle() | ||||
| { | ||||
|     delete m_bitmapCompatible; | ||||
| 	assert(m_bitmapCompatible != nullptr); | ||||
| 	assert(m_bitmapIncompatible != nullptr); | ||||
| 	delete m_bitmapCompatible; | ||||
| 	m_bitmapCompatible = nullptr; | ||||
|     delete m_bitmapIncompatible; | ||||
| 	m_bitmapIncompatible = nullptr; | ||||
|     for (std::pair<const std::string, wxBitmap*> &bitmap : m_mapColorToBitmap) | ||||
|         delete bitmap.second; | ||||
| } | ||||
| 
 | ||||
| void PresetBundle::load_presets(const std::string &dir_path) | ||||
| { | ||||
|     this->prints.load_presets(dir_path, "print"); | ||||
|     this->prints.load_presets(dir_path, "filament"); | ||||
|     this->prints.load_presets(dir_path, "printer"); | ||||
| } | ||||
| 
 | ||||
| bool PresetBundle::load_bitmaps(const std::string &path_bitmap_compatible, const std::string &path_bitmap_incompatible) | ||||
| { | ||||
|     bool loaded_compatible   = m_bitmapCompatible  ->LoadFile(wxString::FromUTF8(path_bitmap_compatible.c_str())); | ||||
|  |  | |||
|  | @ -66,6 +66,9 @@ public: | |||
|     // Initialize the PresetCollection with the "- default -" preset.
 | ||||
|     PresetCollection(Preset::Type type, const std::vector<std::string> &keys); | ||||
| 
 | ||||
|     // Load ini files of the particular type from the provided directory path.
 | ||||
|     void            load_presets(const std::string &dir_path, const std::string &subdir); | ||||
| 
 | ||||
|     // Compatible & incompatible marks, to be placed at the wxBitmapComboBox items.
 | ||||
|     void            set_bitmap_compatible  (const wxBitmap *bmp) { m_bitmap_compatible   = bmp; } | ||||
|     void            set_bitmap_incompatible(const wxBitmap *bmp) { m_bitmap_incompatible = bmp; } | ||||
|  | @ -120,7 +123,10 @@ public: | |||
|     PresetBundle(); | ||||
|     ~PresetBundle(); | ||||
| 
 | ||||
|     bool load_bitmaps(const std::string &path_bitmap_compatible, const std::string &path_bitmap_incompatible); | ||||
|     bool            load_bitmaps(const std::string &path_bitmap_compatible, const std::string &path_bitmap_incompatible); | ||||
| 
 | ||||
|     // Load ini files of all types (print, filament, printer) from the provided directory path.
 | ||||
|     void            load_presets(const std::string &dir_path); | ||||
| 
 | ||||
|     PresetCollection        prints; | ||||
|     PresetCollection        filaments; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv