sub*_*754 1 javascript canvas html5-canvas fabricjs
我正在使用 Fabricjs 并尝试限制图像外部矩形的移动/调整大小。
这是我到目前为止所拥有的小提琴:小提琴
代码:
var canvas = new fabric.Canvas('c');
canvas.add(new fabric.Circle({ radius: 30, fill: '#f55', top: 100, left: 100 }));
canvas.setBackgroundImage('http://www.beatnyama.com/wp-content/uploads/2015/05/assets.jpg', canvas.renderAll.bind(canvas));
this.__canvases.push(canvas);
canvas.observe("object:moving", function(e){
var obj = e.target;
//code goes here to restrict moving/resizing outside image
});
Run Code Online (Sandbox Code Playgroud)
我怎样才能实现这个?
请参阅更新的小提琴或在此处运行代码片段。 http://jsfiddle.net/h2zvj3un/2/
基本上你不应该使用背景,因为你需要知道图像尺寸。使用普通图像更容易(可读性方面,您可以获得与backgroundImage对象相同的效果),而不是事件化的,不可选择的。并设置到画布的背面。
在图像加载时保存其边界坐标。
在物体移动时计算物体边界框并检查它是否不会接触图像框。如果触及它,则使用最新的已知良好值恢复图像的顶部和左侧值。
var canvas = new fabric.Canvas('canvas');
var minX, minY, maxX, maxY;
canvas.add(new fabric.Circle({ radius: 30, fill: '#f55', top: 100, left: 100 }));
fabric.Image.fromURL('http://www.beatnyama.com/wp-content/uploads/2015/05/assets.jpg', function(img){
img.evented=false;
img.selectable=false;
canvas.add(img);
minX = img.oCoords.tl.x;
maxX = img.oCoords.br.x;
minY = img.oCoords.tl.y;
maxY = img.oCoords.br.y;
canvas.sendToBack(img);
});
function checkmove(e) {
var obj = e.target;
obj.setCoords();
var b = obj.getBoundingRect();
if (!(b.left >= minX && maxX >= b.left + b.width)) {
obj.left = obj.lastLeft;
obj.scaleX= obj.lastScaleX
obj.scaleY= obj.lastScaleY
} else {
obj.lastLeft = obj.left;
obj.lastScaleX = obj.scaleX
}
if (!(maxY >= b.top + b.height && b.top >= minY)) {
obj.top = obj.lastTop;
obj.scaleX= obj.lastScaleX
obj.scaleY= obj.lastScaleY
} else {
obj.lastTop = obj.top;
obj.lastScaleY = obj.scaleY
}
}
function checkscale(e) {
var obj = e.target;
obj.setCoords();
var b = obj.getBoundingRect();
if (!(b.left >= minX && maxX >= b.left + b.width && maxY >= b.top + b.height && b.top >= minY)) {
obj.left = obj.lastLeft;
obj.top = obj.lastTop;
obj.scaleX= obj.lastScaleX
obj.scaleY= obj.lastScaleY
} else {
obj.lastLeft = obj.left;
obj.lastTop = obj.top;
obj.lastScaleX = obj.scaleX
obj.lastScaleY = obj.scaleY
}
}
canvas.observe("object:moving", checkmove);
canvas.observe("object:scaling", checkscale);Run Code Online (Sandbox Code Playgroud)
<script src="http://fabricjs.com/lib/fabric.js"></script>
<canvas id='canvas' width="550" height="550" style="border:#000 1px solid;"></canvas>Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2721 次 |
| 最近记录: |