-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Tutorial: ChatSystem
sl-sandy edited this page May 20, 2020
·
12 revisions
The goal of this tutorial is to show how to process the message that comes from the client-side and how to send a message to players who in the same room.
1. First of all, we need to define the message-id for communicating between client-side and game server before we start (Now NF has done this for you.)
{ServerProject}/NFComm/NFMessageDefine/NFDefine.proto
REQ_CHAT = 350;
ACK_CHAT = 351;
2. Besides, we need to define a message structure to describe what is that message's content (Now NF has done this for you.)
{ServerProject}/NFComm/NFMessageDefine/NFMsgShare.proto
message ReqAckPlayerChat
{
enum EGameChatChannel
{
EGCC_GLOBAL = 0;
EGCC_CLAN = 1;
EGCC_FRIEND = 2;
EGCC_BATTLE = 3;
EGCC_TEAM = 4;
EGCC_ROOM = 5;
}
enum EGameChatType
{
EGCT_TEXT= 0;
EGCT_VOICE = 1;
EGCT_EMOJI = 2;
EGCT_DONATE_HERO = 10;
EGCT_DONATE_BUILDING = 11;
EGCT_DONATE_ITEM = 12;
}
Ident player_id = 1;
bytes player_name = 2;
bytes player_hero_id = 3;
bytes player_hero_level = 4;
EGameChatChannel chat_channel = 5;
EGameChatType chat_type = 6;
bytes chat_info = 7;
Ident target_id = 8;
}
Run the script "NFComm/NFMessageDefine/cpp.bat" and "NFComm/NFMessageDefine/cs.bat" (cpp.sh cs.sh) to generate the source code, and copy the source code where located at _Out/NFDataCfg/client/ to the folder Assets/Resources/NFDataCfg/ (client-side)
4. Equally important, add a Plugin and a module for the chat system. (Now NF has done this: NoahFrame/NFExamples/NFChatPlugin)
5. Last but not least, add an observer(or call it as a watchdog?) for that message-id we defined at step 1
bool NFChatModule::AfterInit()
{
m_pNetModule->AddReceiveCallBack(NFMsg::REQ_CHAT, this, &NFChatModule::OnClientChatProcess);
return true;
}
void NFChatModule::OnClientChatProcess(const NFSOCK nSockIndex, const int nMsgID, const char* msg, const uint32_t nLen)
{
CLIENT_MSG_PROCESS( nMsgID, msg, nLen, NFMsg::ReqAckPlayerChat);
switch (xMsg.chat_channel())
{
case NFMsg::ReqAckPlayerChat::EGCC_GLOBAL:
{
//this code means the game server will sends a message to all players who playing game
m_pNetModule->SendMsgPBToAllClient(NFMsg::ACK_CHAT, xMsg);
}
break;
case NFMsg::ReqAckPlayerChat::EGCC_ROOM:
{
const int sceneID = m_pKernelModule->GetPropertyInt(nPlayerID, NFrame::Player::SceneID());
const int groupID = m_pKernelModule->GetPropertyInt(nPlayerID, NFrame::Player::GroupID());
//this code means the game server will sends a message to all players who in the same room
m_pGameServerNet_ServerModule->SendGroupMsgPBToGate(NFMsg::ACK_CHAT, xMsg, sceneID, groupID);
}
break;
default:
{
//this code means the game server will sends a message yourself(nPlayerID)
m_pGameServerNet_ServerModule->SendMsgPBToGate(NFMsg::ACK_CHAT, xMsg, nPlayerID);
}
break;;
}
}