码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Fabric.js 元素中心缩放



    theme: smartblue

    我报名参加金石计划1期挑战——瓜分10万奖池,这是我的第10篇文章,点击查看活动详情


    本文简介

    点赞 + 关注 + 收藏 = 学会了

    使用 fabric.js 创建的图形,默认的缩放原点是元素操作点的对角点。

    如下图所示:

    01.gif

    如果按住 alt 键 操作会把原点移动到元素中心。

    如下图所示:

    02.gif

    如果想将默认缩放操作设置为“中心缩放”,只需将 centeredScaling 属性设置为 true 即可。

    设置中心缩放

    虽然只要将 `centeredScaling 设置为true` 就行了,但还能再细分成2种情况。

    一个是全局设置,一个是只设置指定元素。

    在实际操作之前,我先创建画布,并在画布上添加2个元素,一个矩形,一个圆形。

    03.png

    ```html

    ```

    全局设置

    全局设置的话,画布上所有元素都会生效。

    只需在创建画布时将 centeredScaling 设为 true 即可。

    04.gif

    ```js // 省略部分代码.

    // 方式1 let canvas = new fabric.Canvas('canvasBox', { centeredScaling: true // 全局所有元素都生效 })

    // 方式2 let canvas = new fabric.Canvas('canvasBox') canvas.centeredScaling = true ```

    从上图中可以看到,不管是圆形还是矩形都是以中心点为缩放原点。因为在 new fabric.Canvas 时或者其返回的实例对象上设置 centeredScaling 都是全局生效的。

    单独设置指定元素

    如果只是设置指定元素以中心点为缩放原点,那么被设置的元素会生效,其他元素不会生效。

    本例只将矩形设置成以中心点为缩放原点,圆形还是默认的操作。

    05.gif

    ```js // 省略部分代码

    // 矩形 let rect = new fabric.Rect({ width: 100, height: 60, left: 100, top: 100, fill: 'pink', centeredScaling: true // 单个元素生效 })

    // 将矩形添加到画布里 canvas.add(rect) ```

    上面的代码只设置了矩形的 centeredScaling ,圆形还是默认值。

    所以在操作矩形缩放时是以中心点为原点,圆形还是默认值。

    同样,也支持在创建元素后再设置。

    ```js // 省略部分代码

    let rect = new fabric.Rect({...})

    rect.centeredScaling = true ```

    代码仓库

    ⭐ Fabric.js 中心缩放

    推荐阅读

    👍《Fabric.js 从入门到 _ _ _ _ _ _》

    👍《Fabric.js IText 手动设置斜体》

    👍《Fabric.js 动态设置字号大小》

    👍《Fabric.js 锁定背景图,不受缩放和拖拽的影响》

    👍《Fabric.js 自由绘制椭圆》

    👍《Fabric.js 橡皮擦的用法(包含恢复功能)》

    点赞 + 关注 + 收藏 = 学会了

  • 相关阅读:
    阿里云添加端口
    大气污染扩散模型Calpuff实践
    【Spark】Spark 高频面试题英语版(1)
    【原创】SpringBoot 2.7.0通过lettuce及commons-pool2 v2.9.0集成Redis踩坑记录
    小景的Dba之路--Oracle用exp导出dmp文件很慢
    maven集成nexus伺服服务实现项目快速自动化构建与发布
    ExoPlayer架构详解与源码分析(9)——TsExtractor
    (附源码)ssm考务管理系统 毕业设计 221504
    训练一个目标检测模型
    【深度学习】聊一聊什么是卷积神经网络,卷积是什么意思?
  • 原文地址:https://blog.csdn.net/weixin_39415598/article/details/126815956
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号