mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Fixed DoubleSlider manipulation from Preview scene
This commit is contained in:
		
							parent
							
								
									90beadb65f
								
							
						
					
					
						commit
						917702f252
					
				
					 7 changed files with 38 additions and 12 deletions
				
			
		|  | @ -17,6 +17,7 @@ | ||||||
| #include "slic3r/GUI/GUI.hpp" | #include "slic3r/GUI/GUI.hpp" | ||||||
| #include "slic3r/GUI/PresetBundle.hpp" | #include "slic3r/GUI/PresetBundle.hpp" | ||||||
| #include "slic3r/GUI/Tab.hpp" | #include "slic3r/GUI/Tab.hpp" | ||||||
|  | #include "slic3r/GUI/GUI_Preview.hpp" | ||||||
| #include "GUI_App.hpp" | #include "GUI_App.hpp" | ||||||
| #include "GUI_ObjectList.hpp" | #include "GUI_ObjectList.hpp" | ||||||
| #include "GUI_ObjectManipulation.hpp" | #include "GUI_ObjectManipulation.hpp" | ||||||
|  | @ -1209,6 +1210,7 @@ wxDEFINE_EVENT(EVT_GLCANVAS_UPDATE_BED_SHAPE, SimpleEvent); | ||||||
| wxDEFINE_EVENT(EVT_GLCANVAS_TAB, SimpleEvent); | wxDEFINE_EVENT(EVT_GLCANVAS_TAB, SimpleEvent); | ||||||
| wxDEFINE_EVENT(EVT_GLCANVAS_RESETGIZMOS, SimpleEvent); | wxDEFINE_EVENT(EVT_GLCANVAS_RESETGIZMOS, SimpleEvent); | ||||||
| wxDEFINE_EVENT(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, wxKeyEvent); | wxDEFINE_EVENT(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, wxKeyEvent); | ||||||
|  | wxDEFINE_EVENT(EVT_GLCANVAS_EDIT_COLOR_CHANGE, wxKeyEvent); | ||||||
| 
 | 
 | ||||||
