cocoscreator:websocket集成使用protobuf

首先在Google搜索中找到些相关资料,这里吐槽下百度,用百度真心搜索不到有用的资料,大部分均是广告,不知道作为一个搜索引擎,情何以堪。综合谷歌搜索到的各项资料,将本菜鸟cocos2dx_js集成方式贴出:

1.需要protobuf.js(http://pan.baidu.com/s/1dFfpXsd),bytebuffer.js(http://pan.baidu.com/s/1hs36tUG),long.js(http://pan.baidu.com/s/1slBv57n)文件,此处给出我使用的版本。

2.将此三个文件复制到脚本文件夹下

3.引用 protobuf.js,bytebuffer,js

 

var ByteBuffer = require("bytebuffer");
var ProtoBuf = require("protobuf");
4.将protobuf原文件(.proto)复制到项目assets/resources目录下,如果没有resources目录,新建一个即可

 

5.使用protobuf.js解析proto文件,因为我的原文件放在assets/resources/protobuf/guaji.proto,此处不需要加后缀,cocos2d会自动查找 ,ProtoBuf.protoFromString方法会解析文件生成一个protobuf对象工厂。

 

        var protoFile = "protobuf/guaji";
        cc.loader.loadRes(protoFile, function (err, bgTexture2D){
            cc.log("loadfinish");

            Builder = ProtoBuf.protoFromString(bgTexture2D);
        });
6.拿到工厂之后使用工厂对象生成原文件中数据对象,如果源文件中存在package包名,在创建protobuf对象的时候记得加上包名,此处我的包名为(game.service.data),拿到protobuf对象之后记得使用new创建实例,然后使用set方法即可设置数据
        var Message = Builder.build("game.service.data.MsgLoginData");
        var loginMessage = new Message();
        loginMessage.set("UserAccount","webTest");
        loginMessage.set("UserPassWord","123456");
7.使用BUFF数据解析生成protobuf数据实例messageBuff为ArrayBuffer对象实例,使用get方法,或直接使用取属性符号(.)即可获取数据

 

 

        var Message = Builder.build("game.service.data.MsgLoginResult");
        var msg = Message.decode(messageBuff);


到此js和protobuf集成基本完成

 


websocket集成使用

 

 

        var Message = Builder.build("game.service.data.MsgLoginData");
        var loginMessage = new Message();
        loginMessage.set("UserAccount","webTest");
        loginMessage.set("UserPassWord","123456");
        var msgBuf = loginMessage.<span style="color:#ff0000;">encode().toBuffer()</span>;
1.数据打包

在protobuf数据结构填写完成后,即可调用encode().toBuffer()将对象转换为ArrayBuffer对象,使用websockt发送数据即可

 

     var Message = Builder.build("game.service.data.MsgLoginResult");
     var msg = Message.decode(messageBuff);

 

 

if(cc.sys.isNative){
    webSocket.onDataReceived(event.data);
}else {
    var fileReader = new FileReader();
    fileReader.onload  = function(progressEvent) {
        var arrayBuffer = this.result; // arrayBuffer即为blob对应的arrayBuffer
        webSocket.onDataReceived(arrayBuffer);
    };
    fileReader.readAsArrayBuffer(event.data);
}
2.数据接收,数据接收有一个需要注意,需要判断是原生环境还是浏览器环境,如果是浏览器环境websocket收到的data将是BLOB类型,需要将BLOB类型转换为ArrayBuffer,

如果是原生环境,直接使用即可

 

posted on   &大飞  阅读(1669)  评论(0编辑  收藏  举报

编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示