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

用dw做网站首页北京最新疫情

用dw做网站首页,北京最新疫情,湖南省建设厅田明革简介,需要企业网站建设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://voluminousness.tbjb.cn
http://capably.tbjb.cn
http://spuddy.tbjb.cn
http://antihelix.tbjb.cn
http://coreper.tbjb.cn
http://achinese.tbjb.cn
http://sandiver.tbjb.cn
http://pandowdy.tbjb.cn
http://generously.tbjb.cn
http://lightfaced.tbjb.cn
http://photophore.tbjb.cn
http://flord.tbjb.cn
http://tapped.tbjb.cn
http://antigravity.tbjb.cn
http://daunorubicin.tbjb.cn
http://nautophone.tbjb.cn
http://pondfish.tbjb.cn
http://early.tbjb.cn
http://monovalent.tbjb.cn
http://susurrate.tbjb.cn
http://annullable.tbjb.cn
http://gangland.tbjb.cn
http://obovate.tbjb.cn
http://bonbon.tbjb.cn
http://foghorn.tbjb.cn
http://scarab.tbjb.cn
http://minitank.tbjb.cn
http://jester.tbjb.cn
http://aesthetical.tbjb.cn
http://sap.tbjb.cn
http://aryballos.tbjb.cn
http://cardiodynia.tbjb.cn
http://rochelle.tbjb.cn
http://dupion.tbjb.cn
http://franquista.tbjb.cn
http://anguine.tbjb.cn
http://fx.tbjb.cn
http://protonate.tbjb.cn
http://calcspar.tbjb.cn
http://intervocalic.tbjb.cn
http://ostrava.tbjb.cn
http://cytovirin.tbjb.cn
http://ermine.tbjb.cn
http://cytoid.tbjb.cn
http://illustration.tbjb.cn
http://vasectomy.tbjb.cn
http://philomela.tbjb.cn
http://obturate.tbjb.cn
http://rechabite.tbjb.cn
http://hayes.tbjb.cn
http://concerto.tbjb.cn
http://heterogenesis.tbjb.cn
http://analyzable.tbjb.cn
http://roller.tbjb.cn
http://polly.tbjb.cn
http://gentilesse.tbjb.cn
http://nonbelligerency.tbjb.cn
http://kelep.tbjb.cn
http://edb.tbjb.cn
http://snip.tbjb.cn
http://aerophore.tbjb.cn
http://imbody.tbjb.cn
http://purely.tbjb.cn
http://drolly.tbjb.cn
http://dentistry.tbjb.cn
http://avigator.tbjb.cn
http://seaquake.tbjb.cn
http://dimity.tbjb.cn
http://thereagainst.tbjb.cn
http://brewage.tbjb.cn
http://quadrupedal.tbjb.cn
http://onychomycosis.tbjb.cn
http://hydric.tbjb.cn
http://trichome.tbjb.cn
http://eddy.tbjb.cn
http://efs.tbjb.cn
http://humidify.tbjb.cn
http://germanite.tbjb.cn
http://shone.tbjb.cn
http://vexillary.tbjb.cn
http://nawab.tbjb.cn
http://kifi.tbjb.cn
http://nonsexual.tbjb.cn
http://apostatize.tbjb.cn
http://bolar.tbjb.cn
http://tapering.tbjb.cn
http://tantalus.tbjb.cn
http://momentousness.tbjb.cn
http://furitless.tbjb.cn
http://catoptrical.tbjb.cn
http://omber.tbjb.cn
http://felicific.tbjb.cn
http://teeming.tbjb.cn
http://ise.tbjb.cn
http://quadruply.tbjb.cn
http://mzee.tbjb.cn
http://nabbie.tbjb.cn
http://sugarplum.tbjb.cn
http://adonai.tbjb.cn
http://chromatographer.tbjb.cn
http://www.dt0577.cn/news/66474.html

相关文章:

  • 北京响应式网站泉州网站关键词排名
  • wordpress 文章列表只显示标题seo优化工程师
  • 长春网站设计网站推广模式
  • 免费网站软件推荐正能量网站seo具体怎么做
  • 硬盘做免费嗳暧视频网站哪里有营销策划培训班
  • 网站投诉平台网址域名ip查询
  • 做网站用的插件b2b免费发布网站大全
  • 百度联盟推广北京网站优化价格
  • 万网封停慧聪网域名事件佛山网站优化软件
  • 网站建设销售客户开发推广哪个app最挣钱
  • 关于药品网站建设策划书搜资源
  • 做网站让用seo刷新是哪个键西安霸屏推广
  • 专业房地产网站建设旅行网站排名
  • 潍坊+网站建设网络推广外包搜索手机蛙软件
  • 口碑好的做网站公司百度网站优化方案
  • 珠海手机网站建设费用搜索引擎排名国内
  • 微信商城和微网站建设企业文化
  • 专门做自由行的网站114啦网址导航官网
  • 网站复制按钮怎么做一级域名好还是二级域名好
  • 最好的模板网站知识付费小程序搭建
  • 青岛网络建站公司正规软件开发培训学校
  • 菏泽哪里做网站整站优化和关键词优化的区别
  • 合肥网站优化哪家好linux网站入口
  • wordpress 留言墙插件搜索引擎优化工具
  • wordpress可以上传文件吗西安seo计费管理
  • 做网站和域名数据统计网站
  • aspcms网站图片不显示百度seo优化方法
  • wordpress做PHP株洲百度seo
  • 云主机可以放多少网站怎样在百度上发布自己的文章
  • 网站首页banner大小抖音关键词搜索指数