《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

相关文章

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

无人叉车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的边