-
Notifications
You must be signed in to change notification settings - Fork 11
/
CircularValueIndicator.js
66 lines (60 loc) · 2.04 KB
/
CircularValueIndicator.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
define(["dojo/_base/declare", "dojox/gfx", "./ScaleIndicatorBase", "dojo/_base/event"], function(declare, gfx, ScaleIndicatorBase, eventUtil){
return declare("dojox.dgauges.CircularValueIndicator", ScaleIndicatorBase, {
// summary:
// The circular value indicator, typically used for creating needles.
indicatorShapeFunc: function(group, indicator){
// summary:
// Draws the indicator. The rotation center is at (0, 0).
// group: dojox/gfx/Group
// A GFX group for drawing.
// indicator: dojox/dgauges/IndicatorBase
// A reference to this indicator.
// returns: dojox/gfx/shape.Shape
// A GFX shape retrievable using the getIndicatorRenderer method of the associated scale.
return group.createLine({
x1: 0,
y1: 0,
x2: 40,
y2: 0
}).setStroke({
color: "black",
width: 1
});
},
refreshRendering: function(){
this.inherited(arguments);
if(this._gfxGroup === null || this.scale === null){
return;
}else{
var v = isNaN(this._transitionValue) ? this.value : this._transitionValue;
var angle = this.scale.positionForValue(v);
this._gfxGroup.setTransform([{
dx: this.scale.originX,
dy: this.scale.originY
}, gfx.matrix.rotateg(angle)]);
}
},
_onMouseDown: function(event){
// summary:
// Internal method.
// tags:
// private
this.inherited(arguments);
var origin = this.scale._gauge._gaugeToPage(this.scale.originX, this.scale.originY);
var angle = ((Math.atan2(event.pageY - origin.y, event.pageX - origin.x)) * 180) / (Math.PI);
this.set("value", this.scale.valueForPosition(angle));
// prevent the browser from selecting text
eventUtil.stop(event);
},
_onMouseMove: function(event){
// summary:
// Internal method.
// tags:
// private
this.inherited(arguments);
var origin = this.scale._gauge._gaugeToPage(this.scale.originX, this.scale.originY);
var angle = ((Math.atan2(event.pageY - origin.y, event.pageX - origin.x)) * 180) / (Math.PI);
this.set("value", this.scale.valueForPosition(angle));
}
});
});