mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Follow-up to 3eb63c93e1:
				
					
				
			If value for "Extrusion Multiplier" is out of range, and "NO" is selected in warning message dialog, then set previous value instead of max limit value
This commit is contained in:
		
							parent
							
								
									642223dadc
								
							
						
					
					
						commit
						64e68f418b
					
				
					 1 changed files with 12 additions and 8 deletions
				
			
		|  | @ -259,23 +259,27 @@ void Field::get_value_by_opt_type(wxString& str, const bool check_value/* = true | |||
|                     m_value.clear(); | ||||
|                     break; | ||||
|                 } | ||||
|                 auto set_val = [this](double& val) { | ||||
|                     if (m_opt.min > val) val = m_opt.min; | ||||
|                     if (val > m_opt.max) val = m_opt.max; | ||||
|                     set_value(double_to_string(val), true); | ||||
|                 }; | ||||
|                 if (m_opt_id == "extrusion_multiplier") { | ||||
|                     if (m_value.empty() || boost::any_cast<double>(m_value) != val) { | ||||
|                         wxString msg_text = format_wxstr(_L("Input value is out of range\n" | ||||
|                             "Are you sure that %s is a correct value and that you want to continue?"), str); | ||||
|                         wxMessageDialog dialog(m_parent, msg_text, _L("Parameter validation") + ": " + m_opt_id, wxICON_WARNING | wxYES | wxNO); | ||||
|                         if (dialog.ShowModal() == wxID_NO) | ||||
|                             set_val(val); | ||||
|                         if (dialog.ShowModal() == wxID_NO) { | ||||
|                             if (m_value.empty()) { | ||||
|                                 if (m_opt.min > val) val = m_opt.min; | ||||
|                                 if (val > m_opt.max) val = m_opt.max; | ||||
|                             } | ||||
|                             else | ||||
|                                 val = boost::any_cast<double>(m_value); | ||||
|                             set_value(double_to_string(val), true); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 else { | ||||
|                     show_error(m_parent, _L("Input value is out of range")); | ||||
|                     set_val(val); | ||||
|                     if (m_opt.min > val) val = m_opt.min; | ||||
|                     if (val > m_opt.max) val = m_opt.max; | ||||
|                     set_value(double_to_string(val), true); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka