最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

HTML5游戏开发之资源加载篇(2)

来源:懂视网 责编:小采 时间:2020-11-27 15:16:18
文档

HTML5游戏开发之资源加载篇(2)

HTML5游戏开发之资源加载篇(2):四) 下载过程的管理 4.1) 如何管理成千上百的资源 在游戏开发的过程中,很有可能会有成千上百张图片。最直接的方式,是将这些图片编写在代码中,但是图片的名字很容易改变的,会造成大量的维护工作,甚至影响代码的打包和发布。我的同事Boris,在他的代码
推荐度:
导读HTML5游戏开发之资源加载篇(2):四) 下载过程的管理 4.1) 如何管理成千上百的资源 在游戏开发的过程中,很有可能会有成千上百张图片。最直接的方式,是将这些图片编写在代码中,但是图片的名字很容易改变的,会造成大量的维护工作,甚至影响代码的打包和发布。我的同事Boris,在他的代码

四) 下载过程的管理

4.1) 如何管理成千上百的资源

在游戏开发的过程中,很有可能会有成千上百张图片。最直接的方式,是将这些图片编写在代码中,但是图片的名字很容易改变的,会造成大量的维护工作,甚至影响代码的打包和发布。我的同事Boris,在他的代码演示库中,给出了一个参考实现方式,如下。这种方式,可以保证,在需要修改或者调整资源名称或者路径的时候,不需要接触代码。

  1. {
  2. "assetRoot": "url/to/assets",
  3. "bundles": [
  4. {
  5. "name": "unique bundle name",
  6. "contents": [
  7. "relative/path/to/asset.jpg",
  8. "another/asset.mp3"
  9. ]
  10. },
  11. "autoDownload": true
  12. }
  13. var gal = new GameAssetLoader("http://path.to/gal.manifest");
  14. // Load the GAL. If manifest indicates autoDownload, this call will
  15. // start loading assets one by one.
  16. gal.init(function() {
  17. // Called when the library is initialized
  18. });

更完整的代码,可以参考GitHub上的源代码

4.2) 如何实现批处理的下载

再获得了资源列表之后,就要开始资源的下载。显然,需要这样的方法。

  1. AssetManager.prototype.downloadAll = function(downloadCallback) {
  2. for (var i = 0; i < this.downloadQueue.length; i++) {
  3. var path = this.downloadQueue[i];
  4. var img = new Image();
  5. var that = this;
  6. img.addEventListener("load", function() {
  7. // coming soon
  8. }, false);
  9. img.addEventListener("error", function() {
  10. // coming soon
  11. }, false);
  12. img.src = path;
  13. }
  14. }

  15. 下载的过程中,一般情况下都需要一个进度条,来显示完成的情况,所以必须对AssetManager进行计数。



  16. function AssetManager() {
  17. this.successCount = 0;
  18. this.errorCount = 0;
  19. this.downloadQueue = [];
  20. }

  21. AssetManager.prototype.isDone = function() {
  22. return (this.downloadQueue.length == this.successCount + this.errorCount);
  23. }
  24. AssetManager.prototype.getProcess = function() {
  25. return (this.successCount + this.errorCount)/this.downloadQueue.length;
  26. }

显然,也需要对每个img的load和error事件,进行计数。还请注意downloadAll函数有个参数叫做downloadCallback,在资源下载完成以后,通知此函数,进入游戏过程中。

  1. img.addEventListener("load", function() {
  2. that.successCount += 1;
  3. if (that.isDone()) {
  4. downloadCallback();
  5. }
  6. }, false);
  7. img.addEventListener("error", function() {
  8. that.errorCount += 1;
  9. if (that.isDone()) {
  10. downloadCallback();
  11. }
  12. }, false

4.3) 游戏中的不同关卡

游戏通常是分关卡的,完全没有必要在一开始就将游戏的所有资源下载到本地,毕竟不是每个玩家都会将游戏通关。为了按需下载,比较完备的资源加载器,应该可以对每个资源配上一个标签或者属性,可以标志它属于哪一关。每一关的开始,只下载和本关相关联的资源,在每一关结束的时候,在去下载下一关的资源。不仅减少用户的不必要的等待时间,还可以有效的减少服务器的压力。

5.资源加载器的具体实现

5.1 PreloadJS

官方网站:http://www.createjs.com/#!/PreloadJS/download

开源代码:https://github.com/CreateJS/PreloadJS/

专门用于资源下载的类库,非常好用,考虑的也非常全面,首先推荐的一款软件,尤其是读者不希望加载特别大的游戏引擎是,这款软件可以作为首选。

具体的例子可以参考:https://github.com/CreateJS/PreloadJS/tree/master/examples

(未完待续)

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

HTML5游戏开发之资源加载篇(2)

HTML5游戏开发之资源加载篇(2):四) 下载过程的管理 4.1) 如何管理成千上百的资源 在游戏开发的过程中,很有可能会有成千上百张图片。最直接的方式,是将这些图片编写在代码中,但是图片的名字很容易改变的,会造成大量的维护工作,甚至影响代码的打包和发布。我的同事Boris,在他的代码
推荐度:
标签: 资源 加载 游戏
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top