AnalogArrowIndicator.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. define("dojox/gauges/AnalogArrowIndicator", ["dojo/_base/declare","./AnalogIndicatorBase"],
  2. function(declare, AnalogIndicatorBase) {
  3. /*=====
  4. AnalogIndicatorBase = dojox.gauges.AnalogIndicatorBase;
  5. =====*/
  6. return declare("dojox.gauges.AnalogArrowIndicator", [AnalogIndicatorBase],{
  7. // summary:
  8. // An indicator for the AnalogGauge that draws an arrow. The arrow is drawn on the angle that corresponds
  9. // to the value of the indicator.
  10. _getShapes: function(group){
  11. // summary:
  12. // Override of dojox.gauges.AnalogLineIndicator._getShapes
  13. if(!this._gauge){
  14. return null;
  15. }
  16. var color = this.color ? this.color : 'black';
  17. var strokeColor = this.strokeColor ? this.strokeColor : color;
  18. var stroke = { color: strokeColor, width: 1};
  19. if (this.color.type && !this.strokeColor){
  20. stroke.color = this.color.colors[0].color;
  21. }
  22. var x = Math.floor(this.width/2);
  23. var head = this.width * 5;
  24. var odd = (this.width & 1);
  25. var shapes = [];
  26. var points = [{x:-x, y:0},
  27. {x:-x, y:-this.length+head},
  28. {x:-2*x, y:-this.length+head},
  29. {x:0, y:-this.length},
  30. {x:2*x+odd,y:-this.length+head},
  31. {x:x+odd, y:-this.length+head},
  32. {x:x+odd, y:0},
  33. {x:-x, y:0}];
  34. shapes[0] = group.createPolyline(points)
  35. .setStroke(stroke)
  36. .setFill(color);
  37. shapes[1] = group.createLine({ x1:-x, y1: 0, x2: -x, y2:-this.length+head })
  38. .setStroke({color: this.highlight});
  39. shapes[2] = group.createLine({ x1:-x-3, y1: -this.length+head, x2: 0, y2:-this.length })
  40. .setStroke({color: this.highlight});
  41. shapes[3] = group.createCircle({cx: 0, cy: 0, r: this.width})
  42. .setStroke(stroke)
  43. .setFill(color);
  44. return shapes;
  45. }
  46. });
  47. });