mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Tech ENABLE_GCODE_VIEWER -> Adapting DoubleSlider::Control for sequential view
This commit is contained in:
		
							parent
							
								
									94b431f3af
								
							
						
					
					
						commit
						2b536137d2
					
				
					 3 changed files with 73 additions and 8 deletions
				
			
		|  | @ -838,8 +838,20 @@ void Control::draw_cog_icon(wxDC& dc) | ||||||
|     get_size(&width, &height); |     get_size(&width, &height); | ||||||
| 
 | 
 | ||||||
|     wxCoord x_draw, y_draw; |     wxCoord x_draw, y_draw; | ||||||
|     is_horizontal() ? x_draw = width-2 : x_draw = width - m_cog_icon_dim - 2; | #if ENABLE_GCODE_VIEWER | ||||||
|     is_horizontal() ? y_draw = height - m_cog_icon_dim - 2 : y_draw = height-2; |     if (m_draw_mode == dmSequentialGCodeView) | ||||||
|  |     { | ||||||
|  |         is_horizontal() ? x_draw = width - 2 : x_draw = 0.5 * width - 0.5 * m_cog_icon_dim; | ||||||
|  |         is_horizontal() ? y_draw = 0.5 * height - 0.5 * m_cog_icon_dim : y_draw = height - 2; | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|  |         is_horizontal() ? x_draw = width - 2 : x_draw = width - m_cog_icon_dim - 2; | ||||||
|  |         is_horizontal() ? y_draw = height - m_cog_icon_dim - 2 : y_draw = height - 2; | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     } | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
|     dc.DrawBitmap(m_bmp_cog.bmp(), x_draw, y_draw); |     dc.DrawBitmap(m_bmp_cog.bmp(), x_draw, y_draw); | ||||||
| 
 | 
 | ||||||
|  | @ -977,10 +989,19 @@ wxString Control::get_tooltip(int tick/*=-1*/) | ||||||
|     if (m_focus == fiRevertIcon) |     if (m_focus == fiRevertIcon) | ||||||
|         return _(L("Discard all custom changes")); |         return _(L("Discard all custom changes")); | ||||||
|     if (m_focus == fiCogIcon) |     if (m_focus == fiCogIcon) | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     { | ||||||
|  |         if (m_draw_mode == dmSequentialGCodeView) | ||||||
|  |             return _L("Jump to move") + " (Shift + G)"; | ||||||
|  |         else | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|             return m_mode == t_mode::MultiAsSingle ? |             return m_mode == t_mode::MultiAsSingle ? | ||||||
|                    GUI::from_u8((boost::format(_utf8(L("Jump to height %s or " |                    GUI::from_u8((boost::format(_utf8(L("Jump to height %s or " | ||||||
|                    "Set extruder sequence for the entire print"))) % " (Shift + G)\n").str()) : |                    "Set extruder sequence for the entire print"))) % " (Shift + G)\n").str()) : | ||||||
|                    _(L("Jump to height")) + " (Shift + G)"; |                    _(L("Jump to height")) + " (Shift + G)"; | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     } | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|     if (m_focus == fiColorBand) |     if (m_focus == fiColorBand) | ||||||
|         return m_mode != t_mode::SingleExtruder ? "" : |         return m_mode != t_mode::SingleExtruder ? "" : | ||||||
|                _(L("Edit current color - Right click the colored slider segment")); |                _(L("Edit current color - Right click the colored slider segment")); | ||||||
|  | @ -1230,7 +1251,11 @@ void Control::OnLeftUp(wxMouseEvent& event) | ||||||
|         if (m_mode == t_mode::MultiAsSingle && m_draw_mode == dmRegular) |         if (m_mode == t_mode::MultiAsSingle && m_draw_mode == dmRegular) | ||||||
|             show_cog_icon_context_menu(); |             show_cog_icon_context_menu(); | ||||||
|         else |         else | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |             jump_to_value(); | ||||||
|  | #else | ||||||
|             jump_to_print_z(); |             jump_to_print_z(); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|         break; |         break; | ||||||
|     case maOneLayerIconClick: |     case maOneLayerIconClick: | ||||||
|         switch_one_layer_mode(); |         switch_one_layer_mode(); | ||||||
|  | @ -1385,7 +1410,11 @@ void Control::OnChar(wxKeyEvent& event) | ||||||
|         m_ticks.suppress_minus(false); |         m_ticks.suppress_minus(false); | ||||||
|     } |     } | ||||||
|     if (key == 'G') |     if (key == 'G') | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |         jump_to_value(); | ||||||
|  | #else | ||||||
|         jump_to_print_z(); |         jump_to_print_z(); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Control::OnRightDown(wxMouseEvent& event) | void Control::OnRightDown(wxMouseEvent& event) | ||||||
|  | @ -1571,7 +1600,11 @@ void Control::show_cog_icon_context_menu() | ||||||
|     wxMenu menu; |     wxMenu menu; | ||||||
| 
 | 
 | ||||||
