fix: Adjust chained line angle ref dir for free drawing
Co-authored-by: aider (gemini/gemini-2.5-pro) <aider@aider.chat>
This commit is contained in:
@@ -394,6 +394,10 @@ void ViewportWidget::paintGL()
|
|||||||
if (relativeMouseAngle >= 90 || relativeMouseAngle < -90) {
|
if (relativeMouseAngle >= 90 || relativeMouseAngle < -90) {
|
||||||
refDir = -refDir;
|
refDir = -refDir;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (property("isChainedLine").toBool()) {
|
||||||
|
refDir = -refDir;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double refAngle, lineAngle;
|
double refAngle, lineAngle;
|
||||||
@@ -693,22 +697,28 @@ void ViewportWidget::paintGL()
|
|||||||
QVector3D currentMouseWorldPosForText = unproject(m_currentMousePos, m_currentPlane);
|
QVector3D currentMouseWorldPosForText = unproject(m_currentMousePos, m_currentPlane);
|
||||||
QVector3D mouseVecForText = currentMouseWorldPosForText - startPos;
|
QVector3D mouseVecForText = currentMouseWorldPosForText - startPos;
|
||||||
|
|
||||||
if (mouseVecForText.length() > 1e-6) {
|
if (angleFromInput) {
|
||||||
double mouseAngle;
|
if (mouseVecForText.length() > 1e-6) {
|
||||||
if (m_currentPlane == SketchPlane::XY) mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.z(), mouseVecForText.x()));
|
double mouseAngle;
|
||||||
else if (m_currentPlane == SketchPlane::XZ) mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.y(), mouseVecForText.x()));
|
if (m_currentPlane == SketchPlane::XY) mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.z(), mouseVecForText.x()));
|
||||||
else mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.z(), mouseVecForText.y()));
|
else if (m_currentPlane == SketchPlane::XZ) mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.y(), mouseVecForText.x()));
|
||||||
|
else mouseAngle = qRadiansToDegrees(atan2(mouseVecForText.z(), mouseVecForText.y()));
|
||||||
|
|
||||||
double refAngleForQuadrant;
|
double refAngleForQuadrant;
|
||||||
if (m_currentPlane == SketchPlane::XY) refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.z(), refDir.x()));
|
if (m_currentPlane == SketchPlane::XY) refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.z(), refDir.x()));
|
||||||
else if (m_currentPlane == SketchPlane::XZ) refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.y(), refDir.x()));
|
else if (m_currentPlane == SketchPlane::XZ) refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.y(), refDir.x()));
|
||||||
else refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.z(), refDir.y()));
|
else refAngleForQuadrant = qRadiansToDegrees(atan2(refDir.z(), refDir.y()));
|
||||||
|
|
||||||
double relativeMouseAngle = mouseAngle - refAngleForQuadrant;
|
double relativeMouseAngle = mouseAngle - refAngleForQuadrant;
|
||||||
while (relativeMouseAngle <= -180.0) relativeMouseAngle += 360.0;
|
while (relativeMouseAngle <= -180.0) relativeMouseAngle += 360.0;
|
||||||
while (relativeMouseAngle > 180.0) relativeMouseAngle -= 360.0;
|
while (relativeMouseAngle > 180.0) relativeMouseAngle -= 360.0;
|
||||||
|
|
||||||
if (relativeMouseAngle >= 90 || relativeMouseAngle < -90) {
|
if (relativeMouseAngle >= 90 || relativeMouseAngle < -90) {
|
||||||
|
refDir = -refDir;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (property("isChainedLine").toBool()) {
|
||||||
refDir = -refDir;
|
refDir = -refDir;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user