PMX ArduinoLib MemREADToByte()
『PMX Library for Arduino』のMemREADToByte()関数について解説します。
【解説】
MemREADコマンドは、メモリマップのRAM領域から情報を読み出すためのコマンドです。PMXサーボのメモリマップにはRAM領域とROM領域があります。サーボ起動時にROM領域からRAM領域にデータが展開され、サーボの制御にはRAM領域のデータが使用されます。
この関数は、アドレスで指定したRAM領域から1バイトのデータを読み出すことができます。
【構文】
status = MemREADToByte(ID, address, &byteData);
【例】
1 2 3 |
byte byteData; // サーボから読み出したデータを受け取るための変数 flag = pmx.MemREADToByte(ServoID, PMX::RamAddrList::TorqueSwitch, &byteData); Serial.println(byteData); |
【パラメータ】
引数1:ID(byte型)
第一引数の「ID」はサーボIDです。「ID」は、MemREADコマンドの命令の対象になるサーボを指定しています。「ID」を0に指定すると、ID0のサーボを指定することができます。
引数2:address(unsigned short型)
第二引数の「address」は先頭アドレスです。「先頭アドレス」とは、メモリマップのアドレスを指し、読み出すデータの先頭のアドレスを指定することができます。上記の例では「PMX::RamAddrList::TorqueSwitch」と書いていますが、これはライブラリ内で定義された変数で、メモリマップのアドレスを指定しています。「PMX::RamAddrList::TorqueSwitch」には500が代入されていますので、実行の際は500に変換されます。また数値で500と指定しても同じ番地からデータを読み出すことができます。アドレスは『オンラインマニュアル』をご参照ください。
引数3:byteData(byte型)
第三引数の「byteData」に変数のポインタを渡します。MemREADコマンドで読み出したデータが代入されます。
【戻り値】
戻り値:status(unsigned short型)
戻り値は、サーボとの通信状態とサーボの状態が正常かどうかのステータスを足したものが返ってきます。データが0であれば問題ありません。0以外の場合は、なんらかの問題が発生していますので、ステータス部がエラーの場合はオンラインマニュアルの『5.エラー状態』、または『PmxStatusErrorList』を、通信部がエラーの場合は『ComError』を参照してください。
status = PMXからの返信のステータス(PMX::PmxStatusErrorList) + 送受信の状態(PMX::ComError)