我试图使用子类化,如http://fabricjs.com/polaroid中的示例所示。Fabric.js:分组子类化对象时缺少src属性
的PolaroidPhoto子类只是增加了在图像上边框上以下小提琴如图所示:https://jsfiddle.net/gusy54rr/6/
canvas = this.__canvas = new fabric.Canvas('c', {
backgroundColor: '#333',
HOVER_CURSOR: 'pointer'
});
var PolaroidPhoto = fabric.util.createClass(fabric.Image, {
H_PADDING: 20,
V_PADDING: 20,
originX: 'center',
originY: 'center',
initialize: function(src, options) {
this.callSuper('initialize', options);
this.image = new Image();
this.image.src = src;
console.log("In initialize, src is:" + src);
this.image.onload = (function() {
this.width = this.image.width;
this.height = this.image.height;
this.loaded = true;
this.setCoords();
this.fire('image:loaded');
}).bind(this);
},
_render: function(ctx) {
if (this.loaded) {
ctx.fillStyle = '#fff';
ctx.fillRect(
-(this.width/2) - this.H_PADDING,
-(this.height/2) - this.H_PADDING,
this.width + this.H_PADDING * 2,
this.height + this.V_PADDING * 2);
ctx.drawImage(this.image, -this.width/2, -this.height/2);
}
}
});
var photo = new PolaroidPhoto('https://i.stack.imgur.com/cqmQ9.png', { });
photo.on('image:loaded', canvas.renderAll.bind(canvas));
photo.set('scaleX', 1);
photo.set('scaleY', 1);
photo.set('top', 180);
photo.set('left', 150);
console.log("photo,src is :" + photo.get('src'));
// forcing src value (but ineffective)
photo.set('src', 'https://i.stack.imgur.com/cqmQ9.png');
canvas.add(photo);
canvas.add(
rect= new fabric.Rect({ top: 50, left: 100, width: 50, height: 50, fill: '#f55' }),
circle = new fabric.Circle({ top: 140, left: 230, radius: 75, fill: 'green' }),
triangle = new fabric.Triangle({ top: 300, left: 210, width: 100, height: 100, fill: 'blue' })
);
$("#group").on('click', function() {
var activegroup = canvas.getActiveGroup();
var objectsInGroup = activegroup.getObjects();
activegroup.clone(function(newgroup) {
canvas.discardActiveGroup();
objectsInGroup.forEach(function(object) {
canvas.remove(object);
});
canvas.add(newgroup);
});
});
$("#ungroup").click(function(){
var activeObject = canvas.getActiveObject();
if(activeObject.type=="group"){
var items = activeObject._objects;
alert(items);
activeObject._restoreObjectsState();
canvas.remove(activeObject);
for(var i = 0; i < items.length; i++) {
canvas.add(items[i]);
items[i].dirty = true;
canvas.item(canvas.size()-1).hasControls = true;
}
canvas.renderAll();
}
});
,直到我想字符串化或使与子类的对象分组一些它工作正常。
在小提琴中,我通过添加几个基础对象(矩形,圆形和三角形)完成了Fabric演示的示例。 如果我选择subclassed图像和任何其他物体,然后单击组按钮: 图像消失。
未设置照片的scr属性(如前一组的“取消组合”警报所示)。
画布的字符串化还显示缺少“src”。
即使我使用“photo.set('src',...)”强制(见小提琴)src值: - 分组仍然使图片消失。 - 字符串化仍然缺少“src”属性。 (我试图扩展到对象无济于事)
如何获得分组和字符串化以处理子类对象? 感谢您的帮助。
检查[这](https://jsfiddle.net/durga598/gusy54rr/7/),该版本'2.0.0 beta7' – Durga
非常感谢杜尔加。事实上,你可以很好地转换到2.0.0-beta7版本。 但是,loadFromJSON仍然没有成功。 无论如何,我仍然必须找到一种方法,使分组和loadFromJSON与织物1.7一起工作 – mikkaye