效果
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style>
canvas {
border: 1px solid black;
}
</style>
</head>
<body>
<canvas id="myCanvas" width="1000" height="500"></canvas>
<script>
var canvas = document.getElementById("myCanvas");
var ctx = canvas.getContext("2d");
var backgroundImage = new Image();
backgroundImage.src = "../img.jpg";
backgroundImage.onload = function () {
ctx.drawImage(backgroundImage, 0, 0, canvas.width, canvas.height);
// 根据后端接口返回的定位数据渲染
var dataList = [
{ x: 125, y: 125, width: 100, height: 100 },
{ x: 303, y: 90, width: 100, height: 100 },
{ x: 490, y: 130, width: 100, height: 100 },
{ x: 695, y: 140, width: 100, height: 100 },
{ x: 830, y: 110, width: 100, height: 100 },
];
dataList.forEach(function (rect) {
ctx.fillStyle = "transparent";
ctx.strokeStyle = "red";
ctx.lineWidth = 2;
ctx.fillRect(rect.x, rect.y, rect.width, rect.height);
ctx.strokeRect(rect.x, rect.y, rect.width, rect.height);
});
};
</script>
</body>
</html>