/** * @class Ext.draw.sprite.EllipticalArc * @extends Ext.draw.sprite.Ellipse * * A sprite that represents an elliptical arc. * * @example preview miniphone * var component = new Ext.draw.Component({ * items: [{ * type: 'ellipticalArc', * cx: 100, * cy: 100, * rx: 40, * ry: 25, * fillStyle: 'blue', * startAngle: 0, * endAngle: Math.PI, * anticlockwise: true * }] * }); * Ext.Viewport.setLayout('fit'); * Ext.Viewport.add(component); */ Ext.define("Ext.draw.sprite.EllipticalArc", { extend: "Ext.draw.sprite.Ellipse", alias: 'sprite.ellipticalArc', type: 'ellipticalArc', inheritableStatics: { def: { processors: { /** * @cfg {Number} [startAngle=0] The beginning angle of the arc. */ startAngle: "number", /** * @cfg {Number} [endAngle=Math.PI*2] The ending angle of the arc. */ endAngle: "number", /** * @cfg {Boolean} [anticlockwise=false] Determines whether or not the arc is drawn clockwise. */ anticlockwise: "bool" }, aliases: { from: "startAngle", to: "endAngle", start: "startAngle", end: "endAngle" }, defaults: { startAngle: 0, endAngle: Math.PI * 2, anticlockwise: false }, dirtyTriggers: { startAngle: 'path', endAngle: 'path', anticlockwise: 'path' } } }, updatePath: function (path, attr) { path.ellipse(attr.cx, attr.cy, attr.rx, attr.ry, attr.axisRotation, attr.startAngle, attr.endAngle, attr.anticlockwise); } });