| GLCanvas3D::GLCanvas3D(wxGLCanvas* canvas, Bed3D& bed, Camera& camera, GLToolbar& view_toolbar) | GLCanvas3D::GLCanvas3D(wxGLCanvas* canvas, Bed3D& bed, Camera& camera, GLToolbar& view_toolbar) | ||||||
|     : m_canvas(canvas) |     : m_canvas(canvas) | ||||||
|  | @ -2387,8 +2389,18 @@ void GLCanvas3D::on_char(wxKeyEvent& evt) | ||||||
|         case '4': { select_view("rear"); break; } |         case '4': { select_view("rear"); break; } | ||||||
|         case '5': { select_view("left"); break; } |         case '5': { select_view("left"); break; } | ||||||
|         case '6': { select_view("right"); break; } |         case '6': { select_view("right"); break; } | ||||||
|         case '+': { post_event(Event<int>(EVT_GLCANVAS_INCREASE_INSTANCES, +1)); break; } |         case '+': {  | ||||||
|         case '-': { post_event(Event<int>(EVT_GLCANVAS_INCREASE_INSTANCES, -1)); break; } |                     if (dynamic_cast<Preview*>(m_canvas->GetParent()) != nullptr) | ||||||
|  |                         post_event(wxKeyEvent(EVT_GLCANVAS_EDIT_COLOR_CHANGE, evt));  | ||||||
|  |                     else | ||||||
|  |                         post_event(Event<int>(EVT_GLCANVAS_INCREASE_INSTANCES, +1));  | ||||||
|  |                     break; } | ||||||
|  |         case '-': {   | ||||||
|  |                     if (dynamic_cast<Preview*>(m_canvas->GetParent()) != nullptr) | ||||||
|  |                         post_event(wxKeyEvent(EVT_GLCANVAS_EDIT_COLOR_CHANGE, evt));  | ||||||
|  |                     else | ||||||
|  |                         post_event(Event<int>(EVT_GLCANVAS_INCREASE_INSTANCES, -1));  | ||||||
|  |                     break; } | ||||||
|         case '?': { post_event(SimpleEvent(EVT_GLCANVAS_QUESTION_MARK)); break; } |         case '?': { post_event(SimpleEvent(EVT_GLCANVAS_QUESTION_MARK)); break; } | ||||||
|         case 'A': |         case 'A': | ||||||
|         case 'a': { post_event(SimpleEvent(EVT_GLCANVAS_ARRANGE)); break; } |         case 'a': { post_event(SimpleEvent(EVT_GLCANVAS_ARRANGE)); break; } | ||||||
|  | @ -2472,15 +2484,10 @@ void GLCanvas3D::on_key(wxKeyEvent& evt) | ||||||
|                 else if (keyCode == WXK_LEFT    ||  |                 else if (keyCode == WXK_LEFT    ||  | ||||||
|                          keyCode == WXK_RIGHT   || |                          keyCode == WXK_RIGHT   || | ||||||
|                          keyCode == WXK_UP      ||  |                          keyCode == WXK_UP      ||  | ||||||
|                          keyCode == WXK_DOWN    || |                          keyCode == WXK_DOWN    ) | ||||||
|                          keyCode == '+'         ||  |  | ||||||
|                          keyCode == WXK_NUMPAD_ADD ||  |  | ||||||
|                          keyCode == '-'         ||  |  | ||||||
|                          keyCode == 390         ||  |  | ||||||
|                          keyCode == WXK_DELETE  ||  |  | ||||||
|                          keyCode == WXK_BACK    ) |  | ||||||
|                 { |                 { | ||||||
|                     post_event(wxKeyEvent(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, evt)); |                     if (dynamic_cast<Preview*>(m_canvas->GetParent()) != nullptr) | ||||||
|  |                         post_event(wxKeyEvent(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, evt)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -125,6 +125,7 @@ wxDECLARE_EVENT(EVT_GLCANVAS_UPDATE_BED_SHAPE, SimpleEvent); | ||||||
| wxDECLARE_EVENT(EVT_GLCANVAS_TAB, SimpleEvent); | wxDECLARE_EVENT(EVT_GLCANVAS_TAB, SimpleEvent); | ||||||
| wxDECLARE_EVENT(EVT_GLCANVAS_RESETGIZMOS, SimpleEvent); | wxDECLARE_EVENT(EVT_GLCANVAS_RESETGIZMOS, SimpleEvent); | ||||||
| wxDECLARE_EVENT(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, wxKeyEvent); | wxDECLARE_EVENT(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, wxKeyEvent); | ||||||
|  | wxDECLARE_EVENT(EVT_GLCANVAS_EDIT_COLOR_CHANGE, wxKeyEvent); | ||||||
| 
 | 
 | ||||||
| class GLCanvas3D | class GLCanvas3D | ||||||
| { | { | ||||||
|  |  | ||||||
|  | @ -420,6 +420,12 @@ void Preview::move_double_slider(wxKeyEvent& evt) | ||||||
|         m_slider->OnKeyDown(evt); |         m_slider->OnKeyDown(evt); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void Preview::edit_double_slider(wxKeyEvent& evt) | ||||||
|  | { | ||||||
|  |     if (m_slider)  | ||||||
|  |         m_slider->OnChar(evt); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void Preview::bind_event_handlers() | void Preview::bind_event_handlers() | ||||||
| { | { | ||||||
|     this->Bind(wxEVT_SIZE, &Preview::on_size, this); |     this->Bind(wxEVT_SIZE, &Preview::on_size, this); | ||||||
|  |  | ||||||
|  | @ -123,6 +123,7 @@ public: | ||||||
| 
 | 
 | ||||||
|     void msw_rescale(); |     void msw_rescale(); | ||||||
|     void move_double_slider(wxKeyEvent& evt); |     void move_double_slider(wxKeyEvent& evt); | ||||||
|  |     void edit_double_slider(wxKeyEvent& evt); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     bool init(wxWindow* parent, Bed3D& bed, Camera& camera, GLToolbar& view_toolbar, Model* model); |     bool init(wxWindow* parent, Bed3D& bed, Camera& camera, GLToolbar& view_toolbar, Model* model); | ||||||
|  |  | ||||||
|  | @ -1518,6 +1518,7 @@ Plater::priv::priv(Plater *q, MainFrame *main_frame) | ||||||
|     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_UPDATE_BED_SHAPE, [this](SimpleEvent&) { set_bed_shape(config->option<ConfigOptionPoints>("bed_shape")->values); }); |     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_UPDATE_BED_SHAPE, [this](SimpleEvent&) { set_bed_shape(config->option<ConfigOptionPoints>("bed_shape")->values); }); | ||||||
|     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_TAB, [this](SimpleEvent&) { select_next_view_3D(); }); |     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_TAB, [this](SimpleEvent&) { select_next_view_3D(); }); | ||||||
|     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, [this](wxKeyEvent& evt) { preview->move_double_slider(evt); }); |     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_MOVE_DOUBLE_SLIDER, [this](wxKeyEvent& evt) { preview->move_double_slider(evt); }); | ||||||
|  |     preview->get_wxglcanvas()->Bind(EVT_GLCANVAS_EDIT_COLOR_CHANGE, [this](wxKeyEvent& evt) { preview->edit_double_slider(evt); }); | ||||||
| 
 | 
 | ||||||
|     q->Bind(EVT_SLICING_COMPLETED, &priv::on_slicing_completed, this); |     q->Bind(EVT_SLICING_COMPLETED, &priv::on_slicing_completed, this); | ||||||
|     q->Bind(EVT_PROCESS_COMPLETED, &priv::on_process_completed, this); |     q->Bind(EVT_PROCESS_COMPLETED, &priv::on_process_completed, this); | ||||||
|  |  | ||||||
|  | @ -2366,9 +2366,9 @@ void DoubleSlider::OnWheel(wxMouseEvent& event) | ||||||
| void DoubleSlider::OnKeyDown(wxKeyEvent &event) | void DoubleSlider::OnKeyDown(wxKeyEvent &event) | ||||||
| { | { | ||||||
|     const int key = event.GetKeyCode(); |     const int key = event.GetKeyCode(); | ||||||
|     if (key == '+' || key == WXK_NUMPAD_ADD) |     if (key == WXK_NUMPAD_ADD) | ||||||
|         action_tick(taAdd); |         action_tick(taAdd); | ||||||
|     else if (key == '-' || key == 390 || key == WXK_DELETE || key == WXK_BACK) |     else if (key == 390 || key == WXK_DELETE || key == WXK_BACK) | ||||||
|         action_tick(taDel); |         action_tick(taDel); | ||||||
|     else if (is_horizontal()) |     else if (is_horizontal()) | ||||||
|     { |     { | ||||||
|  | @ -2398,6 +2398,15 @@ void DoubleSlider::OnKeyUp(wxKeyEvent &event) | ||||||
|     event.Skip(); |     event.Skip(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void DoubleSlider::OnChar(wxKeyEvent& event) | ||||||
|  | { | ||||||
|  |     const int key = event.GetKeyCode(); | ||||||
|  |     if (key == '+') | ||||||
|  |         action_tick(taAdd); | ||||||
|  |     else if (key == '-') | ||||||
|  |         action_tick(taDel); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void DoubleSlider::OnRightDown(wxMouseEvent& event) | void DoubleSlider::OnRightDown(wxMouseEvent& event) | ||||||
| { | { | ||||||
|     this->CaptureMouse(); |     this->CaptureMouse(); | ||||||
|  |  | ||||||
|  | @ -727,6 +727,7 @@ public: | ||||||
|     void OnWheel(wxMouseEvent& event); |     void OnWheel(wxMouseEvent& event); | ||||||
|     void OnKeyDown(wxKeyEvent &event); |     void OnKeyDown(wxKeyEvent &event); | ||||||
|     void OnKeyUp(wxKeyEvent &event); |     void OnKeyUp(wxKeyEvent &event); | ||||||
|  |     void OnChar(wxKeyEvent &event); | ||||||
|     void OnRightDown(wxMouseEvent& event); |     void OnRightDown(wxMouseEvent& event); | ||||||
|     void OnRightUp(wxMouseEvent& event); |     void OnRightUp(wxMouseEvent& event); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka