Fabricjs loadFromJSON Line 的子类
Posted
技术标签:
【中文标题】Fabricjs loadFromJSON Line 的子类【英文标题】:fabricjs loadFromJSON subclass of Line 【发布时间】:2020-02-25 02:17:37 【问题描述】:我正在使用this post 答案,对我来说效果很好。 当我使用画布制作 json 并尝试使用 loadFromJSON 方法将其设置在另一个画布上时,问题就出现了。 我认为问题在于这个新的子类没有 fromObject 方法,我尝试输入它,但我写不出任何有效的东西。
这就是我定义子类的方式(几乎是从链接复制粘贴)
fabric.LineaBote = fabric.util.createClass(fabric.Line,
type: 'linea_bote',
initialize: function (element, options)
options || (options = );
this.callSuper('initialize', element, options);
// Set default options
this.set(
hasBorders: false,
hasControls: false,
);
,
_render: function (ctx)
this.callSuper('_render', ctx);
ctx.save();
const xDiff = this.x2 - this.x1;
const yDiff = this.y2 - this.y1;
const angle = Math.atan2(yDiff, xDiff);
ctx.translate(xDiff / 2, yDiff / 2);
ctx.rotate(angle);
ctx.beginPath();
ctx.closePath();
ctx.fillStyle = this.stroke;
ctx.fill();
ctx.restore();
var p = this.calcLinePoints();
var point = this.pointOnLine(this.point(p.x2, p.y2), this.point(p.x1, p.y1), 15)
this.wavy(this.point(p.x1, p.y1), point, this.point(p.x2, p.y2), ctx);
ctx.stroke();
,
point: function (x, y)
return
x: x,
y: y
;
,
wavy: function (from, to, endPoint, ctx)
var cx = 0,
cy = 0,
fx = from.x,
fy = from.y,
tx = to.x,
ty = to.y,
i = 0,
step = 2,
waveOffsetLength = 0,
ang = Math.atan2(ty - fy, tx - fx),
distance = Math.sqrt((fx - tx) * (fx - tx) + (fy - ty) * (fy - ty)),
amplitude = -3,
f = Math.PI * distance / 10;
for (i; i <= distance; i += step)
waveOffsetLength = Math.sin((i / distance) * f) * amplitude;
cx = from.x + Math.cos(ang) * i + Math.cos(ang - Math.PI / 2) * waveOffsetLength;
cy = from.y + Math.sin(ang) * i + Math.sin(ang - Math.PI / 2) * waveOffsetLength;
i > 0 ? ctx.lineTo(cx, cy) : ctx.moveTo(cx, cy);
ctx.lineTo(to.x, to.y);
ctx.lineTo(endPoint.x, endPoint.y);
,
pointOnLine: function (point1, point2, dist)
var len = Math.sqrt(((point2.x - point1.x) * (point2.x - point1.x)) + ((point2.y - point1.y) * (point2.y - point1.y)));
var t = (dist) / len;
var x3 = ((1 - t) * point1.x) + (t * point2.x),
y3 = ((1 - t) * point1.y) + (t * point2.y);
return new fabric.Point(x3, y3);
,
toObject: function ()
return fabric.util.object.extend(this.callSuper('toObject'),
customProps: this.customProps,
);
,);
这就是我尝试编写 fromObject() 函数的方式:
fabric.LineaBote.fromObject = function (points, callback)
callback && callback(new fabric.LineaBote(points, object));;
来自 google chorme 控制台的错误:未捕获的 TypeError:无法读取未定义的属性“fromObject”
【问题讨论】:
我认为问题与 fromObject() 定义有关,您可以检查它是如何为 Line here 完成的,并为这个新类修改它。 您好,已更新 same answer 中的 fromObject。 Drawing a wavy line in FabricJS的可能重复 我应该删除帖子吗? 【参考方案1】:我认为,问题在于 fromObject 没有定义。作者更新了原帖answer,写了函数。谢谢他。
【讨论】:
以上是关于Fabricjs loadFromJSON Line 的子类的主要内容,如果未能解决你的问题,请参考以下文章
如何从 JSON 重新加载自定义 fabricJS 画布对象?
Fabric.js - 自定义 Fabric.Image 类在“loadFromJSON”>“fromObject”中不起作用