fabric.js 中originX originY center设置问题

在最开始一直对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元素中心对齐。
相关推荐
q***T5837 分钟前
前端路由懒加载实现,React与Vue
前端·vue.js·react.js
灵犀坠11 分钟前
前端开发核心知识:HTML5特性与经典面试题详解
前端·html·html5
Hilaku12 分钟前
我为什么说全栈正在杀死前端?
前端·javascript·后端
8***B21 分钟前
前端性能优化插件,图片懒加载与压缩
前端
木易士心32 分钟前
Vue2 和 Vue3 中 watch 用法和原理详解
前端·vue.js
Harlen37 分钟前
Cesium.js基本使用
前端
拿不拿铁1938 分钟前
Webpack 5.x 开发模式启动流程详解
前端
百***35941 小时前
如何在树莓派部署Nginx并实现无公网ip远程访问内网制作的web网站
前端·tcp/ip·nginx
花果山总钻风1 小时前
Chrome 插件框架 Plasmo 基本使用示例
前端·chrome
资讯第一线1 小时前
《Chrome》 [142.0.7444.60][绿色便携版] 下载
前端·chrome