在最开始一直对fabric中的originX和originY很迷,设置center属性是怎么的一个中心对齐方式,为什么一个组里, 有一个设置了center,其他的都会连带呢?
于是自己就进行代表探索
javascript
// 左侧组:只有蓝色圆设置center origin
var circle_left = new this.$fabric.Circle({
radius: 80,
fill: 'pink',
});
var circle1_left = new this.$fabric.Circle({
radius: 60,
fill: 'blue',
originX: 'center', // 只有这个设置了center
originY: 'center',
});
var text_left = new this.$fabric.Text('蓝圆center', {
fontSize: 16,
});
var group_left = new this.$fabric.Group([circle_left, circle1_left, text_left], {
left: 150,
top: 150,
});
this.canvas.add(group_left);

在组当中是这样的效果
最形象的解释是:
1. 默认对象(左上角对齐):
- 就像把一本书的左上角贴在桌子的左上角
- 书的其他部分自然延伸到右边和下面
2. 设置了center的对象(中心点对齐):
- 就像把一本书的中心点贴在桌子的左上角
- 书的左上角就会跑到桌子的外面(左上方向)


个人认为,第一个元素设置了center,其余元素都会以这个center元素为准,之后的元素设置center都会把圆心向最先的center元素中心对齐。
