HTML5 Canvas(画布)

<canvas>标签定义图形,比如图表和其他图像,你必须用脚本来绘制图形。

在画布上( Canvas )画一个共红色矩形,渐变矩形,彩色矩形,和一些彩色文字。

什么是 Canvas?

HTML5<canvas>元素用于图形绘制,通过脚本(通常是 Javascript)来完成。

<canvas>标签是图形容器,必须使用脚来绘制图形。

你可以通过很多方法使用canvas来绘制路径,盒,圆、字符以及图像。

创建一个画布( Canvas )

一个画布在网页中是一个矩形框通过 <canvas> 元素来绘制。

注意:默认情况下<canvas>元素没有边框内容

<canvas简单实例如下:

html 复制代码
<canvas id="mycanva" width="200px" height="200px"></canvas>

注意:标签通常需要一个指定 id 属性( 脚本中经常引用 ),width 和 height属性定义的画布的大小,也可以使用 style属性添加边框。

使用 Javascript 来绘制图像

canvas 元素本身是没绘图能力。所有的绘制工作必须在 Javascript 内完成

javascript 复制代码
var canvas = documnet.getElementById("mycancas")

var ctx = canvas.getContext('2d')

ctx.fillStyle = '#000000'

// fillStyle :属性是填充 CSS背景 渐变  默认是:"#000000"


ctx.fillRect(0,0,150,75) 

/*
参数1:x坐标
参数2:y坐标
参数3:宽
参数4:高
*/

canvas坐标

canvas是一个二维网格

canvas的左上角坐标为(0,0)

上面的 fillRect 方法拥有参数(0,0,,150,75)

意思是:在画布上绘制 150*75的图形,从左上角(0,0)开始

坐标实例

如下图所示,画布的 X 和 Y 坐标用于在画布上对绘画进行定位。鼠标移动的矩形框上,显示定位坐标。

Canvas - 路径

在 canvas 上画线,我们可以使用这两种方法:

moveTo(x,y)定义线条开始坐标

lineTo(x,y)定义线条结束坐标

strock()绘制线条的方法

javascript 复制代码
var canvvas = document.getElementById('mycanvas')

var ctx = canvas.getContext('2d')

//绘制坐标的起始位置  参数一:x轴  参数二:y轴

ctx.moveTo(0,0)

//绘制坐标的结束位置  参数一:x轴  参数二:y轴

ctx.lineTo(200,100)

//开始绘制图表

ctx.stroke()

在 canvas 中绘制图形,我可以将方法以下方法:

arc(x,y,r,start,stop)

实际上我们可以 strke() 或者 fill()

使用 arc() 方法绘制一个圆:

javascript 复制代码
var canvas = documnet.getElementById('mycanvas')

var ctx = canvas.getContext('2d')

// 使用 beginPath() 开始绘画

ctx.beginPath()

// 使用 arc() 开始绘制

ctx.arc(150,40,20,0,2*Math*PI)

/*
参数一:x轴的位置
参数二:y轴的位置
参数三:半径的位置
参数四:圆的起始位置
参数五:圆的结束位置
*/

// 结束绘画

ctx.stroke()

Canvas - 文本

使用 canvas 绘制文本,重要的属性和方法如下:

font - 定义字体

filltext( text,x,y ):在 canvas 上绘制实心的文本

sreokeText( text,x,y ):在 canvas 上绘制空心的文本

javascript 复制代码
// 绘制实心的文本

var canvas = document.getElementById('mycanvas')

var ctx = canvas.getContext('2d')

// 字体大小为 30 px

ctx.font = '30px Arial'

ctx.fillText(' Eoklee ',15,50)

/*
fillText()
参数一:添加文字的内容
参数二:x轴的位置
参数三:y轴的位置
*/

// 绘制空心的文本

var canvas = document.getElementById('mycanvas')

var ctx = canvas.getContext('2d')

// 字体大小为 30 px

ctx.font = '30px Arial'

ctx.strokeText(' Eoklee ',15,50)

/*
strokeText()
参数一:添加文字的内容
参数二:x轴的位置
参数三:y轴的位置
*/-
相关推荐
极客密码4 小时前
感谢雷总!Mimo大模型价值¥659/月的 MAX 套餐,让我免费领到了!
前端·ai编程·claude
深念Y5 小时前
我明白为什么B站没法在浏览器开直播了——Windows Chrome推流踩坑全记录
前端·chrome·webrtc·浏览器·srs·直播·flv
zhangxingchao5 小时前
AI应用开发七:可以替代 RAG 的技术
前端·人工智能·后端
Sun@happy6 小时前
现代 Web 前端渗透——基础篇(1)
前端·web安全
希冀1236 小时前
【CSS学习第十一篇】
前端·css·学习
隔窗听雨眠6 小时前
doctype、charset、meta如何控制整个渲染流水线
java·服务器·前端
kyriewen6 小时前
写组件文档写到吐?我用AI自动生成Storybook,同事以后直接抄
前端·javascript·面试
excel7 小时前
🧠 Prisma 表名大写 vs SQL 导出小写问题深度解析(附踩坑与解决方案)
前端·后端
周淳APP7 小时前
【前端工程化原理通识:从源头到运行时的理论阐述】
前端·编译·打包·前端工程化
五点六六六7 小时前
你敢信这是非Native页面写出来的渐变效果吗🌝(底层原理解析
前端·javascript·面试