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

用dw做网站首页网页设计与制作代码成品

用dw做网站首页,网页设计与制作代码成品,wordpress 商品分类,厦门国外网站建设公司哪家好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.shuangfujiaoyu.com/news/50909.html

相关文章:

  • 有关网站开发的论文网站优化名词解释
  • 如何做软件类型的网站北京网站优化实战
  • 临沂网站建设咨询百度提交网址
  • 搭一个网站揭阳百度seo公司
  • wordpress 自带播放器怎么把网站排名优化
  • 网站做海康直播成都今天宣布的最新疫情消息
  • 工信部备案网站查询营销软件商城
  • 外贸手机网站建设整合营销沟通
  • 帮人做网站一个多少钱网站关键词优化系统
  • 搭建免费个人网站2022新手如何涨1000粉
  • 优酷网站谁做的百度关键词点击
  • 爱名网做网站教程深圳搜索seo优化排名
  • 政府门户网站建设管理工作视频号直播推广二维码
  • 手机代理ip免费网址企业怎么做好网站优化
  • 佛山网站推广学新媒体运营最好的培训学校
  • 孝义网站建设电子制作网站
  • 仿wordpress长沙seo霜天
  • 电子商务网站建设与实例google chrome官网
  • 做金融网站需要什么营业执照电脑培训学校排名
  • 网站排名易下拉系统百度网盘手机app下载安装
  • 大型外包公司有哪些西安关键词排名优化
  • 做百度还是阿里网站好汕头网站建设方案外包
  • 校园网站系统建设需求企业自助建站
  • 十大不充钱的手游香港seo公司
  • 深圳政府门户网站设计亮点网站正能量免费推广软件
  • 定制型网站一般价格seo搜索排名优化是什么意思
  • 建站专业团队一站式服务新疆今日头条新闻
  • jsp网站怎么运行seo优化技术
  • 长沙建设信息中心网站百度搜索如何去广告
  • 做实体上什么网站找项目2023年时政热点事件