konva/src/shapes/Ring.ts

90 lines
2.0 KiB
TypeScript
Raw Normal View History

2019-01-06 16:01:20 +08:00
import { Collection } from '../Util';
2019-02-25 01:06:04 +08:00
import { Factory } from '../Factory';
2019-01-02 04:59:27 +08:00
import { Shape } from '../Shape';
import { GetSet } from '../types';
2019-02-25 01:06:04 +08:00
import { getNumberValidator } from '../Validators';
2019-01-02 04:59:27 +08:00
2019-01-06 16:01:20 +08:00
var PIx2 = Math.PI * 2;
2019-01-02 04:59:27 +08:00
/**
* Ring constructor
* @constructor
* @augments Konva.Shape
2019-02-19 01:12:03 +08:00
* @memberof Konva
2019-01-02 04:59:27 +08:00
* @param {Object} config
* @param {Number} config.innerRadius
* @param {Number} config.outerRadius
* @param {Boolean} [config.clockwise]
* @@shapeParams
* @@nodeParams
* @example
* var ring = new Konva.Ring({
* innerRadius: 40,
* outerRadius: 80,
* fill: 'red',
* stroke: 'black',
* strokeWidth: 5
* });
*/
export class Ring extends Shape {
_sceneFunc(context) {
context.beginPath();
context.arc(0, 0, this.innerRadius(), 0, PIx2, false);
context.moveTo(this.outerRadius(), 0);
context.arc(0, 0, this.outerRadius(), PIx2, 0, true);
context.closePath();
context.fillStrokeShape(this);
}
getWidth() {
return this.outerRadius() * 2;
}
getHeight() {
return this.outerRadius() * 2;
}
setWidth(width) {
this.outerRadius(width / 2);
2019-01-02 04:59:27 +08:00
}
setHeight(height) {
this.outerRadius(height / 2);
2019-01-02 04:59:27 +08:00
}
outerRadius: GetSet<number, this>;
innerRadius: GetSet<number, this>;
}
2019-01-06 16:01:20 +08:00
Ring.prototype.className = 'Ring';
Ring.prototype._centroid = true;
Ring.prototype._attrsAffectingSize = ['innerRadius', 'outerRadius'];
2019-01-06 16:01:20 +08:00
2019-01-02 04:59:27 +08:00
/**
* get/set innerRadius
* @method
2019-01-06 16:01:20 +08:00
* @name Konva.Ring#innerRadius
2019-01-02 04:59:27 +08:00
* @param {Number} innerRadius
* @returns {Number}
* @example
* // get inner radius
* var innerRadius = ring.innerRadius();
*
* // set inner radius
* ring.innerRadius(20);
*/
2019-01-06 16:01:20 +08:00
2019-02-25 01:06:04 +08:00
Factory.addGetterSetter(Ring, 'innerRadius', 0, getNumberValidator());
2019-01-02 04:59:27 +08:00
/**
* get/set outerRadius
2019-01-06 16:01:20 +08:00
* @name Konva.Ring#outerRadius
2019-01-02 04:59:27 +08:00
* @method
* @param {Number} outerRadius
* @returns {Number}
* @example
* // get outer radius
* var outerRadius = ring.outerRadius();
*
* // set outer radius
* ring.outerRadius(20);
*/
2019-02-25 01:06:04 +08:00
Factory.addGetterSetter(Ring, 'outerRadius', 0, getNumberValidator());
2019-01-02 04:59:27 +08:00
Collection.mapMethods(Ring);