news 2026/4/23 17:56:59

canvas绘制图片

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
canvas绘制图片

项目中有一个点击图片,在点击区域画圆标注的需求,需要知道点击的位置,并判断位置是否正确,类似“找不同”小游戏。这种就需要用到canvas了

基本说明

canvas是 一个 HTML 元素,用于绘制图形和图像,通过 JavaScript 来控制其行为。
<img>元素是用来在网页中显示图像的 HTML 元素。
drawImage()方法是Canvas 提供的一种方法,用于将图像、视频或另一个 canvas 的内容绘制到当前 canvas 上。

canvas 与 <img> 元素的结合,可以实现动态图像处理,包括但不限于图像裁剪、缩放、旋转等。

实现方法

最简单的方式是直接使用drawImage方法来绘制<img>元素的内容到 Canvas 上。需要注意的是,在使用drawImage之前,必须等待<img>元素加载完成。

<template> <div> <canvas id="myCanvas"></canvas> </div> </template> <script setup lang="ts"> import { onMounted } from "vue"; const draw = () => { // 创建 canvas 元素 const canvas:any = document.getElementById("myCanvas"); const ctx = canvas.getContext("2d", { willReadFrequently: true, }); // 创建 img 元素 const img = new Image(); img.src = '/src/assets/pro.png'; // 图片加载完成后绘制到 canvas img.onload = () => { canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0, canvas.width, canvas.height); // 也可以省略后两个参数,默认画满 // ctx.drawImage(img, 0, 0); }; canvas.addEventListener("click", (e:any) => { const x = e.clientX; const y = e.clientY; console.log("点击的位置", x, y); // 点击的位置画出圆形 ctx.beginPath(); ctx.strokeStyle = "#0f0"; ctx.lineWidth = 5; ctx.arc(x, y - 50, 50, 0, 360); ctx.stroke(); }) } onMounted(() => { draw() }); </script>

效果如图:

注意:

  • img.src会把图片路径加载为绝对路径
  • 如果直接使用相对路径的话,会找不到图片资源,要使用require引入相对路径

img.src = '@/assets/pro.png' 加载失败

img.src = require('@/assets/pro.png') 加载成功

  • 或者 可以把图片放在public文件夹下,直接引入

img.src = 'pro.png';

  • 若使用在线的图片,可能会有跨域问题,设置 img.crossOrigin

img.crossOrigin = ""; //解决图片跨域问题

img.src = "https://imgs.699pic.com/images/401/061/200.png!detail.oblique.v1";

其他功能

1. 使用drawImage绘制并裁剪图像

img.onload = () => { canvas.width = img.width; canvas.height = img.height; // 指定裁剪区域 x, y, width, height,以及目标绘制位置 dx, dy, dWidth, dHeight // (img, x, y, width, height, dx, dy, dWidth, dHeight) ctx.drawImage(img, 100, 100, 200, 200, 0, 0, canvas.width, canvas.height); };
代码解释
  1. 定义裁剪区域(100, 100, 200, 200),表示从原图像的(100, 100)开始裁剪,裁剪区域宽高分别为200像素。
  2. 指定了目标绘制位置(0, 0)以及绘制区域的宽高canvas.widthcanvas.height

裁剪如图:

2. 使用drawImage绘制图像并做其他变换

除了裁剪之外,我们还可以利用transform方法来改变图像的位置、大小和方向。这里我们将展示如何旋转图像。

img.onload = () => { canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0, canvas.width, canvas.height); // 保存当前的绘图状态 ctx.save(); // 设置转换中心点 ctx.translate(canvas.width / 2, canvas.height / 2); // 旋转 45 度角 ctx.rotate(Math.PI / 4); // Math.PI / 4 = 45deg // 绘制图像 ctx.drawImage(img, -img.width / 2, -img.height / 2, img.width, img.height); // 恢复之前的绘图状态 ctx.restore(); };
代码解释
  1. 使用 translate 方法将坐标系原点移动到画布的中心。
  2. 使用 rotate 方法旋转坐标系。
  3. 使用 drawImage 方法绘制图像,通过减去图像的一半宽度和高度来确保图像绘制在新的坐标系原点上。
  4. 使用 save 和 restore 方法来保存和恢复绘图状态,避免影响后续的绘图操作。

旋转如图:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:23:48

20、开发线程安全的 COM 代码

开发线程安全的 COM 代码 在多线程编程中,确保代码的线程安全性是一项至关重要的任务。尤其是在 COM(Component Object Model)编程环境中,由于多个线程可能同时访问共享资源,因此需要特别注意处理共享数据冲突的问题。本文将介绍一些开发公寓安全(apartment-safe)和线程…

作者头像 李华
网站建设 2026/4/23 12:15:51

容联七陌 X 凯德MALL|大模型客服驱动购物中心服务升级

凯德&#xff08;中国&#xff09;企业管理有限公司作为凯德集团旗下核心成员&#xff0c;专注于线下大型商业综合体运营&#xff0c;旗下核心品牌"凯德MALL"覆盖全国多座城市。其业务以零售、餐饮、休闲娱乐等多业态融合为核心&#xff0c;致力于通过数字化手段提升…

作者头像 李华
网站建设 2026/4/23 12:23:32

SSM小型超市货物仓储管理系统w8wry(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面

系统程序文件列表 系统项目功能&#xff1a;仓库管理员,主管,货物种类,货物区域,货物信息,货物分区,货物出库,货物入库,每日结存,供应商,日志,每月结存,出入库申请 开题报告&#xff1a;基于SSM的小型超市货物仓储管理系统设计与实现 一、研究背景与意义 1. 研究背景 当前小…

作者头像 李华
网站建设 2026/4/23 12:22:23

「2026最新排行榜」国内外TOP6背景音乐素材网站精选!口碑靠谱必收藏,零侵权风险,企业/个人首选下载渠道!

在音乐创作、影视制作、广告剪辑、短视频创作等领域&#xff0c;适配的背景音乐是提升作品质感的关键。但优质、合规的背景音乐素材筛选难度较高&#xff0c;本文整理了国内外口碑出众的背景音乐素材网站&#xff0c;涵盖不同风格、授权模式&#xff0c;满足个人与商业创作需求…

作者头像 李华
网站建设 2026/4/23 17:24:30

Wifi跨VLAN三层漫游

一、适用场景 1、移动语音/视讯 校园、医院、 VoWiFi、无线 IPC、移动护理终端&#xff0c;漫游时若 IP 变化&#xff0c;SIP 会话会掉话或重注册&#xff1b;三层漫游把流量隧道回“原网关”&#xff0c;保证会话不中断。 2、移动扫码支付/POS 商场、超市的无线 POS 机、扫码枪…

作者头像 李华