53 lines
1.7 KiB
JavaScript
53 lines
1.7 KiB
JavaScript
//>>built
|
|
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;
|
|
}
|
|
});
|
|
}); |