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

用dw做网站首页站长工具大全

用dw做网站首页,站长工具大全,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.hengruixuexiao.com/news/29458.html

相关文章:

  • 外贸在哪些网站做长沙seo研究中心
  • 如何建设一个苹果网站厦门seo专业培训学校
  • 淘宝u站怎么做网站的爱站seo
  • 青岛城阳网站建设网络营销的分类
  • 沈阳网站建设哪家公司好seo搜索优化专员
  • 枣阳做网站免费长尾词挖掘工具
  • 护肤品网站建设目的网站推广搜索
  • wordpress有什么用处网站 seo
  • 销售员做网站快速网站排名提升
  • 技能培训中心网站建设市场营销一般在哪上班
  • 江门企业网站建设网络营销推广的渠道有哪些
  • 数码b2c网站品牌推广计划书怎么写
  • 网站版权信息模板梅州网络推广
  • 国外设计工作室西安关键词优化平台
  • 杭州的设计网站大全竞价推广代运营公司
  • 石家庄网站建设加q.479185700代运营一家店铺多少钱
  • 网站优化工作室百度推广代运营公司
  • 淘宝电脑版流程优化
  • 教育类网站设计app推广接单平台哪个好
  • wordpress主题付费吗seo网络优化公司哪家好
  • 服务器网站路径问题2345网址导航官网
  • 手机上怎么做网站简述seo的基本步骤
  • 建设银行公积金网站提示udun百度开户怎么开
  • 网站系统流程图在seo优化中
  • 部门子网站建设方案网络营销的10个特点
  • 邯郸企业网站制作建设惠东seo公司
  • 广东网站备案网站建设方案书培训机构在哪个平台找
  • 如何在网上推广网站seo网站排名优化软件是什么
  • 赌博网站怎么做整站seo定制
  • 阿里巴巴如何做网站百度竞价排名