图形编辑器基于Paper.js教程09:鼠标拖动画布,以鼠标点为缩放中心进行视图的缩放

news2025/1/8 21:02:57

如何使用Paper.js实现画布的缩放与拖动功能

在Web开发中,利用Paper.js库进行图形的绘制和交互操作是一种常见的实践。Paper.js是一个强大的矢量图形库,可以让开发者通过简洁的API完成复杂的图形操作。在本文中,我们将详细探讨如何使用Paper.js来实现对画布的缩放和拖动功能,提供用户友好的交互体验。
(作者:CSDN@拿我格子衫来)

效果图

请添加图片描述

环境设置与基本图形绘制

首先,我们需要在HTML中引入Paper.js,并设置一个画布:

<script src="https://unpkg.com/paper/dist/paper-full.js"></script>
<canvas id="myCanvas" resize></canvas>
<script>
  paper.setup('myCanvas');
</script>

接下来,在paper.setup('myCanvas');之后,我们绘制了几种基本的图形,包括圆形、椭圆和矩形:

var circle = new paper.Path.Circle({
  center: [80, 50],
  radius: 30,
  fillColor: "red",
});

var ellipse = new paper.Path.Ellipse({
  point: [150, 20],
  size: [80, 40],
  fillColor: "blue",
});

var rectangle = new paper.Path.Rectangle({
  point: [250, 20],
  size: [100, 50],
  fillColor: "green",
});
鼠标滚轮实现画布缩放

缩放功能是通过监听鼠标滚轮事件来实现的。当用户滚动鼠标滚轮时,我们根据滚动方向调整画布的缩放比例:

paper.view.element.addEventListener('wheel', function (event) {
  event.preventDefault();

  var delta = event.deltaY > 0 ? 0.9 : 1.1;

  var mousePosition = new paper.Point(event.offsetX, event.offsetY);
  var viewPosition = paper.view.viewToProject(mousePosition);

  paper.view.scale(delta, viewPosition);
});

这段代码中,delta变量决定了缩放的快慢和方向(向上滚动放大,向下滚动缩小)。viewPosition是将鼠标的屏幕位置转换为画布上的坐标,确保缩放操作围绕鼠标当前位置进行。

实现画布的拖动功能

画布的拖动功能是通过一个Tool实例来处理鼠标的拖动事件。首先,我们定义一些变量来跟踪鼠标的状态和位置:

const tool = new paper.Tool();
var lastPoint = null;
var dragging = false;
var lastViewCenter;

接着,定义鼠标事件的处理函数:

tool.onMouseDown = (event) => {
  lastPoint = event.point;
  dragging = true;
};

tool.onMouseDrag = (event) => {
  if (dragging && lastPoint) {
    lastViewCenter = paper.view.center;
    const delta = lastPoint.subtract(event.point);
    paper.view.center = paper.view.center.add(delta);

    lastPoint = event.point.add(paper.view.center.subtract(lastViewCenter));
  }
};

tool.onMouseUp = () => {
  dragging = false;
};

onMouseDown事件中,我们记录了鼠标点击的位置,并开始跟踪拖动状态。在onMouseDrag事件中,我们计算从上一次事件到当前事件鼠标移动的差值,并相应地调整视图中心,实现拖动效果。最后,在onMouseUp事件中结束拖动。

结论

通过上述步骤,我们利用Paper.js实现了对画布的基本缩放和拖动操作。这些功能不仅增强了用户界面的交互性,也提供了更为直观的图形操作方式。希望本文的解析能帮助你理解并实现类似的功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1947386.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

electron安装及快速创建

electron安装及快速创建 electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 详细内容见官网&#xff1a;https://www.electronjs.org/zh/docs/latest/。 今天来记录下练习中的安装过程和hello world的创建。 创建项目文件夹&#xff0c;并执行npm 初始化命…

【MetaGPT系列】【MetaGPT完全实践宝典——如何定义单一行为多行为Agent】

目录 前言一、智能体1-1、Agent概述1-2、Agent与ChatGPT的区别 二、多智能体框架MetaGPT2-1、安装&配置2-2、使用已有的Agent&#xff08;ProductManager&#xff09;2-3、拥有单一行为的Agent&#xff08;SimpleCoder&#xff09;2-3-1、定义写代码行为2-3-2、角色定义2-3…

增材制造与智能制造关系

在撰写的增材制造技术与装备书籍中有着明确的描述&#xff0c;增材制造是智能制造的典型范例&#xff0c;是智能制造“类”的实例化过程。这种借助于计算机编程面向对象思想的解释可以更全面的理解增材制造和智能制造的关系。增材制造实例具备了智能制造类的属性&#xff0c;智…

第4章 .NET 8.0 ASP.NET Core图书管理系统 :项目布局

第1章 框架学习的基石与实战策略 第2章 大话ASP.NET Core 入门 第3章 创建最小&#xff08;Minimal APIs&#xff09;API应用程序 第4章 .NET 8.0 ASP.NET Core图书管理系统 &#xff1a;项目布局 在第3章中&#xff0c;我们利用ASP.NET Core的“空”模板创建了BookQueryS…

2、springboot3 vue3开发平台-后端-基础数据准备,MybatisPlus整合

