使用 p5.js 预加载 JSON 数据中的图片

使用 p5.js 预加载 json 数据中的图片

本文旨在解决 p5.js 中预加载 JSON 数据,并根据 JSON 数据中的文件名列表加载图片资源的问题。由于 loadJSON() 和 loadImage() 都是异步函数,直接使用会导致图片未加载完成就开始执行后续代码。本文将介绍如何利用 loadJSON() 的回调函数确保在所有图片加载完成后再开始执行 setup() 函数,避免出现资源未加载完全的问题。

利用 loadJSON 的回调函数

loadJSON() 函数允许传入一个回调函数作为第二个参数。这个回调函数会在 JSON 数据加载完成后被调用。我们可以利用这个特性,在回调函数中加载图片,从而保证 JSON 数据加载完成后再加载图片。

示例代码

假设你有一个名为 images.json 的文件,内容如下:

{  "images": ["1.jpg", "2.jpg", "3.jpg"]}

以下代码展示了如何使用 loadJSON() 的回调函数来加载图片:

let imgData;let images = [];let numImagesLoaded = 0;function preload() {  imgData = loadJSON("images.json", data => {    imgData = data; // 确保 imgData 在回调函数外部可用    for (let filename of imgData.images) {      loadImage(filename, img => {        images.push(img); // 将加载的图片添加到数组中        numImagesLoaded++;        if (numImagesLoaded === imgData.images.length) {          console.log("所有图片加载完成!");        }      });    }  });}function setup() {  createCanvas(400, 400);  imageMode(CENTER);}function draw() {  background(220);  // 确保所有图片加载完成后再绘制  if (numImagesLoaded === imgData.images.length) {    for(let i = 0; i < images.length; i++){      image(images[i], width / 2 + i * 50, height / 2, 50, 50);    }  } else {    text("Loading...", width / 2, height / 2);    textAlign(CENTER, CENTER);  }}

代码解释

preload() 函数:使用 loadJSON(“images.json”, data => { … }) 加载 JSON 数据。data 参数是加载完成的 JSON 对象。在回调函数中,遍历 imgData.images 数组,使用 loadImage() 函数加载每个图片。loadImage() 函数同样是异步的,所以我们使用它的回调函数来跟踪图片的加载进度。每次图片加载完成,numImagesLoaded 计数器加 1。当 numImagesLoaded 等于 imgData.images.length 时,表示所有图片都已加载完成。setup() 函数:创建画布。设置 imageMode(CENTER),使图片以中心点为基准绘制。draw() 函数:清空画布。检查 numImagesLoaded 是否等于 imgData.images.length。如果是,则绘制所有图片;否则,显示 “Loading…” 文本。

注意事项

确保 images.json 文件存在,并且文件路径正确。loadImage() 函数也是异步的,所以需要使用回调函数来跟踪图片的加载进度。在 draw() 函数中,需要检查所有图片是否加载完成,然后再进行绘制操作,避免出现错误。如果图片数量很多,可以使用更高效的加载方式,例如使用 Promise 或 async/await。

总结

通过使用 loadJSON() 的回调函数,我们可以确保在 JSON 数据加载完成后再加载图片,从而避免出现资源未加载完全的问题。这种方法简单易懂,适用于大多数情况。同时,需要注意 loadImage() 函数也是异步的,需要使用回调函数来跟踪图片的加载进度。

以上就是使用 p5.js 预加载 JSON 数据中的图片的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1514221.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 08:17:47
下一篇 2025年12月20日 08:18:03

相关推荐

  • HTML表单提交时函数未被调用的问题排查与解决

    本文旨在帮助开发者解决HTML表单提交时JavaScript函数未被调用的问题。通过分析常见的错误原因,例如拼写错误、函数调用方式不正确以及表单结构问题,提供详细的排查步骤和修正方法,确保表单提交时能够正确执行验证或其他自定义逻辑。 在开发Web应用时,经常需要在表单提交时执行一些客户端验证或预处理…

    2025年12月20日
    000
  • 前端自动化部署流程

    前端自动化部署的核心是通过工具链实现代码提交后自动构建、测试与发布。1. 代码推送到指定分支(如 main)触发流程,由 Git Hooks 或 Webhook 检测事件,GitHub/GitLab 等平台支持此机制,并可通过分支策略控制触发条件;2. CI 阶段拉取代码后执行依赖安装、代码检查(E…

    2025年12月20日
    000
  • 将React组件转换为Qwik组件:qwik-react 的使用与考量

    本文旨在阐述如何使用 `qwik-react` 将 React 组件集成到 Qwik 应用中。我们将深入探讨 `qwikify$` 的作用机制,分析其在迁移 React 应用到 Qwik 时的优势与局限性,并强调过度使用 `qwikify$` 可能带来的性能问题。同时,本文还将讨论在 Qwik 项目…

    2025年12月20日
    000
  • JavaScript动画引擎实现原理

    JavaScript动画引擎通过requestAnimationFrame实现时间驱动,利用性能时间计算动画进度,结合缓动函数对属性进行插值更新,支持队列控制与链式调用,优化DOM操作以提升性能。 JavaScript动画引擎的核心在于控制元素在一段时间内的视觉变化,比如位置、大小、透明度等。它不依…

    2025年12月20日
    000
  • 解决 React Native Android 应用启动时出现的伪启动页问题

    本文旨在解决 React Native Android 应用在启动时,先显示一个带有应用图标的黑色伪启动页,然后再显示自定义启动页的问题。通过修改 Android 项目的 `styles.xml` 文件,禁用应用的预览窗口,即可有效避免此问题,提升用户体验。 在开发 React Native 应用时…

    2025年12月20日
    000
  • 移动端动画性能优化

    使用transform和opacity替代top/left与rgba动画,避免布局抖动,合理启用硬件加速与will-change,结合requestAnimationFrame优化动画节奏,减少重排重绘,提升移动端动画性能。 移动端动画性能直接影响用户体验,尤其在中低端设备上更容易出现卡顿、掉帧等问…

    2025年12月20日
    000
  • 处理跨多个标签的字符串选区:避免 Range 对象修改后的选区重置

    本文探讨了在使用 javascript 的 `range.surroundcontents` 方法处理跨越多个 html 标签的文本选区时,可能出现的选区重置问题。通过分析问题原因,并提供一种通过提取选区内容、循环处理节点、重新构建 html 并插入文档的解决方案,帮助开发者避免选区丢失,实现对复杂…

    2025年12月20日
    000
  • 使用jQuery实现卡片内信息面板的折叠与展开(手风琴效果)

    本教程详细介绍了如何使用jquery高效地管理卡片(card)内部信息面板(div)的显示与隐藏。通过优化事件绑定机制,利用`closest()`和`find()`进行精确的dom元素定位,并提供两种核心切换逻辑:独立的面板切换和手风琴式(一次只展开一个)的面板切换,旨在帮助开发者构建更简洁、功能更…

    2025年12月20日 好文分享
    000
  • 创建类似宝可梦盒子功能的 Discord.js 指令并解决“无法发送空消息”错误

    本文旨在解决在使用 Discord.js 和 MongoDB 创建类似宝可梦盒子功能的指令时,遇到的“无法发送空消息”错误。通过检查数据查询、消息构建和嵌入发送等关键步骤,提供详细的排查思路和解决方案,帮助开发者顺利实现该功能。 问题分析 在使用 Discord.js 创建指令时,经常会遇到 Dis…

    2025年12月20日
    000
  • 如何用JavaScript构建一个简单的区块链模拟?

    答案:用JavaScript构建简单区块链需定义区块结构和链式连接逻辑。1. 创建含索引、时间戳、数据、前后哈希的Block类,用SHA-256计算哈希;2. 实现Blockchain类,包含创世块、添加区块及验证链有效性方法;3. 示例中添加区块并验证完整性,篡改数据后链失效,体现不可篡改性。 用…

    2025年12月20日
    000
  • JavaScript生成器与迭代器协议

    生成器和迭代器协议是JavaScript处理数据序列的核心机制,通过实现Symbol.iterator方法和next()返回value与done属性的对象,使对象可迭代。生成器函数使用yield暂停执行,并能通过next()传参实现双向通信,如greet()示例所示,支持状态保持与惰性求值,广泛应用…

    2025年12月20日
    000
  • JavaScript性能监控与分析

    JavaScript性能监控需关注首屏加载、脚本执行耗时、主线程阻塞、内存使用及长任务等核心指标,通过Performance API、User Timing API和Navigation Timing采集数据,结合Chrome DevTools分析调用栈与内存快照,定位瓶颈;线上采用RUM方案按采样…

    2025年12月20日
    000
  • JavaScript音频可视化技术

    JavaScript音频可视化通过Web Audio API获取音频数据,利用AnalyserNode提取时域和频域信息,并结合Canvas绘制波形图、频谱柱状图等实时视觉效果。 JavaScript音频可视化是通过分析音频数据,将声音信息转化为图形表现的技术。它常用于音乐播放器、互动艺术项目或数据…

    2025年12月20日
    000
  • JavaScript函数式编程范式实践

    函数式编程在JavaScript中通过纯函数、不可变数据和高阶函数提升代码可读性与可靠性。使用纯函数确保输入输出一致,避免副作用;采用扩展运算符或map、filter等方法维护数据不可变性;利用高阶函数如compose实现逻辑组合;结合柯里化与生成器支持惰性求值,增强复用性与性能。 函数式编程不是新…

    2025年12月20日
    000
  • JavaScript中间件机制解析

    中间件是Node.js中用于处理请求响应流程的函数,可执行日志、认证等任务,按注册顺序形成处理管道,Express中通过next()传递控制权,Koa采用洋葱模型支持进入与离开双向处理,适合性能监控等场景,编写时需注意调用next()、避免随意修改对象、保持职责单一及正确处理异步操作。 JavaSc…

    2025年12月20日
    000
  • JavaScript日期时间处理进阶

    JavaScript日期处理需注意原生Date对象的月份从0开始、字符串解析歧义等问题,应使用getFullYear()等安全方法获取日期值,并通过时间戳或明确参数创建日期。时区处理上,推荐用toISOString()转UTC时间供后端存储,toLocaleString()结合timeZone选项适…

    2025年12月20日
    000
  • 如何实现一个符合Promises/A+规范的Promise库?

    实现符合Promises/A+规范的Promise库需处理状态机、异步解析和链式调用。1. 定义三种不可逆状态:pending、fulfilled、rejected;2. 构造函数中通过resolve/reject控制状态流转并存储回调;3. then方法返回新Promise,根据当前状态异步执行对…

    好文分享 2025年12月20日
    000
  • JavaScript Prettier代码格式化

    Prettier是提升JavaScript代码可读性和团队协作效率的主流格式化工具,支持多种语言,能自动处理空格、换行、引号等格式问题。通过npm或yarn在项目中本地安装可避免版本不一致问题。支持配置文件如.prettierrc或prettier.config.js来自定义规则,常用配置包括sem…

    2025年12月20日
    000
  • Node.js异步编程:正确处理HTTP请求与数据同步

    本文深入探讨了Node.js中因`https.get`等异步操作未等待完成就返回结果,导致外部变量未更新的问题。通过分析Node.js的事件循环和非阻塞I/O机制,教程将详细介绍如何利用Promise和`async/await`语法,确保所有异步请求完成后再处理数据并发送响应,从而解决数据同步难题,…

    2025年12月20日
    000
  • 使用jQuery高效实现卡片内信息面板的显示与隐藏切换

    本文将指导您如何使用jquery,以简洁高效的方式实现卡片(card)组件内部信息面板的显示与隐藏切换功能。我们将探讨两种常见模式:独立的面板切换和手风琴式(accordion)面板切换,并通过最佳实践和示例代码,帮助您优化事件处理、元素查找及css类管理,避免常见的开发陷阱。 在现代Web应用中,…

    2025年12月20日 好文分享
    000

发表回复

登录后才能评论
关注微信