//tips
AI搭載のバーチャル・ヒューマンがオークションに出品 落札額は約5,300万円
自分の分身を作れればなおgood。
//vivox理解
次はsendmessageができるように実装を進めていく。
public void Send_Group_Message(string message)
{
vivox.channelSession.BeginSendText(message, ar =>
{
try
{
vivox.channelSession.EndSendText(ar);
}
catch(Exception e)
{
Debug.Log(e.Message);
}
});
}
public void On_Message_Received(object sender,QueueItemAddedEventArgs<IChannelTextMessage> msgArgs)
{
var messenger = (VivoxUnity.IReadOnlyQueue<IChannelTextMessage>)sender;
Debug.Log($"From {msgArgs.Value.Sender}:Message - {msgArgs.Value.Message}");
}
さらにUIスクリプトの方に下記を追加。
public void Send_Group_Message()
{
credentials.Send_Group_Message(tmp_Input_SendMessages.text);
}
UIにボタンのメソッドをアタッチしていくと、無事にメッセージを送れたことを示すログが確認できた。
From sip:.naki352-vo35-dev.2.@mt1s.vivox.com:Message - hi
UnityEngine.Debug:Log(Object)
このログの部分をUIに表示させたいので、下記のように変更。
public void On_Message_Received(object sender,QueueItemAddedEventArgs<IChannelTextMessage> msgArgs)
{
var messenger = (VivoxUnity.IReadOnlyQueue<IChannelTextMessage>)sender;
Debug.Log($"From {msgArgs.Value.Sender}:Message - {msgArgs.Value.Message}");
Text temp = Instantiate(lobbyUI.txt_Message_Prefab,lobbyUI.container.transform);
temp.text = $"From {msgArgs.Value.Sender.DisplayName}:Message - {msgArgs.Value.Message}";
}
これによりmessageをきちんと表示できるようになった。
今回の内容はシンプルで、もしchat可能な形でチャネルに参加した際、ユーザーはグループメッセージの送受信ができる。その際には、IChannelSession.BeginSendText methodが使用される。送信された内容は、他のユーザーには IChannelSession.MessageLog.AfterItemAdded event.の形で取得される。
If the game has joined the channel with text enabled, users can send and receive group text messages. To send messages, the game uses the IChannelSession.BeginSendText method. After this SDK call is made, other users in that channel receive an IChannelSession.MessageLog.AfterItemAdded event.
using UnityEngine;
using VivoxUnity;
class VivoxGroupTextExample : MonoBehaviour
{
. . .
// For this example, _channelSession is a connected IChannelSession and _accountId is the local user’s AccountId.
. . .
// Sending
void SendGroupMessage()
{
var channelName = _channelSession.Channel.Name;
var senderName = _accountId.Name;
var message = "Hello World!";
_channelSession.BeginSendText(message, ar =>
{
try
{
_channelSession.EndSendText(ar);
}
catch (Exception e)
{
// Handle error
return;
}
Debug.Log(channelName + ": " + senderName + ": " + message);
});
}
. . .
// Receiving
. . .
_channelSession.MessageLog.AfterItemAdded += onChannelMessageReceived;
. . .
void onChannelMessageReceived(object sender, QueueItemAddedEventArgs<IChannelTextMessage> queueItemAddedEventArgs)
{
var channelName = queueItemAddedEventArgs.Value.ChannelSession.Channel.Name;
var senderName = queueItemAddedEventArgs.Value.Sender.Name;
var message = queueItemAddedEventArgs.Value.Message;
Debug.Log(channelName + ": " + senderName + ": " + message);
}
. . .
}
BeginとEndの関係に混乱してきて文章を探していたが、下記文言以外は見つからなかったので、コードそのものの意味で捉え直した。EndはBeginのメソッドの中にあり、処理の実行を担う部分でbeginでは処理の実行のエラー処理も踏まえた上で内容を返すもので、beginメソッドが完了した時点で処理は完了したものと捉える。なので、endの方がbeginよりも先に処理されると理解した。単語に惑わされないよう注意。
Every BeginLogin method call must have an access token that authorizes that game instance to sign in as the specified account.
The EndLogin method must be called within a try block in case an error occurs.