メッセージ拡張
機能説明
メッセージ拡張はメッセージにkey/valueタグを追加できます。メッセージ拡張をベースにし、投票、しりとり、アンケート調査などの機能を実装できます。
投票の運用し―ンでは、まず、
createCustomMessage
(詳細はこちら)インターフェースを呼び出し、投票に用いるカスタムメッセージを作成します。そのうち、data
に投票のタイトルとオプションを保存します。 次に、メッセージ拡張keyに投票したユーザのIDを保存し、メッセージ拡張valueに投票したユーザのオプションを保存します。各ユーザが投票したオプションがあれば、オプションごとの投票したユーザがユーザ全員に占める比率を動的に計算できます。しりとりの運用し―ンでは、まず、
createCustomMessage
インターフェースを呼び出し、しりとりに用いるカスタムメッセージを作成します。そのうち、data
にしりとりのタイトルを保存します。 次に、メッセージ拡張keyにしりとりをしたユーザのIDを保存し、メッセージ拡張valueにしりとりの情報を保存します。アンケート調査の運用し―ンでは、まず、
createCustomMessage
インターフェースを呼び出し、アンケート調査に用いるカスタムメッセージを作成します。そのうち、data
にアンケートのタイトルとオプションを保存します。 次に、メッセージ拡張keyに調査対象となるユーザのIDを保存し、メッセージ拡張valueにアンケートの調査情報を保存します。説明:
この機能はUltimate版のユーザのみに提供し、Ultimate版を購入後に使用できます。
この機能はSDK 4.1.8以降でサポートされます。
この機能を使用するには、IMコンソール > 機能設定 > ログインとメッセージ > メッセージ拡張で有効にする必要があります。
コミュニテ(Community)とライブストリーミンググループ(AVChatRoom)のメッセージはこの機能をサポートしません。
メッセージ拡張の設定
setMessageExtensions
(詳細はこちら)インターフェースを呼び出してメッセージ拡張を設定できます。拡張keyがすでに存在している場合、拡張valueを変更します。拡張keyが存在しない場合、拡張を追加します。メッセージ拡張インターフェースの入力パラメータの詳細は以下の通りです:
属性 | 意味 | 説明 |
message | メッセージオブジェクト | メッセージは次の3つの条件を満たす必要があります: メッセージの状態は送信成功であること。 メッセージはコミュニティ(Community)とライブストリーミンググループ(AVChatRoom)のメッセージではないこと。 |
extensions | 拡張リスト | 拡張keyがすでに存在している場合、拡張valueを変更します。拡張keyが存在しない場合、拡張を追加します。 |
説明:
拡張keyは最大100バイトをサポートします。拡張valueは最大1KBをサポートします。1回で最大20拡張を設定できます。1通のメッセージに対して、最大300拡張を設定できます。
1. 複数のユーザが同時に同じ拡張keyを設定または削除する時、1番目のユーザだけが正常に削除できます。他のユーザは返されたメッセージからエラーコード23001と最新の拡張情報を受信します。エラーコードと最新の拡張情報を受信した後、必要に応じて再設定してください。
2. ユーザ同士が異なる拡張keyを設定することを強くお勧めします。そうすれば、ほとんどの運用シーンでは衝突が発生しません。例えば、投票、しりとり、アンケート調査の運用シーンでは、自分のuserIDを拡張keyとして設定するなど。
サンプルコードは次のとおりです:
// メッセージ拡張を設定するV2TimValueCallback<List<V2TimMessageExtensionResult>>setMessageExtensionsRes = await TencentImSDKPlugin.v2TIMManager.getMessageManager().setMessageExtensions(msgID: '', // 拡張するメッセージのidextensions: []); // メッセージ拡張フィールドif (setMessageExtensionsRes.code == 0) {// 正常にメッセージ拡張を設定した}
メッセージ拡張の取得
説明:
ネットワークに接続していない場合、SDKはそのままローカルにキャッシングされたメッセージ拡張リストを返します。
サンプルコードは次のとおりです:
// メッセージ拡張を取得するV2TimValueCallback<List<V2TimMessageExtension>> getMessageExtensionsRes =await TencentImSDKPlugin.v2TIMManager.getMessageManager().getMessageExtensions(msgID: '', // 拡張情報を取得するメッセージのid);if (getMessageExtensionsRes.code == 0) {// 正常にメッセージ拡張を取得したgetMessageExtensionsRes.data?.forEach((element) {element.extensionKey; // 変更された拡張フィールドkeyelement.extensionValue; // 変更された拡張フィールドvalues});}
メッセージ拡張の削除
deleteMessageExtensions
(詳細はこちら)インターフェースを呼び出し、指定したメッセージ拡張を削除します。keys
フィールドにnull
が設定されている場合、すべてのメッセージ拡張が削除されます。サンプルコードは次のとおりです:
// メッセージ拡張の削除V2TimValueCallback<List<V2TimMessageExtensionResult>>deleteMessageExtensionsRes = await TencentImSDKPlugin.v2TIMManager.getMessageManager().deleteMessageExtensions(msgID: '', // 拡張を削除するメッセージのidkeys: []); // 拡張フィールドを削除するkeyのリストif (deleteMessageExtensionsRes.code == 0) {// 正常にメッセージ拡張を削除したdeleteMessageExtensionsRes.data?.forEach((element) {element.extension; //メッセージ拡張情報element.resultCode; //実行結果コードelement.resultInfo; //詳細情報});}
メッセージ拡張の更新
事前に
addAdvancedMsgListener
を呼び出して高度なメッセージイベントリスナーを追加した場合、メッセージ拡張が追加または更新されると、onRecvMessageExtensionsChanged
(詳細はこちら)コールバックを受信します。メッセージ拡張が削除されると、onRecvMessageExtensionsDeleted
(詳細はこちら)コールバックを受信します。サンプルコードは次のとおりです:
//メッセージリスナーを作成するV2TimAdvancedMsgListener listener = V2TimAdvancedMsgListener(onRecvMessageExtensionsChanged:(String msgID, List<V2TimMessageExtension> extensions) {// msgID 変更されたメッセージのid// extensions 変更された拡張フィールドのリストfor (V2TimMessageExtension element in extensions) {element.extensionKey; // 変更された拡張フィールドkeyelement.extensionValue; // 変更された拡張フィールドvalues}},onRecvMessageExtensionsDeleted: (msgID, extensionKeys) {// msgID 拡張メッセージが削除されたメッセージのid// extensionKeys 拡張メッセージが削除されたkeyのリスト},);// 高度なメッセージのイベントリスナーを追加するTencentImSDKPlugin.v2TIMManager.getMessageManager().addAdvancedMsgListener(listener: listener);