dojox
Version:
Dojo eXtensions, a rollup of many useful sub-projects and varying states of maturity – from very stable and robust, to alpha and experimental. See individual projects contain README files for details.
87 lines (74 loc) • 2.01 kB
JavaScript
define(["dojo/_base/lang", "../util/oo", "./_Base", "../manager/_registry"],
function(lang, oo, Base, registry){
var Rect = oo.declare(
Base,
function(options){
// summary:
// constructor
if(this.points.length){
//this.render();
}
},
{
// summary:
// Creates a dojox.gfx rectangle based on data or points provided.
type:"dojox.drawing.stencil.Rect",
anchorType: "group",
baseRender:true,
dataToPoints: function(/*Object*/d){
// summary:
// Converts data to points.
d = d || this.data;
this.points = [
{x:d.x, y:d.y}, // TL
{x:d.x + d.width, y:d.y}, // TR
{x:d.x + d.width, y:d.y + d.height}, // BR
{x:d.x, y:d.y + d.height} // BL
];
return this.points;
},
pointsToData: function(/*Array*/p){
// summary:
// Converts points to data
p = p || this.points;
var s = p[0];
var e = p[2];
this.data = {
x: s.x,
y: s.y,
width: e.x-s.x,
height: e.y-s.y,
r:this.data.r || 0
};
return this.data;
},
_create: function(/*String*/shp, /*StencilData*/d, /*Object*/sty){
// summary:
// Creates a dojox.gfx.shape based on passed arguments.
// Can be called many times by implementation to create
// multiple shapes in one stencil.
//console.log("render rect", d)
//console.log("rect sty:", sty)
this.remove(this[shp]);
this[shp] = this.container.createRect(d)
.setStroke(sty)
.setFill(sty.fill);
this._setNodeAtts(this[shp]);
},
render: function(){
// summary:
// Renders the 'hit' object (the shape used for an expanded
// hit area and for highlighting) and the'shape' (the actual
// display object).
this.onBeforeRender(this);
this.renderHit && this._create("hit", this.data, this.style.currentHit);
this._create("shape", this.data, this.style.current);
}
}
);
lang.setObject("dojox.drawing.stencil.Rect", Rect);
registry.register({
name:"dojox.drawing.stencil.Rect"
}, "stencil");
return Rect;
});