mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Fix of #1782
This commit is contained in:
parent
7c59c218c1
commit
21a7fa6af2
3 changed files with 24 additions and 23 deletions
|
@ -1333,6 +1333,8 @@ void Transformation::set_rotation(const Vec3d& rotation)
|
||||||
void Transformation::set_rotation(Axis axis, double rotation)
|
void Transformation::set_rotation(Axis axis, double rotation)
|
||||||
{
|
{
|
||||||
rotation = angle_to_0_2PI(rotation);
|
rotation = angle_to_0_2PI(rotation);
|
||||||
|
if (is_approx(std::abs(rotation), 2.0 * (double)PI))
|
||||||
|
rotation = 0.0;
|
||||||
|
|
||||||
if (m_rotation(axis) != rotation)
|
if (m_rotation(axis) != rotation)
|
||||||
{
|
{
|
||||||
|
|
|
@ -145,7 +145,11 @@ void Field::get_value_by_opt_type(wxString& str)
|
||||||
double val;
|
double val;
|
||||||
// Replace the first occurence of comma in decimal number.
|
// Replace the first occurence of comma in decimal number.
|
||||||
str.Replace(",", ".", false);
|
str.Replace(",", ".", false);
|
||||||
if(!str.ToCDouble(&val))
|
if (str == ".")
|
||||||
|
val = 0.0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!str.ToCDouble(&val))
|
||||||
{
|
{
|
||||||
show_error(m_parent, _(L("Invalid numeric input.")));
|
show_error(m_parent, _(L("Invalid numeric input.")));
|
||||||
set_value(double_to_string(val), true);
|
set_value(double_to_string(val), true);
|
||||||
|
@ -157,6 +161,7 @@ void Field::get_value_by_opt_type(wxString& str)
|
||||||
if (val > m_opt.max) val = m_opt.max;
|
if (val > m_opt.max) val = m_opt.max;
|
||||||
set_value(double_to_string(val), true);
|
set_value(double_to_string(val), true);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
m_value = val;
|
m_value = val;
|
||||||
break; }
|
break; }
|
||||||
case coString:
|
case coString:
|
||||||
|
|
|
@ -73,14 +73,8 @@ ObjectManipulation::ObjectManipulation(wxWindow* parent) :
|
||||||
def.default_value = new ConfigOptionFloat(0.0);
|
def.default_value = new ConfigOptionFloat(0.0);
|
||||||
def.width = 50;
|
def.width = 50;
|
||||||
|
|
||||||
if (option_name == "Rotation")
|
|
||||||
{
|
|
||||||
def.min = -360;
|
|
||||||
def.max = 360;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add "uniform scaling" button in front of "Scale" option
|
// Add "uniform scaling" button in front of "Scale" option
|
||||||
else if (option_name == "Scale") {
|
if (option_name == "Scale") {
|
||||||
line.near_label_widget = [this](wxWindow* parent) {
|
line.near_label_widget = [this](wxWindow* parent) {
|
||||||
auto btn = new PrusaLockButton(parent, wxID_ANY);
|
auto btn = new PrusaLockButton(parent, wxID_ANY);
|
||||||
btn->Bind(wxEVT_BUTTON, [btn, this](wxCommandEvent &event){
|
btn->Bind(wxEVT_BUTTON, [btn, this](wxCommandEvent &event){
|
||||||
|
@ -293,13 +287,13 @@ void ObjectManipulation::update_if_dirty()
|
||||||
deg_rotation(i) = Geometry::rad2deg(m_new_rotation(i));
|
deg_rotation(i) = Geometry::rad2deg(m_new_rotation(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_cache.rotation(0) != m_new_rotation(0))
|
if ((m_cache.rotation(0) != m_new_rotation(0)) || (m_new_rotation(0) == 0.0))
|
||||||
m_og->set_value("rotation_x", double_to_string(deg_rotation(0), 2));
|
m_og->set_value("rotation_x", double_to_string(deg_rotation(0), 2));
|
||||||
|
|
||||||
if (m_cache.rotation(1) != m_new_rotation(1))
|
if ((m_cache.rotation(1) != m_new_rotation(1)) || (m_new_rotation(1) == 0.0))
|
||||||
m_og->set_value("rotation_y", double_to_string(deg_rotation(1), 2));
|
m_og->set_value("rotation_y", double_to_string(deg_rotation(1), 2));
|
||||||
|
|
||||||
if (m_cache.rotation(2) != m_new_rotation(2))
|
if ((m_cache.rotation(2) != m_new_rotation(2)) || (m_new_rotation(2) == 0.0))
|
||||||
m_og->set_value("rotation_z", double_to_string(deg_rotation(2), 2));
|
m_og->set_value("rotation_z", double_to_string(deg_rotation(2), 2));
|
||||||
|
|
||||||
m_cache.rotation = deg_rotation;
|
m_cache.rotation = deg_rotation;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue