この記事は、
事務所デジタルツインプロジェクト-PlayCanvas/Babylonjs | GWアドベントカレンダーの8日目の記事です。
弊社の事務所にDALIというオープンでデジタルな照明制御の機器を導入したので、PlayCanvasで仮想空間に同じ事務所を作成し、Web上でボタンを押すと仮想空間の照明器具も点灯すると同時に、現実空間の照明も点灯、その逆もしかりというデジタルツインをやろうとしています。
前回の記事ではPCのキーボードのキーを押すと、照明が点灯するというふうにしました。(題名はボタンになっていますが…)
PlayCanvasでボタンを押すと照明をOn/Offする方法|デジタルライト(Digital-light.jp)
今度は、PlayCanvasでボタンを表示させて、そこをマウスでクリックしてボタンを押すようなことをしたいとおもいます。
そうすることで、Buttonを押すというイベントから、外部APIを叩き、現実空間のDALI照明を点灯・消灯させることにつなげられるかなと。
参考にするプロジェクト
data:image/s3,"s3://crabby-images/b9820/b98202f54d39006dabefb4154226792860729642" alt="UntitledImage.png UntitledImage"
参考にするプロジェクトはこちら。
User Interface – Buttons | Learn PlayCanvas
あと、2019年のPlayCanvasアドベントカレンダーで解説されている記事もよさそうです。
PlayCanvasでクリックできるボタンを設置する – Qiita
2D Screenの作成
data:image/s3,"s3://crabby-images/23df7/23df767dd5b57cc84369b97cdb2c2db11cba82d8" alt="UntitledImage.png UntitledImage"
Tutorialでは2D Screenのセットアップをしていますので、自分でも新しくPlayCanvasのプロジェクトを作成し、Add Unser Interfaceから2D Screenを追加します。
data:image/s3,"s3://crabby-images/ec8f1/ec8f1ae9aed554c2f351983920825ef811b271e2" alt="UntitledImage.png UntitledImage"
HIERARCYから追加。
data:image/s3,"s3://crabby-images/2f1bc/2f1bc56bdbac0a1356b68d334e68c6ba9a293df8" alt="UntitledImage.png UntitledImage"
これで2Dスクリーンがはいりました。
data:image/s3,"s3://crabby-images/d7799/d7799be70b8ba960b5ab6b092ab60edaf7e46796" alt="UntitledImage.png UntitledImage"
スクリーンの解像度はここで設定できます。
data:image/s3,"s3://crabby-images/d75ad/d75ad282aef09df108866f35531b58319740131a" alt="UntitledImage.png UntitledImage"
カメラの位置は2D Screenが見えるところに移動させます。
テキストの挿入
data:image/s3,"s3://crabby-images/30939/309392095ebc131a8a93496c5da742b78d79b755" alt="2022-05-05_22-19-03.png 2022 05 05 22 19 03"
TEXTもいれてみました。
data:image/s3,"s3://crabby-images/c963b/c963b1d144f9c34762a38e0ae1b5f864d6c0d948" alt="UntitledImage.png UntitledImage"
TEXTはフォントをいれないと表示されないので、TutorialプロジェクトにあったフォントをASSETSにコピペ。
data:image/s3,"s3://crabby-images/e6102/e61026f347c87348bb8fa30ec9e4b5bc545d3048" alt="UntitledImage.png UntitledImage"
TEXTのELEMENTのFONTにドラッグ&ドロップ。
data:image/s3,"s3://crabby-images/df2c0/df2c073e3981482147f6703dea9b7c18c0426bee" alt="UntitledImage.png UntitledImage"
位置を調整してTEXTが表示されました。
ボタンの挿入
data:image/s3,"s3://crabby-images/ddca8/ddca8982cee16a6410371b1a2fbd2d6e7ce61292" alt="UntitledImage.png UntitledImage"
HIERARCYからButton Elementを挿入しました。
ボタンの使い方については、こちらの公式マニュアルを参照。
Transition ModeはTintとSprite Changeがありますが、Tintだと単純にマウスを上にした時や押したときに色を変える、Sprite Changeはスプライトを変えて複雑なことができる様子です。
data:image/s3,"s3://crabby-images/e5ad6/e5ad6b12d9126d1a545f615a945a45d2397368a3" alt="UntitledImage.png UntitledImage"
今回はTintでいきます。
data:image/s3,"s3://crabby-images/9d06a/9d06a588821fb99bd396650eaf32f9c93ddc6e63" alt="UntitledImage.png UntitledImage"
Launchしてみたところ、マウスを上にのせると赤、押すと青になりました。
data:image/s3,"s3://crabby-images/ca5ce/ca5cec559e02b001f9a0f8b006ce89d9c797a647" alt="UntitledImage.png UntitledImage"
いろいろボタンのテキストや位置・サイズを変更したら、Launchの画面で押しても反応しなくなりました。
data:image/s3,"s3://crabby-images/09255/09255b95957584eb317dbeb450ef5347d68bb0d8" alt="UntitledImage.png UntitledImage"
確認の為、新しいButtonを追加し、Launchをやり直したところ、最初のボタンも反応するようになりました。変更があった場合には、再度、Launchをやり直すほうが良さそうです。
Buttonを押すとスクリプトが動くようにする
このボタンにスクリプトを組み込みます。
data:image/s3,"s3://crabby-images/cddc8/cddc8ec747a73ce776e99b7af4c585c2d7cfb6a0" alt="UntitledImage.png UntitledImage"
ButtonにADD COMPONENTでScriptを追加します。
data:image/s3,"s3://crabby-images/ccf11/ccf1192bf91ce12c741c03cae0d303bac0058bd6" alt="UntitledImage.png UntitledImage"
button.jsというスクリプトをASSETSに作成。
Buttonのスクリプトはこちらの記事を参考にしました。
PlayCanvasでクリックできるボタンを設置する – Qiita
var Button = pc.createScript('button'); Button.attributes.add("message", {type: "string", default: "message"}) // initialize code called once per entity Button.prototype.initialize = function() { // タッチできる端末だったら if(this.app.touch){ // element componentがタッチされたらattributes: messageアラートとして表示する this.entity.element.on(pc.EVENT_TOUCHSTART, () => this.show(this.message)) }else{ // element componentがクリックされたらattributes: messageアラートとして表示する this.entity.element.on("click", () => this.show(this.message)) } }; // update code called every frame Button.prototype.update = function(dt) { }; Button.prototype.show = (message) => alert(message)
これでLaunchしてみます。
実行画面
data:image/s3,"s3://crabby-images/d9947/d9947ad50298541af04cfc407c3f0bb02c37a181" alt="UntitledImage.png UntitledImage"
ボタンをクリックすると、alertメッセージが表示されました。
まとめ
以上、ボタンを押すとイベントが発生するということができました。
次は、ボタンを押すと、照明が点灯・消灯するということをやっていきたいとおもいます。