MESHアプリに標準で搭載されているタイマーブロックの「待つ」機能では、分と秒で待ち時間を設定するようになっているため、1秒未満の待ち時間を設定することができません。
その代わり、MESH SDKを使うと、ミリ秒単位で設定できるタイマーを作ることが可能です。
ミリ秒単位の待ち時間を設定できるタイマーの例
ここでは、あらかじめ作成されたカスタムブロックをインポートして使えるようにするための方法を説明します。プログラミング不要なので、お気軽にお試しください。
大まかな流れ
1.ブラウザで「MESH SDK」にログインして、カスタムブロック「タイマー(ミリ秒単位)」をインポートする 2.MESHアプリでアカウントにログインし、カスタムブロックを追加する 3.キャンバス上で「タイマー(ミリ秒単位)」を使う |
1.ブラウザで「MESH SDK」にログインして、カスタムブロック「タイマー(ミリ秒単位)」をインポートする
このステップでは、あらかじめ作成された「タイマー(ミリ秒単位)」のブロックをMESH SDKでインポートして、MESHアプリから読み込めるようにするための準備を行います。
1-1. MESH SDKのページにアクセスして、ログインします。
MESH SDK https://meshprj.com/sdk-jp/
以下のページの「MESH SDKを使う」をクリックします。
MESHアカウントをお持ちの方はサインインします。
アカウントをお持ち出ない方は「Create New Account」からアカウントを作成してください。
1-2. サインインしたら、カスタムブロックの管理画面で「Create New Block」の「+」ボタンをクリックします。
1-3. 編集画面の「Import」をクリックします。
1-4. インポート用のコードをコピーして貼り付けます。
「タイマー(ミリ秒単位)」のインポート用コード
{"formatVersion":"1.0","tagData":{"name":"タイマー(ミリ秒単位)","icon":"","description":"タイマーブロックの「待つ」をミリ秒単位で指定できるようにしたものです。","functions":[{"id":"function_0","name":"待つ","connector":{"inputs":[{"label":""}],"outputs":[{"label":""}]},"properties":[{"name":"時間(ミリ秒)※1秒=1000","referenceName":"waitTime","type":"number","defaultValue":"200"}],"extension":{"initialize":"","receive":"","execute":"async function wait() {\n await new Promise(resolve => setTimeout(resolve,properties.waitTime));\n return ;\n}\n\nwait().then(function() {\n\tcallbackSuccess( {\n\t\tresultType : \"continue\"\n\t} );\n});\n\nreturn {\n resultType : \"pause\"\n};","result":""}}]}}
※ 上記コードのコピーがうまくいかない方は、以下のテキストファイルを開いてコピーしてから貼り付けてください。
コピーしたインポート用コードを以下のエリアに貼り付けます。
貼り付けたら「Load JSON」をクリックします。
以下のような表示が出た場合は「OK」を押してください。
1-5. 正しく読み込まれると、以下のような画面になります。「Save *」をクリックしてください。
1-6. 正しく保存されると「Save *」から「Save」に表記が変わります。 保存された後は、右上の「×」ボタンをクリックして編集画面を閉じてください。
1-7. カスタムブロックの一覧にインポートしたブロックが追加されます。ここでMESH SDK画面での作業は完了です。
2.MESHアプリでアカウントにログインし、カスタムブロックを追加する
ここからは、MESHアプリで操作を行います。
2-1. MESHアプリのキャンバス画面右上のメニューから「アカウント」を選択します。
2-2. 「MESH SDK」で使用したものと同じアカウントでログインします。
2-3. サインインすると、右側のブロックリストの一番下に「カスタム」が表示されます。「[+]追加」を選択します。
2-4. 「MESH SDK」でインポートしておいた「タイマー(ミリ秒単位)」が表示されるので選択します。
2-5. 以下のように追加されれば、使える状態になっています。
3.キャンバス上で「タイマー(ミリ秒単位)」を使う
カスタムブロックを読み込んだ後は、他のブロックと同じように使うことができます。
3-1. キャンバス上に読み込んだ「タイマー(ミリ秒単位)」をドラッグ&ドロップします。
3-2. タイマーの待ち時間をミリ秒単位で設定します。
※MESHアプリの動作スピードにより、あまり短い時間を設定しても差がでない場合があります。
3-3. レシピを作成します。
例えば、GPIOの電源出力をオンにしてから0.2秒でオフにするといった、1秒未満の待ち時間でタイマーを動作させることが可能です。
もっと詳しく知りたい方は
MESH SDKのリファレンスマニュアルをご参照ください。
https://meshprj.com/sdk/doc/ja/
書籍「MESHをはじめよう」でもMESH SDKの詳細を解説しています。
https://www.oreilly.co.jp/books/9784873118536/