《3D山地赛车》游戏-网络部分(一)

2023-10-22 14:20

本文主要是介绍《3D山地赛车》游戏-网络部分(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《3D山地赛车》游戏-网络部分(一)
这里写图片描述

1 前言

《3D山地赛车》项目从6月12日做到7月7日,花了3周多的时间。其中网络部分的实现就花了一周多,将近2周。所以关于其中网络部分,我想写写我的一点心得。

《3D山地赛车》项目要求里有个optional要求是实现联机。虽然这是一个可选项,做不做影响不大,但是我想做出来。

因为《3D山地赛车》是一款Android端的3d赛车游戏,如果有联机的功能的话,就能够让2个人对战,这样整个游戏就变得有意思起来。如果仅仅有单人模式(pve),玩家会很快搞清楚ai是怎样行动的,这样很容易就会无聊起来。但是有了联机(pvp),玩家们会在游戏竞速的规则下,自己去思考一定的策略,毕竟和自己对战的是另一名玩家的话,难道你会不认真起来吗?

(至于说为什么有时要做出选择,是因为关卡设计时,有些地方是可以走“捷径”的,但是走“捷径”需要一定的操作,不然很容易翻车)

还有一个原因,我是项目的程序,一个人在这么短时间内将整个游戏“单人模式”的3大关卡给实现出来,还能把联机部分给实现的话,那我会相当有成就感。联机部分的实现是一个挑战,需要搭建服务器,还要实现客户端、服务器之间的通信,编写2端的代码。这是一个挑战。但是我有自信,因为我大一大二学过一段时间前端、后台,服务器、linux也用过,对网络之间如何通信还是比较熟悉。关键是理清思路,跑通整个流程。所以我觉得应该不难吧。

始料未及的是,本来我以为很容易就能做完联机,却花了一周多。。。

2 联机方案的选择
查网上的资料,看了一些案例,可行的联机方案有3种:Unity自带的network、photon+unity、自己实现socket。其中靠谱的是2种:photon+unity、自己实现socket。

下面讲下这几种方案

  • 1 Unity自带network
    网上搜的话最多的也就是这个,Unity官方联机实例,它用的也是自己network模块。 我在写这个项目之前的一段时间有学了学Unity自己的联机实现,相当难用,文档api写得也不是很清楚。Unity给每个Unity开发者20个免费的同时在线玩家数,但是我当时试用时发现貌似因为在中国的原因,所以它网络延迟比较大。
    网上很多Unity实现局域网联机,用的也是它自带的network。实现方式是将其中一台客户端作为server,其他客户端发送数据给server后,server经过计算后发回给各个客户端。这样的方式本身也是有一定问题的。只适合做一些简单,自己玩玩的游戏。

  • 2 photon+Unity
    看网上实例后,觉得photon设计,提供出来的api比较好,好用而且易读,看名字就知道这个函数有什么用。比Unity自己提供的好太多了。
    但是我不知道它会不会因为在中国的原因,网络延迟会大些。而且服务器端做了什么我也不知道,这样我难以实现一些联机设计上的思路,以及优化游戏。再如果出了问题,我难以知道是延迟问题,还是服务端数据处理出了问题。

  • 3 自己实现socket
    “自己实现socket”是国内端游、手游采用的方案。它的特点就是可定制性高,编写难度大。
    因为国内端游、手游对游戏的网络性能要求很高,一般要求能够实现多人联机,实时对战。所以自己实现socket,就能够根据相应的游戏做出不少算法上、设计上的优化。
    虽然《3D山地赛车》一个场景里是2个玩家进行对战,但其实和多人联机没多大区别,只是人数上的差异罢了。而且赛车游戏也是实时的,对网络要求也很高。所以采用这个方案很合适。

所以最终选择自己实现socket通信这一方案。

下一篇写《3D山地赛车》网络部分实现-第二部分,客户端、服务端网络同步实现上的一些思路。

这篇关于《3D山地赛车》游戏-网络部分(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

国产游戏崛起:技术革新与文化自信的双重推动

近年来,国产游戏行业发展迅猛,技术水平和作品质量均得到了显著提升。特别是以《黑神话:悟空》为代表的一系列优秀作品,成功打破了过去中国游戏市场以手游和网游为主的局限,向全球玩家展示了中国在单机游戏领域的实力与潜力。随着中国开发者在画面渲染、物理引擎、AI 技术和服务器架构等方面取得了显著进展,国产游戏正逐步赢得国际市场的认可。然而,面对全球游戏行业的激烈竞争,国产游戏技术依然面临诸多挑战,未来的

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络 服务器端配置 在服务器端,你需要确保安装了必要的驱动程序和软件包,并且正确配置了网络接口。 安装 OFED 首先,安装 Open Fabrics Enterprise Distribution (OFED),它包含了 InfiniBand 所需的驱动程序和库。 sudo