2 * @fileOverview DigitalInクラスを定義します。
\r
10 * <a href="https://mbed.org/handbook/DigitalIn">mbed::DigitalIn</a>と同等の機能を持ちます。
\r
11 * @name mbedJS.DigitalIn
\r
13 * @param {mbedJS.Mcu} i_mcu
\r
14 * インスタンスをバインドするMCUオブジェクトです。
\r
15 * @param {PinName} i_params
\r
17 * @param {HashMap|Generator|function} i_handler
\r
18 * 非同期イベントハンドラの連想配列、Generator、コールバック関数の何れかを指定します。
\r
20 * 非同期イベントハンドラの場合、関数はイベントハンドラで結果を通知します。
\r
22 * <li>{function()} onNew -
\r
23 * インスタンスが使用可能になった時に呼び出されます。
\r
25 * <li>{function(v)} onRead -
\r
26 * read関数のコールバック関数です。
\r
28 * <li>{int} v - 現在のピンの値です。</li>
\r
31 * <li>{function()} onMode -
\r
32 * mode関数のコールバック関数です。
\r
36 * Generatorを指定した場合、コールバック関数の引数はyiledの戻り値として取得できます。
\r
39 * コールバック関数を指定した場合、RPCが完了したときに呼び出されます。メンバ関数のイベントハンドラは個別に設定する必要があります。
\r
41 * @return {mbedJS.DigitalIn}
\r
42 * @example //Callback
\r
43 * var mcu=new mbedJS.Mcu("192.168.128.39",
\r
46 * var pin=new mbedJS.DigitalIn(mcu,mbedJS.PinName.P0_22,{
\r
48 * pin.mode(mbedJS.PinMode.PullUp);
\r
54 * onRead:function(v){
\r
58 * onClose:function(){
\r
60 * onError:function(){
\r
63 * @example //Generator
\r
64 * var g=function*(){
\r
66 * var mcu=new mbedJS.Mcu("192.168.128.39",g);
\r
67 * yield mcu.waitForNew();
\r
68 * var pin=new mbedJS.DigitalIn(mcu,mbedJS.PinName.P0_22,g);
\r
69 * yield pin.waitForNew();
\r
70 * var v=yield pin.read();
\r
71 * yield pin.mode(mbedJS.PinMode.PullDown);
\r
72 * yield mcu.close();
\r
78 var CLASS=function DigitalIn(i_mcu,i_params,i_handler)
\r
84 var cb=MI._initHandler.call(_t,i_handler);
\r
85 MI.assertInt(i_params);
\r
86 _t._mcu.rpc(_t.RPC_NS+":_new1",i_params,
\r
89 _t._oid=j.result[0];
\r
91 if(_t._gen){_t._gen.next(_t);}
\r
97 throw new MI.MiMicException(e);
\r
103 RPC_NS:"mbedJS:DigitalIn",
\r
104 /** @private 最後にコールしたAPIです。*/
\r
106 /** @private Generatorモードの場合にGeneratorオブジェクトを保持します。*/
\r
108 /** @private コールバック関数の連想配列です。要素はコンストラクタを参照してください。*/
\r
110 /** @private リモートインスタンスのオブジェクトIDです。*/
\r
113 * Generatorモードのときに使用する関数です。
\r
114 * Generatorモードの時は、yieldと併用してnew DigitalIn()の完了を待ちます。
\r
115 * @name mbedJS.DigitalIn#waitForNew
\r
118 waitForNew:function DigitalIn_waitForNew()
\r
121 if(this._lc!=CLASS){throw new MI.MiMicException(MI.Error.NG_ILLEGAL_CALL);}
\r
122 this._lc=CLASS.waitForNew;
\r
124 throw new MI.MiMicException(e);
\r
128 * ピンからアナログ値を読み込みます。
\r
129 * 関数の完了時にonReadイベントが発生します。
\r
130 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
131 * @name mbedJS.DigitalIn#read
\r
134 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
136 * Generatorモードの時はピンの値を返します。
\r
138 read:function DigitalIn_read()
\r
142 var cb=MI._getCb(arguments,_t._event.onRead);
\r
143 MI._assertYield.call(_t);
\r
145 return _t._mcu.rpc(_t.RPC_NS+":read",_t._oid,
\r
150 if(_t._gen){_t._gen.next(v);}
\r
155 throw new MI.MiMicException(e);
\r
160 * 関数の完了時にonModeイベントが発生します。
\r
161 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
162 * @name mbedJS.DigitalIn#mode
\r
164 * @param {PinMode} i_value
\r
167 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
169 mode:function DigitalIn_mode(i_value)
\r
173 var cb=MI._getCb(arguments,_t._event.onMode);
\r
174 MI._assertYield.call(_t);
\r
176 MI.assertInt(i_value);
\r
177 return _t._mcu.rpc(_t.RPC_NS+":mode",_t._oid+","+i_value,
\r
182 if(_t._gen){_t._gen.next(v);}
\r
187 throw new MI.MiMicException(e);
\r
191 NS.DigitalIn=CLASS;
\r