|     append_menu_item(&menu, wxID_ANY, _(L("Jump to height")) + " (Shift+G)", "", |     append_menu_item(&menu, wxID_ANY, _(L("Jump to height")) + " (Shift+G)", "", | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |                      [this](wxCommandEvent&) { jump_to_value(); }, "", & menu); | ||||||
|  | #else | ||||||
|                      [this](wxCommandEvent&) { jump_to_print_z(); }, "", &menu); |                      [this](wxCommandEvent&) { jump_to_print_z(); }, "", &menu); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
|     append_menu_item(&menu, wxID_ANY, _(L("Set extruder sequence for the entire print")), "", |     append_menu_item(&menu, wxID_ANY, _(L("Set extruder sequence for the entire print")), "", | ||||||
|         [this](wxCommandEvent&) { edit_extruder_sequence(); }, "", &menu); |         [this](wxCommandEvent&) { edit_extruder_sequence(); }, "", &menu); | ||||||
|  | @ -1689,11 +1722,21 @@ static std::string get_pause_print_msg(const std::string& msg_in, double height) | ||||||
|     return into_u8(dlg.GetValue()); |     return into_u8(dlg.GetValue()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  | static double get_value_to_jump(double active_value, double min_z, double max_z, DrawMode mode) | ||||||
|  | #else | ||||||
| static double get_print_z_to_jump(double active_print_z, double min_z, double max_z) | static double get_print_z_to_jump(double active_print_z, double min_z, double max_z) | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| { | { | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     wxString msg_text = (mode == dmSequentialGCodeView) ? _L("Enter the move you want to jump to") + ":" : _L("Enter the height you want to jump to") + ":"; | ||||||
|  |     wxString msg_header = (mode == dmSequentialGCodeView) ? _L("Jump to move") : _L("Jump to height"); | ||||||
|  |     wxString msg_in = GUI::double_to_string(active_value); | ||||||
|  | #else | ||||||
|     wxString msg_text = _(L("Enter the height you want to jump to")) + ":"; |     wxString msg_text = _(L("Enter the height you want to jump to")) + ":"; | ||||||
|     wxString msg_header = _(L("Jump to height")); |     wxString msg_header = _(L("Jump to height")); | ||||||
|     wxString msg_in = GUI::double_to_string(active_print_z); |     wxString msg_in = GUI::double_to_string(active_print_z); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
|     // get custom gcode
 |     // get custom gcode
 | ||||||
|     wxTextEntryDialog dlg(nullptr, msg_text, msg_header, msg_in, wxTextEntryDialogStyle); |     wxTextEntryDialog dlg(nullptr, msg_text, msg_header, msg_in, wxTextEntryDialogStyle); | ||||||
|  | @ -1902,6 +1945,23 @@ void Control::edit_extruder_sequence() | ||||||
|     post_ticks_changed_event(ToolChangeCode); |     post_ticks_changed_event(ToolChangeCode); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  | void Control::jump_to_value() | ||||||
|  | { | ||||||
|  |     double value = get_value_to_jump(m_values[m_selection == ssLower ? m_lower_value : m_higher_value], | ||||||
|  |                                      m_values[m_min_value], m_values[m_max_value], m_draw_mode); | ||||||
|  |     if (value < 0.0) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     auto it = std::lower_bound(m_values.begin(), m_values.end(), value - epsilon()); | ||||||
|  |     int tick_value = it - m_values.begin(); | ||||||
|  | 
 | ||||||
|  |     if (m_selection == ssLower) | ||||||
|  |         SetLowerValue(tick_value); | ||||||
|  |     else | ||||||
|  |         SetHigherValue(tick_value); | ||||||
|  | } | ||||||
|  | #else | ||||||
| void Control::jump_to_print_z() | void Control::jump_to_print_z() | ||||||
| { | { | ||||||
|     double print_z = get_print_z_to_jump(m_values[m_selection == ssLower ? m_lower_value : m_higher_value],  |     double print_z = get_print_z_to_jump(m_values[m_selection == ssLower ? m_lower_value : m_higher_value],  | ||||||
|  | @ -1917,6 +1977,7 @@ void Control::jump_to_print_z() | ||||||
|     else |     else | ||||||
|         SetHigherValue(tick_value); |         SetHigherValue(tick_value); | ||||||
| } | } | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
| void Control::post_ticks_changed_event(const std::string& gcode /*= ""*/) | void Control::post_ticks_changed_event(const std::string& gcode /*= ""*/) | ||||||
| { | { | ||||||
|  |  | ||||||
|  | @ -253,7 +253,11 @@ public: | ||||||
|     void discard_all_thicks(); |     void discard_all_thicks(); | ||||||
|     void move_current_thumb_to_pos(wxPoint pos); |     void move_current_thumb_to_pos(wxPoint pos); | ||||||
|     void edit_extruder_sequence(); |     void edit_extruder_sequence(); | ||||||
|  | #if ENABLE_GCODE_VIEWER | ||||||
|  |     void jump_to_value(); | ||||||
|  | #else | ||||||
|     void jump_to_print_z(); |     void jump_to_print_z(); | ||||||
|  | #endif // ENABLE_GCODE_VIEWER
 | ||||||
|     void show_add_context_menu(); |     void show_add_context_menu(); | ||||||
|     void show_edit_context_menu(); |     void show_edit_context_menu(); | ||||||
|     void show_cog_icon_context_menu(); |     void show_cog_icon_context_menu(); | ||||||
|  |  | ||||||
|  | @ -558,7 +558,7 @@ public: | ||||||
| #if ENABLE_GCODE_VIEWER | #if ENABLE_GCODE_VIEWER | ||||||
|     void reset_gcode_toolpaths() { m_gcode_viewer.reset(); } |     void reset_gcode_toolpaths() { m_gcode_viewer.reset(); } | ||||||
|     const GCodeViewer::SequentialView& get_gcode_sequential_view() const { return m_gcode_viewer.get_sequential_view(); } |     const GCodeViewer::SequentialView& get_gcode_sequential_view() const { return m_gcode_viewer.get_sequential_view(); } | ||||||
|     void update_gcode_sequential_view_current(unsigned int low, unsigned int high) { m_gcode_viewer.update_sequential_view_current(low, high); } |     void update_gcode_sequential_view_current(unsigned int first, unsigned int last) { m_gcode_viewer.update_sequential_view_current(first, last); } | ||||||
| #endif // ENABLE_GCODE_VIEWER
 | #endif // ENABLE_GCODE_VIEWER
 | ||||||
| 
 | 
 | ||||||
|     void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1); |     void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966