タイマーブロックの「待つ」の時間を1秒未満に設定できますか?

MESHアプリに標準で搭載されているタイマーブロックの「待つ」機能では、分と秒で待ち時間を設定するようになっているため、1秒未満の待ち時間を設定することができません。

IMG_3734.PNG

 

その代わり、MESH SDKを使うと、ミリ秒単位で設定できるタイマーを作ることが可能です。

IMG_3718.jpg
ミリ秒単位の待ち時間を設定できるタイマーの例

 

ここでは、あらかじめ作成されたカスタムブロックをインポートして使えるようにするための方法を説明します。プログラミング不要なので、お気軽にお試しください。

 

大まかな流れ

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を使う」をクリックします。
mceclip0.png

 

MESHアカウントをお持ちの方はサインインします。

アカウントをお持ち出ない方は「Create New Account」からアカウントを作成してください。
mceclip1.png

 

1-2. サインインしたら、カスタムブロックの管理画面で「Create New Block」の「+」ボタンをクリックします。

mceclip2.png

 

1-3. 編集画面の「Import」をクリックします。

mceclip3.png

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":""}}]}}

※ 上記コードのコピーがうまくいかない方は、以下のテキストファイルを開いてコピーしてから貼り付けてください。

「タイマー(ミリ秒単位)」のインポート用コード

 

コピーしたインポート用コードを以下のエリアに貼り付けます。

mceclip9.png

 

貼り付けたら「Load JSON」をクリックします。

mceclip4.png

 

以下のような表示が出た場合は「OK」を押してください。
mceclip5.png

1-5. 正しく読み込まれると、以下のような画面になります。「Save *」をクリックしてください。

mceclip6.png

1-6. 正しく保存されると「Save *」から「Save」に表記が変わります。 保存された後は、右上の「×」ボタンをクリックして編集画面を閉じてください。

mceclip8.png

1-7. カスタムブロックの一覧にインポートしたブロックが追加されます。ここでMESH SDK画面での作業は完了です。

mceclip7.png

 

 

2.MESHアプリでアカウントにログインし、カスタムブロックを追加する

 

ここからは、MESHアプリで操作を行います。

 

2-1. MESHアプリのキャンバス画面右上のメニューから「アカウント」を選択します。

IMG_3721.png

 

2-2. 「MESH SDK」で使用したものと同じアカウントでログインします。

IMG_3720.PNG

 

2-3. サインインすると、右側のブロックリストの一番下に「カスタム」が表示されます。「[+]追加」を選択します。

IMG_3724.png

 

2-4. 「MESH SDK」でインポートしておいた「タイマー(ミリ秒単位)」が表示されるので選択します。

IMG_3726.png

 

IMG_3727.png

 

2-5. 以下のように追加されれば、使える状態になっています。

IMG_3729.png

 

 

3.キャンバス上で「タイマー(ミリ秒単位)」を使う

 

カスタムブロックを読み込んだ後は、他のブロックと同じように使うことができます。

 

3-1. キャンバス上に読み込んだ「タイマー(ミリ秒単位)」をドラッグ&ドロップします。

IMG_3731.PNG

 

3-2. タイマーの待ち時間をミリ秒単位で設定します。

 

※MESHアプリの動作スピードにより、あまり短い時間を設定しても差がでない場合があります。

IMG_3732.png

 

3-3. レシピを作成します。

 

例えば、GPIOの電源出力をオンにしてから0.2秒でオフにするといった、1秒未満の待ち時間でタイマーを動作させることが可能です。

IMG_3733.PNG

 

 

もっと詳しく知りたい方は

 

MESH SDKのリファレンスマニュアルをご参照ください。

https://meshprj.com/sdk/doc/ja/

 

 

書籍「MESHをはじめよう」でもMESH SDKの詳細を解説しています。

https://www.oreilly.co.jp/books/9784873118536/

[cover photo]