文章目录 1. 基础数据准备2. 整合MybatisPlus3. MybatisPlus 配置3.1 数据源配置3.2 mybatis-plus 分页插件配置3.3 mybatis-plus 自动填充3.4 代码生成器 1. 基础数据准备 直接拿前辈做的表结构使用。 /*Navicat Premium Data TransferSource Server : localhost_my…

光伏气象站可以监测哪些数据?

推荐型号&#xff1a;TH-BGF11】光伏气象站是一种专门为评估太阳能光伏发电资源而设计的综合气象监测设备&#xff0c;能够实时监测和记录影响太阳能发电效率的关键气象参数。这些参数包括太阳辐射强度、温度&#xff08;环境温度和光伏组件表面温度&#xff09;、风速、风向、…

Mindspore框架CRF条件随机场概率图模型实现文本序列命名实体标注|(三)双向LSTM+CRF模型构建实现

Mindspore框架CRF条件随机场概率图模型实现文本序列命名实体标注|&#xff08;一&#xff09;序列标注与条件随机场的关系 Mindspore框架CRF条件随机场概率图模型实现文本序列命名实体标注|&#xff08;二&#xff09;CRF模型构建 Mindspore框架CRF条件随机场概率图模型实现文本…

MySQL4.索引及视图

1.建库 create database mydb15_indexstu; use mydb15_indexstu;2.建表 2.1 student表学&#xff08;sno&#xff09;号为主键&#xff0c;姓名&#xff08;sname&#xff09;不能重名&#xff0c;性别&#xff08;ssex&#xff09;仅能输入男或女&#xff0c;默认所在系别&a…

BSV区块链在人工智能时代的数字化转型中的角色

​​发表时间&#xff1a;2024年6月13日 企业数字化转型已有约30年的历史&#xff0c;而人工智能&#xff08;以下简称AI&#xff09;将这种转型提升到了一个全新的高度。这并不难理解&#xff0c;因为AI终于使企业能够发挥其潜力&#xff0c;实现更宏大的目标。然而&#xff0…

Flowable-整合系统角色人员

一、整合角色人员 在设置审批人和候选人的时候&#xff0c;我们希望能够选取业务数据库中的用户&#xff0c;也是是集成系统中的用户和角色&#xff0c;来帮助我们快速选择审批人&#xff0c;不再需要通过flowable的用户。 1. 加载系统用户 在设置候选用户的时候&#xff0c…

手把手教你本地运行Meta最新大模型:Llama3.1,可是它说自己是ChatGPT?

就在昨晚&#xff0c;Meta发布了可以与OpenAI掰手腕的最新开源大模型&#xff1a;Llama 3.1。 该模型共有三个版本&#xff1a; 8B70B405B 对于这次发布&#xff0c;Meta已经在超过150个涵盖广泛语言范围的基准数据集上评估了性能。此外&#xff0c;Meta还进行了广泛的人工评…

ADS 使用教程(十六)Using Sliders for Data Processing

上一篇&#xff1a;ADS 使用教程&#xff08;十五&#xff09;Multi-Dimensional Data Processing in ADS 在这一节&#xff0c;我们来谈论一下如何在进行多维数据处理时使用滑块&#xff08;Sliders&#xff09;来进行数据处理和分析。通过该方法&#xff0c;我们可以通过拖动…

SkyWalking入门搭建【apache-skywalking-apm-10.0.0】

Java学习文档 视频讲解 文章目录 一、准备二、服务启动2-1、Nacos启动2-2、SkyWalking服务端启动2-3、SkyWalking控制台启动2-4、自定义服务接入 SkyWalking 三、常用监控3-1、服务请求通过率3-2、服务请求拓扑图3-3、链路 四、日志配置五、性能剖析六、数据持久化6-1、MySQL持…

相机的内参与外参

目录 一、相机的内参二、相机的外参 一、相机的内参 如下图所示是相机的针孔模型示意图&#xff1a; 光心O所处平面是相机坐标系(O&#xff0c;P)&#xff0c;像素平面所在坐标系为像素坐标系(O’&#xff0c;P’)。 焦距f&#xff1a;O到O’的距离 相机的内参表示的是相机坐标…

运算符的运算顺序

【单目算术位关系&#xff0c;逻辑三目后赋值】 ![在这里插入图片描述] (https://i-blog.csdnimg.cn/direct/e4c8f4e22b5044a48154bf7378e3b3b3.png)

【React】useState:状态更新规则详解

文章目录 一、基本用法二、直接修改状态 vs 使用 setState 更新状态三、对象状态的更新四、深层次对象的更新五、函数式更新六、优化性能的建议 在 React 中&#xff0c;useState 是一个非常重要的 Hook&#xff0c;用于在函数组件中添加状态管理功能。正确理解和使用 useState…

同步库存扣减到数据库

跟接上文: 并发情况下的库存扣减 一 库存扣减 public DefaultTreeFactory.TreeActionEntity logic(String userId, Long strategyId, Integer awardId, String ruleValue, Date endDateTime) {log.info("规则过滤-库存扣减 userId:{} strategyId:{} awardId:{}", u…

结合el-upload上传组件,验证文件格式及大小

结合el-upload上传组件&#xff0c;验证文件格式及大小 效果如下&#xff1a; 代码如下&#xff1a; upgradeFirmwareInfo.vue页面 <template><div><el-dialog title"新增固件升级包" :visible.sync"dialogFormVisible"top"7vh&qu…

电商数据集成之电商商品信息采集系统架构设计||电商API接口

一、引言 本架构设计文档旨在阐述基于 Selenium 的电商商品信息采集系统的整体架构&#xff0c;包括系统视图、逻辑视图、物理视图、开发视图和进程视图&#xff0c;并提供一个简单的采集电商商品信息的 demo。该系统通过模拟浏览器行为&#xff0c;实现对电商商品信息的自…

力扣高频SQL 50题(基础版)第九题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第九题197. 上升的温度题目说明思路分析实现过程准备数据实现方式结果截图总结 力扣高频SQL 50题&#xff08;基础版&#xff09;第九题 197. 上升的温度 题目说明 Weather ---------------------- | Column Name…