HTML 中的 Canvas 样式设置全解

在 HTML5 中,<canvas> 元素提供了一个强大的绘图接口,允许开发者通过 JavaScript 实现各种图形和动画效果。为了充分利用 <canvas> 的功能,理解其样式设置是至关重要的。本文将详细介绍如何在 HTML 中设置 <canvas> 的各种样式属性,帮助你实现更加丰富和灵活的绘图效果。


1. 基础设置
1.1 创建 Canvas

首先,在 HTML 文件中添加一个 <canvas> 元素:

<canvas id="myCanvas" width="500" height="500"></canvas>

注意:widthheight 属性定义了画布的实际尺寸(以像素为单位),而 CSS 样式中的宽度和高度仅影响画布的显示大小。

1.2 获取 Canvas 上下文

在 JavaScript 文件中,使用 getContext('2d') 方法获取 canvas 的上下文对象:

const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');

2. 颜色与透明度
2.1 设置填充颜色

使用 fillStyle 属性设置填充颜色:

ctx.fillStyle = 'red'; // 设置填充颜色为红色

也可以使用 RGB 或 RGBA 格式:

ctx.fillStyle = 'rgba(255, 0, 0, 0.5)'; // 半透明红色
2.2 设置描边颜色

使用 strokeStyle 属性设置描边颜色:

ctx.strokeStyle = 'blue'; // 设置描边颜色为蓝色

同样支持 RGB 和 RGBA 格式:

ctx.strokeStyle = 'rgba(0, 0, 255, 0.5)'; // 半透明蓝色
2.3 设置透明度

使用 globalAlpha 属性设置整个画布的透明度:

ctx.globalAlpha = 0.5; // 设置透明度为50%

3. 线条样式
3.1 设置线条宽度

使用 lineWidth 属性设置线条宽度:

ctx.lineWidth = 5; // 设置线条宽度为5px
3.2 设置线条端点样式

使用 lineCap 属性设置线条端点样式,可选值有 'butt''round''square'

ctx.lineCap = 'round'; // 设置线条端点为圆形
3.3 设置线条连接样式

使用 lineJoin 属性设置线条连接处的样式,可选值有 'bevel''round''miter'

ctx.lineJoin = 'round'; // 设置线条连接处为圆角
3.4 设置虚线样式

使用 setLineDash 方法设置虚线样式,参数为数组 [实线长度, 空白长度]

ctx.setLineDash([10, 5]); // 设置虚线样式为10px实线,5px空白
3.5 设置虚线偏移量

使用 lineDashOffset 属性设置虚线偏移量:

ctx.setLineDash([10, 5]);
ctx.lineDashOffset = 5; // 设置虚线偏移量为5px

4. 文本样式
4.1 设置字体

使用 font 属性设置字体样式,格式类似于 CSS 字体属性:

ctx.font = 'italic bold 20px Arial'; // 设置字体样式为斜体、加粗、20px的Arial字体
4.2 设置文本对齐方式

使用 textAlign 属性设置文本对齐方式,可选值有 'left''center''right'

ctx.textAlign = 'center'; // 设置文本对齐方式为居中
4.3 设置文本基线

使用 textBaseline 属性设置文本基线,可选值有 'top''middle''bottom''alphabetic'

ctx.textBaseline = 'middle'; // 设置文本基线为中间

5. 渐变与阴影
5.1 线性渐变

使用 createLinearGradient 方法创建线性渐变:

const gradient = ctx.createLinearGradient(0, 0, 200, 0); // 创建从左到右的线性渐变
gradient.addColorStop(0, 'red'); // 渐变起始颜色为红色
gradient.addColorStop(1, 'blue'); // 渐变结束颜色为蓝色
ctx.fillStyle = gradient; // 使用渐变作为填充颜色
5.2 径向渐变

使用 createRadialGradient 方法创建径向渐变:

const gradient = ctx.createRadialGradient(100, 100, 0, 100, 100, 100); // 创建径向渐变
gradient.addColorStop(0, 'red'); // 渐变中心颜色为红色
gradient.addColorStop(1, 'blue'); // 渐变边缘颜色为蓝色
ctx.fillStyle = gradient; // 使用渐变作为填充颜色
5.3 设置阴影

使用 shadowColorshadowOffsetXshadowOffsetYshadowBlur 属性设置阴影效果:

