水库大坝浸润线绘制

devtools/2024/12/27 19:20:40/

先看效果
在这里插入图片描述

直接上代码(vue环境)

<template><div id="canvas-continer" class="h100 w100 mt4"><canvas  ref="canvas" id="canvas" class="canvas"></canvas></div>
</template><script lang="ts" setup>
import { onMounted, ref } from 'vue'
import damSrc from './dam2.png'
const canvas = ref()
let ctx = ref()
let canvasWidth = ''
let canvasHeight = ''
const initContext = () => {ctx.value = canvas.value.getContext('2d')
}function resize_canvas() {let continer:any = document.getElementById('canvas-continer')canvas.value.width = continer.offsetWidth;canvas.value.height = continer.offsetHeight;canvasWidth = canvas.value.widthcanvasHeight = canvas.value.height}const drawdampic = () => {const image = new Image()image.src = damSrcimage.onload = () => {ctx.value.drawImage(image, 0, 40, canvasWidth, canvasHeight)drawlserve()}
}
const drawwater = () => {ctx.value.fillStyle = '#73BCD7'ctx.value.fillRect(0, 245,800, 400)ctx.value.fillStyle = '#73BCD7'// ctx.value.fillRect(200, 80, 160, 60)
}
const drawlserve = () => {ctx.value.fillStyle = 'white'ctx.value.fillRect(800, 40, 10, 500)ctx.value.fillRect(980, 240, 10, 300)ctx.value.fillStyle = '#77C8E6'ctx.value.fillRect(800, 365, 10, 300)ctx.value.fillRect(980, 435, 10, 345)drawY()drawLine()
}
const drawY = () => {// 绘制坐标轴ctx.value.beginPath();// X 轴ctx.value.moveTo(0, 40);ctx.value.lineTo(0, 500);ctx.value.strokeStyle = 'white';ctx.value.fillStyle = 'white'; // 设置文本填充颜色ctx.value.lineWidth = 3;for (let i = 0; i < 21; i++) {ctx.value.moveTo(0, 40 + i * 23);ctx.value.lineTo(10, 40 + i * 23);ctx.value.fillText(98-(i), 20, 40 + i * 23)ctx.value.moveTo(0, 40 + i * 23);ctx.value.lineTo(-10, 40 + i * 23);}// Y坝底ctx.value.moveTo(0, 500);ctx.value.lineTo(1450, 500);ctx.value.stroke()deawLabel()
}
const deawLabel = () => {ctx.value.fillStyle = 'white'ctx.value.font = '13px Arial';ctx.value.fillText('坝顶高程:98m', 600, 15)ctx.value.beginPath()ctx.value.lineWidth = 1;ctx.value.strokeStyle = 'white';ctx.value.moveTo(640, 22);ctx.value.lineTo(640, 40);ctx.value.stroke()ctx.value.fillStyle = 'red'ctx.value.fillText('校核洪水位:95.44m',120, 80)ctx.value.beginPath()ctx.value.strokeStyle = 'red';ctx.value.lineWidth = 0.6;ctx.value.moveTo(0, 100);ctx.value.lineTo(80, 100);ctx.value.lineTo(120, 80);ctx.value.stroke()ctx.value.fillStyle = 'yellow'ctx.value.fillText('设计洪水位:94.72m', 122, 130)ctx.value.beginPath()ctx.value.strokeStyle = 'yellow';ctx.value.lineWidth = 0.4;ctx.value.moveTo(0, 130);ctx.value.lineTo(120, 130);ctx.value.stroke()ctx.value.fillStyle = 'rgb(4 154 184)'ctx.value.fillText('正常蓄水位:92.78m', 122, 200)ctx.value.beginPath()ctx.value.strokeStyle = 'rgb(4 154 184)';ctx.value.lineWidth = 0.4;ctx.value.moveTo(0, 180);ctx.value.lineTo(80, 180);ctx.value.lineTo(120, 200);ctx.value.stroke()ctx.value.fillStyle = 'white'//坝前水位变量控制ctx.value.fillText('坝前水位:89.44m', 120, 260)ctx.value.fillText('死水位:85.m', 70, 340)ctx.value.beginPath()ctx.value.strokeStyle = 'white';ctx.value.lineWidth = 0.4;ctx.value.moveTo(0, 340);ctx.value.lineTo(70,340);ctx.value.stroke()ctx.value.save()
//断面
ctx.value.fillText('断面:B0+27', 550, 200)//孔口高程ctx.value.beginPath()ctx.value.strokeStyle = 'red';ctx.value.lineWidth = 1;ctx.value.moveTo(810, 40);ctx.value.lineTo(830,20);ctx.value.lineTo(950, 20);ctx.value.stroke()ctx.value.fillText('P1 (渗压系数:0664)', 830, 15)ctx.value.strokeStyle = 'red';ctx.value.lineWidth = 1;ctx.value.moveTo(990, 240);ctx.value.lineTo(1020,220);ctx.value.lineTo(1120, 220);ctx.value.stroke()ctx.value.fillText('管口高程:90m', 1020, 215)//孔底高程ctx.value.fillText('孔底高程:78m', 820, 540)ctx.value.fillText('孔底高程:78m', 1000, 540)
//浸润高程
ctx.value.beginPath()ctx.value.strokeStyle = 'white';ctx.value.lineWidth = 1;ctx.value.moveTo(800, 365);ctx.value.lineTo(750,300);ctx.value.lineTo(700,300);ctx.value.stroke()
ctx.value.fillText('85 m', 698,296)
ctx.value.lineWidth = 1;ctx.value.moveTo(980, 435);ctx.value.lineTo(940,350);ctx.value.lineTo(900,350);ctx.value.stroke()
ctx.value.fillText('82 m', 897,345)//坝底高程
ctx.value.fillText('坝底高程:78.56m', 40, 540)
}
const drawLine = () => {//变量控制ctx.value.beginPath()ctx.value.moveTo(315, 245)ctx.value.lineTo(800, 365)ctx.value.lineTo(800, 365)ctx.value.lineTo(980, 435)ctx.value.lineTo(1230, 501)ctx.value.setLineDash([5, 5]);ctx.value.strokeStyle = '#77C8E6'ctx.value.lineWidth = 2;ctx.value.stroke()drawPoint()
}
const drawPoint = () => { // 三角形的顶点const A = { x: 315, y: 245 };const B = { x: 100, y: 498 };const C = { x: 1225, y: 500 };// 绘制三角形function drawTriangle() {// ctx.value.beginPath();// ctx.value.moveTo(A.x, A.y);// ctx.value.lineTo(B.x, B.y);// ctx.value.lineTo(C.x, C.y);// ctx.value.closePath();// ctx.value.stroke();}// 在三角形内生成一个随机点function getRandomPointInTriangle(A:any, B:any, C:any) {let r1 = Math.random();let r2 = Math.random();// 确保点在三角形内部if (r1 + r2 > 1) {r1 = 1 - r1;r2 = 1 - r2;}const x = A.x + r1 * (B.x - A.x) + r2 * (C.x - A.x);const y = A.y + r1 * (B.y - A.y) + r2 * (C.y - A.y);return { x, y };}// 在三角形内生成多个随机点并绘制function drawRandomPointsInTriangle(count:number) {for (let i = 0; i < count; i++) {const point = getRandomPointInTriangle(A, B, C);ctx.value.beginPath();ctx.value.fillStyle = '#73BCD7';ctx.value.arc(point.x, point.y, 2, 0, Math.PI * 2);ctx.value.fill();}}// 主流程drawTriangle();drawRandomPointsInTriangle(5000); // 生成 100 个随机点
}
onMounted(() => {initContext()resize_canvas()drawwater()drawdampic()
})
</script><style scoped lang="scss">
.container-canvas {width: 1000px;height: 500px;
}
</style>

