dojo.provide("dojox.sketch.SingleArrowAnnotation"); dojo.require("dojox.sketch.Annotation"); dojo.require("dojox.sketch.Anchor"); (function(){ var ta=dojox.sketch; ta.SingleArrowAnnotation=function(figure, id){ ta.Annotation.call(this, figure, id); this.transform={ dx:0, dy:0 }; this.start={x:0, y:0}; this.control={x:100, y:-50}; this.end={x:200, y:0}; this.textPosition={ x:0, y:0 }; this.textOffset=4; this.textAlign="middle"; this.textYOffset=10; this.rotation=0; // this.property('label',this.id); // this.label=this.id; this.pathShape=null; this.arrowhead=null; this.arrowheadGroup=null; this.labelShape=null; this.anchors.start=new ta.Anchor(this, "start"); this.anchors.control=new ta.Anchor(this, "control"); this.anchors.end=new ta.Anchor(this, "end"); }; ta.SingleArrowAnnotation.prototype=new ta.Annotation; var p=ta.SingleArrowAnnotation.prototype; p.constructor=ta.SingleArrowAnnotation; p.type=function(){ return 'SingleArrow'; }; p.getType=function(){ return ta.SingleArrowAnnotation; }; // helper functions p._rot=function(){ // arrowhead rotation var opp=this.control.y-this.start.y; var adj=this.control.x-this.start.x; //if(!adj){ adj=1; } this.rotation=Math.atan2(opp,adj); }; p._pos=function(){ // text position var offset=this.textOffset, x=0, y=0; var slope=this.calculate.slope(this.control, this.end); if(Math.abs(slope)>=1){ x=this.end.x+this.calculate.dx(this.control, this.end, offset); if(this.control.y>this.end.y){ y=this.end.y-offset; } else{ y=this.end.y+offset+this.textYOffset; } } else if(slope==0){ x=this.end.x+offset; y=this.end.y+this.textYOffset; } else { if(this.start.x>this.end.x){ x=this.end.x-offset; this.textAlign="end"; } else { x=this.end.x+offset; this.textAlign="start"; } if(this.start.y1?20:Math.floor(20/pct), w=pct>1?5:Math.floor(5/pct),h=pct>1?3:Math.floor(3/pct); this.arrowhead.setShape("M0,0 l"+l+",-"+w+" -"+h+","+w+" "+h+","+w+" Z"); } } }; p.getBBox=function(){ var x=Math.min(this.start.x, this.control.x, this.end.x); var y=Math.min(this.start.y, this.control.y, this.end.y); var w=Math.max(this.start.x, this.control.x, this.end.x)-x; var h=Math.max(this.start.y, this.control.y, this.end.y)-y; return { x:x, y:y, width:w, height:h }; }; p.serialize=function(){ var s=this.property('stroke'); var r=this.rotation*(180/Math.PI); r=Math.round(r*Math.pow(10,4))/Math.pow(10,4); return '' + '' + '' + '' + '' + '' + this.property('label') + '' + ''; }; ta.Annotation.register("SingleArrow"); })();