mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 04:21:09 +08:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/Slic3r
This commit is contained in:
		
						commit
						b00178013f
					
				| @ -2501,9 +2501,9 @@ void GLCanvas3D::Selection::_ensure_on_bed() | |||||||
| } | } | ||||||
| #endif // ENABLE_ENSURE_ON_BED_WHILE_SCALING
 | #endif // ENABLE_ENSURE_ON_BED_WHILE_SCALING
 | ||||||
| 
 | 
 | ||||||
| const float GLCanvas3D::Gizmos::OverlayTexturesScale = 1.0f; | const float GLCanvas3D::Gizmos::OverlayIconsScale = 1.0f; | ||||||
| const float GLCanvas3D::Gizmos::OverlayOffsetX = 10.0f * OverlayTexturesScale; | const float GLCanvas3D::Gizmos::OverlayBorder = 5.0f; | ||||||
| const float GLCanvas3D::Gizmos::OverlayGapY = 5.0f * OverlayTexturesScale; | const float GLCanvas3D::Gizmos::OverlayGapY = 5.0f * OverlayIconsScale; | ||||||
| 
 | 
 | ||||||
| GLCanvas3D::Gizmos::Gizmos() | GLCanvas3D::Gizmos::Gizmos() | ||||||
|     : m_enabled(false) |     : m_enabled(false) | ||||||
| @ -2606,19 +2606,18 @@ std::string GLCanvas3D::Gizmos::update_hover_state(const GLCanvas3D& canvas, con | |||||||
| 
 | 
 | ||||||
|     float cnv_h = (float)canvas.get_canvas_size().get_height(); |     float cnv_h = (float)canvas.get_canvas_size().get_height(); | ||||||
|     float height = _get_total_overlay_height(); |     float height = _get_total_overlay_height(); | ||||||
|     float top_y = 0.5f * (cnv_h - height); |     float top_y = 0.5f * (cnv_h - height) + OverlayBorder; | ||||||
|     for (GizmosMap::iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) |     for (GizmosMap::iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) | ||||||
|     { |     { | ||||||
|         if ((it->second == nullptr) || !it->second->is_selectable()) |         if ((it->second == nullptr) || !it->second->is_selectable()) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         float tex_size = (float)it->second->get_textures_size() * OverlayTexturesScale; |         float tex_size = (float)it->second->get_textures_size() * OverlayIconsScale; | ||||||
|         float half_tex_size = 0.5f * tex_size; |  | ||||||
| 
 | 
 | ||||||
|         // we currently use circular icons for gizmo, so we check the radius
 |         // we currently use circular icons for gizmo, so we check the radius
 | ||||||
|         if (it->second->is_activable(selection) && (it->second->get_state() != GLGizmoBase::On)) |         if (it->second->is_activable(selection) && (it->second->get_state() != GLGizmoBase::On)) | ||||||
|         { |         { | ||||||
|             bool inside = (mouse_pos - Vec2d(OverlayOffsetX + half_tex_size, top_y + half_tex_size)).norm() < half_tex_size; |             bool inside = (OverlayBorder <= (float)mouse_pos(0)) && ((float)mouse_pos(0) <= OverlayBorder + tex_size) && (top_y <= (float)mouse_pos(1)) && ((float)mouse_pos(1) <= top_y + tex_size); | ||||||
|             it->second->set_state(inside ? GLGizmoBase::Hover : GLGizmoBase::Off); |             it->second->set_state(inside ? GLGizmoBase::Hover : GLGizmoBase::Off); | ||||||
|             if (inside) |             if (inside) | ||||||
|                 name = it->second->get_name(); |                 name = it->second->get_name(); | ||||||
| @ -2636,17 +2635,17 @@ void GLCanvas3D::Gizmos::update_on_off_state(const GLCanvas3D& canvas, const Vec | |||||||
| 
 | 
 | ||||||
|     float cnv_h = (float)canvas.get_canvas_size().get_height(); |     float cnv_h = (float)canvas.get_canvas_size().get_height(); | ||||||
|     float height = _get_total_overlay_height(); |     float height = _get_total_overlay_height(); | ||||||
|     float top_y = 0.5f * (cnv_h - height); |     float top_y = 0.5f * (cnv_h - height) + OverlayBorder; | ||||||
|     for (GizmosMap::iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) |     for (GizmosMap::iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) | ||||||
|     { |     { | ||||||
|         if ((it->second == nullptr) || !it->second->is_selectable()) |         if ((it->second == nullptr) || !it->second->is_selectable()) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         float tex_size = (float)it->second->get_textures_size() * OverlayTexturesScale; |         float tex_size = (float)it->second->get_textures_size() * OverlayIconsScale; | ||||||
|         float half_tex_size = 0.5f * tex_size; |  | ||||||
| 
 | 
 | ||||||
|         // we currently use circular icons for gizmo, so we check the radius
 |         // we currently use circular icons for gizmo, so we check the radius
 | ||||||
|         if (it->second->is_activable(selection) && ((mouse_pos - Vec2d(OverlayOffsetX + half_tex_size, top_y + half_tex_size)).norm() < half_tex_size)) |         bool inside = (OverlayBorder <= (float)mouse_pos(0)) && ((float)mouse_pos(0) <= OverlayBorder + tex_size) && (top_y <= (float)mouse_pos(1)) && ((float)mouse_pos(1) <= top_y + tex_size); | ||||||
|  |         if (it->second->is_activable(selection) && inside) | ||||||
|         { |         { | ||||||
|             if ((it->second->get_state() == GLGizmoBase::On)) |             if ((it->second->get_state() == GLGizmoBase::On)) | ||||||
|             { |             { | ||||||
| @ -2734,17 +2733,17 @@ bool GLCanvas3D::Gizmos::overlay_contains_mouse(const GLCanvas3D& canvas, const | |||||||
| 
 | 
 | ||||||
|     float cnv_h = (float)canvas.get_canvas_size().get_height(); |     float cnv_h = (float)canvas.get_canvas_size().get_height(); | ||||||
|     float height = _get_total_overlay_height(); |     float height = _get_total_overlay_height(); | ||||||
|     float top_y = 0.5f * (cnv_h - height); |     float top_y = 0.5f * (cnv_h - height) + OverlayBorder; | ||||||
|     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) |     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) | ||||||
|     { |     { | ||||||
|         if ((it->second == nullptr) || !it->second->is_selectable()) |         if ((it->second == nullptr) || !it->second->is_selectable()) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         float tex_size = (float)it->second->get_textures_size() * OverlayTexturesScale; |         float tex_size = (float)it->second->get_textures_size() * OverlayIconsScale; | ||||||
|         float half_tex_size = 0.5f * tex_size; |         float half_tex_size = 0.5f * tex_size; | ||||||
| 
 | 
 | ||||||
|         // we currently use circular icons for gizmo, so we check the radius
 |         // we currently use circular icons for gizmo, so we check the radius
 | ||||||
|         if ((mouse_pos - Vec2d(OverlayOffsetX + half_tex_size, top_y + half_tex_size)).norm() < half_tex_size) |         if ((OverlayBorder <= (float)mouse_pos(0)) && ((float)mouse_pos(0) <= OverlayBorder + tex_size) && (top_y <= (float)mouse_pos(1)) && ((float)mouse_pos(1) <= top_y + tex_size)) | ||||||
|             return true; |             return true; | ||||||
| 
 | 
 | ||||||
|         top_y += (tex_size + OverlayGapY); |         top_y += (tex_size + OverlayGapY); | ||||||
| @ -3020,19 +3019,19 @@ void GLCanvas3D::Gizmos::_render_overlay(const GLCanvas3D& canvas, const GLCanva | |||||||
|     float inv_zoom = (zoom != 0.0f) ? 1.0f / zoom : 0.0f; |     float inv_zoom = (zoom != 0.0f) ? 1.0f / zoom : 0.0f; | ||||||
| 
 | 
 | ||||||
|     float height = _get_total_overlay_height(); |     float height = _get_total_overlay_height(); | ||||||
|     float top_x = (OverlayOffsetX - 0.5f * cnv_w) * inv_zoom; |     float top_x = (OverlayBorder - 0.5f * cnv_w) * inv_zoom; | ||||||
|     float top_y = 0.5f * height * inv_zoom; |     float top_y = (0.5f * height - OverlayBorder) * inv_zoom; | ||||||
|     float scaled_gap_y = OverlayGapY * inv_zoom; |     float scaled_gap_y = OverlayGapY * inv_zoom; | ||||||
|     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) |     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) | ||||||
|     { |     { | ||||||
|         if ((it->second == nullptr) || !it->second->is_selectable()) |         if ((it->second == nullptr) || !it->second->is_selectable()) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         float tex_size = (float)it->second->get_textures_size() * OverlayTexturesScale * inv_zoom; |         float tex_size = (float)it->second->get_textures_size() * OverlayIconsScale * inv_zoom; | ||||||
|         GLTexture::render_texture(it->second->get_texture_id(), top_x, top_x + tex_size, top_y - tex_size, top_y); |         GLTexture::render_texture(it->second->get_texture_id(), top_x, top_x + tex_size, top_y - tex_size, top_y); | ||||||
| #if ENABLE_IMGUI | #if ENABLE_IMGUI | ||||||
|         if (it->second->get_state() == GLGizmoBase::On) |         if (it->second->get_state() == GLGizmoBase::On) | ||||||
|             it->second->render_input_window(2.0f * OverlayOffsetX + tex_size * zoom, 0.5f * cnv_h - top_y * zoom, selection); |             it->second->render_input_window(2.0f * OverlayBorder + tex_size * zoom, 0.5f * cnv_h - top_y * zoom, selection); | ||||||
| #endif // ENABLE_IMGUI
 | #endif // ENABLE_IMGUI
 | ||||||
|         top_y -= (tex_size + scaled_gap_y); |         top_y -= (tex_size + scaled_gap_y); | ||||||
|     } |     } | ||||||
| @ -3047,14 +3046,14 @@ void GLCanvas3D::Gizmos::_render_current_gizmo(const GLCanvas3D::Selection& sele | |||||||
| 
 | 
 | ||||||
| float GLCanvas3D::Gizmos::_get_total_overlay_height() const | float GLCanvas3D::Gizmos::_get_total_overlay_height() const | ||||||
| { | { | ||||||
|     float height = 0.0f; |     float height = 2.0f * OverlayBorder; | ||||||
| 
 | 
 | ||||||
|     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) |     for (GizmosMap::const_iterator it = m_gizmos.begin(); it != m_gizmos.end(); ++it) | ||||||
|     { |     { | ||||||
|         if (it->first == SlaSupports && wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() != ptSLA) |         if ((it->second == nullptr) || !it->second->is_selectable()) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         height += (float)it->second->get_textures_size() * OverlayTexturesScale + OverlayGapY; |         height += (float)it->second->get_textures_size() * OverlayIconsScale + OverlayGapY; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return height - OverlayGapY; |     return height - OverlayGapY; | ||||||
|  | |||||||
| @ -607,8 +607,8 @@ public: | |||||||
| private: | private: | ||||||
|     class Gizmos |     class Gizmos | ||||||
|     { |     { | ||||||
|         static const float OverlayTexturesScale; |         static const float OverlayIconsScale; | ||||||
|         static const float OverlayOffsetX; |         static const float OverlayBorder; | ||||||
|         static const float OverlayGapY; |         static const float OverlayGapY; | ||||||
| 
 | 
 | ||||||
|     public: |     public: | ||||||
|  | |||||||
| @ -1460,12 +1460,9 @@ void ObjectList::update_selections() | |||||||
|     select_items(sels); |     select_items(sels); | ||||||
| 
 | 
 | ||||||
|     if (GetSelection()) { |     if (GetSelection()) { | ||||||
|         const wxRect& sel_rc = GetItemRect(GetSelection()); |         const int sel_item_row = m_objects_model->GetRowByItem(GetSelection()); | ||||||
|         if (!sel_rc.IsEmpty()) { |         ScrollLines(sel_item_row - m_selected_row); | ||||||
|             const int rc_h = sel_rc.height; |         m_selected_row = sel_item_row; | ||||||
|             const int displ = GetMainWindow()->GetClientRect().GetHeight()/(2*rc_h)+1; |  | ||||||
|             ScrollLines(int(sel_rc.y / rc_h - displ)); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -108,6 +108,8 @@ class ObjectList : public wxDataViewCtrl | |||||||
|     bool        m_parts_changed = false; |     bool        m_parts_changed = false; | ||||||
|     bool        m_part_settings_changed = false; |     bool        m_part_settings_changed = false; | ||||||
| 
 | 
 | ||||||
|  |     int         m_selected_row = 0; | ||||||
|  | 
 | ||||||
| public: | public: | ||||||
|     ObjectList(wxWindow* parent); |     ObjectList(wxWindow* parent); | ||||||
|     ~ObjectList(); |     ~ObjectList(); | ||||||
|  | |||||||
| @ -953,6 +953,44 @@ void PrusaObjectDataViewModel::GetItemInfo(const wxDataViewItem& item, ItemType& | |||||||
|         type = itUndef; |         type = itUndef; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | int PrusaObjectDataViewModel::GetRowByItem(const wxDataViewItem& item) const | ||||||
|  | { | ||||||
|  |     if (m_objects.empty()) | ||||||
|  |         return -1; | ||||||
|  | 
 | ||||||
|  |     int row_num = 0; | ||||||
|  |      | ||||||
|  |     for (int i = 0; i < m_objects.size(); i++) | ||||||
|  |     { | ||||||
|  |         row_num++; | ||||||
|  |         if (item == wxDataViewItem(m_objects[i])) | ||||||
|  |             return row_num; | ||||||
|  | 
 | ||||||
|  |         for (int j = 0; j < m_objects[i]->GetChildCount(); j++) | ||||||
|  |         { | ||||||
|  |             row_num++; | ||||||
|  |             PrusaObjectDataViewModelNode* cur_node = m_objects[i]->GetNthChild(j); | ||||||
|  |             if (item == wxDataViewItem(cur_node)) | ||||||
|  |                 return row_num; | ||||||
|  | 
 | ||||||
|  |             if (cur_node->m_type == itVolume && cur_node->GetChildCount() == 1) | ||||||
|  |                 row_num++; | ||||||
|  |             if (cur_node->m_type == itInstanceRoot) | ||||||
|  |             { | ||||||
|  |                 row_num++; | ||||||
|  |                 for (int t = 0; t < cur_node->GetChildCount(); t++) | ||||||
|  |                 { | ||||||
|  |                     row_num++; | ||||||
|  |                     if (item == wxDataViewItem(cur_node->GetNthChild(t))) | ||||||
|  |                         return row_num; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }         | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return -1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| wxString PrusaObjectDataViewModel::GetName(const wxDataViewItem &item) const | wxString PrusaObjectDataViewModel::GetName(const wxDataViewItem &item) const | ||||||
| { | { | ||||||
| 	PrusaObjectDataViewModelNode *node = (PrusaObjectDataViewModelNode*)item.GetID(); | 	PrusaObjectDataViewModelNode *node = (PrusaObjectDataViewModelNode*)item.GetID(); | ||||||
|  | |||||||
| @ -463,6 +463,7 @@ public: | |||||||
|     int GetVolumeIdByItem(const wxDataViewItem& item) const; |     int GetVolumeIdByItem(const wxDataViewItem& item) const; | ||||||
|     int GetInstanceIdByItem(const wxDataViewItem& item) const; |     int GetInstanceIdByItem(const wxDataViewItem& item) const; | ||||||
|     void GetItemInfo(const wxDataViewItem& item, ItemType& type, int& obj_idx, int& idx); |     void GetItemInfo(const wxDataViewItem& item, ItemType& type, int& obj_idx, int& idx); | ||||||
|  |     int GetRowByItem(const wxDataViewItem& item) const; | ||||||
|     bool IsEmpty() { return m_objects.empty(); } |     bool IsEmpty() { return m_objects.empty(); } | ||||||
| 
 | 
 | ||||||
| 	// helper method for wxLog
 | 	// helper method for wxLog
 | ||||||
| @ -525,8 +526,14 @@ class PrusaBitmapTextRenderer : public wxDataViewCustomRenderer | |||||||
| #endif //ENABLE_NONCUSTOM_DATA_VIEW_RENDERING
 | #endif //ENABLE_NONCUSTOM_DATA_VIEW_RENDERING
 | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     PrusaBitmapTextRenderer(wxDataViewCellMode mode = wxDATAVIEW_CELL_EDITABLE, |     PrusaBitmapTextRenderer(wxDataViewCellMode mode = | ||||||
|                             int align = wxDVR_DEFAULT_ALIGNMENT | #ifdef __WXOSX__ | ||||||
|  |                                                         wxDATAVIEW_CELL_INERT | ||||||
|  | #else | ||||||
|  |                                                         wxDATAVIEW_CELL_EDITABLE | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  |                             ,int align = wxDVR_DEFAULT_ALIGNMENT | ||||||
| #if ENABLE_NONCUSTOM_DATA_VIEW_RENDERING | #if ENABLE_NONCUSTOM_DATA_VIEW_RENDERING | ||||||
|                             ); |                             ); | ||||||
| #else | #else | ||||||
| @ -542,7 +549,14 @@ public: | |||||||
|     virtual bool Render(wxRect cell, wxDC *dc, int state); |     virtual bool Render(wxRect cell, wxDC *dc, int state); | ||||||
|     virtual wxSize GetSize() const; |     virtual wxSize GetSize() const; | ||||||
| 
 | 
 | ||||||
|     bool        HasEditorCtrl() const override { return true; } |     bool        HasEditorCtrl() const override | ||||||
|  |     { | ||||||
|  | #ifdef __WXOSX__ | ||||||
|  |         return false; | ||||||
|  | #else | ||||||
|  |         return true; | ||||||
|  | #endif         | ||||||
|  |     } | ||||||
|     wxWindow*   CreateEditorCtrl(wxWindow* parent,  |     wxWindow*   CreateEditorCtrl(wxWindow* parent,  | ||||||
|                                  wxRect labelRect,  |                                  wxRect labelRect,  | ||||||
|                                  const wxVariant& value) override; |                                  const wxVariant& value) override; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Enrico Turri
						Enrico Turri