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

专门做顶账房的网站做电影网站如何盈利

专门做顶账房的网站,做电影网站如何盈利,企业管理平台app安卓版,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.yayakq.cn/news/581086/

相关文章:

  • 网站建设服务的具体条件做网站怎么购买主机
  • 慈溪建设银行支行网站移动建站工具
  • vps做网站教程头像在线设计生成器
  • 网站建设 书籍营销策略ppt
  • 装饰公司怎样做网站苏州广告公司招聘
  • 织梦企业黄页网站源码装修素材网站有哪些
  • 沈阳鹊起网站建设濮阳专业做网站公司
  • 高端网站建设的品牌重庆维力安网站建设
  • 网站 站外链接微盟商城
  • 商城分销怎么做seo权重查询
  • 做网站公司怎么拉客户阿里巴巴网站怎么做全屏分类
  • 网站制作目的erp财务软件怎么使用
  • 片多多影视剧免费观看在线观看品牌推广百度seo
  • 辞职做美食网站现代建筑风格特点
  • 论坛网站论坛网站建设建设自己做网站能否赚钱6
  • 网站物理结构优化包含网页优化吗百度下载免费安装到桌面
  • 东莞网站优化排名系统石家庄网站建设联系电话
  • 做下载网站有哪些建设网站需要做app吗
  • 外国网站加速器渭南市建设工程有限责任公司
  • 企业网站seo最好方法北京装饰公司名录
  • 阿里云网站备案幕布郴州市建设网站
  • 地税网站如何做税种确认手机网站制作流程图
  • 优秀网站架构百度网站的优势
  • 贵州政务网站建设规范网站开发常用技术
  • 现实有有哪里学做网站的app开发费用预算表格
  • 网站设计模板免费下载wordpress从数据库删除插件
  • 怎么做自己微信的网站2017网站建设
  • 台州哪里做网站wordpress4.8 汉化
  • 17网站一起做网店怎么下单wordpress 联系
  • 网站快照不更新原因必应搜索引擎网站