当前位置: 首页 > news >正文

免费网页设计制作网站网站建设不一定当地

免费网页设计制作网站,网站建设不一定当地,阿里云服务器学生机,html个人源码canvas绘制表格 最近在为公司产品做技术预研,经理让用canvas做一个表格,于是就有了这篇博客。 我们的数据是后端通过MQTT推送过来的 我在代码中也直接使用了 具体MQTT的实现代码,可见博客 在vue使用MQTT 在这里为了方便实用我直接封装成组件…

canvas绘制表格

最近在为公司产品做技术预研,经理让用canvas做一个表格,于是就有了这篇博客。

我们的数据是后端通过MQTT推送过来的
我在代码中也直接使用了
具体MQTT的实现代码,可见博客
在vue使用MQTT

在这里为了方便实用我直接封装成组件了,当MQTT数据来了就出发绘制方法

<template>  <div>  <!-- 画布元素,用于绘图 -->  <canvas ref="canvasRef" height="180" width="600"></canvas>  </div>  
</template>  <script setup>  
import {defineExpose, onMounted, ref} from 'vue';  
import UseMqtt from "../hooks/useMqtt.js"; // 引入MQTT通信的自定义hook  // 画布引用  
const canvasRef = ref(null);  
// 画布上下文  
const ctx = ref(null);  
// 存储接收到的数据  
const data = ref([]);  
// 行高  
const rowHeight = 30;  
// 当前偏移量,用于控制画布滚动  
const currentOffset = ref(30);  // 数据格式示例  
/*[{  "hx": 56,  "szy": 77,  "xl": 74,  "ssy": 122,  "xybhd": 0.36  
}]*/  /**  * 绘制函数,用于在画布上绘制表格  */  
const drawTable = () => {  const canvas = canvasRef.value;  ctx.value = canvas.getContext('2d');  ctx.value.clearRect(0, 0, canvas.width, canvas.height); // 清除画布  ctx.value.fillStyle = 'black'; // 设置填充颜色  ctx.value.font = '16px Arial'; // 设置字体  // 绘制列标题  const headers = ["hx", "szy", "xl", "ssy", "xybhd"];  headers.forEach((header, index) => {  ctx.value.fillText(header, index * 120, rowHeight);  });  // 绘制数据行  data.value.forEach((item, rowIndex) => {  const y = (rowIndex + 1) * rowHeight + currentOffset.value;  if (y < canvas.height) {  Object.values(item).forEach((value, colIndex) => {  ctx.value.fillText(value, colIndex * 120, y);  });  }  });  
};  onMounted(() => {  drawTable(); // 组件挂载后绘制表格  
});  const options = {  subscription: {topic: "/testtopic/yq", qos: 0} // MQTT订阅配置  
}  
const {  createAndDo,  destroyConnection  
} = UseMqtt(options, getMessage); // 使用MQTT hook,并传入消息处理函数  /**  * 接收消息  * @param v 接收到的消息  */  
function getMessage(v) {  try {  data.value.push(JSON.parse(v)) // 解析并存储消息  if (data.value.length >= 5) {  data.value.shift() // 如果数据超过5条,移除最旧的一条  }  drawTable(); // 重新绘制表格  } catch (e) {  console.error(e) // 错误处理  }  
}  onMounted(() => {  createAndDo() // 组件挂载后建立MQTT连接并开始接收消息  
})  defineExpose({  destroyConnection, // 暴露销毁MQTT连接的方法  createAndDo // 暴露建立并开始MQTT连接的方法  
})  
</script>

效果图

http://www.yayakq.cn/news/946299/

相关文章:

  • wordpress关闭站点网站推广效果怎么样
  • 巴中市做网站根据网站集约化建设的要求
  • 网站建设整体解决方案山西网站推广公司
  • 建设厅查询网站进网站备案
  • 建站模板招募设计师外贸是做什么的经营范围
  • 邢台做网站信息春花直播
  • 济宁网站建设软件建设协会官方网站
  • 做网站论坛赚钱住建部网站村镇建设管理平台
  • 建设企业网站专业服务php 网站部署后乱码
  • 杭州网站建设技术企业站系统
  • 环保工程网站建设价格wordpress和typecho
  • 湖北黄石网站建设开发帮官方网站
  • 合肥网站设计建互联网营销师报考
  • 宁波网站建设运营h5页面制作多少钱
  • 做玄幻封面素材网站政务服务大厅网站建设方案
  • 做app模板网站安卓应用商店下载
  • 课程网站怎么做公司部门职能介绍
  • 怎么做网络彩票网站精湛的企业网站建设
  • 中医网站开发长春网站建设联系吉网传媒优
  • 网站开发教程视频百度云资源wordpress附件下载失败
  • 鼓楼公司网站建设费用怀来县建设局网站
  • 企业网站建设费用预算企业网站建站意义
  • vs2013做网站wordpress文章如何匪类
  • 做外链的博客网站备案网站内容说明
  • 做网站文章要一篇一篇的写吗如何建英文网站
  • 如何区分官方网站和空壳网站手机网站跟PC端网站有啥区别
  • 网站都有哪些类型方维制网站
  • 湖南鸿泰电力建设有限公司网站vue.js网站建设
  • .网站建设课程设计广州市品牌网站建设怎么样
  • 乌兰浩特网站制作推广策划方案怎么做