http://www.ppmy.cn/devtools/145562.html

相关文章

Java如何避免过度打印日志导致性能问题

文章目录 Java如何避免过度打印日志导致性能问题前言日常开发如何打印日志1、优化日志结构&#xff08;1&#xff09;不要打印一些没用的日志&#xff0c;也不要在 for 循环里面去打印&#xff08;2&#xff09;不要做字符串的拼接&#xff0c;多用占位符&#xff08;3&#xf…

成功解决GPU和Cuda环境下执行torch.__version__输出2.0.1+cpu而不是正确版本(如2.1.0+cu121)等类似问题?

成功解决GPU和Cuda环境下执行torch.__version__输出2.0.1+cpu而不是正确版本(如2.1.0+cu121)等类似问题? 目录 解决问题 解决思路 T1、安装了CPU版本的PyTorch T2、环境问题 解决方法 重新安装 再次测试 解决问题 GPU和Cuda环境下执行torch.__version__输出2.0.1+cpu而…

游戏引擎学习第58天

发现一个vscode Log 断点的用法 回顾 我们正在继续推进工作&#xff0c;之前做了一些测试和清理工作&#xff0c;但还有一件事没有完成&#xff0c;因此我们还没有完全回到功能平衡的状态。昨天我们已经为实体做了空间划分&#xff0c;所以接下来的目标是继续完成这部分工作&a…

HarmonyOS NEXT 实战之元服务:静态案例效果---电台推荐

背景&#xff1a; 前几篇学习了元服务&#xff0c;后面几期就让我们开发简单的元服务吧&#xff0c;里面丰富的内容大家自己加&#xff0c;本期案例 仅供参考 先上本期效果图 &#xff0c;里面图片自行替换 效果图1完整代码案例如下&#xff1a; Index import { authentica…

怎样正确做 Web 应用的压力测试?

Web应用&#xff0c;通俗来讲就是一个网站&#xff0c;主要依托于浏览器来访问其功能。 那怎么正确做网站的压力测试呢&#xff1f; 提到压力测试&#xff0c;我们想到的是服务端压力测试&#xff0c;其实这是片面的&#xff0c;完整的压力测试包含服务端压力测试和前端压力测…

音视频入门知识(五):流媒体篇

⭐五、流媒体篇 ES流&#xff08;基本流&#xff09; 在视频或音频编码后&#xff0c;最初得到的就是ES流。例如H.264、H.265、AAC、MP3等编码格式 单一性&#xff1a;每个ES流只包含一种类型的数据&#xff0c;如编码后的视频帧或音频帧。 无时间戳&#xff1a;ES流本身不包含…

探秘 DNS 服务器:揭开域名解析的神秘面纱

嘿&#xff0c;小伙伴们&#xff01;在我们畅游互联网的奇妙世界时&#xff0c;有没有想过&#xff0c;当我们在浏览器中输入那些熟悉的网址&#xff0c;比如b站&#xff0c;是如何瞬间就能访问到对应的网站呢&#xff1f;这背后的魔法就来自于一个超级重要的网络基础设施 ——…

02-18.python入门基础一基础算法

&#xff08;一&#xff09;排序算法 简述&#xff1a; 在 Python 中&#xff0c;有多种常用的排序算法&#xff0c;下面为你详细介绍几种常见的排序算法及其原理、实现代码、时间复杂度以及稳定性等特点&#xff0c;并对比它们适用的场景。 冒泡排序&#xff08;Bubble Sor…