aboutsummaryrefslogtreecommitdiff
path: root/js/controllers/elements/shapes-controller.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/controllers/elements/shapes-controller.js')
-rwxr-xr-xjs/controllers/elements/shapes-controller.js67
1 files changed, 65 insertions, 2 deletions
diff --git a/js/controllers/elements/shapes-controller.js b/js/controllers/elements/shapes-controller.js
index f0e9458b..c9164e3e 100755
--- a/js/controllers/elements/shapes-controller.js
+++ b/js/controllers/elements/shapes-controller.js
@@ -72,8 +72,9 @@ exports.ShapesController = Montage.create(CanvasController, {
72 canvas.setAttribute("data-RDGE-id", njModule.NJUtils.generateRandom()); 72 canvas.setAttribute("data-RDGE-id", njModule.NJUtils.generateRandom());
73 canvas.width = el.width; 73 canvas.width = el.width;
74 canvas.height = el.height; 74 canvas.height = el.height;
75 this.application.ninja.elementMediator.replaceElement(el, canvas); 75 canvas.elementModel = el.elementModel;
76 NJevent("elementDeleted", el); 76 this.application.ninja.currentDocument.documentRoot.replaceChild(canvas, el);
77 NJevent("elementsRemoved", el);
77 el = canvas; 78 el = canvas;
78 this.toggleWebGlMode(el, value); 79 this.toggleWebGlMode(el, value);
79 el.elementModel.shapeModel.GLWorld.render(); 80 el.elementModel.shapeModel.GLWorld.render();
@@ -119,6 +120,31 @@ exports.ShapesController = Montage.create(CanvasController, {
119 el.elementModel.shapeModel.GLWorld._canvas.task.stop(); 120 el.elementModel.shapeModel.GLWorld._canvas.task.stop();
120 } 121 }
121 break; 122 break;
123 case "strokeHardness":
124 this.setShapeProperty(el, "strokeHardness", value);
125 el.elementModel.shapeModel.GLGeomObj.setStrokeHardness(val);
126 el.elementModel.shapeModel.GLWorld.render();
127 break;
128 case "strokeSmoothing":
129 this.setShapeProperty(el, "strokeSmoothing", value);
130 el.elementModel.shapeModel.GLGeomObj.setSmoothingAmount(val);
131 el.elementModel.shapeModel.GLWorld.render();
132 break;
133 case "doSmoothing":
134 this.setShapeProperty(el, "doSmoothing", value);
135 el.elementModel.shapeModel.GLGeomObj.setDoSmoothing(value);
136 el.elementModel.shapeModel.GLWorld.render();
137 break;
138 case "isCalligraphic":
139 this.setShapeProperty(el, "isCalligraphic", value);
140 el.elementModel.shapeModel.GLGeomObj.setStrokeUseCalligraphic(value);
141 el.elementModel.shapeModel.GLWorld.render();
142 break;
143 case "strokeAngle":
144 this.setShapeProperty(el, "strokeAngle", value);
145 el.elementModel.shapeModel.GLGeomObj.setStrokeAngle(Math.PI * val/180);
146 el.elementModel.shapeModel.GLWorld.render();
147 break;
122 default: 148 default:
123 CanvasController.setProperty(el, p, value); 149 CanvasController.setProperty(el, p, value);
124 } 150 }
@@ -139,6 +165,43 @@ exports.ShapesController = Montage.create(CanvasController, {
139 case "useWebGl": 165 case "useWebGl":
140 case "animate": 166 case "animate":
141 return this.getShapeProperty(el, p); 167 return this.getShapeProperty(el, p);
168 case "strokeHardness":
169 if (el.elementModel && el.elementModel.shapeModel){
170 return el.elementModel.shapeModel.GLGeomObj.getStrokeHardness();
171 } else {
172 return null;
173 }
174 break;
175 case "doSmoothing":
176 if (el.elementModel && el.elementModel.shapeModel){
177 return el.elementModel.shapeModel.GLGeomObj.getDoSmoothing();
178 } else {
179 return null;
180 }
181 break;
182 case "strokeSmoothing":
183 if (el.elementModel && el.elementModel.shapeModel){
184 return el.elementModel.shapeModel.GLGeomObj.getSmoothingAmount();
185 } else {
186 return null;
187 }
188 break;
189 case "isCalligraphic":
190 if (el.elementModel && el.elementModel.shapeModel){
191 return el.elementModel.shapeModel.GLGeomObj.getStrokeUseCalligraphic();
192 } else {
193 return null;
194 }
195 break;
196 case "strokeAngle":
197 if (el.elementModel && el.elementModel.shapeModel){
198 return 180*el.elementModel.shapeModel.GLGeomObj.getStrokeAngle()/Math.PI;
199 } else {
200 return null;
201 }
202 break;
203
204
142 case "strokeMaterial": 205 case "strokeMaterial":
143 case "fillMaterial": 206 case "fillMaterial":
144 var m = this.getShapeProperty(el, p); 207 var m = this.getShapeProperty(el, p);