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

微信小程序canvas画布如何解决在for循环绘制图像显示不全的问题

如下所示,在for循环中绘制图像,由于onload函数加载图像是异步执行,会导致显示不全所有图片的问题。

  for(var a=0;a<2;++a){       var img = canvas.createImage()img.src = product_image[items[a]]img.onload = ()=>{ctx.drawImage(el,0,h,image_w,image_h)}                }

可以将异步执行过程通过promise变为同步执行,但此方法相对复杂。

可以在第一个for循环中保存img对象,然后单独增加一个for循环加载图片,如下所示:

  var image = []for(var a=0;a<2;++a){       var img = canvas.createImage()img.src = product_image[items[a]]image[a] = img               }image.forEach(function(el,index){var h = index*pr_height+pr_h_margin+p_name_size+sp_el_hel.onload = ()=>{ctx.drawImage(el,0,h,image_w,image_h)}});

更多微信小程序内容欢迎关注博主和订阅专栏。

有相关业务可以联系博主。

http://www.lryc.cn/news/290727.html

相关文章:

  • Python计算机二级/Python期末考试 刷题(一)
  • 最新GPT4.0使用教程,AI绘画-Midjourney绘画,GPT语音对话使用,DALL-E3文生图+思维导图一站式解决
  • 【JavaScript】两种方法实现继承
  • 张维迎《博弈与社会》笔记(3)导论:一些经济学的基础知识
  • 随机生成UI不重叠
  • 【C/C++】C/C++编程——第一个 C++ 程序:HelloWorld
  • 扩散视觉反事实算法 DVC:对抗性鲁棒分类器 + 扩散模型,跨模态对比原始的 fundus 图 VS 生成的 OCT 图
  • C++(6) 继承
  • 【Servlet】Smart Tomcat插件简化Servlet开发流程及解决常见问题
  • 解决Qt连接不上mysql数据库
  • kubernetes-快速部署一套k8s集群
  • Windows Server 安装 Docker
  • 智能分析网关V4智慧机房:视频AI智能安全监管方案
  • 一些反序列化总结
  • 分披萨(100%用例)C卷(JavaPythonC++Node.jsC语言)
  • SQL字符串截取函数【简笔记】
  • 会话技术复习笔记
  • 我用Rust开发Rocketmq name server
  • 【Deep Dive: Al Webinar】开源人工智能中赋能、透明性和可重复性三者之间的关系...
  • 将Html页面转换为Wordpress页面
  • Next.js 学习笔记(七)——样式
  • 金线检测步骤
  • 电池-电量监测基础知识
  • 西瓜书学习笔记——层次聚类(公式推导+举例应用)
  • 深度视觉目标跟踪进展综述-论文笔记
  • 【数据结构:顺序表】
  • android tts播报破音解决方案汇总
  • 2024年新提出的算法:一种新的基于数学的优化算法——牛顿-拉夫森优化算法|Newton-Raphson-based optimizer,NRBO
  • 笔记 | Clickhouse 命令行连接及查询
  • 设计模式—行为型模式之责任链模式