diff options
Diffstat (limited to 'js/helper-classes/3D/snap-manager.js')
-rwxr-xr-x | js/helper-classes/3D/snap-manager.js | 40 |
1 files changed, 16 insertions, 24 deletions
diff --git a/js/helper-classes/3D/snap-manager.js b/js/helper-classes/3D/snap-manager.js index 97901d50..0f456e1e 100755 --- a/js/helper-classes/3D/snap-manager.js +++ b/js/helper-classes/3D/snap-manager.js | |||
@@ -21,7 +21,6 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
21 | /////////////////////////////////////////////////////////////////////// | 21 | /////////////////////////////////////////////////////////////////////// |
22 | // Instance variables | 22 | // Instance variables |
23 | /////////////////////////////////////////////////////////////////////// | 23 | /////////////////////////////////////////////////////////////////////// |
24 | currentStage: { value: null, writable: true }, | ||
25 | drawingCanvas: { value: null, writable: true}, | 24 | drawingCanvas: { value: null, writable: true}, |
26 | 25 | ||
27 | // we keep a stack of working planes to facilitate working on other planes temporarily | 26 | // we keep a stack of working planes to facilitate working on other planes temporarily |
@@ -84,14 +83,14 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
84 | popWorkingPlane : { value: function () { workingPlane = this._workingPlaneStack.pop(); return workingPlane; }}, | 83 | popWorkingPlane : { value: function () { workingPlane = this._workingPlaneStack.pop(); return workingPlane; }}, |
85 | 84 | ||
86 | getStageWidth : { value: function () { | 85 | getStageWidth : { value: function () { |
87 | return parseInt(this.currentStage.offsetWidth); | 86 | return parseInt(this.application.ninja.currentDocument.documentRoot.offsetWidth); |
88 | }}, | 87 | }}, |
89 | 88 | ||
90 | getStageHeight : { value: function () { | 89 | getStageHeight : { value: function () { |
91 | return parseInt(this.currentStage.offsetHeight); | 90 | return parseInt(this.application.ninja.currentDocument.documentRoot.offsetHeight); |
92 | }}, | 91 | }}, |
93 | 92 | ||
94 | getStage : { value: function() { return this.currentStage; }}, | 93 | getStage : { value: function() { return this.application.ninja.currentDocument.documentRoot; }}, |
95 | 94 | ||
96 | getGridVertexHitRad : { value: function() { return this._gridVertexHitRad; }}, | 95 | getGridVertexHitRad : { value: function() { return this._gridVertexHitRad; }}, |
97 | getGridEdgeHitRad : { value: function() { return this._gridEdgeHitRad; }}, | 96 | getGridEdgeHitRad : { value: function() { return this._gridEdgeHitRad; }}, |
@@ -130,10 +129,10 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
130 | 129 | ||
131 | bindSnap: { | 130 | bindSnap: { |
132 | value: function() { | 131 | value: function() { |
133 | this.addEventListener("change@appModel.snap", this.toggleSnap, false); | 132 | this.addPropertyChangeListener("appModel.snap", this.toggleSnap, false); |
134 | this.addEventListener("change@appModel.snapGrid", this.toggleSnapGrid, false); | 133 | this.addPropertyChangeListener("appModel.snapGrid", this.toggleSnapGrid, false); |
135 | this.addEventListener("change@appModel.snapObjects", this.toggleSnapObjects, false); | 134 | this.addPropertyChangeListener("appModel.snapObjects", this.toggleSnapObjects, false); |
136 | this.addEventListener("change@appModel.snapAlign", this.toggleSnapAlign, false); | 135 | this.addPropertyChangeListener("appModel.snapAlign", this.toggleSnapAlign, false); |
137 | } | 136 | } |
138 | }, | 137 | }, |
139 | 138 | ||
@@ -185,12 +184,6 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
185 | } | 184 | } |
186 | }, | 185 | }, |
187 | 186 | ||
188 | setCurrentStage: { | ||
189 | value: function(stage) { | ||
190 | this.currentStage = stage; | ||
191 | } | ||
192 | }, | ||
193 | |||
194 | snap : { | 187 | snap : { |
195 | value: function (xScreen, yScreen, snap3D, quadPt) | 188 | value: function (xScreen, yScreen, snap3D, quadPt) |
196 | { | 189 | { |
@@ -477,6 +470,13 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
477 | } | 470 | } |
478 | }, | 471 | }, |
479 | 472 | ||
473 | reload2DCache: { | ||
474 | value: function() { | ||
475 | this.clear2DCache(); | ||
476 | this.load2DCache(workingPlane); | ||
477 | } | ||
478 | }, | ||
479 | |||
480 | clear2DCache : { | 480 | clear2DCache : { |
481 | value : function() { | 481 | value : function() { |
482 | // clear the 2D cache flags in the objects | 482 | // clear the 2D cache flags in the objects |
@@ -1631,11 +1631,7 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
1631 | if (x > y) { | 1631 | if (x > y) { |
1632 | if (x > z) { | 1632 | if (x > z) { |
1633 | plane[0] = 1; | 1633 | plane[0] = 1; |
1634 | if(this.application.ninja.currentDocument.documentRoot.id !== "UserContent") { | 1634 | plane[3] = this.getStageWidth() / 2.0; |
1635 | plane[3] = stage.scrollWidth / 2.0; | ||
1636 | } else { | ||
1637 | plane[3] = this.getStageWidth() / 2.0; | ||
1638 | } | ||
1639 | if (dir[0] > 0) plane[3] = -plane[3]; | 1635 | if (dir[0] > 0) plane[3] = -plane[3]; |
1640 | change = !drawUtils.drawYZ; | 1636 | change = !drawUtils.drawYZ; |
1641 | drawUtils.drawXY = drawUtils.drawXZ = false; | 1637 | drawUtils.drawXY = drawUtils.drawXZ = false; |
@@ -1653,11 +1649,7 @@ var SnapManager = exports.SnapManager = Montage.create(Component, { | |||
1653 | else { | 1649 | else { |
1654 | if (y > z) { | 1650 | if (y > z) { |
1655 | plane[1] = 1; | 1651 | plane[1] = 1; |
1656 | if(this.application.ninja.currentDocument.documentRoot.id !== "UserContent") { | 1652 | plane[3] = this.getStageHeight() / 2.0; |
1657 | plane[3] = stage.scrollHeight / 2.0; | ||
1658 | } else { | ||
1659 | plane[3] = this.getStageHeight() / 2.0; | ||
1660 | } | ||
1661 | if (dir[1] > 0) plane[3] = -plane[3]; | 1653 | if (dir[1] > 0) plane[3] = -plane[3]; |
1662 | change = !drawUtils.drawXZ; | 1654 | change = !drawUtils.drawXZ; |
1663 | drawUtils.drawXY = drawUtils.drawYZ = false; | 1655 | drawUtils.drawXY = drawUtils.drawYZ = false; |