mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge branch 'master' into ys_menuicons
This commit is contained in:
		
						commit
						347a65bc4a
					
				
					 41 changed files with 2572 additions and 1562 deletions
				
			
		|  | @ -370,9 +370,13 @@ int em_unit(wxWindow* win) | |||
| { | ||||
|     if (win) | ||||
|     { | ||||
|         Slic3r::GUI::DPIDialog* dlg = dynamic_cast<Slic3r::GUI::DPIDialog*>(Slic3r::GUI::find_toplevel_parent(win)); | ||||
|         wxTopLevelWindow *toplevel = Slic3r::GUI::find_toplevel_parent(win); | ||||
|         Slic3r::GUI::DPIDialog* dlg = dynamic_cast<Slic3r::GUI::DPIDialog*>(toplevel); | ||||
|         if (dlg) | ||||
|             return dlg->em_unit(); | ||||
|         Slic3r::GUI::DPIFrame* frame = dynamic_cast<Slic3r::GUI::DPIFrame*>(toplevel); | ||||
|         if (frame) | ||||
|             return frame->em_unit(); | ||||
|     } | ||||
|      | ||||
|     return Slic3r::GUI::wxGetApp().em_unit(); | ||||
|  | @ -417,6 +421,28 @@ wxBitmap create_scaled_bitmap(wxWindow *win, const std::string& bmp_name_in, con | |||
| // ObjectDataViewModelNode
 | ||||
| // ----------------------------------------------------------------------------
 | ||||
| 
 | ||||
| ObjectDataViewModelNode::ObjectDataViewModelNode(ObjectDataViewModelNode* parent, const ItemType type) : | ||||
|     m_parent(parent), | ||||
|     m_type(type), | ||||
|     m_extruder(wxEmptyString) | ||||
| { | ||||
|     if (type == itSettings) { | ||||
|         m_name = "Settings to modified"; | ||||
|     } | ||||
|     else if (type == itInstanceRoot) { | ||||
|         m_name = _(L("Instances")); | ||||
| #ifdef __WXGTK__ | ||||
|         m_container = true; | ||||
| #endif  //__WXGTK__
 | ||||
|     } | ||||
|     else if (type == itInstance) { | ||||
|         m_idx = parent->GetChildCount(); | ||||
|         m_name = wxString::Format(_(L("Instance_%d")), m_idx + 1); | ||||
| 
 | ||||
|         set_action_icon(); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void ObjectDataViewModelNode::set_action_icon() | ||||
| { | ||||
|     m_action_icon_name = m_type == itObject ? "advanced_plus" :  | ||||
|  | @ -455,7 +481,7 @@ bool ObjectDataViewModelNode::update_settings_digest(const std::vector<std::stri | |||
|     m_name = wxEmptyString; | ||||
| 
 | ||||
|     for (auto& cat : m_opt_categories) | ||||
|         m_name += cat + "; "; | ||||
|         m_name += _(cat) + "; "; | ||||
|     if (!m_name.IsEmpty()) | ||||
|         m_name.erase(m_name.Length()-2, 2); // Delete last "; "
 | ||||
| 
 | ||||
|  | @ -491,14 +517,21 @@ ObjectDataViewModel::~ObjectDataViewModel() | |||
|     m_bitmap_cache = nullptr; | ||||
| } | ||||
| 
 | ||||
| wxDataViewItem ObjectDataViewModel::Add(const wxString &name, const int extruder) | ||||
| wxDataViewItem ObjectDataViewModel::Add(const wxString &name,  | ||||
|                                         const int extruder, | ||||
|                                         const bool has_errors/* = false*/) | ||||
| { | ||||
|     const wxString extruder_str = extruder == 0 ? "default" : wxString::Format("%d", extruder); | ||||
| 	auto root = new ObjectDataViewModelNode(name, extruder_str); | ||||
|     // Add error icon if detected auto-repaire
 | ||||
|     if (has_errors) | ||||
|         root->m_bmp = *m_warning_bmp; | ||||
| 
 | ||||
| 	m_objects.push_back(root); | ||||
| 	// notify control
 | ||||
| 	wxDataViewItem child((void*)root); | ||||
| 	wxDataViewItem parent((void*)NULL); | ||||
| 
 | ||||
| 	ItemAdded(parent, child); | ||||
| 	return child; | ||||
| } | ||||
|  | @ -506,6 +539,7 @@ wxDataViewItem ObjectDataViewModel::Add(const wxString &name, const int extruder | |||
| wxDataViewItem ObjectDataViewModel::AddVolumeChild( const wxDataViewItem &parent_item, | ||||
|                                                     const wxString &name, | ||||
|                                                     const Slic3r::ModelVolumeType volume_type, | ||||
|                                                     const bool has_errors/* = false*/, | ||||
|                                                     const int extruder/* = 0*/, | ||||
|                                                     const bool create_frst_child/* = true*/) | ||||
| { | ||||
|  | @ -519,9 +553,14 @@ wxDataViewItem ObjectDataViewModel::AddVolumeChild( const wxDataViewItem &parent | |||
|     if (insert_position < 0 || root->GetNthChild(insert_position)->m_type != itInstanceRoot) | ||||
|         insert_position = -1; | ||||
| 
 | ||||
|     const bool obj_errors = root->m_bmp.IsOk(); | ||||
| 
 | ||||
|     if (create_frst_child && root->m_volumes_cnt == 0) | ||||
|     { | ||||
| 		const auto node = new ObjectDataViewModelNode(root, root->m_name, *m_volume_bmps[0], extruder_str, 0); | ||||
|         const Slic3r::ModelVolumeType type = Slic3r::ModelVolumeType::MODEL_PART; | ||||
|         const auto node = new ObjectDataViewModelNode(root, root->m_name, GetVolumeIcon(type, obj_errors), extruder_str, 0); | ||||
|         node->m_volume_type = type; | ||||
| 
 | ||||
|         insert_position < 0 ? root->Append(node) : root->Insert(node, insert_position); | ||||
| 		// notify control
 | ||||
| 		const wxDataViewItem child((void*)node); | ||||
|  | @ -529,12 +568,15 @@ wxDataViewItem ObjectDataViewModel::AddVolumeChild( const wxDataViewItem &parent | |||
| 
 | ||||
|         root->m_volumes_cnt++; | ||||
|         if (insert_position > 0) insert_position++; | ||||
| 
 | ||||
|         node->m_volume_type = volume_type; | ||||
| 	} | ||||
| 
 | ||||
|     const auto node = new ObjectDataViewModelNode(root, name, *m_volume_bmps[int(volume_type)], extruder_str, root->m_volumes_cnt); | ||||
|     const auto node = new ObjectDataViewModelNode(root, name, GetVolumeIcon(volume_type, has_errors), extruder_str, root->m_volumes_cnt); | ||||
|     insert_position < 0 ? root->Append(node) : root->Insert(node, insert_position); | ||||
| 
 | ||||
|     // if part with errors is added, but object wasn't marked, then mark it
 | ||||
|     if (!obj_errors && has_errors) | ||||
|         root->SetBitmap(*m_warning_bmp); | ||||
| 
 | ||||
| 	// notify control
 | ||||
| 	const wxDataViewItem child((void*)node); | ||||
|     ItemAdded(parent_item, child); | ||||
|  | @ -1299,15 +1341,61 @@ void ObjectDataViewModel::Rescale() | |||
|         node->msw_rescale(); | ||||
| 
 | ||||
|         if (node->m_type & itVolume) | ||||
|             node->m_bmp = *m_volume_bmps[node->volume_type()]; | ||||
|             node->m_bmp = GetVolumeIcon(node->m_volume_type, node->m_bmp.GetWidth() != node->m_bmp.GetHeight()); | ||||
| 
 | ||||
|         if (node->m_type & itObject && node->m_bmp.IsOk()) | ||||
|             node->m_bmp = create_scaled_bitmap(nullptr, "exclamation"); | ||||
|             node->m_bmp = *m_warning_bmp; | ||||
| 
 | ||||
|         ItemChanged(item); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| wxBitmap ObjectDataViewModel::GetVolumeIcon(const Slic3r::ModelVolumeType vol_type, const bool is_marked/* = false*/) | ||||
| { | ||||
|     if (!is_marked) | ||||
|         return *m_volume_bmps[static_cast<int>(vol_type)]; | ||||
| 
 | ||||
|     std::string scaled_bitmap_name = "warning" + std::to_string(static_cast<int>(vol_type)); | ||||
|     scaled_bitmap_name += "-em" + std::to_string(Slic3r::GUI::wxGetApp().em_unit()); | ||||
| 
 | ||||
|     wxBitmap *bmp = m_bitmap_cache->find(scaled_bitmap_name); | ||||
|     if (bmp == nullptr) { | ||||
|         std::vector<wxBitmap> bmps; | ||||
| 
 | ||||
|         bmps.emplace_back(*m_warning_bmp); | ||||
|         bmps.emplace_back(*m_volume_bmps[static_cast<int>(vol_type)]); | ||||
| 
 | ||||
|         bmp = m_bitmap_cache->insert(scaled_bitmap_name, bmps); | ||||
|     } | ||||
| 
 | ||||
|     return *bmp; | ||||
| } | ||||
| 
 | ||||
| void ObjectDataViewModel::DeleteWarningIcon(const wxDataViewItem& item, const bool unmark_object/* = false*/) | ||||
| { | ||||
|     if (!item.IsOk()) | ||||
|         return; | ||||
| 
 | ||||
|     ObjectDataViewModelNode *node = (ObjectDataViewModelNode*)item.GetID(); | ||||
| 
 | ||||
|     if (!node->GetBitmap().IsOk() || !(node->GetType() & (itVolume | itObject))) | ||||
|         return; | ||||
| 
 | ||||
|     if (node->GetType() & itVolume) { | ||||
|         node->SetBitmap(*m_volume_bmps[static_cast<int>(node->volume_type())]); | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     node->SetBitmap(wxNullBitmap); | ||||
|     if (unmark_object) | ||||
|     { | ||||
|         wxDataViewItemArray children; | ||||
|         GetChildren(item, children); | ||||
|         for (const wxDataViewItem& child : children) | ||||
|             DeleteWarningIcon(child); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| //-----------------------------------------------------------------------------
 | ||||
| // PrusaDataViewBitmapText
 | ||||
| //-----------------------------------------------------------------------------
 | ||||
|  | @ -2450,11 +2538,7 @@ ModeSizer::ModeSizer(wxWindow *parent, int hgap/* = 10*/) : | |||
| 
 | ||||
|     m_mode_btns.reserve(3); | ||||
|     for (const auto& button : buttons) { | ||||
| //         int x, y;
 | ||||
| //         parent->GetTextExtent(button.first, &x, &y, nullptr, nullptr, &Slic3r::GUI::wxGetApp().bold_font());
 | ||||
| //         const wxSize size = wxSize(x + button.second.GetWidth() + Slic3r::GUI::wxGetApp().em_unit(), 
 | ||||
| //                                    y + Slic3r::GUI::wxGetApp().em_unit());
 | ||||
|         m_mode_btns.push_back(new ModeButton(parent, wxID_ANY, button.second, button.first/*, size*/)); | ||||
|         m_mode_btns.push_back(new ModeButton(parent, wxID_ANY, button.second, button.first)); | ||||
|     } | ||||
| 
 | ||||
|     for (auto btn : m_mode_btns) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv