summaryrefslogtreecommitdiffstats
path: root/o3d/samples
diff options
context:
space:
mode:
authorkbr@google.com <kbr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-06 18:29:08 +0000
committerkbr@google.com <kbr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-06 18:29:08 +0000
commita97063189b7596ec805dab89f0d2fa7222c63191 (patch)
treea1935af83e5b7529266f3bb875d19ff10a46946b /o3d/samples
parentad317b497cdc23c26ed86421b6a873e9ede151a2 (diff)
downloadchromium_src-a97063189b7596ec805dab89f0d2fa7222c63191.zip
chromium_src-a97063189b7596ec805dab89f0d2fa7222c63191.tar.gz
chromium_src-a97063189b7596ec805dab89f0d2fa7222c63191.tar.bz2
Improved documentation for the derivation of Line_.closestPointToRay().
Review URL: http://codereview.chromium.org/251097 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@28132 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'o3d/samples')
-rw-r--r--o3d/samples/o3djs/manipulators.js42
1 files changed, 41 insertions, 1 deletions
diff --git a/o3d/samples/o3djs/manipulators.js b/o3d/samples/o3djs/manipulators.js
index bc37de1..d84cea0 100644
--- a/o3d/samples/o3djs/manipulators.js
+++ b/o3d/samples/o3djs/manipulators.js
@@ -100,7 +100,7 @@ o3djs.manipulators.createManager = function(pack,
* line. Does not need to be normalized but must not be the zero
* vector. Defaults to [1, 0, 0] if not specified.
* @param {o3djs.math.Vector3} opt_point A point through which the
- * line goes.
+ * line goes. Defaults to [0, 0, 0] if not specified.
*/
o3djs.manipulators.Line_ = function(opt_direction,
opt_point) {
@@ -193,6 +193,46 @@ o3djs.manipulators.X_AXIS = [1, 0, 0];
*/
o3djs.manipulators.Line_.prototype.closestPointToRay = function(startPoint,
endPoint) {
+ // Consider a two-sided line and a one-sided ray, both in in 3D
+ // space, and assume they are not parallel. Their parametric
+ // formulation is:
+ //
+ // p1 = point + t * dir
+ // p2 = raystart + u * raydir
+ //
+ // Here t and u are scalar parameter values, and the other values
+ // are three-dimensional vectors. p1 and p2 are arbitrary points on
+ // the line and ray, respectively.
+ //
+ // At the points cp1 and cp2 on these two lines where the line and
+ // the ray are closest together, the line segment between cp1 and
+ // cp2 is perpendicular to both of the lines.
+ //
+ // We can therefore write the following equations ("**" is the "dot"
+ // operator):
+ //
+ // dir ** (cp2 - cp1) = 0
+ // raydir ** (cp2 - cp1) = 0
+ //
+ // Define t' and u' as the parameter values for cp1 and cp2,
+ // respectively. Expanding, these equations become
+ //
+ // dir ** ((raystart + u' * raydir) - (point + t' * dir)) = 0
+ // raydir ** ((raystart + u' * raydir) - (point + t' * dir)) = 0
+ //
+ // With some reshuffling, these can be expressed in vector/matrix
+ // form:
+ //
+ // [ dir ** raystart - dir ** point ]
+ // [ raydir ** raystart - raydir ** point ] * (continued)
+ //
+ // [ -( dir ** dir) dir ** raydir ] [ t' ] [0]
+ // [ -(raydir ** dir) raydir ** raydir ] [ u' ] = [0]
+ //
+ // u' is the parameter for the world space ray being cast into the
+ // screen. We can deduce whether the starting point of the ray is
+ // actually the closest point to the infinite 3D line by whether the
+ // value of u' is less than zero.
var rayDirection = o3djs.math.subVector(endPoint, startPoint);
var ddrd = o3djs.math.dot(this.direction_, rayDirection);
var A = [[-o3djs.math.lengthSquared(this.direction_), ddrd],