diff options
Diffstat (limited to 'js/controllers/elements/shapes-controller.js')
-rwxr-xr-x | js/controllers/elements/shapes-controller.js | 119 |
1 files changed, 82 insertions, 37 deletions
diff --git a/js/controllers/elements/shapes-controller.js b/js/controllers/elements/shapes-controller.js index e62af921..c3099459 100755 --- a/js/controllers/elements/shapes-controller.js +++ b/js/controllers/elements/shapes-controller.js | |||
@@ -138,6 +138,10 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
138 | this.application.ninja.elementMediator.replaceElement(canvas, el); | 138 | this.application.ninja.elementMediator.replaceElement(canvas, el); |
139 | break; | 139 | break; |
140 | case "strokeMaterial": | 140 | case "strokeMaterial": |
141 | // skip shape types that don't support WebGL | ||
142 | if(!el.elementModel.shapeModel.useWebGl) { | ||
143 | return; | ||
144 | } | ||
141 | m = Object.create(MaterialsModel.getMaterial(value)); | 145 | m = Object.create(MaterialsModel.getMaterial(value)); |
142 | if(m) | 146 | if(m) |
143 | { | 147 | { |
@@ -152,6 +156,10 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
152 | } | 156 | } |
153 | break; | 157 | break; |
154 | case "fillMaterial": | 158 | case "fillMaterial": |
159 | // skip shape types that don't support WebGL or fill color | ||
160 | if(!el.elementModel.shapeModel.GLGeomObj.canFill || !el.elementModel.shapeModel.useWebGl) { | ||
161 | return; | ||
162 | } | ||
155 | m = Object.create(MaterialsModel.getMaterial(value)); | 163 | m = Object.create(MaterialsModel.getMaterial(value)); |
156 | if(m) | 164 | if(m) |
157 | { | 165 | { |
@@ -278,7 +286,7 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
278 | } | 286 | } |
279 | else | 287 | else |
280 | { | 288 | { |
281 | return "FlatMaterial"; | 289 | return "Flat"; |
282 | } | 290 | } |
283 | case "fillMaterial": | 291 | case "fillMaterial": |
284 | var fm = el.elementModel.shapeModel.GLGeomObj.getFillMaterial(); | 292 | var fm = el.elementModel.shapeModel.GLGeomObj.getFillMaterial(); |
@@ -288,7 +296,7 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
288 | } | 296 | } |
289 | else | 297 | else |
290 | { | 298 | { |
291 | return "FlatMaterial"; | 299 | return "Flat"; |
292 | } | 300 | } |
293 | default: | 301 | default: |
294 | return CanvasController.getProperty(el, p); | 302 | return CanvasController.getProperty(el, p); |
@@ -430,32 +438,32 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
430 | 438 | ||
431 | if(gradientMode === "radial") | 439 | if(gradientMode === "radial") |
432 | { | 440 | { |
433 | if( !m || (m.getName() !== "RadialGradientMaterial") ) | 441 | if( !m || (m.getName() !== "Radial Gradient") ) |
434 | { | 442 | { |
435 | gradientM = Object.create(MaterialsModel.getMaterial("RadialGradientMaterial")); | 443 | gradientM = Object.create(MaterialsModel.getMaterial("Radial Gradient")); |
436 | } | 444 | } |
437 | } | 445 | } |
438 | else | 446 | else |
439 | { | 447 | { |
440 | if( !m || (m.getName() !== "LinearGradientMaterial") ) | 448 | if( !m || (m.getName() !== "Linear Gradient") ) |
441 | { | 449 | { |
442 | gradientM = Object.create(MaterialsModel.getMaterial("LinearGradientMaterial")); | 450 | gradientM = Object.create(MaterialsModel.getMaterial("Linear Gradient")); |
443 | } | 451 | } |
444 | } | 452 | } |
445 | 453 | ||
446 | if(gradientM) | 454 | if(gradientM) |
447 | { | 455 | { |
448 | if(isFill) | 456 | if(isFill) |
449 | { | 457 | { |
450 | el.elementModel.shapeModel.GLGeomObj.setFillMaterial(gradientM); | 458 | el.elementModel.shapeModel.GLGeomObj.setFillMaterial(gradientM); |
451 | } | 459 | } |
452 | else | 460 | else |
453 | { | 461 | { |
454 | el.elementModel.shapeModel.GLGeomObj.setStrokeMaterial(gradientM); | 462 | el.elementModel.shapeModel.GLGeomObj.setStrokeMaterial(gradientM); |
455 | } | 463 | } |
456 | el.elementModel.shapeModel.GLGeomObj.buildBuffers(); | 464 | el.elementModel.shapeModel.GLGeomObj.buildBuffers(); |
457 | } | 465 | } |
458 | } | 466 | } |
459 | }, | 467 | }, |
460 | 468 | ||
461 | _setFlatMaterial: { | 469 | _setFlatMaterial: { |
@@ -471,11 +479,14 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
471 | m = el.elementModel.shapeModel.GLGeomObj.getStrokeMaterial(); | 479 | m = el.elementModel.shapeModel.GLGeomObj.getStrokeMaterial(); |
472 | } | 480 | } |
473 | 481 | ||
474 | if(!m || ((m.getName() === "LinearGradientMaterial") || m.getName() === "RadialGradientMaterial") ) | 482 | if(!m || ((m.getName() === "Linear Gradient") || m.getName() === "Radial Gradient") ) |
475 | { | 483 | { |
476 | flatM = Object.create(MaterialsModel.getMaterial("FlatMaterial")); | 484 | // Uber Material also supports solid colors, so don't change from Uber to Flat Material |
485 | if(m && (m.getName() === "Uber")) { return; } | ||
486 | |||
487 | flatM = Object.create(MaterialsModel.getMaterial("Flat")); | ||
477 | if(flatM) | 488 | if(flatM) |
478 | { | 489 | { |
479 | if(isFill) | 490 | if(isFill) |
480 | { | 491 | { |
481 | el.elementModel.shapeModel.GLGeomObj.setFillMaterial(flatM); | 492 | el.elementModel.shapeModel.GLGeomObj.setFillMaterial(flatM); |
@@ -484,10 +495,10 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
484 | { | 495 | { |
485 | el.elementModel.shapeModel.GLGeomObj.setStrokeMaterial(flatM); | 496 | el.elementModel.shapeModel.GLGeomObj.setStrokeMaterial(flatM); |
486 | } | 497 | } |
487 | el.elementModel.shapeModel.GLGeomObj.buildBuffers(); | 498 | el.elementModel.shapeModel.GLGeomObj.buildBuffers(); |
488 | } | ||
489 | } | 499 | } |
490 | } | 500 | } |
501 | } | ||
491 | }, | 502 | }, |
492 | 503 | ||
493 | setColor: { | 504 | setColor: { |
@@ -597,14 +608,31 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
597 | 608 | ||
598 | setStroke: { | 609 | setStroke: { |
599 | value: function(el, stroke, eventType, source) { | 610 | value: function(el, stroke, eventType, source) { |
600 | if(stroke.colorInfo) { | ||
601 | this.setColor(el, stroke.colorInfo, false); | ||
602 | } | ||
603 | if(stroke.shapeInfo) { | 611 | if(stroke.shapeInfo) { |
604 | this.setProperty(el, "strokeSize", stroke.shapeInfo.strokeSize + " " + stroke.shapeInfo.strokeUnits, eventType, source); | 612 | this.setProperty(el, "strokeSize", stroke.shapeInfo.strokeSize + " " + stroke.shapeInfo.strokeUnits, eventType, source); |
605 | } | 613 | } |
614 | var m; | ||
606 | if(stroke.webGLInfo) { | 615 | if(stroke.webGLInfo) { |
607 | this.setProperty(el, "strokeMaterial", stroke.webGLInfo.material); | 616 | m = stroke.webGLInfo.material; |
617 | this.setProperty(el, "strokeMaterial", m); | ||
618 | if((m === "Linear Gradient") || (m === "Radial Gradient")) { | ||
619 | // Just use the default gradient material values | ||
620 | return; | ||
621 | } | ||
622 | } | ||
623 | if(stroke.colorInfo) { | ||
624 | if(el.elementModel.shapeModel.useWebGl) { | ||
625 | m = el.elementModel.shapeModel.GLGeomObj.getStrokeMaterial().getName(); | ||
626 | if( ((stroke.colorInfo.mode === "gradient") && (m !== "Linear Gradient") && (m !== "Radial Gradient")) || | ||
627 | ((stroke.colorInfo.mode !== "gradient") && ((m === "Linear Gradient") || (m === "Radial Gradient")))) | ||
628 | { | ||
629 | return; | ||
630 | } else { | ||
631 | this.setColor(el, stroke.colorInfo, false); | ||
632 | } | ||
633 | } else { | ||
634 | this.setColor(el, stroke.colorInfo, false); | ||
635 | } | ||
608 | } | 636 | } |
609 | } | 637 | } |
610 | }, | 638 | }, |
@@ -638,11 +666,28 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
638 | 666 | ||
639 | setFill: { | 667 | setFill: { |
640 | value: function(el, fill) { | 668 | value: function(el, fill) { |
641 | if(fill.colorInfo) { | 669 | var m; |
642 | this.setColor(el, fill.colorInfo, true); | ||
643 | } | ||
644 | if(fill.webGLInfo) { | 670 | if(fill.webGLInfo) { |
645 | this.setProperty(el, "fillMaterial", fill.webGLInfo.material); | 671 | m = fill.webGLInfo.material; |
672 | this.setProperty(el, "fillMaterial", m); | ||
673 | if((m === "Linear Gradient") || (m === "Radial Gradient")) { | ||
674 | // Just use the default gradient material values | ||
675 | return; | ||
676 | } | ||
677 | } | ||
678 | if(fill.colorInfo) { | ||
679 | if(el.elementModel.shapeModel.useWebGl) { | ||
680 | m = el.elementModel.shapeModel.GLGeomObj.getFillMaterial().getName(); | ||
681 | if( ((fill.colorInfo.mode === "gradient") && (m !== "Linear Gradient") && (m !== "Radial Gradient")) || | ||
682 | ((fill.colorInfo.mode !== "gradient") && ((m === "Linear Gradient") || (m === "Radial Gradient")))) | ||
683 | { | ||
684 | return; | ||
685 | } else { | ||
686 | this.setColor(el, fill.colorInfo, true); | ||
687 | } | ||
688 | } else { | ||
689 | this.setColor(el, fill.colorInfo, true); | ||
690 | } | ||
646 | } | 691 | } |
647 | } | 692 | } |
648 | }, | 693 | }, |
@@ -764,18 +809,18 @@ exports.ShapesController = Montage.create(CanvasController, { | |||
764 | // Set Linear/Radial Gradient Material for children geometry if color in canvas 2d has gradient | 809 | // Set Linear/Radial Gradient Material for children geometry if color in canvas 2d has gradient |
765 | if(child.strokeColor.gradientMode === "radial") | 810 | if(child.str |