HTML5之canvas绘图

news2025/1/11 13:01:20

介绍

<canvas> 是 HTML5 引入的一个强大元素,允许直接在网页上进行矢量图形和位图图像的绘制,为网页提供了一个动态图形渲染的平台。这一特性极大丰富了网页的表现力,特别是在数据可视化、游戏开发、交互式图表和动画制作等领域发挥着关键作用。

查看浏览器支持率

在这里插入图片描述

应用场景(实现业务上)

  • 动画
  • 游戏
  • 视频(因为生产环境还不成熟,略)
  • 截图
  • 合成图
  • 分享网页截图
  • 滤镜
  • 抠图
  • 旋转、缩放、位移、形变
  • 粒子
  • 将canvas转换为图片 – toDataURL方法

基本使用

画直线

<!-- 默认 300*150, 类似ps中的一个透明的图层 -->
<canvas id="myCanvas" width="200" height="100"></canvas>
var myCanvas=document.getElementById("myCanvas");
var ctx=myCanvas.getContext("2d");
ctx.moveTo(0,0);
ctx.lineTo(200,100);

//对路径进行描边。
ctx.stroke();

效果:

在这里插入图片描述

一个画布在网页中是一个矩形框,默认绘制出来的画布大小为300×150像素的HTML元素。

注意: 默认情况下 (canvas) 元素没有边框和内容。

画圆形

var myCanvas=document.getElementById("myCanvas");
var ctx=myCanvas.getContext("2d");
ctx.arc(95,50,40,0,2*Math.PI);
ctx.stroke();

效果:
在这里插入图片描述

画三角形

var canvas = document.getElementById("myCanvas");
var ctx = canvas.getContext('2d');
// 开始一个新的路径
ctx.beginPath();
ctx.moveTo(20, 30);
ctx.lineTo(180, 80);
ctx.lineTo(100, 120);

// 线宽度,默认1px
ctx.lineWidth = 8
// 闭合路径
ctx.closePath();
// 描边(相当于边框)
ctx.stroke();

效果:

在这里插入图片描述

刮刮卡效果

  • 代码如下:
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>
  .box {
    width: 200px;
    height: 100px;
    line-height: 100px;
    text-align: center;
    margin: 50px auto;
    position: relative;
  }

  .box .text {
    font-size: 50px;
    color: red;
  }

  #canvas {
    position: absolute;
    top: 0;
    left: 0;
    cursor: pointer;
  }
</style>

</head>

<body>
  <div class="box">
    <span class="text"></span>
    <canvas id="canvas"></canvas>
  </div>
