mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Fixed update after editing for "infill_ancor" and "infill_ancor_max" parameters.
* Update value only if it is changed * Show info dialog (suggestion to change mm to %) only when parameter value is bigger than 100
This commit is contained in:
		
							parent
							
								
									b71c001845
								
							
						
					
					
						commit
						7ab1fcaa5c
					
				
					 1 changed files with 20 additions and 6 deletions
				
			
		|  | @ -262,6 +262,11 @@ void Field::get_value_by_opt_type(wxString& str, const bool check_value/* = true | |||
|             double val = 0.; | ||||
| 			// Replace the first occurence of comma in decimal number.
 | ||||
| 			str.Replace(",", ".", false); | ||||
| 
 | ||||
|             // remove space and "mm" substring, if any exists
 | ||||
|             str.Replace(" ", "", true); | ||||
|             str.Replace("m", "", true); | ||||
| 
 | ||||
|             if (!str.ToCDouble(&val)) | ||||
|             { | ||||
|                 if (!check_value) { | ||||
|  | @ -280,13 +285,15 @@ void Field::get_value_by_opt_type(wxString& str, const bool check_value/* = true | |||
|                     break; | ||||
|                 } | ||||
| 
 | ||||
|                 bool infill_anchors = m_opt.opt_key == "infill_anchor" || m_opt.opt_key == "infill_anchor_max"; | ||||
| 
 | ||||
|                 const std::string sidetext = m_opt.sidetext.rfind("mm/s") != std::string::npos ? "mm/s" : "mm"; | ||||
|                 const wxString stVal = double_to_string(val, 2); | ||||
|                 const wxString msg_text = from_u8((boost::format(_utf8(L("Do you mean %s%% instead of %s %s?\n" | ||||
|                     "Select YES if you want to change this value to %s%%, \n" | ||||
|                     "or NO if you are sure that %s %s is a correct value."))) % stVal % stVal % sidetext % stVal % stVal % sidetext).str()); | ||||
|                 wxMessageDialog dialog(m_parent, msg_text, _(L("Parameter validation")) + ": " + m_opt_id , wxICON_WARNING | wxYES | wxNO); | ||||
|                 if (dialog.ShowModal() == wxID_YES) { | ||||
|                 if ((!infill_anchors || val > 100) && dialog.ShowModal() == wxID_YES) { | ||||
|                     set_value(from_u8((boost::format("%s%%") % stVal).str()), false/*true*/); | ||||
|                     str += "%%"; | ||||
|                 } | ||||
|  | @ -870,20 +877,27 @@ void Choice::BUILD() { | |||
|     temp->Bind(wxEVT_COMBOBOX_DROPDOWN, [this](wxCommandEvent&) { m_is_dropped = true; }); | ||||
|     temp->Bind(wxEVT_COMBOBOX_CLOSEUP,  [this](wxCommandEvent&) { m_is_dropped = false; }); | ||||
| 
 | ||||
|     temp->Bind(wxEVT_COMBOBOX, ([this, temp](wxCommandEvent) { on_change_field(); }), temp->GetId()); | ||||
|     temp->Bind(wxEVT_COMBOBOX,          [this](wxCommandEvent&) { on_change_field(); }, temp->GetId()); | ||||
| 
 | ||||
|     if (m_is_editable) { | ||||
|         temp->Bind(wxEVT_KILL_FOCUS, ([this](wxEvent& e) { | ||||
|             e.Skip(); | ||||
|             if (m_opt.type == coStrings || m_opt.type == coFloatOrPercent) { | ||||
|             if (m_opt.type == coStrings) { | ||||
|                 on_change_field(); | ||||
|                 return; | ||||
|             } | ||||
| 
 | ||||
|             double old_val = !m_value.empty() ? boost::any_cast<double>(m_value) : -99999; | ||||
|             if (is_defined_input_value<choice_ctrl>(window, m_opt.type)) { | ||||
|                 if (fabs(old_val - boost::any_cast<double>(get_value())) <= 0.0001) | ||||
|                     return; | ||||
|                 if (m_opt.type == coFloatOrPercent) { | ||||
|                     std::string old_val = !m_value.empty() ? boost::any_cast<std::string>(m_value) : ""; | ||||
|                     if (old_val == boost::any_cast<std::string>(get_value())) | ||||
|                         return; | ||||
|                 } | ||||
|                 else { | ||||
|                     double old_val = !m_value.empty() ? boost::any_cast<double>(m_value) : -99999; | ||||
|                     if (fabs(old_val - boost::any_cast<double>(get_value())) <= 0.0001) | ||||
|                         return; | ||||
|                 } | ||||
|                 on_change_field(); | ||||
|             } | ||||
|             else | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka