diff options
author | gman@chromium.org <gman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-12-05 01:25:21 +0000 |
---|---|---|
committer | gman@chromium.org <gman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-12-05 01:25:21 +0000 |
commit | 01ee861ca7a7e1655e97197dfc634904710bbe3d (patch) | |
tree | 980625a4f88507ebd31aea21cf4749f61610357d /o3d | |
parent | bd76fc2bcef23c62e570bdb67d782f4811a5f92d (diff) | |
download | chromium_src-01ee861ca7a7e1655e97197dfc634904710bbe3d.zip chromium_src-01ee861ca7a7e1655e97197dfc634904710bbe3d.tar.gz chromium_src-01ee861ca7a7e1655e97197dfc634904710bbe3d.tar.bz2 |
Add obscured / unobscured rendering to
manipulators.
I only did it on the rotate1 manipulators
because it was easy. On the translate ones
you either need to put each shape on it's own
transform so you can set the parameters different
or you need the materials to use different named
parameters.
Review URL: http://codereview.chromium.org/463025
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@33900 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'o3d')
-rw-r--r-- | o3d/samples/manipulators/rotate1.html | 22 | ||||
-rw-r--r-- | o3d/samples/manipulators/translate1.html | 22 | ||||
-rw-r--r-- | o3d/samples/manipulators/translate2.html | 22 | ||||
-rw-r--r-- | o3d/samples/o3djs/manipulators.js | 318 |
4 files changed, 215 insertions, 169 deletions
diff --git a/o3d/samples/manipulators/rotate1.html b/o3d/samples/manipulators/rotate1.html index 0b418db..7f4f27d 100644 --- a/o3d/samples/manipulators/rotate1.html +++ b/o3d/samples/manipulators/rotate1.html @@ -259,31 +259,13 @@ function createManipulators() { // from the scene's transforms. var manipulatorRoot = pack.createObject('Transform'); - // Create the render graph for the manipulators view that uses the same - // DrawContext as the main view. - var manipulatorViewInfo = o3djs.rendergraph.createView( + g_manager = o3djs.manipulators.createManager( pack, manipulatorRoot, g_client.renderGraphRoot, - undefined, // clearColor - undefined, // priority - undefined, // viewport - undefined, // performanceDrawList - undefined, // zOrderedDrawList + g_mainViewInfo.root.priority + 1, g_mainViewInfo.drawContext); - // Make sure the manipulators gets drawn after the scene. - manipulatorViewInfo.root.priority = g_mainViewInfo.root.priority + 1; - - // Turn off clearing the color for the manipulators. - manipulatorViewInfo.clearBuffer.clearColorFlag = false; - - g_manager = o3djs.manipulators.createManager( - pack, - manipulatorViewInfo.performanceDrawList, - manipulatorRoot, - null, - 0); var jj = 2; for (var ii = 0; ii < g_primitives.length; ii++) { var manip1 = g_manager.createRotate1(); diff --git a/o3d/samples/manipulators/translate1.html b/o3d/samples/manipulators/translate1.html index c8eb98e..06c7193 100644 --- a/o3d/samples/manipulators/translate1.html +++ b/o3d/samples/manipulators/translate1.html @@ -259,31 +259,13 @@ function createManipulators() { // from the scene's transforms. var manipulatorRoot = pack.createObject('Transform'); - // Create the render graph for the manipulators view that uses the same - // DrawContext as the main view. - var manipulatorViewInfo = o3djs.rendergraph.createView( + g_manager = o3djs.manipulators.createManager( pack, manipulatorRoot, g_client.renderGraphRoot, - undefined, // clearColor - undefined, // priority - undefined, // viewport - undefined, // performanceDrawList - undefined, // zOrderedDrawList + g_mainViewInfo.root.priority + 1, g_mainViewInfo.drawContext); - // Make sure the manipulators gets drawn after the scene. - manipulatorViewInfo.root.priority = g_mainViewInfo.root.priority + 1; - - // Turn off clearing the color for the manipulators. - manipulatorViewInfo.clearBuffer.clearColorFlag = false; - - g_manager = o3djs.manipulators.createManager( - pack, - manipulatorViewInfo.performanceDrawList, - manipulatorRoot, - null, - 0); var jj = 2; for (var ii = 0; ii < g_primitives.length; ii++) { var manip = g_manager.createTranslate1(); diff --git a/o3d/samples/manipulators/translate2.html b/o3d/samples/manipulators/translate2.html index 3946d74..a284f89 100644 --- a/o3d/samples/manipulators/translate2.html +++ b/o3d/samples/manipulators/translate2.html @@ -259,31 +259,13 @@ function createManipulators() { // from the scene's transforms. var manipulatorRoot = pack.createObject('Transform'); - // Create the render graph for the manipulators view that uses the same - // DrawContext as the main view. - var manipulatorViewInfo = o3djs.rendergraph.createView( + g_manager = o3djs.manipulators.createManager( pack, manipulatorRoot, g_client.renderGraphRoot, - undefined, // clearColor - undefined, // priority - undefined, // viewport - undefined, // performanceDrawList - undefined, // zOrderedDrawList + g_mainViewInfo.root.priority + 1, g_mainViewInfo.drawContext); - // Make sure the manipulators gets drawn after the scene. - manipulatorViewInfo.root.priority = g_mainViewInfo.root.priority + 1; - - // Turn off clearing the color for the manipulators. - manipulatorViewInfo.clearBuffer.clearColorFlag = false; - - g_manager = o3djs.manipulators.createManager( - pack, - manipulatorViewInfo.performanceDrawList, - manipulatorRoot, - null, - 0); var jj = 2; for (var ii = 0; ii < g_primitives.length; ii++) { var manip = g_manager.createTranslate2(); diff --git a/o3d/samples/o3djs/manipulators.js b/o3d/samples/o3djs/manipulators.js index 76db16c..f1ac3ae 100644 --- a/o3d/samples/o3djs/manipulators.js +++ b/o3d/samples/o3djs/manipulators.js @@ -38,15 +38,10 @@ o3djs.provide('o3djs.manipulators'); o3djs.require('o3djs.lineprimitives'); - o3djs.require('o3djs.material'); - o3djs.require('o3djs.math'); - o3djs.require('o3djs.picking'); - o3djs.require('o3djs.primitives'); - o3djs.require('o3djs.quaternions'); /** @@ -65,28 +60,28 @@ o3djs.manipulators = o3djs.manipulators || {}; * is passed in. * @param {!o3d.Pack} pack Pack in which manipulators' geometry and * materials will be created. - * @param {!o3d.DrawList} drawList The draw list against which - * internal materials are created. * @param {!o3d.Transform} parentTransform The parent transform under * which the manipulators' geometry should be parented. * @param {!o3d.RenderNode} parentRenderNode The parent render node * under which the manipulators' draw elements should be placed. * @param {number} renderNodePriority The priority that the * manipulators' geometry should use for rendering. + * @param {!o3d.DrawContext} drawContext The DrawContext to use for the + * manipulators. * @return {!o3djs.manipulators.Manager} The created manipulator * manager. */ o3djs.manipulators.createManager = function(pack, - drawList, parentTransform, parentRenderNode, - renderNodePriority) { + renderNodePriority, + drawContext) { return new o3djs.manipulators.Manager(pack, - drawList, parentTransform, parentRenderNode, - renderNodePriority); -} + renderNodePriority, + drawContext); +}; // // Some linear algebra classes. @@ -119,7 +114,7 @@ o3djs.manipulators.Line_ = function(opt_direction, */ this.point_ = o3djs.math.copyVector(opt_point || [0, 0, 0]); this.recalc_(); -} +}; /** * Sets the direction of this line. @@ -131,7 +126,7 @@ o3djs.manipulators.Line_ = function(opt_direction, o3djs.manipulators.Line_.prototype.setDirection = function(direction) { this.direction_ = o3djs.math.copyVector(direction); this.recalc_(); -} +}; /** * Gets the direction of this line. @@ -140,7 +135,7 @@ o3djs.manipulators.Line_.prototype.setDirection = function(direction) { */ o3djs.manipulators.Line_.prototype.getDirection = function() { return this.direction_; -} +}; /** * Sets one point through which this line travels. @@ -151,7 +146,7 @@ o3djs.manipulators.Line_.prototype.getDirection = function() { o3djs.manipulators.Line_.prototype.setPoint = function(point) { this.point_ = o3djs.math.copyVector(point); this.recalc_(); -} +}; /** * Gets one point through which this line travels. @@ -161,7 +156,7 @@ o3djs.manipulators.Line_.prototype.setPoint = function(point) { */ o3djs.manipulators.Line_.prototype.getPoint = function() { return this.point_; -} +}; /** * Projects a point onto the line. @@ -175,7 +170,7 @@ o3djs.manipulators.Line_.prototype.projectPoint = function(point) { return o3djs.math.addVector(this.alongVec_, o3djs.math.mulScalarVector(dotp, this.direction_)); -} +}; /** * A threshold / error tolerance for determining if a number should be @@ -196,7 +191,6 @@ o3djs.manipulators.X_AXIS = [1, 0, 0]; */ o3djs.manipulators.Z_AXIS = [0, 0, 1]; - /** * Returns the closest point on this line to the given ray, which is * specified by start and end points. If the ray is parallel to the @@ -271,7 +265,7 @@ o3djs.manipulators.Line_.prototype.closestPointToRay = function(startPoint, x[0], this.direction_)); } -} +}; /** * Performs internal recalculations when the parameters of the line change. @@ -294,7 +288,7 @@ o3djs.manipulators.Line_.prototype.recalc_ = function() { o3djs.math.dot(this.point_, this.direction_), this.direction_)); -} +}; /** * A vector with 4 entries, the R,G,B, and A components of the default color @@ -310,7 +304,6 @@ o3djs.manipulators.DEFAULT_COLOR = [0.8, 0.8, 0.8, 1.0]; */ o3djs.manipulators.HIGHLIGHTED_COLOR = [0.9, 0.9, 0.0, 1.0]; - /** * Creates a new Plane object. * @constructor @@ -330,7 +323,7 @@ o3djs.manipulators.Plane_ = function(opt_normal, */ this.point_ = o3djs.math.copyVector(opt_point || [0, 0, 0]); this.setNormal(opt_normal || [0, 1, 0]); -} +}; /** * Sets the normal of this plane. @@ -353,7 +346,7 @@ o3djs.manipulators.Plane_.prototype.setNormal = function(normal) { */ this.normal_ = o3djs.math.normalize(normal); // Makes copy. this.recalc_(); -} +}; /** * Gets the normal of this plane, as a unit vector. @@ -362,7 +355,7 @@ o3djs.manipulators.Plane_.prototype.setNormal = function(normal) { */ o3djs.manipulators.Plane_.prototype.getNormal = function() { return this.normal_; -} +}; /** * Sets one point through which this plane passes. @@ -372,7 +365,7 @@ o3djs.manipulators.Plane_.prototype.getNormal = function() { o3djs.manipulators.Plane_.prototype.setPoint = function(point) { this.point_ = o3djs.math.copyVector(point); this.recalc_(); -} +}; /** * Gets one point through which this plane passes. @@ -381,7 +374,7 @@ o3djs.manipulators.Plane_.prototype.setPoint = function(point) { */ o3djs.manipulators.Plane_.prototype.getPoint = function() { return this.point_; -} +}; /** * Projects a point onto the plane. @@ -396,7 +389,7 @@ o3djs.manipulators.Plane_.prototype.projectPoint = function(point) { return o3djs.math.subVector(point, o3djs.math.mulScalarVector(distFromPlane, this.normal_)); -} +}; /** * Intersects a ray with the plane. Returns the point of intersection. @@ -420,7 +413,7 @@ o3djs.manipulators.Plane_.prototype.intersectRay = function(rayStart, var t = distFromPlane / denom; return o3djs.math.addVector(rayStart, o3djs.math.mulScalarVector(t, rayDirection)); -} +}; /** * Performs internal recalculations when the parameters of the plane change. @@ -434,9 +427,7 @@ o3djs.manipulators.Plane_.prototype.recalc_ = function() { * @type {!number} */ this.normalDotPoint_ = o3djs.math.dot(this.normal_, this.point_); -} - - +}; /** * Constructs a new manipulator manager. Do not call this directly; @@ -444,30 +435,80 @@ o3djs.manipulators.Plane_.prototype.recalc_ = function() { * @constructor * @param {!o3d.Pack} pack Pack in which manipulators' geometry and * materials will be created. - * @param {!o3d.DrawList} drawList The draw list against which - * internal materials are created. * @param {!o3d.Transform} parentTransform The parent transform under * which the manipulators' geometry should be parented. * @param {!o3d.RenderNode} parentRenderNode The parent render node * under which the manipulators' draw elements should be placed. * @param {number} renderNodePriority The priority that the * manipulators' geometry should use for rendering. + * @param {!o3d.DrawContext} drawContext The DrawContext to use for the + * manipulators. */ o3djs.manipulators.Manager = function(pack, - drawList, parentTransform, parentRenderNode, - renderNodePriority) { + renderNodePriority, + drawContext) { /** * Pack in which manipulators' geometry and materials are created. * @type {!o3d.Pack} */ this.pack = pack; /** - * The draw list against which internal materials are created. + * The ViewInfo used to render the manipulators. + * @type {!o3djs.rendergraph.ViewInfo} + */ + this.viewInfo = o3djs.rendergraph.createView( + pack, + parentTransform, + parentRenderNode, + undefined, // clearColor + renderNodePriority, // priority + undefined, // viewport + undefined, // performanceDrawList + undefined, // zOrderedDrawList + drawContext); + + // Turn off clearing the color for the manipulators. + this.viewInfo.clearBuffer.active = false; + + // Set the ZComparisonFunction to the opposite of normal so we only + // draw when we should be obscured for the obscured DrawList. + var state = this.viewInfo.zOrderedState; + state.getStateParam('ZComparisonFunction').value = + o3djs.base.o3d.State.CMP_GREATER; + + // Swap the priorities of the DrawPasses so they get drawn in the + // opposite order + var temp = this.viewInfo.performanceDrawPassInfo.root.priority; + this.viewInfo.performanceDrawPassInfo.root.priority = + this.viewInfo.zOrderedDrawPassInfo.root.priority + this.viewInfo.zOrderedDrawPassInfo.root.priority = temp; + + // The following two DrawLists are used to render manipulators. We give each + // manipulator 2 DrawElements so they get drawn twice. Once they are + // drawn with the reverse of the normal zBuffer test so that only the parts + // of the manipulator that would be obscured by zbuffering are drawn. Then we + // draw them again with normal zBuffering test so that the parts that are not + // obscured get drawn as normal. This allows the obscured parts + // of the manipulators to be rendered with a different material. + + /** + * The DrawList we use to render manipulators that are unobscured by the main + * scene. + * @private + * @type {!o3d.DrawList} + */ + this.unobscuredDrawList_ = this.viewInfo.performanceDrawList; + + /** + * The DrawList we use to render manipulators that are obscured by the main + * scene. + * @private * @type {!o3d.DrawList} */ - this.drawList = drawList; + this.obscuredDrawList_ = this.viewInfo.zOrderedDrawList; + /** * The parent transform under which the manipulators' geometry * shall be parented. @@ -500,12 +541,29 @@ o3djs.manipulators.Manager = function(pack, * use this constant shader for Translate1+2 line geometry, if we add it. * Rotate1 line geometry uses a different, special shader. * + * @private * @type {!o3d.Material} */ - this.constantMaterial = + this.constantMaterial_ = this.createConstantMaterial_(o3djs.manipulators.DEFAULT_COLOR); /** + * The material used to draw the obscured part of some + * manipulators.. + * + * @private + * @type {!o3d.Material} + * + * TODO(gman): Use a different material that doesn't use the same param + * names as the constant material OR put them on separate transforms. + */ + this.obscuredConstantMaterial_ = o3djs.material.createBasicMaterial( + pack, + this.viewInfo, + [1, 0, 0, 0.3], // TODO(gman): Pick an appropriate color. + true); + + /** * A map from the manip's parent Transform clientId to the manip. * @type {!Array.<!o3djs.manipulators.Manip>} */ @@ -529,20 +587,63 @@ o3djs.manipulators.Manager = function(pack, * @type {o3djs.manipulators.Manip} */ this.draggedManip_ = null; -} +}; /** * Creates a constant-shaded material based on the given single color. * @private * @param {!o3djs.math.Vector4} baseColor A vector with 4 entries, the * R,G,B, and A components of a color. - * @return {!o3d.Material} A constant material whose overall pigment is baseColor. + * @return {!o3d.Material} A constant material whose overall pigment is + * baseColor. */ o3djs.manipulators.Manager.prototype.createConstantMaterial_ = function(baseColor) { return o3djs.material.createConstantMaterialEx( - this.pack, this.drawList, baseColor); -} + this.pack, this.unobscuredDrawList_, baseColor); +}; + +/** + * Gets the constant material used for manipulators. + * @return {!o3d.Material} A material. + */ +o3djs.manipulators.Manager.prototype.getConstantMaterial = function() { + return this.constantMaterial_; +}; + +/** + * Gets the constant material used for manipulators. + * @return {!o3d.Material} A material. + */ +o3djs.manipulators.Manager.prototype.getObscuredConstantMaterial = function() { + return this.obscuredConstantMaterial_; +}; + +/** + * Gets the material used for the line ring manipulators. + * @return {!o3d.Material} A material. + */ +o3djs.manipulators.Manager.prototype.getLineRingMaterial = function() { + if (!this.lineRingMaterial_) { + this.lineRingMaterial_ = o3djs.manipulators.createLineRingMaterial( + this.pack, this.unobscuredDrawList_, + [1, 1, 1, 1], [1, 1, 1, 0.4]); + } + return this.lineRingMaterial_; +}; + +/** + * Gets the material used for the line ring manipulators. + * @return {!o3d.Material} A material. + */ +o3djs.manipulators.Manager.prototype.getObscuredLineRingMaterial = function() { + if (!this.obscuredLineRingMaterial_) { + this.obscuredLineRingMaterial_ = o3djs.manipulators.createLineRingMaterial( + this.pack, this.obscuredDrawList_, + [1, 0, 0, 1], [1, 1, 1, 0.4]); // TODO(gman): Pick a color. + } + return this.obscuredLineRingMaterial_; +}; // TODO(simonrad): Add phong shader back in. We need it for the solid cones // of the Translate1+2 manipulators. Note that for highlighting, the phong @@ -559,7 +660,7 @@ o3djs.manipulators.Manager.prototype.createTranslate1 = function() { var manip = new o3djs.manipulators.Translate1(this); this.add_(manip); return manip; -} +}; /** * Creates a new Translate2 manipulator. A Translate2 moves around the @@ -570,7 +671,7 @@ o3djs.manipulators.Manager.prototype.createTranslate2 = function() { var manip = new o3djs.manipulators.Translate2(this); this.add_(manip); return manip; -} +}; /** * Creates a new Rotate1 manipulator. A Rotate1 rotates about the @@ -581,7 +682,7 @@ o3djs.manipulators.Manager.prototype.createRotate1 = function() { var manip = new o3djs.manipulators.Rotate1(this); this.add_(manip); return manip; -} +}; /** * Adds a manipulator to this manager's set. @@ -593,7 +694,7 @@ o3djs.manipulators.Manager.prototype.add_ = function(manip) { manip.getTransform().createDrawElements(this.pack, null); // Add the manipulator into our managed list this.manipsByClientId[manip.getTransform().clientId] = manip; -} +}; /** * Event handler for multiple kinds of mouse events. @@ -642,7 +743,7 @@ o3djs.manipulators.Manager.prototype.handleMouse_ = function(x, } else { func(this, null, null); } -} +}; /** * Callback handling the mouse-down event on a manipulator. @@ -661,7 +762,7 @@ o3djs.manipulators.mouseDownCallback_ = function(manager, manager.draggedManip_ = manip; manip.makeActive(pickResult); } -} +}; /** * Callback handling the mouse-over event on a manipulator. @@ -687,7 +788,7 @@ o3djs.manipulators.hoverCallback_ = function(manager, manip.highlight(pickResult); manager.highlightedManip = manip; } -} +}; /** * Method which should be called by end user code upon receiving a @@ -707,7 +808,7 @@ o3djs.manipulators.Manager.prototype.mousedown = function(x, height) { this.handleMouse_(x, y, view, projection, width, height, o3djs.manipulators.mouseDownCallback_); -} +}; /** * Method which should be called by end user code upon receiving a @@ -736,7 +837,7 @@ o3djs.manipulators.Manager.prototype.mousemove = function(x, this.handleMouse_(x, y, view, projection, width, height, o3djs.manipulators.hoverCallback_); } -} +}; /** * Method which should be called by end user code upon receiving a @@ -747,7 +848,7 @@ o3djs.manipulators.Manager.prototype.mouseup = function() { this.draggedManip_.makeInactive(); this.draggedManip_ = null; } -} +}; /** * Method which should be called by end user code, typically in @@ -763,7 +864,7 @@ o3djs.manipulators.Manager.prototype.updateInactiveManipulators = function() { manip.updateBaseTransformFromAttachedTransform_(); } } -} +}; /** * Base class for all manipulators. @@ -854,7 +955,7 @@ o3djs.manipulators.Manip = function(manager) { * @type {boolean} */ this.active_ = false; -} +}; /** * Adds shapes to the internal transform of this manipulator. @@ -874,7 +975,7 @@ o3djs.manipulators.Manip.prototype.addShapes_ = function(shapes, opt_visible) { this.invisibleTransform_.addShape(shapes[ii]); } } -} +}; /** * Returns the "base" transform of this manipulator, which places the @@ -885,7 +986,7 @@ o3djs.manipulators.Manip.prototype.addShapes_ = function(shapes, opt_visible) { */ o3djs.manipulators.Manip.prototype.getBaseTransform_ = function() { return this.baseTransform_; -} +}; /** * Returns the "offset" transform of this manipulator, which allows @@ -895,7 +996,7 @@ o3djs.manipulators.Manip.prototype.getBaseTransform_ = function() { */ o3djs.manipulators.Manip.prototype.getOffsetTransform = function() { return this.offsetTransform_; -} +}; /** * Returns the local transform of this manipulator, which contains the @@ -907,7 +1008,7 @@ o3djs.manipulators.Manip.prototype.getOffsetTransform = function() { */ o3djs.manipulators.Manip.prototype.getTransform = function() { return this.localTransform_; -} +}; /** * Sets the translation component of the offset transform. This is @@ -921,7 +1022,7 @@ o3djs.manipulators.Manip.prototype.setOffsetTranslation = this.getOffsetTransform().localMatrix = o3djs.math.matrix4.setTranslation(this.getOffsetTransform().localMatrix, translation); -} +}; /** * Sets the rotation component of the offset transform. This is useful @@ -935,7 +1036,7 @@ o3djs.manipulators.Manip.prototype.setOffsetRotation = function(quaternion) { this.getOffsetTransform().localMatrix = o3djs.math.matrix4.setUpper3x3(this.getOffsetTransform().localMatrix, rot); -} +}; /** * Explicitly sets the local translation of this manipulator. @@ -948,7 +1049,7 @@ o3djs.manipulators.Manip.prototype.setTranslation = function(translation) { this.getTransform().localMatrix = o3djs.math.matrix4.setTranslation(this.getTransform().localMatrix, translation); -} +}; /** * Explicitly sets the local rotation of this manipulator. (TODO(kbr): @@ -961,7 +1062,7 @@ o3djs.manipulators.Manip.prototype.setRotation = function(quaternion) { this.getTransform().localMatrix = o3djs.math.matrix4.setUpper3x3(this.getTransform().localMatrix, rot); -} +}; /** * Attaches this manipulator to the given transform. Interactions with @@ -975,7 +1076,7 @@ o3djs.manipulators.Manip.prototype.attachTo = function(transform) { // Update our base transform to place the manipulator at exactly the // location of the attached transform. this.updateBaseTransformFromAttachedTransform_(); -} +}; /** * Highlights this manipulator according to the given pick result. @@ -983,13 +1084,13 @@ o3djs.manipulators.Manip.prototype.attachTo = function(transform) { * caused this manipulator to become highlighted. */ o3djs.manipulators.Manip.prototype.highlight = function(pickResult) { -} +}; /** * Clears any highlight for this manipulator. */ o3djs.manipulators.Manip.prototype.clearHighlight = function() { -} +}; /** * Activates this manipulator according to the given pick result. In @@ -1000,14 +1101,14 @@ o3djs.manipulators.Manip.prototype.clearHighlight = function() { */ o3djs.manipulators.Manip.prototype.makeActive = function(pickResult) { this.active_ = true; -} +}; /** * Deactivates this manipulator. */ o3djs.manipulators.Manip.prototype.makeInactive = function() { this.active_ = false; -} +}; /** * Drags this manipulator according to the world-space ray specified @@ -1034,7 +1135,7 @@ o3djs.manipulators.Manip.prototype.drag = function(startPoint, projection, width, height) { -} +}; /** * Indicates whether this manipulator is active. @@ -1042,7 +1143,7 @@ o3djs.manipulators.Manip.prototype.drag = function(startPoint, */ o3djs.manipulators.Manip.prototype.isActive = function() { return this.active_; -} +}; /** * Updates the base transform of this manipulator from the state of @@ -1061,7 +1162,7 @@ o3djs.manipulators.Manip.prototype.updateBaseTransformFromAttachedTransform_ = // Reset the manipulator's local matrix to the identity. this.localTransform_.localMatrix = o3djs.math.matrix4.identity(); } -} +}; /** * Updates this manipulator's attached transform based on the values @@ -1083,7 +1184,6 @@ o3djs.manipulators.Manip.prototype.updateAttachedTransformFromLocalTransform_ = totalMat = o3djs.math.matrix4.mul(totalMat, offset); totalMat = o3djs.math.matrix4.mul(totalMat, base); - // Set this into the attached transform, taking into account its // parent's transform, if any. // Note that we can not query the parent's transform directly, so @@ -1098,7 +1198,7 @@ o3djs.manipulators.Manip.prototype.updateAttachedTransformFromLocalTransform_ = totalMat = o3djs.math.matrix4.mul(totalMat, attParentMatInv); this.attachedTransform_.localMatrix = totalMat; } -} +}; /** * Sets the material of the given shape's draw elements. @@ -1115,7 +1215,7 @@ o3djs.manipulators.Manip.prototype.setMaterial_ = function(shape, material) { drawElements[jj].material = material; } } -} +}; /** * Sets the materials of the given shapes' draw elements. @@ -1128,8 +1228,7 @@ o3djs.manipulators.Manip.prototype.setMaterials_ = function(shapes, material) { for (var ii = 0; ii < shapes.length; ii++) { this.setMaterial_(shapes[ii], material); } -} - +}; /** * Create the geometry for a double-ended arrow going from @@ -1166,8 +1265,7 @@ o3djs.manipulators.createArrowVertices_ = function(matrix) { matrix4.mul(matrix4.translation([0, -0.85, 0]), matrix))); return verts; -} - +}; /** * A manipulator allowing an object to be dragged along a line. @@ -1181,7 +1279,7 @@ o3djs.manipulators.Translate1 = function(manager) { o3djs.manipulators.Manip.call(this, manager); var pack = manager.pack; - var material = manager.constantMaterial; + var material = manager.getConstantMaterial(); var shape = manager.translate1Shape_; if (!shape) { @@ -1190,6 +1288,9 @@ o3djs.manipulators.Translate1 = function(manager) { var verts = o3djs.manipulators.createArrowVertices_( o3djs.math.matrix4.rotationZ(Math.PI / 2)); shape = verts.createShape(pack, material); + // Add a second DrawElement to this shape to draw it a second time + // with a different material when it's obscured. + shape.createDrawElements(pack, manager.getObscuredConstantMaterial()); manager.translate1Shape_ = shape; } @@ -1210,7 +1311,7 @@ o3djs.manipulators.Translate1 = function(manager) { * @type {!o3djs.manipulators.Line_} */ this.dragLine_ = new o3djs.manipulators.Line_(); -} +}; o3djs.base.inherit(o3djs.manipulators.Translate1, o3djs.manipulators.Manip); @@ -1219,11 +1320,11 @@ o3djs.manipulators.Translate1.prototype.highlight = function(pickResult) { // entire color changes during highlighting. // TODO(kbr): support custom user geometry and associated callbacks. this.colorParam_.value = o3djs.manipulators.HIGHLIGHTED_COLOR; -} +}; o3djs.manipulators.Translate1.prototype.clearHighlight = function() { this.colorParam_.value = o3djs.manipulators.DEFAULT_COLOR; -} +}; o3djs.manipulators.Translate1.prototype.makeActive = function(pickResult) { o3djs.manipulators.Manip.prototype.makeActive.call(this, pickResult); @@ -1233,14 +1334,14 @@ o3djs.manipulators.Translate1.prototype.makeActive = function(pickResult) { o3djs.math.matrix4.transformDirection(localToWorld, o3djs.manipulators.X_AXIS)); this.dragLine_.setPoint(pickResult.worldIntersectionPosition); -} +}; o3djs.manipulators.Translate1.prototype.makeInactive = function() { o3djs.manipulators.Manip.prototype.makeInactive.call(this); this.clearHighlight(); this.updateAttachedTransformFromLocalTransform_(); this.updateBaseTransformFromAttachedTransform_(); -} +}; o3djs.manipulators.Translate1.prototype.drag = function(startPoint, endPoint, @@ -1271,8 +1372,7 @@ o3djs.manipulators.Translate1.prototype.drag = function(startPoint, o3djs.math.matrix4.transformDirection(worldToLocal, diffVector)); this.updateAttachedTransformFromLocalTransform_(); -} - +}; /** * A manipulator allowing an object to be dragged around a plane. @@ -1286,7 +1386,7 @@ o3djs.manipulators.Translate2 = function(manager) { o3djs.manipulators.Manip.call(this, manager); var pack = manager.pack; - var material = manager.constantMaterial; + var material = manager.getConstantMaterial(); var shape = manager.Translate2Shape_; if (!shape) { @@ -1298,6 +1398,9 @@ o3djs.manipulators.Translate2 = function(manager) { verts.append(o3djs.manipulators.createArrowVertices_( o3djs.math.matrix4.rotationZ(0))); shape = verts.createShape(pack, material); + // Add a second DrawElement to this shape to draw it a second time + // with a different material when it's obscured. + shape.createDrawElements(pack, manager.getObscuredConstantMaterial()); manager.Translate2Shape_ = shape; } @@ -1318,7 +1421,7 @@ o3djs.manipulators.Translate2 = function(manager) { * @type {!o3djs.manipulators.Plane_} */ this.dragPlane_ = new o3djs.manipulators.Plane_(); -} +}; o3djs.base.inherit(o3djs.manipulators.Translate2, o3djs.manipulators.Manip); @@ -1327,11 +1430,11 @@ o3djs.manipulators.Translate2.prototype.highlight = function(pickResult) { // entire color changes during highlighting. // TODO(kbr): support custom user geometry and associated callbacks. this.colorParam_.value = o3djs.manipulators.HIGHLIGHTED_COLOR; -} +}; o3djs.manipulators.Translate2.prototype.clearHighlight = function() { this.colorParam_.value = o3djs.manipulators.DEFAULT_COLOR; -} +}; o3djs.manipulators.Translate2.prototype.makeActive = function(pickResult) { o3djs.manipulators.Manip.prototype.makeActive.call(this, pickResult); @@ -1341,14 +1444,14 @@ o3djs.manipulators.Translate2.prototype.makeActive = function(pickResult) { o3djs.math.matrix4.transformDirection(localToWorld, o3djs.manipulators.Z_AXIS)); this.dragPlane_.setPoint(pickResult.worldIntersectionPosition); -} +}; o3djs.manipulators.Translate2.prototype.makeInactive = function() { o3djs.manipulators.Manip.prototype.makeInactive.call(this); this.clearHighlight(); this.updateAttachedTransformFromLocalTransform_(); this.updateBaseTransformFromAttachedTransform_(); -} +}; o3djs.manipulators.Translate2.prototype.drag = function(startPoint, endPoint, @@ -1380,8 +1483,7 @@ o3djs.manipulators.Translate2.prototype.drag = function(startPoint, o3djs.math.matrix4.transformDirection(worldToLocal, diffVector)); this.updateAttachedTransformFromLocalTransform_(); -} - +}; /** * A manipulator allowing an object to be rotated about a single axis. @@ -1396,11 +1498,6 @@ o3djs.manipulators.Rotate1 = function(manager) { var pack = manager.pack; - if (!manager.lineRingMaterial) { - manager.lineRingMaterial = o3djs.manipulators.createLineRingMaterial( - pack, manager.drawList, [1, 1, 1, 1], [1, 1, 1, 0.4]); - } - var pickShape = manager.Rotate1PickShape_; if (!pickShape) { // Create the polygon geometry for picking the manipulator, which looks like @@ -1411,7 +1508,7 @@ o3djs.manipulators.Rotate1 = function(manager) { 16, 6, o3djs.math.matrix4.rotationZ(Math.PI / 2)); - pickShape = verts.createShape(pack, manager.constantMaterial); + pickShape = verts.createShape(pack, manager.getConstantMaterial()); manager.Rotate1PickShape_ = pickShape; } @@ -1423,7 +1520,11 @@ o3djs.manipulators.Rotate1 = function(manager) { 1.0, 32, o3djs.math.matrix4.rotationZ(Math.PI / 2)); - visibleShape = verts.createShape(pack, manager.lineRingMaterial); + visibleShape = verts.createShape(pack, manager.getLineRingMaterial()); + // Add a second DrawElement to this shape to draw it a second time + // with a different material when it's obscured. + visibleShape.createDrawElements( + pack, manager.getObscuredLineRingMaterial()); manager.Rotate1VisibleShape_ = visibleShape; } @@ -1446,7 +1547,7 @@ o3djs.manipulators.Rotate1 = function(manager) { * @type {!o3djs.manipulators.Line_} */ this.dragLine_ = new o3djs.manipulators.Line_(); -} +}; o3djs.base.inherit(o3djs.manipulators.Rotate1, o3djs.manipulators.Manip); @@ -1455,11 +1556,11 @@ o3djs.manipulators.Rotate1.prototype.highlight = function(pickResult) { // entire color changes during highlighting. // TODO(kbr): support custom user geometry and associated callbacks. this.colorParam_.value = o3djs.manipulators.HIGHLIGHTED_COLOR; -} +}; o3djs.manipulators.Rotate1.prototype.clearHighlight = function() { this.colorParam_.value = o3djs.manipulators.DEFAULT_COLOR; -} +}; o3djs.manipulators.Rotate1.prototype.makeActive = function(pickResult) { o3djs.manipulators.Manip.prototype.makeActive.call(this, pickResult); @@ -1483,14 +1584,14 @@ o3djs.manipulators.Rotate1.prototype.makeActive = function(pickResult) { // TODO(simonrad): It would be nice to draw an arrow on the screen // at the click position, indicating the direction of the line. -} +}; o3djs.manipulators.Rotate1.prototype.makeInactive = function() { o3djs.manipulators.Manip.prototype.makeInactive.call(this); this.clearHighlight(); this.updateAttachedTransformFromLocalTransform_(); this.updateBaseTransformFromAttachedTransform_(); -} +}; /** * Convert the specified frustum-space position into @@ -1508,7 +1609,7 @@ o3djs.manipulators.frustumPositionToClientPosition_ = function(frustumPoint, height) { return [(frustumPoint[0] + 1) * width / 2, (-frustumPoint[1] + 1) * height / 2]; -} +}; o3djs.manipulators.Rotate1.prototype.drag = function(startPoint, endPoint, @@ -1548,8 +1649,7 @@ o3djs.manipulators.Rotate1.prototype.drag = function(startPoint, var angle = (dragDistance / Math.max(width, height)) * 2 * Math.PI; this.getTransform().localMatrix = o3djs.math.matrix4.rotationX(-angle); this.updateAttachedTransformFromLocalTransform_(); -} - +}; // The shader and material for the Rotate1 manipulator's line ring. // TODO(simonrad): Find a better place for these? |