40 : translationConstraintType_(
FREE), rotationConstraintType_(
FREE)
57 const qreal norm = direction.
norm();
60 qWarning(
"AxisPlaneConstraint::setTranslationConstraintDir: null vector for translation constraint");
80 const qreal norm = direction.
norm();
83 qWarning(
"AxisPlaneConstraint::setRotationConstraintDir: null vector for rotation constraint");
106 qWarning(
"AxisPlaneConstraint::setRotationConstraintType: the PLANE type cannot be used for a rotation constraints");
137 translation =
Vec(0.0, 0.0, 0.0);
156 Vec quat =
Vec(rotation[0], rotation[1], rotation[2]);
158 rotation =
Quaternion(quat, 2.0*acos(rotation[3]));
200 translation =
Vec(0.0, 0.0, 0.0);
218 Vec quat(rotation[0], rotation[1], rotation[2]);
221 rotation =
Quaternion(quat, 2.0*acos(rotation[3]));
263 translation =
Vec(0.0, 0.0, 0.0);
282 Vec quat =
Vec(rotation[0], rotation[1], rotation[2]);
284 rotation =
Quaternion(quat, 2.0*acos(rotation[3]));
void setRotationConstraintDirection(const Vec &direction)
Vec rotationConstraintDir_
void setTranslationConstraint(Type type, const Vec &direction)
void setRotationConstraint(Type type, const Vec &direction)
Vec translationConstraintDir_
An abstract class for Frame Constraints defined by an axis or a plane.
Type rotationConstraintType() const
void projectOnPlane(const Vec &normal)
Vec translationConstraintDirection() const
virtual void constrainTranslation(Vec &translation, Frame *const frame)
CameraConstraint(const Camera *const camera)
virtual void constrainTranslation(Vec &translation, Frame *const frame)
void setTranslationConstraintDirection(const Vec &direction)
The Vec class represents 3D positions and 3D vectors.
virtual void constrainRotation(Quaternion &rotation, Frame *const frame)
Vec rotate(const Vec &v) const
ManipulatedCameraFrame * frame() const
Type translationConstraintType_
A perspective or orthographic camera.
The Quaternion class represents 3D rotations and orientations.
void projectOnAxis(const Vec &direction)
Type rotationConstraintType_
Vec rotationConstraintDirection() const
Vec transformOf(const Vec &src) const
void setTranslationConstraintType(Type type)
The Frame class represents a coordinate system, defined by a position and an orientation.
Type translationConstraintType() const
void setRotationConstraintType(Type type)
Vec inverseTransformOf(const Vec &src) const
const Frame * referenceFrame() const
virtual void constrainTranslation(Vec &translation, Frame *const frame)
const Camera * camera() const
Quaternion rotation() const
virtual void constrainRotation(Quaternion &rotation, Frame *const frame)
virtual void constrainRotation(Quaternion &rotation, Frame *const frame)