我想在我的程序中使用相同var rectangle
繪製矩形和正方形。我修改了繪製平方的函數,給定modeOptions = { "Rectangle", "Square" }
需要在下面添加什麼,以便爲矩形和方形工作。請建議。由於在Javascript中使用相同功能繪製矩形和正方形
也可以看到了這個問題:http://jsfiddle.net/farey/qP3kV/6/
var rectangle=(function() {
var inDrag=false,downPos,upPos;
var obj;
// temporary length for square
var temp;
return {
fillStyle: "none",
strokeStyle: "blue",
lineWidth: 5,
construct: function(pos,parent) {
obj=Object.create(parent);
obj.minx=obj.maxx=pos.x;
obj.miny=obj.maxy=pos.y;
if (fillColor!="inherit")
obj.fillStyle=fillColor;
if (strokeColor!="inherit")
obj.strokeStyle=strokeColor;
if (strokeThickness!="inherit")
obj.lineWidth=strokeThickness;
},
draw: function(selected) {
ctx.beginPath();
ctx.fillStyle=this.fillStyle;
ctx.strokeStyle=(selected) ?
"gray" : this.strokeStyle;
ctx.lineWidth=this.lineWidth;
// making 3rd & fourth argument same for square. greater of maxx and maxy should be there
if (this.maxx - this.minx > this.maxy - this.miny)
{ temp = this.maxx - this.minx
}
else
temp = this.maxy - this.miny
ctx.rect(this.minx,this.miny,temp,temp);
// else
// ctx.rect(this.minx,this.miny,this.maxx - this.minx,this.maxy - this.miny)
ctx.fill();
if (selected) {
ctx.moveTo(this.minx,this.miny);
ctx.lineTo(this.maxx,this.maxy);
ctx.moveTo(this.minx,this.maxy);
ctx.lineTo(this.maxx,this.miny);
}
ctx.stroke();
},
mousedown: function(event) {
downPos=event;
rectangle.construct(downPos,drawObject[containingBox4point(downPos)]);
inDrag=true;
},
mousemove: function(event) {
if (!inDrag)
{
drawPrevious();
drawCursor(event,containingBox4point(event));
return;
}
upPos=event;
if (upPos.x>downPos.x) {
obj.minx=downPos.x;
obj.maxx=upPos.x;
}
else {
obj.minx=upPos.x;
obj.maxx=downPos.x;
}
if (upPos.y>downPos.y) {
obj.miny=downPos.y;
obj.maxy=upPos.y;
}
else {
obj.miny=upPos.y;
obj.maxy=downPos.y;
}
drawPrevious();
obj.draw(containingBox(obj)==(-1));
drawCursor(event,containingBox4point(upPos));
},
mouseup: function(event) {
// commit rectangle
rectangle.mousemove(event);
if (!inDrag)
return;
if (containingBox(obj)==(-1))
trace("U and ur box are evil . . .");
else
{
drawObject.push(obj);
trace("Rectangle props for new box "+String(drawObject.length-1)+
": filled with "+ fillColor+
" stroked with "+strokeColor+
" @ thickness "+ strokeThickness);
}
inDrag=false;
drawPrevious();
},
mouseout: function(event) {
inDrag=false;
drawPrevious();
}
};
})(); // rectangle
試試jsfiddle.net,簡化你的question.post只有你的代碼有問題的相關路徑。這會讓你更多的迴應。 –
好的。我也發佈了它。謝謝。 – user2559199
然後發佈鏈接在您的問題... –