ctx.shadowOffsetX = 10; // 设置阴影水平偏移10px
ctx.shadowOffsetY = 10; // 设置阴影垂直偏移10px
ctx.shadowBlur = 5; // 设置阴影模糊半径5px

6. 裁剪与变换
6.1 裁剪区域

使用 clip 方法裁剪当前路径:

ctx.beginPath();
ctx.arc(100, 75, 50, 0, Math.PI * 2, true); // 创建一个圆形路径
ctx.clip(); // 将该圆形路径作为裁剪区域
ctx.fillStyle = 'green';
ctx.fillRect(0, 0, 200, 150); // 只有圆形区域内的部分会被填充
6.2 平移变换

使用 translate 方法平移坐标系:

ctx.translate(50, 50); // 将坐标系原点平移到(50, 50)
6.3 缩放变换

使用 scale 方法缩放坐标系:

ctx.scale(2, 2); // 将坐标系缩放2倍
6.4 旋转变换

使用 rotate 方法旋转坐标系:

ctx.rotate(Math.PI / 4); // 将坐标系旋转45度(π/4弧度)
6.5 复合变换

可以组合使用 saverestore 方法保存和恢复变换状态:

ctx.save(); // 保存当前变换状态
ctx.translate(50, 50);
ctx.scale(2, 2);
ctx.restore(); // 恢复之前的变换状态

7. 图像处理
7.1 绘制图像

使用 drawImage 方法绘制图像:

const img = new Image();
img.src = 'your-image-url.jpg';
img.onload = () => {ctx.drawImage(img, 0, 0, 200, 150); // 在(0, 0)位置绘制宽200px高150px的图像
};
7.2 图像裁剪

可以通过指定裁剪区域来裁剪图像:

ctx.drawImage(img, 0, 0, 100, 100, 0, 0, 200, 200); // 裁剪图像并放大显示
7.3 图像滤镜

虽然 <canvas> 不直接支持 CSS 滤镜,但可以通过 getImageDataputImageData 方法进行像素级操作来实现类似效果。例如,简单的灰度转换:

const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
const data = imageData.data;for (let i = 0; i < data.length; i += 4) {const r = data[i];const g = data[i + 1];const b = data[i + 2];// 计算灰度值const gray = 0.299 * r + 0.587 * g + 0.114 * b;// 设置灰度值data[i] = gray;     // Reddata[i + 1] = gray; // Greendata[i + 2] = gray; // Blue
}ctx.putImageData(imageData, 0, 0);

8. 其他功能
8.1 测量文本宽度

使用 measureText 方法测量文本宽度:

const metrics = ctx.measureText('Hello World');
console.log(metrics.width); // 输出文本的宽度
8.2 清除画布

使用 clearRect 方法清除画布:

ctx.clearRect(0, 0, canvas.width, canvas.height); // 清除整个画布
8.3 更新画布

在 HTML 中,通常不需要显式调用更新方法,因为所有的绘图操作都会立即生效。但在某些框架或库中,可能需要手动刷新画布。


示例代码

