カスタムファブリックオブジェクト(たとえばfabric.Demo)を作成する必要があります。ファブリックを拡張します。グループオブジェクトです。ファブリック.Demoオブジェクトはグループ化された他の2つのファブリックに使用されます。グループオブジェクト。私はインターネットで検索し、これらのリンクだけが有用であると判断しました。 カスタムfabricjsオブジェクトを作成する方法は?
しかし、私はこのエラー 'this._objectsが未定義である' を取得しています
-
。私は_render()を記述していないことを知っています。しかし、私は_render()内で何をコーディングすべきか理解していません。誰かが答えを知っていれば、それは感謝されます。
ここに私のコードです。
(function (global) {
var fabric = global.fabric || (global.fabric = {}),
extend = fabric.util.object.extend,
clone = fabric.util.object.clone;
var stateProperties = fabric.Text.prototype.stateProperties.concat();
stateProperties.push(
'top',
'left'
);
fabric.Demo = fabric.util.createClass(fabric.Group, {
type: 'demo',
initialize: function() {
this.grp = new fabric.Group([], {
selectable: false,
padding: 0
});
this.grp.add([
new fabric.Group([
new fabric.Text('A', {top: 200, left: 200}),
new fabric.Text('B', {top: 200, left: 200})
]),
new fabric.Group([
new fabric.Text('C', {top: 200, left: 200}),
new fabric.Text('D', {top: 200, left: 200})
])
]);
},
_render: function (ctx) {
}
});
})(typeof exports !== 'undefined' ? exports : this);
$(document).ready(function() {
var canvas = new fabric.Canvas('c');
var abc = new fabric.Demo();
canvas.add(abc);
});