PUN☀️实用API

简介: PUN☀️实用API


本节来讲解PUN的实用API

建议保存收藏,写代码时来查一查哦~

🟥 当前房间人数

int num = PhotonNetwork.CurrentRoom.PlayerCount;


🟧 当前脚本是否属于当前玩家

//需继承MonoBehaviourPun
bool isMine = photonView.IsMine;


🟨 当前互联网中的Player玩家是否属于自己(是否是本地玩家)

bool isLocal = Player玩家.IsLocal;


🟩 当前是否离线模式

bool isConnected = PhotonNetwork.IsConnected;

false为离线,配合 PhotonServerSettings 使用。当勾选Start In Offline Mode时,为离线模式

作用:photonView.IsMine只能在线模式使用,即先连接服务器,这个代码才能判断,才不报错。

但我们测试时,不连服务器。那么这个代码就一直报错。所以我们可以结合是否离线使用。比如这样:

//如果当前处于离线模式,仍继续执行下方代码
//方便我们在离线模式下操作。
if (PhotonNetwork.IsConnected == true && photonView.IsMine == false)
    return;



🟦 PUN当前网络连接状态

string state = PhotonNetwork.NetworkClientState.ToString();


🟪 自己的昵称

PhotonNetwork.NickName


🟫 创建房间

//创建只有最大人数的房间
PhotonNetwork.CreateRoom(null, new RoomOptions { MaxPlayers = maxPlayersPerRoom });
 
//指定房间名、最大人数创建房间
PhotonNetwork.CreateRoom("房间名", new RoomOptions { MaxPlayers = maxPlayers }, null);


⬛ 自定义信息的同步

1、传输信息

using ExitGames.Client.Photon;

Hashtable props = new Hashtable() { { "IsPlayerReady", true } };
PhotonNetwork.LocalPlayer.SetCustomProperties(props);

2、获得信息

foreach (Player p in PhotonNetwork.PlayerList)
{
    print(p.NickName);
 
    object isPlayerReady;
    if (p.CustomProperties.TryGetValue("IsPlayerReady", out isPlayerReady))
    {
        print((bool)isPlayerReady ? "当前玩家已准备好" : "当前玩家未准备好");
    }
}

3、获得该玩家所有自定义信息

Debug.Log(玩家Player.CustomProperties.ToStringFull());


⬜ 玩家分数

这是PUN预制的同步信息,不需要自己定义了

1、传输信息

//这将在本地设置分数,并将同步它在游戏中尽快。
PhotonNetwork.LocalPlayer.SetScore(0);

/2、获得信息

foreach (Player p in PhotonNetwork.PlayerList)
{
    print(p.GetScore());
}


🟥 房间内所有玩家列表

PhotonNetwork.PlayerList

foreach (Player p in PhotonNetwork.PlayerList)
{
    print(p.NickName);
}


🟧 房间内玩家唯一标志符ID

当前房间中该玩家(可获得自己的,也可是获得别人的)的标识符ID。房间外面是-1。

它会在重新加入时改变。每个房间都不会重复使用id。

foreach (Player p in PhotonNetwork.PlayerList)
{
    print(p.ActorNumber);
}


🟨 房间内该玩家的Number

【你想使用该属性,那么需要在连接服务器场景挂载 PlayerNumbering 脚本】

与ID不一样的是,该Number,是从0排序,几个人,就到几。

-1代表无索引(你没挂该脚本,就这样)

demo中,将该属性用于判断玩家信息条应该显示的颜色。

foreach (Player p in PhotonNetwork.PlayerList)
{
    print(p.GetPlayerNumber());
}


🟩 委托:房间索引更改时调用

和上方的 Number 有关,当房间内玩家更新(变多或减少),带动着PUN的Number也会变,这时便调用该委托。

demo中将该方法用于在这个时刻,更新玩家信息条显示的颜色。

//每次房间索引更新时调用
PlayerNumbering.OnPlayerNumberingChanged += OnPlayerNumberingChanged;


相关文章
|
3月前
|
API 开发工具
影创SDK☀️七、讲讲获取SDK按键事件的几种方式
影创SDK☀️七、讲讲获取SDK按键事件的几种方式
|
开发框架 前端开发 Java
什么是API?(详细解说)
API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。——百度百科
|
XML Serverless API
每日一博 - API Architectural Styles
每日一博 - API Architectural Styles
109 0
|
编译器 API 图形学
unity常用API基础知识
常用API基础知识
177 0
|
API Windows
[笔记]Windows核心编程《番外篇》常用的NT API及使用示例
Windows核心编程《番外篇》常用的NT API及使用示例
838 0
[笔记]Windows核心编程《番外篇》常用的NT API及使用示例
|
Java API
java学习第九天笔记-方法173-api和api帮助文档
java学习第九天笔记-方法173-api和api帮助文档
85 0
java学习第九天笔记-方法173-api和api帮助文档
|
Java API
java学习第九天笔记-方法174-api和api帮助文档1
java学习第九天笔记-方法174-api和api帮助文档1
81 0
java学习第九天笔记-方法174-api和api帮助文档1
|
人工智能 API 定位技术
这几个好玩又有趣的API,你用过了吗?
最近在逛ProductHurt时,发现一些好玩又有趣的API,你可能会觉得花里胡哨,but 作为开发者也需要乐趣的!
这几个好玩又有趣的API,你用过了吗?
|
API
QCC304x系列开发教程(实战篇) 之 3.14-QCC3040之开发中常用的API应用
QCC304x系列开发教程(实战篇) 之 3.14-QCC3040之开发中常用的API应用
807 0
足球即时比分api示例代码
足球即时比分api示例代码