12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- define("dojox/gauges/AnalogArrowIndicator", ["dojo/_base/declare","./AnalogIndicatorBase"],
- function(declare, AnalogIndicatorBase) {
- /*=====
- AnalogIndicatorBase = dojox.gauges.AnalogIndicatorBase;
- =====*/
- return declare("dojox.gauges.AnalogArrowIndicator", [AnalogIndicatorBase],{
- // summary:
- // An indicator for the AnalogGauge that draws an arrow. The arrow is drawn on the angle that corresponds
- // to the value of the indicator.
-
- _getShapes: function(group){
- // summary:
- // Override of dojox.gauges.AnalogLineIndicator._getShapes
- if(!this._gauge){
- return null;
- }
- var color = this.color ? this.color : 'black';
- var strokeColor = this.strokeColor ? this.strokeColor : color;
- var stroke = { color: strokeColor, width: 1};
- if (this.color.type && !this.strokeColor){
- stroke.color = this.color.colors[0].color;
- }
-
- var x = Math.floor(this.width/2);
- var head = this.width * 5;
- var odd = (this.width & 1);
- var shapes = [];
- var points = [{x:-x, y:0},
- {x:-x, y:-this.length+head},
- {x:-2*x, y:-this.length+head},
- {x:0, y:-this.length},
- {x:2*x+odd,y:-this.length+head},
- {x:x+odd, y:-this.length+head},
- {x:x+odd, y:0},
- {x:-x, y:0}];
- shapes[0] = group.createPolyline(points)
- .setStroke(stroke)
- .setFill(color);
- shapes[1] = group.createLine({ x1:-x, y1: 0, x2: -x, y2:-this.length+head })
- .setStroke({color: this.highlight});
- shapes[2] = group.createLine({ x1:-x-3, y1: -this.length+head, x2: 0, y2:-this.length })
- .setStroke({color: this.highlight});
- shapes[3] = group.createCircle({cx: 0, cy: 0, r: this.width})
- .setStroke(stroke)
- .setFill(color);
- return shapes;
- }
- });
- });
|