diff --git a/README.md b/README.md index 73771b3..b654737 100644 --- a/README.md +++ b/README.md @@ -17,9 +17,9 @@ Virtual Trackball Orbiting via the Exponential Map [License]: https://img.shields.io/crates/l/trackball.svg This is an alternative trackball technique using exponential map and parallel transport to -preserve distances and angles for coherent and intuitive trackball rotations. For instance, -displacements on straight radial lines through the screen's center are carried to arcs of the -same length on great circles of the trackball. This is in contrast to state-of-the-art +preserve distances and angles for inducing coherent and intuitive trackball rotations. For +instance, displacements on straight radial lines through the screen's center are carried to arcs +of the same length on great circles of the trackball. This is in contrast to state-of-the-art techniques using orthogonal projection which distorts radial distances further away from the screen's center. This implementation strictly follows the recipe given in the paper of Stantchev, G.. “Virtual Trackball Modeling and the Exponential Map.” . [S2CID] [44199608]. @@ -54,7 +54,7 @@ use trackball::Orbit; pub struct Trackball { // Camera eye alignment. align: UnitQuaternion, - // Orbit operation handler along with other handlers for slide, scale, and focus operations. + // Orbit operation handler along with slide, scale, and focus operation handlers. orbit: Orbit, // Maximum cursor/finger position as screen's width and height. frame: Point2, @@ -63,7 +63,7 @@ pub struct Trackball { impl Trackball { // Usually, a cursor position event with left mouse button being pressed. fn handle_left_button_displacement(&mut self, pos: &Point2) { - // Optionally, do a coordinate system transformation like flipping x-axis and z-axis. + // Optionally, do a coordinate system transformation like flipping x-axis/z-axis. let camera_space = UnitQuaternion::from_axis_angle(&Vector3::y_axis(), PI); // Or directly apply this induced rotation. let rotation = self.orbit.compute(&pos, &self.frame).unwrap_or_default(); diff --git a/c11/examples/example.c b/c11/examples/example.c index 3550935..8aa32ad 100644 --- a/c11/examples/example.c +++ b/c11/examples/example.c @@ -10,7 +10,7 @@ typedef struct { double x, y, z, w; } vec4; -// Caches normalization of previous cursor position. +// Caches normalization of previous cursor/finger position. vec4 old = { .w = 0.0 }; // Maximum cursor/finger position as screen's width and height. diff --git a/c11/src/trackball.h b/c11/src/trackball.h index aab4544..2dab981 100644 --- a/c11/src/trackball.h +++ b/c11/src/trackball.h @@ -4,8 +4,8 @@ /// \mainpage Virtual Trackball Orbiting via the Exponential Map /// /// This is an alternative trackball technique using exponential map and -/// parallel transport to preserve distances and angles for coherent and -/// intuitive trackball rotations. For instance, displacements on straight +/// parallel transport to preserve distances and angles for inducing coherent +/// and intuitive trackball rotations. For instance, displacements on straight /// radial lines through the screen's center are carried to arcs of the same /// length on great circles of the trackball. This is in contrast to /// state-of-the-art techniques using orthogonal projection which distorts @@ -25,24 +25,25 @@ /// A trackball camera mode implementation can be as easily as this by /// delegating events of your 3D graphics library of choice to the \ref /// trackball_orbit operation implementation along with other implementations -/// for common trackball camera mode operations like slide, scale and focus. +/// for common trackball camera mode operations like slide, scale, and focus. /// /// \include example.c #ifndef TRACKBALL_H #define TRACKBALL_H -/// Computes rotation from previous, current and maximum cursor/finger position. +/// Computes rotation between previous and current cursor/finger position. /// -/// Normalization of previous cursor/finger position is cached and has to be -/// discarded on button or finger release by resetting it to zero. +/// Normalization of previous position is cached and has to be discarded on +/// button/finger release by resetting it to zero. Current position is clamped +/// between origin and maximum position as screen's width and height. /// /// Screen coordinate system with origin in top left corner: /// /// * x-axis from left to right, /// * y-axis from top to bottom. /// -/// Trackball coordinate system with origin in trackball center: +/// Trackball coordinate system with origin in trackball's center: /// /// * x-axis from left to right, /// * y-axis from bottom to top, @@ -54,9 +55,9 @@ /// xyzw controlling the generic selection of the implementation's scalar type. /// /// \param[out] xyzw Induced rotation as unit quaternion. -/// \param[in,out] xyzm Cached normalization of previous cursor/finger position. -/// \param[in] xy Current cursor/finger position. -/// \param[in] wh Maximum cursor/finger position as screen's width/height. +/// \param[in,out] xyzm Cached normalization of previous position. +/// \param[in] xy Current position. +/// \param[in] wh Maximum position as screen's width and height. #define trackball_orbit(xyzw, xyzm, xy, wh) _Generic((xyzw), \ float*: trackball_orbit_f, \ double*: trackball_orbit_d, \ diff --git a/src/lib.rs b/src/lib.rs index 6a9dd23..860f565 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,9 +1,9 @@ //! Virtual Trackball Orbiting via the Exponential Map //! //! This is an alternative trackball technique using exponential map and parallel transport to -//! preserve distances and angles for coherent and intuitive trackball rotations. For instance, -//! displacements on straight radial lines through the screen's center are carried to arcs of the -//! same length on great circles of the trackball. This is in contrast to state-of-the-art +//! preserve distances and angles for inducing coherent and intuitive trackball rotations. For +//! instance, displacements on straight radial lines through the screen's center are carried to arcs +//! of the same length on great circles of the trackball. This is in contrast to state-of-the-art //! techniques using orthogonal projection which distorts radial distances further away from the //! screen's center. This implementation strictly follows the recipe given in the paper of //! Stantchev, G.. “Virtual Trackball Modeling and the Exponential Map.” . [S2CID] [44199608]. @@ -34,7 +34,7 @@ //! pub struct Trackball { //! // Camera eye alignment. //! align: UnitQuaternion, -//! // Orbit operation handler along with other handlers for slide, scale, and focus operations. +//! // Orbit operation handler along with slide, scale, and focus operation handlers. //! orbit: Orbit, //! // Maximum cursor/finger position as screen's width and height. //! frame: Point2, @@ -43,7 +43,7 @@ //! impl Trackball { //! // Usually, a cursor position event with left mouse button being pressed. //! fn handle_left_button_displacement(&mut self, pos: &Point2) { -//! // Optionally, do a coordinate system transformation like flipping x-axis and z-axis. +//! // Optionally, do a coordinate system transformation like flipping x-axis/z-axis. //! let camera_space = UnitQuaternion::from_axis_angle(&Vector3::y_axis(), PI); //! // Or directly apply this induced rotation. //! let rotation = self.orbit.compute(&pos, &self.frame).unwrap_or_default(); @@ -76,14 +76,18 @@ use nalgebra::Matrix3; #[cfg(not(feature = "cc"))] impl Orbit { - /// Computes rotation from previous, current, and maximum cursor/finger position. + /// Computes rotation between previous and current cursor/finger position. /// - /// Screen coordinate system with origin in left top corner: + /// Normalization of previous position is cached and has to be discarded on button/finger + /// release via [`Self::discard()`]. Current position `pos` is clamped between origin and + /// maximum position `max` as screen's width and height. + /// + /// Screen coordinate system with origin in top left corner: /// /// * x-axis from left to right, /// * y-axis from top to bottom. /// - /// Trackball coordinate system with origin in trackball center: + /// Trackball coordinate system with origin in trackball's center: /// /// * x-axis from left to right, /// * y-axis from bottom to top, @@ -113,7 +117,7 @@ impl Orbit { // Treat maximum of half the screen's width or height as trackball's radius. let max = max.x.max(max.y); // Map trackball's diameter onto half its circumference for start positions so that only - // screen's corners are mapped to lower hemisphere which induces less intuitive rotations. + // screen corners are mapped to lower hemisphere which induces less intuitive rotations. let (sin, cos) = (off / max * N::frac_pi_2()).sin_cos(); // Exponential map of start position. let exp = Vector3::new(sin * pos.x, sin * pos.y, cos); @@ -143,14 +147,18 @@ use nalgebra::Quaternion; #[cfg(feature = "cc")] impl Orbit { - /// Computes rotation from previous, current, and maximum cursor/finger position. + /// Computes rotation between previous and current cursor/finger position. + /// + /// Normalization of previous position is cached and has to be discarded on button/finger + /// release via [`Self::discard()`]. Current position `pos` is clamped between origin and + /// maximum position `max` as screen's width and height. /// - /// Screen coordinate system with origin in left top corner: + /// Screen coordinate system with origin in top left corner: /// /// * x-axis from left to right, /// * y-axis from top to bottom. /// - /// Trackball coordinate system with origin in trackball center: + /// Trackball coordinate system with origin in trackball's center: /// /// * x-axis from left to right, /// * y-axis from bottom to top, @@ -186,14 +194,18 @@ impl Orbit { #[cfg(feature = "cc")] impl Orbit { - /// Computes rotation from previous, current, and maximum cursor/finger position. + /// Computes rotation between previous and current cursor/finger position. + /// + /// Normalization of previous position is cached and has to be discarded on button/finger + /// release via [`Self::discard()`]. Current position `pos` is clamped between origin and + /// maximum position `max` as screen's width and height. /// - /// Screen coordinate system with origin in left top corner: + /// Screen coordinate system with origin in top left corner: /// /// * x-axis from left to right, /// * y-axis from top to bottom. /// - /// Trackball coordinate system with origin in trackball center: + /// Trackball coordinate system with origin in trackball's center: /// /// * x-axis from left to right, /// * y-axis from bottom to top,