aboutsummaryrefslogtreecommitdiff
path: root/js/tools/Translate3DToolBase.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/tools/Translate3DToolBase.js')
-rwxr-xr-xjs/tools/Translate3DToolBase.js255
1 files changed, 165 insertions, 90 deletions
diff --git a/js/tools/Translate3DToolBase.js b/js/tools/Translate3DToolBase.js
index e4f1fb99..41dbb3ae 100755
--- a/js/tools/Translate3DToolBase.js
+++ b/js/tools/Translate3DToolBase.js
@@ -71,9 +71,9 @@ exports.Translate3DToolBase = Montage.create(ModifierToolBase,
71 this._delta = delta.slice(0); 71 this._delta = delta.slice(0);
72 } 72 }
73 73
74 //console.log( "modifyElements delta: " + delta );
74 var transMat = Matrix.Translation( delta ); 75 var transMat = Matrix.Translation( delta );
75 76
76 //console.log( "Translate: " + delta );
77 if(this._inLocalMode && (this._targets.length === 1) ) 77 if(this._inLocalMode && (this._targets.length === 1) )
78 { 78 {
79 this._translateLocally(transMat); 79 this._translateLocally(transMat);
@@ -149,26 +149,28 @@ exports.Translate3DToolBase = Montage.create(ModifierToolBase,
149 149
150 _translateGlobally: { 150 _translateGlobally: {
151 value: function (transMat) { 151 value: function (transMat) {
152 //console.log( "_translateGlobally, startMat: " + this._startMat + ", transMat: " + transMat ); 152 //console.log( "_translateGlobally, transMat: " + transMat );
153 //console.log( "_translateGlobally, transMat: " + transMat ); 153 //console.log( "_translateGlobally, startMat: " + this._startMat + ", transMat: " + transMat[12] + ", " + transMat[13] + ", " + transMat[14] );
154 var len = this._targets.length, 154 var len = this._targets.length,
155 i = 0, 155 i = 0,
156 item, 156 item,
157 elt, 157 elt,
158 curMat = viewUtils.getMatrixFromElement( this._target ), 158 curMat = viewUtils.getMatrixFromElement( this._target ),
159 matInv = glmat4.inverse(this._startMat, []), 159 matInv = glmat4.inverse(this._startMat, []),
160 nMat = glmat4.multiply(transMat, this._startMat, [] ), 160 nMat = glmat4.multiply(transMat, this._startMat, [] ),
161 qMat = glmat4.multiply(matInv, nMat, []); 161 qMat = glmat4.multiply(matInv, nMat, []);
162 162
163 if (this._mode === 1) 163 if (this._mode === 1)
164 { 164 {
165 var curInv = glmat4.inverse( curMat, [] ); 165 if (len > 1) curMat = this._targets[0].mat.slice();
166 transMat = glmat4.multiply( nMat, curInv, [] ); 166 var curInv = glmat4.inverse( curMat, [] );
167 } 167 transMat = glmat4.multiply( nMat, curInv, [] );
168 }
168 169
169 var shouldUpdateStartMat = true; 170 var shouldUpdateStartMat = true;
170 171
171 if(this._clickedOnStage) 172 //if (this._clickedOnStage)
173 if(this._clickedOnStage || ((this._handleMode === 2) && (this._targets.length > 1)))
172 { 174 {
173 shouldUpdateStartMat = false; 175 shouldUpdateStartMat = false;
174 } 176 }
@@ -186,26 +188,25 @@ exports.Translate3DToolBase = Montage.create(ModifierToolBase,
186// glmat4.multiply(curMat, qMat, curMat); 188// glmat4.multiply(curMat, qMat, curMat);
187// 189//
188// viewUtils.setMatrixForElement( elt, curMat, true); 190// viewUtils.setMatrixForElement( elt, curMat, true);
189 curMat[12] += transMat[12]; 191 curMat[12] += transMat[12];
190 curMat[13] += transMat[13]; 192 curMat[13] += transMat[13];
191 curMat[14] += transMat[14]; 193 curMat[14] += transMat[14];
192 viewUtils.setMatrixForElement( elt, curMat, true); 194 viewUtils.setMatrixForElement( elt, curMat, true);
193 195
194 if(shouldUpdateStartMat) 196 if(shouldUpdateStartMat)
195 { 197 {
196 //console.log( "\t\tshouldUpdateStartMat" ); 198 //console.log( "\t\tshouldUpdateStartMat" );
197 this._targets[i].mat = curMat; 199 this._targets[i].mat = curMat;
198 } 200 }
199 } 201 }
200 } 202 }
201 }, 203 },
202 204
203 _updateTargets: { 205 _updateTargets: {
204 value: function(addToUndoStack) { 206 value: function(addToUndoStack) {
205// console.log( "_updateTargets" ); 207 var newStyles = [],
206 var newStyles = [], 208 previousStyles = [],
207 previousStyles = [], 209 len = this.application.ninja.selectedElements.length;
208 len = this.application.ninja.selectedElements.length;
209 this._targets = []; 210 this._targets = [];
210 for(var i = 0; i < len; i++) 211 for(var i = 0; i < len; i++)
211 { 212 {
@@ -215,47 +216,47 @@ exports.Translate3DToolBase = Montage.create(ModifierToolBase,
215 var curMatInv = glmat4.inverse(curMat, []); 216 var curMatInv = glmat4.inverse(curMat, []);
216 217
217 this._targets.push({elt:elt, mat:curMat, matInv:curMatInv}); 218 this._targets.push({elt:elt, mat:curMat, matInv:curMatInv});
218 if(addToUndoStack) 219 if(addToUndoStack)
219 { 220 {
220 var previousStyleStr = {dist:this._undoArray[i].dist, mat:MathUtils.scientificToDecimal(this._undoArray[i].mat.slice(0), 5)}; 221 var previousStyleStr = {dist:this._undoArray[i].dist, mat:MathUtils.scientificToDecimal(this._undoArray[i].mat.slice(0), 5)};
221 222
222 var newStyleStr = {dist:viewUtils.getPerspectiveDistFromElement(elt), mat:MathUtils.scientificToDecimal(curMat, 5)}; 223 var newStyleStr = {dist:viewUtils.getPerspectiveDistFromElement(elt), mat:MathUtils.scientificToDecimal(curMat, 5)};
223 224
224 previousStyles.push(previousStyleStr); 225 previousStyles.push(previousStyleStr);
225 newStyles.push(newStyleStr); 226 newStyles.push(newStyleStr);
226 } 227 }
227 } 228 }
228 if(addToUndoStack) 229 if(addToUndoStack)
229 { 230 {
230 ElementsMediator.set3DProperties(this.application.ninja.selectedElements, 231 ElementsMediator.set3DProperties(this.application.ninja.selectedElements,
231 newStyles, 232 newStyles,
232 "Change", 233 "Change",
233 "translateTool", 234 "translateTool",
234 previousStyles 235 previousStyles
235 ); 236 );
236 if(this._origin && this._delta) 237 if(this._origin && this._delta)
237 { 238 {
238 if(this._handleMode !== null) 239 if(this._handleMode !== null)
239 { 240 {
240 this._origin[this._handleMode] += this._delta; 241 this._origin[this._handleMode] += this._delta;
241 } 242 }
242 else 243 else
243 { 244 {
244 this._origin[0] += this._delta[0]; 245 this._origin[0] += this._delta[0];
245 this._origin[1] += this._delta[1]; 246 this._origin[1] += this._delta[1];
246 } 247 }
247 } 248 }
248 this._delta = null; 249 this._delta = null;
249 } 250 }
250 // Save previous value for undo/redo 251 // Save previous value for undo/redo
251 this._undoArray = []; 252 this._undoArray = [];
252 for(i = 0, len = this._targets.length; i < len; i++) 253 for(i = 0, len = this._targets.length; i < len; i++)
253 { 254 {
254 var elt = this._targets[i].elt; 255 var elt = this._targets[i].elt;
255 var _mat = viewUtils.getMatrixFromElement(elt); 256 var _mat = viewUtils.getMatrixFromElement(elt);
256 var _dist = viewUtils.getPerspectiveDistFromElement(elt); 257 var _dist = viewUtils.getPerspectiveDistFromElement(elt);
257 this._undoArray.push({mat:_mat, dist:_dist}); 258 this._undoArray.push({mat:_mat, dist:_dist});
258 } 259 }
259 260
260 } 261 }
261 }, 262 },
@@ -295,42 +296,113 @@ exports.Translate3DToolBase = Montage.create(ModifierToolBase,
295 viewUtils.popViewportObj(); 296 viewUtils.popViewportObj();
296 ctr[2] = 0; 297 ctr[2] = 0;
297 298
298// var ctrOffset = item.elementModel.props3D.m_transformCtr;
299// if(ctrOffset)
300// {
301// ctr = vecUtils.vecAdd(3, ctr, ctrOffset);
302// }
303
304 this._origin = viewUtils.localToGlobal(ctr, item); 299 this._origin = viewUtils.localToGlobal(ctr, item);
305 } 300 }
306 else 301 else
307 { 302 {
308 if(this._origin) 303 this._origin = undefined;
309 { 304 this._origin = this.calculateMultiSelOrigin();
310 if(this._delta) 305 }
311 { 306 }
312 if(this._handleMode !== null) 307 }
313 { 308 },
314// this._origin[this._handleMode] = this._delta; 309
315 } 310 captureSelectionDrawn: {
316 else 311 value: function(event){
317 { 312 this._origin = null;
318 this._origin[0] += this._delta[0]; 313 this._targets = [];
319 this._origin[1] += this._delta[1]; 314 this._startOriginArray = null;
320 } 315
321 } 316 var len = this.application.ninja.selectedElements.length;
322 } 317 if(len)
323 else 318 {
319 if(len === 1)
320 {
321 this.target = this.application.ninja.selectedElements[0];