diff options
Diffstat (limited to 'js/tools/OvalTool.js')
-rwxr-xr-x | js/tools/OvalTool.js | 53 |
1 files changed, 31 insertions, 22 deletions
diff --git a/js/tools/OvalTool.js b/js/tools/OvalTool.js index 94e4745e..73e39196 100755 --- a/js/tools/OvalTool.js +++ b/js/tools/OvalTool.js | |||
@@ -1,24 +1,25 @@ | |||
1 | /* <copyright> | 1 | /* <copyright> |
2 | Copyright (c) 2012, Motorola Mobility, Inc | 2 | Copyright (c) 2012, Motorola Mobility LLC. |
3 | All Rights Reserved. | 3 | All Rights Reserved. |
4 | BSD License. | ||
5 | 4 | ||
6 | Redistribution and use in source and binary forms, with or without | 5 | Redistribution and use in source and binary forms, with or without |
7 | modification, are permitted provided that the following conditions are met: | 6 | modification, are permitted provided that the following conditions are met: |
8 | 7 | ||
9 | - Redistributions of source code must retain the above copyright notice, | 8 | * Redistributions of source code must retain the above copyright notice, |
10 | this list of conditions and the following disclaimer. | 9 | this list of conditions and the following disclaimer. |
11 | - Redistributions in binary form must reproduce the above copyright | 10 | |
12 | notice, this list of conditions and the following disclaimer in the | 11 | * Redistributions in binary form must reproduce the above copyright notice, |
13 | documentation and/or other materials provided with the distribution. | 12 | this list of conditions and the following disclaimer in the documentation |
14 | - Neither the name of Motorola Mobility nor the names of its contributors | 13 | and/or other materials provided with the distribution. |
15 | may be used to endorse or promote products derived from this software | 14 | |
16 | without specific prior written permission. | 15 | * Neither the name of Motorola Mobility LLC nor the names of its |
16 | contributors may be used to endorse or promote products derived from this | ||
17 | software without specific prior written permission. | ||
17 | 18 | ||
18 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | 19 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
19 | AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 20 | AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
20 | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 21 | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
21 | ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE | 22 | ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
22 | LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | 23 | LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
23 | CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | 24 | CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
24 | SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | 25 | SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
@@ -28,31 +29,31 @@ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |||
28 | POSSIBILITY OF SUCH DAMAGE. | 29 | POSSIBILITY OF SUCH DAMAGE. |
29 | </copyright> */ | 30 | </copyright> */ |
30 | 31 | ||
31 | var Montage = require("montage/core/core").Montage, | 32 | var Montage = require("montage/core/core").Montage, |
32 | ShapeTool = require("js/tools/ShapeTool").ShapeTool, | 33 | ShapeTool = require("js/tools/ShapeTool").ShapeTool, |
33 | ShapesController = require("js/controllers/elements/shapes-controller").ShapesController; | 34 | ShapesController = require("js/controllers/elements/shapes-controller").ShapesController; |
34 | 35 | ||
35 | var Circle = require("js/lib/geom/circle").Circle; | 36 | var Circle = require("js/lib/geom/circle").Circle; |
36 | var MaterialsModel = require("js/models/materials-model").MaterialsModel; | 37 | var MaterialsModel = require("js/models/materials-model").MaterialsModel; |
37 | 38 | ||
38 | exports.OvalTool = Montage.create(ShapeTool, { | 39 | exports.OvalTool = Montage.create(ShapeTool, { |
39 | 40 | ||
40 | _toolID: { value: "ovalTool" }, | 41 | _toolID: { value: "ovalTool" }, |
41 | _imageID: { value: "ovalToolImg" }, | 42 | _imageID: { value: "ovalToolImg" }, |
42 | _toolImageClass: { value: "ovalToolUp" }, | 43 | _toolImageClass: { value: "ovalToolUp" }, |
43 | _selectedToolImageClass: { value: "ovalToolDown" }, | 44 | _selectedToolImageClass: { value: "ovalToolDown" }, |
44 | _toolTipText: { value: "Oval Tool (O)" }, | 45 | _toolTipText: { value: "Oval Tool (O)" }, |
45 | _selectedToolClass:{value:"ovalToolSpecificProperties"}, | 46 | _selectedToolClass:{value:"ovalToolSpecificProperties"}, |
46 | _ovalView : { value: null, writable: true}, | 47 | _ovalView : { value: null, writable: true}, |
47 | 48 | ||
48 | RenderShape: { | 49 | RenderShape: { |
49 | value: function (w, h, planeMat, midPt, canvas) | 50 | value: function (w, h, planeMat, midPt, canvas) |
50 | { | 51 | { |
51 | if( (Math.floor(w) === 0) || (Math.floor(h) === 0) ) | 52 | if( (Math.floor(w) === 0) || (Math.floor(h) === 0) ) |
52 | { | 53 | { |
53 | return; | 54 | return; |
54 | } | 55 | } |
55 | 56 | ||
56 | var left = Math.round(midPt[0] - 0.5*w); | 57 | var left = Math.round(midPt[0] - 0.5*w); |
57 | var top = Math.round(midPt[1] - 0.5*h); | 58 | var top = Math.round(midPt[1] - 0.5*h); |
58 | 59 | ||
@@ -78,14 +79,22 @@ exports.OvalTool = Montage.create(ShapeTool, { | |||
78 | { | 79 | { |
79 | strokeMaterial = Object.create(MaterialsModel.getMaterial(strokeM)); | 80 | strokeMaterial = Object.create(MaterialsModel.getMaterial(strokeM)); |
80 | } | 81 | } |
81 | strokeColor = ShapesController.getMaterialColor(strokeM) || strokeColor; | 82 | if (strokeMaterial && this.options.stroke.color && (strokeMaterial.gradientType === this.options.stroke.color.gradientMode)) { |
83 | strokeColor = {gradientMode:strokeMaterial.gradientType, color:this.options.stroke.color.stops}; | ||
84 | } else { | ||
85 | strokeColor = ShapesController.getMaterialColor(strokeM) || strokeColor; | ||
86 | } | ||
82 | 87 | ||
83 | fillM = this.options.fillMaterial; | 88 | fillM = this.options.fillMaterial; |
84 | if(fillM) | 89 | if(fillM) |
85 | { | 90 | { |
86 | fillMaterial = Object.create(MaterialsModel.getMaterial(fillM)); | 91 | fillMaterial = Object.create(MaterialsModel.getMaterial(fillM)); |
87 | } | 92 | } |
88 | fillColor = ShapesController.getMaterialColor(fillM) || fillColor; | 93 | if (fillMaterial && this.options.fill.color && (fillMaterial.gradientType === this.options.fill.color.gradientMode)) { |
94 | fillColor = {gradientMode:fillMaterial.gradientType, color:this.options.fill.color.stops}; | ||
95 | } else { | ||
96 | fillColor = ShapesController.getMaterialColor(fillM) || fillColor; | ||
97 | } | ||
89 | } | 98 | } |
90 | 99 | ||
91 | var world = this.getGLWorld(canvas, this.options.use3D); | 100 | var world = this.getGLWorld(canvas, this.options.use3D); |