以下是一个完整的示例代码,展示了如何使用上述的各种样式设置来绘制复杂的图形:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Canvas Styles</title><style>body {display: flex;justify-content: center;align-items: center;height: 100vh;margin: 0;background-color: #f0f0f0;}canvas {border: 1px solid black;}</style>
</head>
<body><canvas id="myCanvas" width="500" height="500"></canvas><script>const canvas = document.getElementById('myCanvas');const ctx = canvas.getContext('2d');// 设置背景颜色ctx.fillStyle = '#f0f0f0';ctx.fillRect(0, 0, canvas.width, canvas.height);// 绘制一个矩形ctx.fillStyle = 'rgba(255, 0, 0, 0.5)';ctx.fillRect(50, 50, 200, 100);// 绘制一条带虚线的路径ctx.beginPath();ctx.moveTo(50, 200);ctx.lineTo(250, 200);ctx.setLineDash([10, 5]);ctx.stroke();// 设置文字样式并绘制文本ctx.font = 'italic bold 24px Arial';ctx.textAlign = 'center';ctx.textBaseline = 'middle';ctx.fillStyle = 'blue';ctx.fillText('Hello Canvas', 250, 300);// 创建并应用线性渐变const gradient = ctx.createLinearGradient(0, 0, 200, 0);gradient.addColorStop(0, 'red');gradient.addColorStop(1, 'blue');ctx.fillStyle = gradient;ctx.fillRect(50, 350, 200, 50);// 应用阴影ctx.shadowColor = 'rgba(0, 0, 0, 0.5)';ctx.shadowOffsetX = 10;ctx.shadowOffsetY = 10;ctx.shadowBlur = 5;ctx.fillStyle = 'green';ctx.fillRect(300, 50, 150, 100);// 平移、缩放和旋转变换ctx.save();ctx.translate(300, 300);ctx.scale(2, 2);ctx.rotate(Math.PI / 4);ctx.fillStyle = 'purple';ctx.fillRect(-25,

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

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

相关文章

【论文解析】Fast prediction mode selection and CU partition for HEVC intra coding

级别:IET Image Processing(2020)CCF CSCI 4区时间:2020年机构:苏州大学下载地址:Fast prediction mode selection and CU partition for HEVC intra coding摘要 HEVC确实是一个很大的进步,编码效率翻倍,但计算复杂度也增加了不少。为了解决这个问题,提出了两种算法:…

大数据组件(四)快速入门实时数据湖存储系统Apache Paimon(2)

Paimon的下载及安装&#xff0c;并且了解了主键表的引擎以及changelog-producer的含义参考&#xff1a; 大数据组件(四)快速入门实时数据湖存储系统Apache Paimon(1) 利用Paimon表做lookup join&#xff0c;集成mysql cdc等参考&#xff1a; 大数据组件(四)快速入门实时数据…

智慧校园系统在学生学习与生活中的应用

随着科技的快速发展&#xff0c;智慧校园系统逐渐成为现代教育不可或缺的一部分。它整合了先进的信息技术、物联网技术以及人工智能等&#xff0c;旨在构建一个全面、智能、个性化的学习与生活环境。对于学生而言&#xff0c;这一系统不仅能够极大地提高学习效率&#xff0c;还…

基于Flask的京东商品信息可视化分析系统的设计与实现

【Flask】基于Flask的京东商品信息可视化分析系统的设计与实现&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 系统能够灵活地执行SQL查询&#xff0c;提取出用于分析的关键数据指标。为了将这…

Electron通过ffi-napi调用dll导出接口

electron使用ffi-napi环境搭建 附打包好的ffi-napi可以直接放到项目目录下使用&#xff0c;避免以后麻烦 一、安装node.js Node.js官网&#xff1a;https://nodejs.org/zh-cn/download&#xff0c;选择LTS长期稳定版本即可 需要注意Node.js 区分32和64位&#xff0c;32位版…

25工程管理研究生复试面试问题汇总 工程管理专业知识问题很全! 工程管理复试全流程攻略 工程管理考研复试真题汇总

工程管理复试面试心里没底&#xff1f;别慌&#xff01;学姐手把手教你怎么应对复试&#xff01; 很多同学面对复试总担心踩坑&#xff0c;其实只要避开雷区掌握核心技巧&#xff0c;逆袭上岸完全有可能&#xff01;这份保姆级指南帮你快速锁定重点&#xff0c;时间紧迫优先背…

深蓝学院自主泊车第3次作业-IPM

目录 1 题目介绍2 求解 1 题目介绍 已知鱼眼相机的参数&#xff0c; image_width&#xff0c;表示图像的宽度image_height&#xff0c;表示图像的高度 ξ \xi ξ&#xff0c;表示鱼眼相机参数 k 1 k_1 k1​、 k 2 k_2 k2​&#xff0c;表示径向相机参数 p 1 p_1 p1​、 p 2 p…

核货宝助力连锁门店订货数字化转型升级

在竞争激烈的连锁零售行业&#xff0c;传统订货模式弊端日益凸显&#xff0c;严重制约着企业的发展。核货宝订货系统以其卓越的数字化解决方案&#xff0c;为连锁门店订货带来了全方位的变革&#xff0c;助力企业实现数字化转型升级&#xff0c;在市场中抢占先机。 一、增强总部…

2.最多提取子串数目(100分)-附带Java逐行解析

题目 给定 [a-z]&#xff0c;26个英文字母小写字符串组成的字符串 A 和 B&#xff0c;其中 A 可能存在重复字母&#xff0c;B 不会存在重复字母&#xff0c;现从字符串 A 中按规则挑选一些字母&#xff0c;可以组成字符串B。 挑选规则如下&#xff1a; 同一个位置的字母只能挑…

AutoGen 技术博客系列 八:深入剖析 Swarm—— 智能体协作的新范式

本系列博文在掘金同步发布, 更多优质文章&#xff0c;请关注本人掘金账号&#xff1a; 人肉推土机的掘金账号 AutoGen系列一&#xff1a;基础介绍与入门教程 AutoGen系列二&#xff1a;深入自定义智能体 AutoGen系列三&#xff1a;内置智能体的应用与实战 AutoGen系列四&am…

力扣每日一题【算法学习day.132】

前言 ###我做这类文章一个重要的目的还是记录自己的学习过程&#xff0c;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非常非常高滴&#xff01;&#xff01;&#xff01; 习题 1.统计相似字符串对的数目 题目链…

C语言.h头文件的写法

头文件的内容 #ifndef __SEQUENCE_LIST_H // 定义以防止递归包含 #define __SEQUENCE_LIST_H // (1)、其它头文件 #include <stdio.h> #include <stdlib.h> #include <strings.h> #include <stdbool.h> // (2)、宏定义(函数、变量、常量) // (3)、…

Spring AI + Ollama 实现调用DeepSeek-R1模型API

一、前言 随着人工智能技术的飞速发展&#xff0c;大语言模型&#xff08;LLM&#xff09;在各个领域的应用越来越广泛。DeepSeek 作为一款备受瞩目的国产大语言模型&#xff0c;凭借其强大的自然语言处理能力和丰富的知识储备&#xff0c;迅速成为业界关注的焦点。无论是文本生…

自学Java-AI结合GUI开发一个石头迷阵的游戏

自学Java-AI结合GUI开发一个石头迷阵的游戏 准备环节1、创建石头迷阵的界面2、打乱顺序3、控制上下左右移动4、判断是否通关5、统计移动步骤&#xff0c;重启游戏6、拓展问题 准备环节 技术&#xff1a; 1、GUI界面编程 2、二维数组 3、程序流程控制 4、面向对象编程 ∙ \bulle…

C语言的内存分配:malloc和free

使用库函数分配和管理内存。在运行时&#xff0c;分配更多的内存给程序使用&#xff0c;主要工具是malloc函数&#xff0c;这个函数接受一个参数&#xff1a;所需要要的内存字节数。malloc函数会找到合适的空闲内存块&#xff0c;这样的内存是匿名的&#xff0c;即malloc分配了…

本地安装 Grafana Loki

本地安装 Grafana Loki 一、 安装 Loki1. 下载 Loki2. 创建 Loki 配置文件3. 创建 Loki 服务 二、安装 Promtail1. 下载 Promtail2. 创建 Promtail 配置文件3. 创建 Promtail 服务 三、 安装 Grafana四、启动所有服务五、添加loki 数据源1. 添加仪表板2. 日志查询面板 json 参考…

趣味数学300题1981版-十五个正方形

分析&#xff1a;移动两根变成11个正方形很简单&#xff1a; 移动4根变成15个正方形&#xff0c;分析&#xff1a; 一个田字格包含5个正方形&#xff0c;若要15个正方形需要3个田字格&#xff0c;如果3个田字格完全不重合&#xff0c;需要6*318根火柴。如果合并正方形的边&…

IDEA——Mac版快捷键

目录 按键含义常用组合代码生成快捷键&#xff1a;代码追踪快捷键&#xff1a;高效编辑快捷键&#xff1a;代码重构快捷键&#xff1a;工具类快捷键&#xff1a;常规文件操作快捷键&#xff1a; 按键含义 ⌘ command Command键&#xff08;⌘&#xff09;相当于Windows中的Con…

基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

Prompt:创造性的系统分析者

分享的提示词&#xff1a; 你是一个创造性的系统分析者&#xff0c;作为咨询师&#xff0c;你具有以下特质&#xff1a; 基础能力&#xff1a; 深入理解我的系统性模式 识别模式间的隐藏联系 发现出人意料的关联 提供令人惊讶的洞见 工作方式&#xff1a; 在每次回应中至少…