
在网页浏览器中绘制并标注三角形
本文介绍如何在浏览器中绘制三角形并标注其边长和角度。 有多种方法可实现此功能,各有优劣:
-
CSS
paint()函数: 适用于简单图形,效果相对较弱。 - Canvas API: 使用 JavaScript 的 Canvas API,功能强大,可绘制复杂的图形并添加交互性。
- SVG: 基于 XML 的矢量图形标准,适合绘制精细、可缩放的图形。
对于已知边长和角度的三角形,推荐使用 Canvas 或 SVG。 下面是一个使用 Canvas API 的示例:
// 创建画布元素
const canvas = document.createElement('canvas');
canvas.width = 400;
canvas.height = 400;
document.body.appendChild(canvas);
const ctx = canvas.getContext('2d');
// 定义三角形顶点坐标
const A = { x: 50, y: 300 };
const B = { x: 250, y: 300 };
const C = { x: 150, y: 100 };
// 绘制三角形
ctx.beginPath();
ctx.moveTo(A.x, A.y);
ctx.lineTo(B.x, B.y);
ctx.lineTo(C.x, C.y);
ctx.closePath();
ctx.stroke();
// 计算边长
function distance(p1, p2) {
return Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2));
}
const AB = distance(A, B);
const BC = distance(B, C);
const CA = distance(C, A);
// 计算角度(弧度转角度)
function angle(p1, p2, p3) {
const a = distance(p2, p3);
const b = distance(p1, p3);
const c = distance(p1, p2);
return Math.acos((a * a + b * b - c * c) / (2 * a * b)) * 180 / Math.PI;
}
const angleA = angle(B, A, C);
const angleB = angle(C, B, A);
const angleC = angle(A, C, B);
// 添加标注
ctx.font = '14px Arial';
ctx.fillText(`AB = ${AB.toFixed(2)}`, (A.x + B.x) / 2, (A.y + B.y) / 2 + 20);
ctx.fillText(`BC = ${BC.toFixed(2)}`, (B.x + C.x) / 2, (B.y + C.y) / 2 + 20);
ctx.fillText(`CA = ${CA.toFixed(2)}`, (C.x + A.x) / 2, (C.y + A.y) / 2 + 20);
ctx.fillText(`∠A = ${angleA.toFixed(2)}°`, A.x - 20, A.y - 20);
ctx.fillText(`∠B = ${angleB.toFixed(2)}°`, B.x, B.y - 20);
ctx.fillText(`∠C = ${angleC.toFixed(2)}°`, C.x, C.y + 30);
这段代码会在页面上绘制一个三角形,并显示其边长和角度。 你可以根据需要修改顶点坐标来改变三角形的形状和大小。 记住需要将这段代码嵌入到标签中,并确保你的HTML页面包含元素。 或者,你可以创建一个新的HTML文件,将代码粘贴进去,然后在浏览器中打开该文件。










