0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【MESH カスタムタグ】出力制御(誤動作防止)をするタグの実装方法

Last updated at Posted at 2018-03-08

できること

MESH*アプリ上で、このタグをトリガータグ(トリガーとなるタグ)とアクションタグ(アクションとなるタグ)の間に挟むと、指定した時間内での意図しないアクションタグの複数回実行を防ぐことができます。トリガータグが意図せず反応し、複数回アクションが実行されて『うーん...』って思う事がこれで少なくなります。

*MESHとは、小さな便利を形にできる、ブロック形状の電子タグです。

言葉だと伝わりにくいと思うので、上記のgif画像を見て頂くと今回のタグ(盾マークのアイコン)の挙動が伝わると思います。3000ミリ秒を設定しているので、一度目の入力に対しては出力信号を出しますが、その後3000ミリ秒間は入力が来ても出力信号を出さない状態になります。
動作の挙動としては、動きタグなどで設定できる**間隔(秒)**に近い動作になります。この項目を設定できるタグではこのタグを利用する必要はないのですが、それが出来ないタグの場合は活用する事ができます。

実装

前に実装した【MESH カスタムタグ】ミリ秒単位で処理をsleepさせる方法を少し改良して実装しました。

Initialize

Initialize.js
return {
    runtimeValues : { 
		ignoreSignal:false
	} 
}

Receive

特に書くことはありません。

Execute

Execute_success.js
w
wait().then((v) => {
    log(runtimeValues.ignoreSignal);
});

function sleep() {
	return new Promise(resolve => setTimeout(resolve,properties.millisecond));
}

async function wait() {
	//1回目の入力信号は、出力信号を送る
	if(!runtimeValues.ignoreSignal){

		runtimeValues.ignoreSignal = true;
		callbackSuccess( {
			resultType : "continue"
		} );
		
		//非同期処理が完了するまで待機
		await sleep();
		
		runtimeValues.ignoreSignal = false;		
	}
	//入力信号があってから指定時間以内は、出力信号を送らない
	else{
		callbackSuccess( {
			resultType : "stop"
		} );

	}
	return properties.millisecond.toString();
}

return {
	resultType : "pause"
};

Result

Result.js
return {
	indexes : 0,
	resultType : "continue"
};

importファイル

MESH SDKログインページからID等を入力してログインし、「Create New Tag」から新しいカスタムタグを作ってください。その後、import」を開き、下記のjosnデータをコピペして「Load JSON」を押して読み込んでください。

output_control.json
{"formatVersion":"1.0","tagData":{"name":"出力制御(誤動作防止)","icon":"","description":"一度入力・出力されてから、指定時間経過するまで入力を無視するタグです。\n(誤動作で複数回信号が送信される可能性がある場合、このタグを間に挟む事で指定時間内の出力を1回だけすることができます。)","functions":[{"id":"function_0","name":"時間内の複数入力を1出力とする","connector":{"inputs":[{"label":"入力"}],"outputs":[{"label":"出力"}]},"properties":[{"name":"時間(ミリ秒)","referenceName":"millisecond","type":"string","defaultValue":"1000"}],"extension":{"initialize":"return {\n    runtimeValues : { \n\t\tignoreSignal:false\n\t} \n}","receive":"","execute":"\nwait().then((v) => {\n    log(runtimeValues.ignoreSignal);\n});\n\nfunction sleep() {\n\treturn new Promise(resolve => setTimeout(resolve,properties.millisecond));\n}\n\nasync function wait() {\n\t//1回目の入力信号は、出力信号を送る\n\tif(!runtimeValues.ignoreSignal){\n\n\t\truntimeValues.ignoreSignal = true;\n\t\tcallbackSuccess( {\n\t\t\tresultType : \"continue\"\n\t\t} );\n\t\t\n\t\t//非同期処理が完了するまで待機\n\t\tawait sleep();\n\t\t\n\t\truntimeValues.ignoreSignal = false;\t\t\n\t}\n\t//入力信号があってから指定時間以内は、出力信号を送らない\n\telse{\n\t\tcallbackSuccess( {\n\t\t\tresultType : \"stop\"\n\t\t} );\n\n\t}\n\treturn properties.millisecond.toString();\n}\n\nreturn {\n\tresultType : \"pause\"\n};\n","result":"return {\n\tindexes : 0,\n\tresultType : \"continue\"\n};"}}]}}

感想

意図しないアクションの複数回連続動作に悩まされていたので、これで解決する事ができました!

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?