110 lines
3.1 KiB
JavaScript
110 lines
3.1 KiB
JavaScript
//>>built
|
|
define("dojox/charting/action2d/Shake", ["dojo/_base/connect", "dojo/_base/declare", "./PlotAction",
|
|
"dojo/fx", "dojo/fx/easing", "dojox/gfx/matrix", "dojox/gfx/fx"],
|
|
function(hub, declare, PlotAction, df, dfe, m, gf){
|
|
|
|
/*=====
|
|
dojo.declare("dojox.charting.action2d.__ShakeCtorArgs", dojox.charting.action2d.__PlotActionCtorArgstorArgs, {
|
|
// summary:
|
|
// Additional arguments for highlighting actions.
|
|
|
|
// shift: Number?
|
|
// The amount in pixels to shift the pie slice. Default is 3.
|
|
shift: 3
|
|
});
|
|
var PlotAction = dojox.charting.action2d.PlotAction;
|
|
=====*/
|
|
|
|
var DEFAULT_SHIFT = 3;
|
|
|
|
return declare("dojox.charting.action2d.Shake", PlotAction, {
|
|
// summary:
|
|
// Create a shaking action for use on an element in a chart.
|
|
|
|
// the data description block for the widget parser
|
|
defaultParams: {
|
|
duration: 400, // duration of the action in ms
|
|
easing: dfe.backOut, // easing for the action
|
|
shiftX: DEFAULT_SHIFT, // shift of the element along the X axis
|
|
shiftY: DEFAULT_SHIFT // shift of the element along the Y axis
|
|
},
|
|
optionalParams: {}, // no optional parameters
|
|
|
|
constructor: function(chart, plot, kwArgs){
|
|
// summary:
|
|
// Create the shaking action and connect it to the plot.
|
|
// chart: dojox.charting.Chart
|
|
// The chart this action belongs to.
|
|
// plot: String?
|
|
// The plot this action is attached to. If not passed, "default" is assumed.
|
|
// kwArgs: dojox.charting.action2d.__ShakeCtorArgs?
|
|
// Optional keyword arguments object for setting parameters.
|
|
if(!kwArgs){ kwArgs = {}; }
|
|
this.shiftX = typeof kwArgs.shiftX == "number" ? kwArgs.shiftX : DEFAULT_SHIFT;
|
|
this.shiftY = typeof kwArgs.shiftY == "number" ? kwArgs.shiftY : DEFAULT_SHIFT;
|
|
|
|
this.connect();
|
|
},
|
|
|
|
process: function(o){
|
|
// summary:
|
|
// Process the action on the given object.
|
|
// o: dojox.gfx.Shape
|
|
// The object on which to process the slice moving action.
|
|
if(!o.shape || !(o.type in this.overOutEvents)){ return; }
|
|
|
|
var runName = o.run.name, index = o.index, vector = [], anim,
|
|
shiftX = o.type == "onmouseover" ? this.shiftX : -this.shiftX,
|
|
shiftY = o.type == "onmouseover" ? this.shiftY : -this.shiftY;
|
|
|
|
if(runName in this.anim){
|
|
anim = this.anim[runName][index];
|
|
}else{
|
|
this.anim[runName] = {};
|
|
}
|
|
|
|
if(anim){
|
|
anim.action.stop(true);
|
|
}else{
|
|
this.anim[runName][index] = anim = {};
|
|
}
|
|
|
|
var kwArgs = {
|
|
shape: o.shape,
|
|
duration: this.duration,
|
|
easing: this.easing,
|
|
transform: [
|
|
{name: "translate", start: [this.shiftX, this.shiftY], end: [0, 0]},
|
|
m.identity
|
|
]
|
|
};
|
|
if(o.shape){
|
|
vector.push(gf.animateTransform(kwArgs));
|
|
}
|
|
if(o.oultine){
|
|
kwArgs.shape = o.outline;
|
|
vector.push(gf.animateTransform(kwArgs));
|
|
}
|
|
if(o.shadow){
|
|
kwArgs.shape = o.shadow;
|
|
vector.push(gf.animateTransform(kwArgs));
|
|
}
|
|
|
|
if(!vector.length){
|
|
delete this.anim[runName][index];
|
|
return;
|
|
}
|
|
|
|
anim.action = df.combine(vector);
|
|
if(o.type == "onmouseout"){
|
|
hub.connect(anim.action, "onEnd", this, function(){
|
|
if(this.anim[runName]){
|
|
delete this.anim[runName][index];
|
|
}
|
|
});
|
|
}
|
|
anim.action.play();
|
|
}
|
|
});
|
|
});
|