moba源码类似王者荣耀后台springboot+netty,前端cocoscreator3.x,数据通讯格式用的protoc

本文主要是介绍moba源码类似王者荣耀后台springboot+netty,前端cocoscreator3.x,数据通讯格式用的protoc,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

购买说明

  • 264元限时低价卖开发2年以上的moba源码了,类似王者荣耀,功能已实现90%以上,前端cocoscreator3.x,后台java,已经上架商城了,可以直接购买了,代码简洁清晰明了,可用于学习、二次开发换皮上线等。有问题可加我微信bcp199。安卓包下载试玩链接:https://pan.baidu.com/s/1ZHmp2Nd_nQxqY2YfyTBTHQ?pwd=tjeo
    ,需自行注册一个账号,匹配可以加我微信,至少两个人才能匹配。

购买链接

  • https://store.cocos.com/app/detail/3650

安装包下载

安装包下载

开发环境

  • 引擎版本:Cocos Creator 3.7.3
  • 编程语言:后端 Java、前端 TypeScript

已适配平台

H5微信小游戏Android原生iOS原生抖音小游戏OPPO小游戏vivo小游戏

游戏介绍

  • MOBA实时pk采用后端java+netty+protoc,前端cocos creator 3.7.3。
  • 前后端实现protoc的自动生成,自动拷贝到对应的目录。
  • 用户改为网络协议后只需要点下cmd可执行文件即可。
  • 项目数据配置文件采用json,由excel生成。
  • 使用excel可以快速高效的编辑数据,然后生成的json文件可以在程序中高效的读取。
  • 后端采用服务分离的方式 大厅服+战斗服,战斗服采用帧同步实现,服务器端只做消息转发,不计算战斗逻辑。由客户端计算战斗逻辑。客户端玩家无操作则不封包上传服务器,大幅度降低玩家流量,提高客户端性能。前后端有效代码加起来有10万多行,如果算空行就11万多行了。适合学习、二次开发换皮上线。

帧同步介绍

一、帧同步基础逻辑

图片1.png

  1. 客户端用于处理战斗逻辑,每隔66ms向服务器发送玩家操作数据,由于考虑到客户端h5性能,改为玩家无操作则不向服务器发送数据
  2. 服务器只负责转发客户端操作,每隔66ms向同房间玩家同步操作数据
  3. 服务器收到玩家发送操作数据的同时将按照服务器的帧号将数据存起来
  4. 服务器将在n+1帧向玩家同步n帧操作数据
  5. 客户端解析服务端发送的帧数据更新逻辑位置,渲染位置在update中一直插值平滑的追赶逻辑位置

二、浮点数问题

  1. 放大系数取整法 (小数误差一般都是在小数点最后几位,将玩家初始渲染位置放大然后取整,后面根据放大后的数据进行运算就可以了)
  2. 查表法 (三角函数sin、cos在不同平台下运算会有小数误差,可以将每个角度的x、y分量存在配置文件中,这样用的时候直接查就可以了,降低了运算上的消耗)

三、丢包问题

  1. 客户端丢包
    没有太多影响,下一帧马上就能处理
  2. 服务器丢包
    客户端上传需要补发的帧号,服务器在下一帧会补发丢失的帧操作

四、断线重连

连上后会从当前进度加速播放,直到最新帧

五、录像回放

将服务器下发的帧操作存起来,然后用之前逻辑回播就可以了

六、预测回滚

以当前玩家的操作去预测下一帧,比如当前第n帧角色向右走,那么预测n+1帧还是向右走,可以多预测几帧,然后每帧执行完成后,将角色数据快照,等服务器下发下来,如果哪一帧预测的不对,那么就将回滚到哪一帧前一帧的角色快照数据,然后后面的几帧预测也要丢弃掉

图片介绍

后端代码统计.png
后端代码统计

前端代码统计.png
前端代码统计

QQ截图20230619105152.png
QQ截图20230619105224.png
QQ截图20230619105247.pngQQ截图20230619105314.png
QQ截图20230619105411.pngQQ截图20230619105452.png
QQ截图20230619105514.pngQQ截图20230619105530.png
QQ截图20230619105546.pngQQ截图20230619111838.png
QQ截图20230619113541.pngQQ截图20230619113550.png
QQ截图20230619120930.pngQQ截图20230619121025.png
QQ截图20230619121141.pngQQ截图20230619153446.png
QQ截图20230619153543.pngQQ截图20230619165648.png
QQ截图20230619165721.png
QQ截图20230619153555.png

功能特点

  • 登录
  • 大厅
  • 背包
  • 商店
  • 声音设置
  • 切换英雄
  • 战力排行
  • 拍卖大厅
  • 开房间
  • 加入房间
  • 综合、私聊、房间聊天
  • 关注/直播
  • 英雄属性提升
  • 匹配对战
  • 战斗系统包括移动同步、技能释放同步、技能释放、伤害弹字、buff伤害弹字、攻击特效、受击特效(采用帧同步实现战斗)
  • buff系统
  • 直播观看
  • 直播弹幕
  • 战斗系统队伍消息
  • 战斗结算

资源包说明

11.png
333.png
444.png
素材版权

源码可商用,美术资源不可商用

购买须知

本产品为付费虚拟商品,一经购买成功概不退款,请支付前谨慎确认购买内容。

联系作者

QQ:3306753685
微信:bcp199

这篇关于moba源码类似王者荣耀后台springboot+netty,前端cocoscreator3.x,数据通讯格式用的protoc的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741112

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多