[Gather.town]私を取り巻きで囲む方法

2022.11.03
  • t_o_dと申します。
  • 円滑なリモートコミュニケーションの促進の一環としてGather.townを利用しています。
  • Gather.townは基本機能以外の仕掛けが沢山ありますが、その中の1つがブラウザコンソールで扱えるプロパティやメソッドの存在です。
  • 「現在位置の取得」や「参加者情報の取得」など豊富に存在しており、それらを適切に組み合わせることで色々な操作を行うことが可能です。
  • 今回はその中から私を取り巻きで囲む方法を記録いたします。

結果

  • 以下の内容をChromeコンソール画面に入力して実行するだけで、自身を取り巻きで囲むことができます。
    • ※実行には権限が必要です。
const mapId = gameSpace.mapId;
const {x: curX, y: curY} = gameSpace.gameState[gameSpace.id]
const image = "https://cdn.gather.town/storage.googleapis.com/gather-town.appspot.com/internal-dashboard/images/r_6fDBWpYrYfoccvs0HdP";
for(let x = curX - 1; x <= curX + 1; x++){
    for(let y = curY -1; y <= curY + 1; y++){
        if(x === curX && y === curY) continue;
        const objId = `john_${Math.floor(Math.random()*10000)}`
        const obj = {
          id: 'john',
          normal: image,
          height: 1,
          width: 1,
          x: x,
          y: y,
          type: 0,
        }
        game.setObject(mapId, objId, obj);
    }
}

  • 実行後、自身の現在位置の上下左右斜め1マスに人のオブジェクトが配置されていれば成功です。

  • 他の場所に移動して2回目での実行でも周りに配置されます。

内容

  • 上記のスクリプトは以下3つのGather.townで用意されているプロパティ及びメソッドを利用しています。
    • gameSpace.mapId : 現在位置のマップID
    • gameSpace.gameState.参加者ID : 指定の参加者の情報
    • gameSpace.id : 自身の参加者ID
    • game.setObject(マップID, オブジェクトID, オブジェクト設定情報) : 指定のマップ及びオブジェクト設定情報に記載した座標に任意のオブジェクトを設置
  • つまり処理の流れは以下のようになっております。
    • 自身の現在位置のマップIDや座標を取得。
    • 現在位置の上下左右斜め1マスに指定のオブジェクトを設置。
  • ※処理内のimageで指定しているものは既存のオブジェクトのCDN画像です。オブジェクトのCDNを確認する場合は一度配置して、ChromeコンソールでgameSpace.mapState[gameSpace.mapId].objectsを実行して返ってくる情報を参照してください。

補足

  • 他の操作の情報はこちらのサイトから確認できます。
  • より詳細な情報を知るためには、以下のようにコンソール画面で「game」「gameSpace」を入力して実行すれば確認できます。

まとめ

  • こうした基本機能以外に提供されているものを利用してより良いリモートコミュニケーションの促進につながると実感しました。
  • 今回扱った機能以外にも豊富なメソッドやプロパティがあるので、適切に組み合わせて節度ある利用を行おうと思います。

参考

アノテーション株式会社について

アノテーション株式会社は、クラスメソッド社のグループ企業として「オペレーション・エクセレンス」を担える企業を目指してチャレンジを続けています。「らしく働く、らしく生きる」のスローガンを掲げ、様々な背景をもつ多様なメンバーが自由度の高い働き方を通してお客様へサービスを提供し続けてきました。現在当社では一緒に会社を盛り上げていただけるメンバーを募集中です。少しでもご興味あれば、アノテーション株式会社WEBサイトをご覧ください。