Canvas 允许使用直线、曲线、矩形、圆形等基本图形绘制出复杂的图形
Canvas 可以加载图像,并进行各种处理,如裁剪、缩放、旋转等操作
Canvas 可以通过 JavaScript 控制,所以你可以利用帧动画原理,在画布上连续绘制图形,从而实现流畅的动画效果。
Canvas 提供了强大的绘图能力,使得将复杂的数据以图表或图形的方式展示变得更加容易。你可以绘制柱状图、折线图、饼状图等,以直观的方式展示数据
上下文对象可以理解为画笔,画布建好了,然后再准备好画笔 是不是就可以开画拉
const canvas = document.querySelector('#canvas')
canvas.height = window.innerHeight
canvas.width = window.innerWidth
const ctx = canvas.getContext(‘2d’)
ctx.fillStyle = 'red'
ctx.fillRect(0, 0, 500, 500)
就完成一个最简单的绘制:
beginPath()
: 这个方法用于开始一个新的路径,相当于重置了路径的起点和样式。
closePath()
: 这个方法将路径的最后一个点与路径起点连接,形成封闭的图形。
moveTo(50, 100)
:起点坐标 (x, y)
lineTo(200, 50)
:下一个点的坐标 (x, y)
stroke()
: 这个方法用于描边路径,将上面的坐标用一条线连接起来
fill()
: 这个方法用于填充路径所包围的区域,采用当前路径样式的设置(例如填充的颜色)
lineWidth
:线的粗细
strokeStyle
:线的颜色
lineCap
:线帽:默认: butt
; 圆形: round
; 方形: square
详细可看:
Canvas 从入门到劝朋友放弃(图解版)✨ - 知乎
function updateTime() {
var now = new Date();
var today = now.toDateString();
var time = now.toLocaleTimeString();
var hours = now.getHours();
var minutes = now.getMinutes();
var seconds = now.getSeconds();
var minutesString = minutes.toString().padStart(2, '0')
var secondsString = seconds.toString().padStart(2, '0');
var timeString = hours + ":" + minutesString + ":" + secondsString;
$("h1").text(timeString);
}
updateTime()
setInterval(updateTime, 1000);
var minutesString = minutes.toString().padStart(2, '0')
这段代码的作用是将分钟数和秒数转换为字符串,并在字符串长度不足2位时,在字符串前面填充0
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
// 线条宽度、线条末端样式、阴影模糊度
ctx.lineWidth = 15;
ctx.lineCap = "round";
ctx.shadowBlur = 15;
// 将角度值转换为弧度值
function degToRad(degree) {
var factor = Math.PI / 180;
return degree * factor;
}
// 转换数值 360度转换成24份,并修正从0点开始
function convertNum(num) {
return degToRad(num * 15 - 90);
}
function draw() {
ctx.strokeStyle = "#42dfbf";
ctx.shadowColor = '#95e0d1';
// 创建了一个径向渐变对象
gradient = ctx.createRadialGradient(100, 100, 50, 100, 100, 150);
ctx.fillStyle = gradient;
ctx.fillRect(0, 0, 400, 400);
// 0点到3点
// beginPath 开始一个新的绘图路径
ctx.beginPath();
// arc 方法绘制了一个弧线
ctx.arc(200, 200, 170, convertNum(0), convertNum(4));
// stroke 方法绘制出刻度线
ctx.stroke();
// 7到8
ctx.beginPath();
ctx.arc(200, 200, 170, convertNum(7), convertNum(8));
ctx.stroke();
// 14-16
ctx.beginPath();
ctx.arc(200, 200, 170, convertNum(14), convertNum(16));
ctx.stroke();
}
draw();
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
// 线条宽度、线条末端样式、阴影模糊度
ctx.lineWidth = 15;
ctx.lineCap = "round";
ctx.shadowBlur = 15;
// 将角度值转换为弧度值
function degToRad(degree) {
var factor = Math.PI / 180;
return degree * factor;
}
// 绘制表盘刻度线
function drawClockFace() {
ctx.shadowColor = '#40b7c6';
ctx.strokeStyle = "#90bdc3";
for (var i = 0; i < 24; i++) {
var angle = degToRad(i * 15 - 90);
ctx.beginPath();
ctx.arc(200, 200, 170, angle, angle + degToRad(0.5));
if (i % 3 === 0) {
// 绘制文本
ctx.save();
ctx.translate(200, 200); // 将坐标原点移动到表盘中心
ctx.rotate(angle + Math.PI / 2); // 旋转文本使其与刻度对齐
ctx.textAlign = "center";
ctx.font = "bold 20px Arial";
ctx.fillStyle = "#fff";
ctx.fillText(i.toString(), 0, -163); // 在指定位置绘制文本
ctx.restore();
} else {
// 绘制圆点
ctx.stroke();
}
}
}
drawClockFace();
Document
Document
你好
效果图:
完整代码:
Document