PLAYCANVASを学習中。
data:image/s3,"s3://crabby-images/365ea/365eac5dfdb1d0f1b115db1f23f34e227fff50c1" alt="CSS UI | Learn PlayCanvas 2022-03-20 10-00-10.jpg CSS UI | Learn PlayCanvas 2022 03 20 10 00 10"
HTML/CSS UI | Learn PlayCanvas
このTutorialで、ボタンを押すとクリックした回数が増えるサンプルがあるので、これを見て、ボタンをクリックした情報をどのように処理しているのかを学びます。
サンプルの検証
data:image/s3,"s3://crabby-images/1f869/1f8697946f4ef1304556e1f84e9dfb86ebf347d2" alt="UntitledImage.png UntitledImage"
HIERARCHYには、camera,box(Entity),html+css(Entity)の3つがあります。
data:image/s3,"s3://crabby-images/73f19/73f19bd5316123a31899f1c7c358f58bab7daaf6" alt="UntitledImage.png UntitledImage"
ASSETSには、box、skyboxのフォルダがあり、このskyboxはどうやら背景の画像っぽいです。boxは画面に表示されるものです。
直下ファイルとして、css,html,turn.js,ui.jsの4つがあります。
コードの確認
<div class='button'>BUTTON</div> <div class='counterBox'> times clicked <span class='counter'>0</span> </div> <div class='text'> Hit the button to increment the counter<br /> </div>
Htmlのコードはこちら。
var Turn = pc.createScript('turn'); Turn.prototype.update = function (dt) { this.entity.rotate(0, dt * 90, 0); };
turn.jsのコード。
このdtという値ですが、スクリプトの構造 | Learn PlayCanvasを見ると、
各フレームのdtは、最後のフレームからの秒単位の時間となる引数として渡されます。
となっており、PLAYCANVAS上で決まった変数のよう。
var Ui = pc.createScript('ui'); Ui.attributes.add('css', {type: 'asset', assetType:'css', title: 'CSS Asset'}); Ui.attributes.add('html', {type: 'asset', assetType:'html', title: 'HTML Asset'}); Ui.prototype.initialize = function () { // create STYLE element var style = document.createElement('style'); // append to head document.head.appendChild(style); style.innerHTML = this.css.resource || ''; // Add the HTML this.div = document.createElement('div'); this.div.classList.add('container'); this.div.innerHTML = this.html.resource || ''; // append to body // can be appended somewhere else // it is recommended to have some container element // to prevent iOS problems of overfloating elements off the screen document.body.appendChild(this.div); this.counter = 0; this.bindEvents(); }; Ui.prototype.bindEvents = function() { var self = this; // example // // get button element by class var button = this.div.querySelector('.button'); var counter = this.div.querySelector('.counter'); // if found if (button) { // add event listener on `click` button.addEventListener('click', function() { ++self.counter; if (counter) counter.textContent = self.counter; console.log('button clicked'); // try to find object and change its material diffuse color // just for fun purposes var obj = pc.app.root.findByName('box'); if (obj && obj.render) { var material = obj.render.meshInstances[0].material; if (material) { material.diffuse.set(Math.random(), Math.random(), Math.random()); material.update(); } } }, false); } if (counter) counter.textContent = self.counter; };
Ui.jsのコード。こちらで全体のコントロールをしている様子。
Ui.attributes.add('css', {type: 'asset', assetType:'css', title: 'CSS Asset'}); Ui.attributes.add('html', {type: 'asset', assetType:'html', title: 'HTML Asset'});
このコードは読み込む外部ファイルを設定しているのかな?
data:image/s3,"s3://crabby-images/46adf/46adfdba79e650c4052d69046d7aa833587f406e" alt="CSS UI | Editor 2022-03-20 10-30-34.jpg CSS UI | Editor 2022 03 20 10 30 34"
Editorにはこのように表示されています。
Ui.attributes.add('css1', {type: 'asset', assetType:'css', title: 'CSS Asset'}); Ui.attributes.add('html', {type: 'asset', assetType:'html', title: 'HTML Asset'});
このように、Editorで’css1’と変更してセーブ。
data:image/s3,"s3://crabby-images/446af/446af4b101391ef7badc726317b06c8307f9193b" alt="CSS UI | Editor 2022-03-20 10-34-09.jpg CSS UI | Editor 2022 03 20 10 34 09"
PARSEをクリック
data:image/s3,"s3://crabby-images/2df90/2df90765cdf9711abef7c88d715aa3a78bcd0c6c" alt="CSS UI | Editor 2022-03-20 10-36-50.jpg CSS UI | Editor 2022 03 20 10 36 50"
Ui.jsをクリックすると
data:image/s3,"s3://crabby-images/d6df2/d6df2023793671a91d9ecc3e99f4a219182788d5" alt="CSS UI | Editor 2022-03-20 10-37-48.jpg CSS UI | Editor 2022 03 20 10 37 48"
Css1に更新されました。
Ui.attributes.add('css', {type: 'asset', assetType:'css', title: 'CSS Asset'}); Ui.attributes.add('css1', {type: 'asset', assetType:'css', title: 'CSS Asset'}); Ui.attributes.add('html', {type: 'asset', assetType:'html', title: 'HTML Asset'});
さらに、Ui.attributes.addを一行追加。
data:image/s3,"s3://crabby-images/0faf4/0faf4a7f85bf270b6b20d80fd1c6968e222b6d5b" alt="CSS UI | Editor 2022-03-20 10-39-35.jpg CSS UI | Editor 2022 03 20 10 39 35"
追加されました。
コードの変更を行ったら、
コードのsave > PARSE > 該当ファイルをクリック
で更新されるようです。
buttonクリックイベントの取得
data:image/s3,"s3://crabby-images/21fba/21fbaadd0465603f3d66b575d7701941c3319304" alt="CSS UI | Code Editor 2022-03-20 10-51-21.jpg CSS UI | Code Editor 2022 03 20 10 51 21"
Buttonがクリックされたイベントについては、bindEventsという関数で .buttonにclickのイベントリスナーを追加して、counterという変数を1増加、
data:image/s3,"s3://crabby-images/0b020/0b0207a995f377a8256e777420f68f7a5530d6c0" alt="CSS UI | Code Editor 2022-03-20 10-51-55.jpg CSS UI | Code Editor 2022 03 20 10 51 55"
また、表示されているboxオブジェクトの外観を、
material.diffuse.set(Math.random(), Math.random(), Math.random());
このコードでランダムに色を変更するという処理をしています。
turn.js
data:image/s3,"s3://crabby-images/228a0/228a0e22e3ecd644f3f209ca54e04860a078bf4c" alt="CSS UI | Editor 2022-03-20 10-55-54.jpg CSS UI | Editor 2022 03 20 10 55 54"
オブジェクトboxのENTITYの中に、Scriptとしてturn.jsがありました。
このスクリプトは
Turn.prototype.update = function (dt) {
this.entity.rotate(0, dt * 90, 0);
};
となっているので、ENTITYであるboxをひたすらrotateさせるコードのようです。
まとめ
オブジェクトとコードの連携のイメージが少しづつつかめてきました。