</body>
<script>
  let arr = ['200元', '300元', '400元', '500元', '600元', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢', '谢谢'];
  let canvas;
  // 定义自执行函数
  (function init() {
    // 获取 canvas 元素
    canvas = document.getElementById('canvas');
    // 设置 canvas 的宽度和高度
    canvas.width = 200;
    canvas.height = 100;
    // 获取 canvas 的 2D 渲染上下文
    let ctx = canvas.getContext("2d")
    // 设置随机值
    setResult();
    // 设置canvas遮盖
    drawMask(ctx)
    // 移动划开遮盖
    drawStroke(ctx);
  })();

  // 设置随机的奖品内容
  function setResult() {
    let max = arr.length - 1;
    // 生成一个随机索引
    let randomInx = randomNum(0, max);

    // 获取文本元素
    let text = document.getElementsByClassName('text')[0];
    // 设置文本元素的内容
    text.innerText = arr[randomInx];
  }

  // 生成随机数的函数
  function randomNum(min, max) {
    return parseInt(Math.random() * (max - min + 1) + min);
  }

  // 绘制遮盖层
  function drawMask(ctx) {
    // 设置幕布颜色
    ctx.fillStyle = "rgb(166,166,166)";
    // 绘制矩形遮盖层
    ctx.fillRect(0, 0, 200, 100);
  }

  // 绘制划开遮盖的线条
  function drawStroke(ctx) {
    // 当鼠标按下时触发
    canvas.onmousedown = function (e) {
      // 获取鼠标按下的位置
      let downX = e.offsetX;
      let downY = e.offsetY;

      // 开始新的路径
      ctx.beginPath();
      // 设置合成模式为 'destination-out',用于擦除效果
      ctx.globalCompositeOperation = 'destination-out';
      // 设置线条宽度
      ctx.lineWidth = 8;

      // 移动到初始位置
      ctx.moveTo(downX, downY);

      // 当鼠标移动时触发
      canvas.onmousemove = function (e) {
        // 绘制线条到当前位置
        ctx.lineTo(e.offsetX, e.offsetY);

        // 绘制线条
        ctx.stroke();
      }

      // 当鼠标抬起时触发
      canvas.onmouseup = function () {
        // 移除鼠标移动事件监听器
        canvas.onmousemove = null;
      }
    }
  }
</script>

</html>

效果如下:

在这里插入图片描述

总结

canvas 是一种强大的 HTML5 技术,用于在网页上绘制图形和图像,支持绘制基本形状、处理图像、实现动画效果以及响应用户事件,广泛应用于游戏开发、数据可视化和交互式应用中。

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

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

相关文章

第311题| 超好用!二重积分求旋转体体积公式|武忠祥老师每日一题

第一步&#xff1a; &#xff08;1&#xff09;找渐近线&#xff0c;先看水平渐近线&#xff0c;看x趋于无穷时&#xff0c;y有没有趋于一个有限的值。 , 得出水平渐近线y1。因为左右两边都是水平渐近线&#xff0c;所以没有斜渐近线。 第二步&#xff1a; 画出图像&#…

Spring Boot环境下的学生读书笔记共享

第4章 系统设计 4.1系统结构设计 读书笔记共享平台的设计主要是为了满足用户的实际需求。 因此&#xff0c;它需要通过Internet实现&#xff0c;因此它必须具备硬件和软件基础。该平台最终可以通过科学技术和各种方式达到支持智能化的信息管理的目的。因此&#xff0c;它必须具…

深入理解Python中的生成器:高效迭代与延迟计算的艺术

在处理大量数据时&#xff0c;如何有效地管理内存成为了一个关键问题。Python中的生成器&#xff08;Generator&#xff09;提供了一种优雅的解决方案&#xff0c;它允许你在迭代过程中按需生成数据&#xff0c;而不是一次性加载所有数据到内存中。本文将详细探讨生成器的工作原…

看Threejs好玩示例,学习创新与技术(三)

本文接上篇内容&#xff0c;继续挖掘应用ThreeJS的一些创新算法。 1、获得鼠标移动对应的地理位置 这个算法如果放在几年前&#xff0c;那肯定会难倒一帮人的。因为是三维投影涉及矩阵变换及求逆&#xff0c;而且还是投影模式下的。在Project Texture这个示例中&#xff0c;作…

Sentaurus TCAD的sdevice求解中选择Math求解方法

目录 并行迭代线性求解器&#xff08;ILS&#xff09;并行超节点直接求解器&#xff08;ParDiSo&#xff09;超节点直接求解器&#xff08;Super&#xff09;详细解释1. 并行迭代线性求解器&#xff08;ILS&#xff09;2. 并行超节点直接求解器&#xff08;ParDiSo&#xff09;…

windows安装docker、elasticsearch、kibana、cerebro、logstash

文章目录 1. 安装docker1.1. 两大要点1.1.1. 安装启用hyper-v电脑不存在hyper-v的情况 1.1.2. 下载安装docker 2. 在docker里面安装elasticSearch&#xff0c;kibana&#xff0c;cerebro3. 安装logstash-将数据导入到elasticSearch3.1 安装logstash3.1.1 注意事项3.1.1.1. 等了…

vue3中把封装svg图标为全局组件

在vue3中我们使用svg图标是下面这样子的 <svg style="width:30px;height:30px;"><use xlink:href="#icon-phone" fill="red"></use></svg>第次使用图标都要写这么多重复的代码,很不方便,所以,如果我们把它封装成全局…

“拍照赚钱”的任务定价(2017数学建模国赛b题)

文章目录 题目说明解题思路第一问第二问第三问第四问 部分结果图项目地址 题目 赛题地址 说明 数模国赛前的练手题。其实我个人感觉这道题很散&#xff0c;都是找一些规律进行总结统计&#xff0c;最多结合一些机器学习算法进行预测拟合之类的我刚开始用matlab&#xff0c;后…

[进阶]面向对象之 包 final

文章目录 包什么是包包名的规则:什么时候需要导包 final常量 包 什么是包 包就是文件夹。用来管理各种不同功能的Java类&#xff0c;方便后期代码维护。 包名的规则: 公司域名反写包的作用&#xff0c;需要全部英文小写&#xff0c;见名知意。使用其他类时&#xff0c;需要…

基于R语言的统计分析基础:使用键盘输入数据

在R语言中&#xff0c;键盘输入数据是一种灵活且直接的数据获取方式&#xff0c;适用于处理小数据集或需要即时用户交互的场景。通常用于交互式数据探索和分析、临时数据处理、交互式图形绘制、脚本自动化中的用户交互、特定应用场景下的数据录入中。 比如利用readline()函数根…

分享一些智慧农业数据集

持续更新中》》》 1.葡萄叶片病虫害数据集 数据集信息&#xff1a;yolo格式&#xff0c;适用于直接训练YOLO目标检测模型(yolo5 yolo8 yolo9 yolo10等)。数据集是已经标注好。训练集验证集已划分好&#xff0c;包含类别标签yaml文件&#xff0c;数据集可直接用于模型训练&…

第十二周:机器学习笔记

第十二周周报 摘要Abstract机器学习1. Recurrent Neural Network&#xff08;下&#xff09;1.1 RNN的Loss Function怎么求&#xff1f;1.2 RNN奇怪的特性1.3 如何解决 RNN 梯度消失或者爆炸1.4 RNN 其他应用 Pytorch学习1. 现有的网络模型使用以及其修改1.1 在VGG16模型添加Mo…

AD原理图编译

AD原理图检查项包括&#xff1a; 1.位号重复 2.网络悬浮 3.电源悬浮 4.单端网络 网络悬浮&#xff0c;在多页原理图时会比较明显,大部分是编译范围不是全部原理图&#xff0c;导致出现该情况&#xff0c;解决方法就是修改编译范围&#xff0c;将网络识别符范围改为全部即可。…

Qt常用控件——QComboBox

文章目录 核心属性、方法、信号模拟点餐文件加载 核心属性、方法、信号 QComboBox表示下拉框 核心属性&#xff1a; 属性说明currentText当前选中文本currentIndex当前选中的条目下标editable是否允许修改设置为true时&#xff0c;QComboBox的行为就非常接近于QLineEdit&…

Python | Leetcode Python题解之第406题根据身高重建队列

题目&#xff1a; 题解&#xff1a; class Solution:def reconstructQueue(self, people: List[List[int]]) -> List[List[int]]:people.sort(keylambda x: (-x[0], x[1]))n len(people)ans list()for person in people:ans[person[1]:person[1]] [person]return ans

SpringCloudAlibaba:Seata

1. 面试题 2.1 你简历上写用微服务boot/cloud做过项目&#xff0c;你不可能只有一个数据库吧&#xff1f;谈谈多个数据库之间如何处理分布式事务&#xff1f; 2.2 阿里巴巴的Seata-AT模式如何做到对业务的无侵入&#xff1f; 在一阶段&#xff0c;Seata 会拦截“业务 SQL”&a…

Python版《天天酷跑+源码》,详细讲解,手把手教学-python游戏开发

天天酷跑游戏 游戏效果: 游戏主要是躲避障碍物&#xff0c;这里也添加了金币&#xff0c;增加一点积分的娱乐性&#xff0c;人物设置是三条命&#xff0c;障碍物有6种&#xff0c;包括金币&#xff0c;障碍物随机生成&#xff0c;碰到障碍物掉一滴血&#xff0c;没血了结束游戏…

消失的数字:

Q&#xff1a;数组nums包含从0到n的所有整数&#xff0c;但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗&#xff1f; 示例 1&#xff1a; 输入&#xff1a;[3,0,1] 输出&#xff1a;2 示例 2&#xff1a; 输入&#xff1a;[9,6,4,2,3,5,7,0,1] …

产品经理如何转型为AI产品经理,如何理解AI产品工程化

技术领域,特别是人工智能和机器学习,其优秀模型的成功应用是一个复杂过程,它不仅要求技术本身的卓越,还须与现有解决方案竞争,这涉及到技术成熟度、成本有效性、市场接受度等多维度因素。 在这一过程中,产品经理扮演着核心角色,负责协调各方利益,确保技术能够转化为满…

5.1 溪降技术:个人装备

Content 5.1 个人装备概览设备概览视频电子书&#xff1a;个人装备安全装备非安全装备 峡谷探险个人安全装备个人安全装备视频*安全扣结构*峡谷探险个人非安全装备 湿峡谷湿峡谷装备视频个人安全装备个人非安全装备 干峡谷干峡谷装备视频个人安全装备个人非安全装备 团队装备&a…