aboutsummaryrefslogtreecommitdiff
path: root/js/tools
diff options
context:
space:
mode:
Diffstat (limited to 'js/tools')
-rwxr-xr-xjs/tools/Rotate3DToolBase.js161
-rwxr-xr-xjs/tools/RotateObject3DTool.js141
-rwxr-xr-xjs/tools/Translate3DToolBase.js177
-rwxr-xr-xjs/tools/TranslateObject3DTool.js1
-rwxr-xr-xjs/tools/modifier-tool-base.js20
5 files changed, 388 insertions, 112 deletions
diff --git a/js/tools/Rotate3DToolBase.js b/js/tools/Rotate3DToolBase.js
index 696408bf..e65dc842 100755
--- a/js/tools/Rotate3DToolBase.js
+++ b/js/tools/Rotate3DToolBase.js
@@ -14,7 +14,8 @@ var Montage = require("montage/core/core").Montage,
14 viewUtils = require("js/helper-classes/3D/view-utils").ViewUtils, 14 viewUtils = require("js/helper-classes/3D/view-utils").ViewUtils,
15 vecUtils = require("js/helper-classes/3D/vec-utils").VecUtils, 15 vecUtils = require("js/helper-classes/3D/vec-utils").VecUtils,
16 drawUtils = require("js/helper-classes/3D/draw-utils").DrawUtils, 16 drawUtils = require("js/helper-classes/3D/draw-utils").DrawUtils,
17 ElementsMediator = require("js/mediators/element-mediator").ElementMediator; 17 ElementsMediator = require("js/mediators/element-mediator").ElementMediator,
18 Rectangle = require("js/helper-classes/3D/rectangle").Rectangle;
18 19
19exports.Rotate3DToolBase = Montage.create(ModifierToolBase, { 20exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
20 _canSnap: { value: false }, 21 _canSnap: { value: false },
@@ -56,17 +57,31 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
56 // move the transform origin handle 57 // move the transform origin handle
57 var dx = pt1.x - pt0.x; 58 var dx = pt1.x - pt0.x;
58 var dy = pt1.y - pt0.y; 59 var dy = pt1.y - pt0.y;
60 var dz = pt1.z - pt0.z;
61
59 this._origin[0] += dx; 62 this._origin[0] += dx;
60 this._origin[1] += dy; 63 this._origin[1] += dy;
64 this._origin[2] += dz;
65 console.log( "modifyElements, _origin: " + this._origin );
61 66
62 var len = this._targets.length; 67 var len = this._targets.length;
63 if(len === 1) 68 if(len === 1)
64 { 69 {
65 this._startOriginArray[0][0] += dx; 70// this._startOriginArray[0][0] += dx;
66 this._startOriginArray[0][1] += dy; 71// this._startOriginArray[0][1] += dy;
72// this._startOriginArray[0][2] += dz;
73 var g2lMat = this._targets[0].g2l;
74 var localOrigin = MathUtils.transformAndDivideHomogeneousPoint( this._origin, g2lMat );
75 var elt = this._targets[0].elt;
76 viewUtils.pushViewportObj( elt );
77 var viewOrigin = viewUtils.screenToView( localOrigin[0], localOrigin[1], localOrigin[2] );
78 viewUtils.popViewportObj();
79 this._startOriginArray[0] = viewOrigin;
80 //console.log( "Rotate3DToolBase.modifyElements, _startOriginArray[0]: " + this._startOriginArray[0] );
67 } 81 }
68 this.downPoint.x = pt1.x; 82 this.downPoint.x = pt1.x;
69 this.downPoint.y = pt1.y; 83 this.downPoint.y = pt1.y;
84 this.downPoint.z = pt1.z;
70 this.DrawHandles(); 85 this.DrawHandles();
71 return; 86 return;
72 } 87 }
@@ -133,8 +148,10 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
133 } 148 }
134 } 149 }
135 150
151
136 if(this._inLocalMode && (this._targets.length === 1) ) 152 if(this._inLocalMode && (this._targets.length === 1) )
137 { 153 {
154 console.log( "modifyElements: rotateLocally " );
138 this._rotateLocally(mat); 155 this._rotateLocally(mat);
139 } 156 }
140 else 157 else
@@ -159,6 +176,8 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
159 // pre-translate by the transformation center 176 // pre-translate by the transformation center
160 var tMat = Matrix.I(4); 177 var tMat = Matrix.I(4);
161 178
179 // _startOriginArray is the location of the center of rotation
180 // in view space of the element.
162 var transformCtr = this._startOriginArray[i]; 181 var transformCtr = this._startOriginArray[i];
163 182
164 tMat[12] = transformCtr[0]; 183 tMat[12] = transformCtr[0];
@@ -198,6 +217,8 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
198 var transformCtr = this._startOriginArray[i].slice(0); 217 var transformCtr = this._startOriginArray[i].slice(0);
199 transformCtr = MathUtils.transformPoint(transformCtr, curMat); 218 transformCtr = MathUtils.transformPoint(transformCtr, curMat);
200 219
220 console.log( "modifyElements: rotateGlobally, ctr: " + transformCtr );
221
201 tMat[12] = transformCtr[0]; 222 tMat[12] = transformCtr[0];
202 tMat[13] = transformCtr[1]; 223 tMat[13] = transformCtr[1];
203 tMat[14] = transformCtr[2]; 224 tMat[14] = transformCtr[2];
@@ -267,6 +288,7 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
267 288
268 viewUtils.pushViewportObj( this.target ); 289 viewUtils.pushViewportObj( this.target );
269 var eltCtr = viewUtils.getCenterOfProjection(); 290 var eltCtr = viewUtils.getCenterOfProjection();
291 eltCtr[2] = 0;
270 viewUtils.popViewportObj(); 292 viewUtils.popViewportObj();
271 293
272 var ctrOffset = this.target.elementModel.props3D.m_transformCtr; 294 var ctrOffset = this.target.elementModel.props3D.m_transformCtr;
@@ -277,17 +299,19 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
277 } 299 }
278 300
279 this._origin = viewUtils.localToGlobal(eltCtr, this.target); 301 this._origin = viewUtils.localToGlobal(eltCtr, this.target);
302 console.log( "Rotate3DToolBase.captureSelectionDrawn _origin: " + this._origin );
280 this._updateTargets(); 303 this._updateTargets();
281 this._setTransformOrigin(false); 304 this._setTransformOrigin(false);
282 } 305 }
283 else 306 else
284 { 307 {
285 this.target = this.application.ninja.currentDocument.documentRoot; 308 this.target = this.application.ninja.currentDocument.documentRoot;
286 this._origin = drawUtils._selectionCtr.slice(0); 309 //this._origin = drawUtils._selectionCtr.slice(0);
287 this._origin[0] += this.application.ninja.stage.userContentLeft; 310 //this._origin[0] += this.application.ninja.stage.userContentLeft;
288 this._origin[1] += this.application.ninja.stage.userContentTop; 311 //this._origin[1] += this.application.ninja.stage.userContentTop;
289 this._updateTargets(); 312 this._updateTargets();
290 this._setTransformOrigin(true); 313 this._origin = this.calculateMultiSelOrigin();
314 this._setTransformOrigin(true);
291 } 315 }
292 } 316 }
293 else 317 else
@@ -303,8 +327,15 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
303 } 327 }
304 }, 328 },
305 329
330 /*
331 _updateHandlesOrigin: {
332 value: function () { }
333 },
334 */
335
306 _updateTargets: { 336 _updateTargets: {
307 value: function(addToUndoStack) { 337 value: function(addToUndoStack) {
338 console.log( "Rotate3DToolBase._updateTargets" );
308 var newStyles = [], 339 var newStyles = [],
309 previousStyles = [], 340 previousStyles = [],
310 len = this.application.ninja.selectedElements.length; 341 len = this.application.ninja.selectedElements.length;
@@ -322,10 +353,14 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
322 var eltCtr = viewUtils.getCenterOfProjection(); 353 var eltCtr = viewUtils.getCenterOfProjection();
323 viewUtils.popViewportObj(); 354 viewUtils.popViewportObj();
324 355
325 eltCtr = viewUtils.localToGlobal(eltCtr, elt); 356 // cache the local to global and global to local matrices
357 var l2gMat = viewUtils.getLocalToGlobalMatrix( elt );
358 var g2lMat = glmat4.inverse( l2gMat, [] );
359 eltCtr = MathUtils.transformAndDivideHomogeneousPoint( eltCtr, l2gMat );
326 360
327 this._targets.push({elt:elt, mat:curMat, matInv:curMatInv, ctr:eltCtr}); 361 this._targets.push({elt:elt, mat:curMat, matInv:curMatInv, ctr:eltCtr, l2g:l2gMat, g2l:g2lMat});
328 if(addToUndoStack) 362
363 if(addToUndoStack)
329 { 364 {
330 var previousStyleStr = {dist:this._undoArray[i].dist, mat:MathUtils.scientificToDecimal(this._undoArray[i].mat.slice(0), 5)}; 365 var previousStyleStr = {dist:this._undoArray[i].dist, mat:MathUtils.scientificToDecimal(this._undoArray[i].mat.slice(0), 5)};
331 366
@@ -356,12 +391,54 @@ exports.Rotate3DToolBase = Montage.create(ModifierToolBase, {
356 } 391 }
357 }, 392 },
358 393
394 calculateMultiSelOrigin:
395 {
396 value: function()
397 {
398 var minPt, maxPt, i,j;
399 this._startOriginArray = [];
400 var len = this.application.ninja.selectedElements.length;
401 for (i = 0; i < len; i++)
402 {
403 // get the next element and localToGlobal matrix
404 elt = this._targets[i].elt;
405 var l2g = this._targets[i].l2g;
406
407 // get the element bounds in 'plane' space
408 bounds = viewUtils.getElementViewBounds3D( elt );
409 for (j=0; j<4; j++)
410 {
411 var localPt = bounds[j];
412 //var pt = MathUtils.transformAndDivideHomogeneousPoint( localPt, l2g );
413 var pt = viewUtils.localToStageWorld( localPt, elt );
414 if (!minPt)
415 {
416 minPt = pt.slice();
417 maxPt = pt.slice();
418 }
419 else
420 {
421 minPt[0] = Math.min(minPt[0],pt[0]); minPt[1] = Math.min(minPt[1],pt[1]); minPt[2] = Math.min(minPt[2],pt[2]);
422 maxPt[0] = Math.max(maxPt[0],pt[0]); maxPt[1] = Math.max(maxPt[1],pt[1]); maxPt[2] = Math.max(maxPt[2],pt[2]);
423 }
424 }
425 }
426 var stageWorldCtr = [ 0.5*(minPt[0] + maxPt[0]), 0.5*(minPt[1] + maxPt[1]), 0.5*(minPt[2] + maxPt[2]) ];
427 var globalCtr = MathUtils.transformAndDivideHomogeneousPoint( stageWorldCtr, viewUtils.getStageWorldToGlobalMatrix() );
428 console.log( "resetting _origin to: " + this._origin );
429
430 return globalCtr;
431 }
432 },
433
359 _setTransformOrigin: { 434 _setTransformOrigin: {
360 value: function(shouldUpdateCenter) { 435 value: function(shouldUpdateCenter) {
361 if(!this._origin) 436 if(!this._origin)
362 { 437