前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >当creator遇上protobufjs—叛逆

当creator遇上protobufjs—叛逆

作者头像
张晓衡
发布2019-09-11 16:30:09
5160
发布2019-09-11 16:30:09
举报

我们之前讲过要在Creator原生环境下使用protobufjs,使用伪装者的方式模拟nodejs的fs和path模块可以完美解决问题。 但随着creator1.7的到来,Shawn也尝了下鲜,但发现在Creator模拟器环境下,原来的伪装方案失效了。

一、疑犯追踪

追踪这个问题,不得不称赞下Creator1.7提供的新的底层引擎,在调试上ios/mac平台使用safari,android/windows使用chrome。

在模拟器上调试require函数中找到一些线索

上图中,从已经加载的模块文件中没有找fs模块,心拔凉拔凉的,继续追查原因。

注意fs的值为2

在数组中2号元素的文件名为empty.js,并不是我们的fs文件,找到原因了。

从上面调试看出,Creator模拟器将fs\path模块认为是nodejs模块,没有按普通模块进行加载。

二、一波三折

伪装的fs\path模块只是不能在Creator1.7的模拟器上运行,在浏览器、自编译的MacApp、ios、android上都能正常运行。但Creator模拟器是平时开发调试的利器,不能运行protobufjs会影响日常的开发效率,也会影响pbkiller的用户,决对不能马虎了事。

1. 明灯

发现问题的第一时间,火速向Creator引擎组的大大汇报了此问题,Jare建议使用cc.loader.loadRes函数抹平不同平台上的文件加载问题,当时眼前一亮,猛拍一下自己的脑袋,我以前怎么没想到这个办法? 不论是web\ios\android所有平台的文件加载都可以用cc.loader.loadRes搞定,比protobufjs中实现的fetch都简单多了,cc.loader.loadRes为我提供了一盏明灯。

2. 熄灭

马上开始动手,刚一动手时,就想到决对不能修改protobufjs的源码,因为有些人是用npm来管理的protobufjs,不能让pbkiller的用户去修改node_moduls吧,这样太low了! 脑子飞快地运转起来,一束光在一片神经网络的触突上闪耀,电光石火的一瞬间,找到了一个方案:动态修改函数

let protobuf = require('protobufjs');
protobuf.Util.fetch = function myfetch(path, callbcak) {
   cc.loader.loadRes(path, (error, data) => {
       if (!error) {
          callback(data);    
       }
   )  
};

正在得意之时,突然之间脑子里翁的一声,有问题?如果这样去实现protobufjs的fetch函数,只能是异步加载,而我之前提供的pbkiller的演示范例全是同步方式,决对不能这样坑了pbkiller的用户呀。

“哎呦!好痛,那个打我” “你看下好多时间了,还不睡觉,明天要上班哈!” “谢谢老婆关心,马上去睡觉”

3. 曙光

不好意思,明天继续


本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-10-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Creator星球游戏开发社区 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、疑犯追踪
  • 二、一波三折
    • 1. 明灯
      • 2. 熄灭
        • 3. 曙光
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档