English | 简体中文 | 繁體中文 | 日本語 | Deutsch | 한국어
NEC IR 伝送プロトコルは、メッセージ ビットのパルス距離エンコーディングを使用します。 各パルスバーストの長さは562.5μsで、キャリア周波数は38kHz (26.3μs)です。 論理ビットは次のように送信されます。
論理「0」 – 562.5μs のパルス バーストの後に 562.5μs のスペースが続き、合計送信時間は 1.125ms です。
論理「1」 – 562.5μs のパルス バーストの後に 1.6875ms のスペースが続き、合計送信時間は 2.25ms です。
リモコンのキーを押すと、送信されるメッセージは次の順序で構成されます。
- 先頭の 9ms パルス バースト (論理データ ビットに使用されるパルス バースト長の 16 倍)。
- 4.5ms のスペース。
- 受信デバイスの 8 ビット アドレス。
- アドレスの 8 ビット論理反転。
- 8 ビット コマンド。
- コマンドの 8 ビット論理反転。
- メッセージ送信の終了を示す最後の 562.5μs パルス バースト。
LibDriver IR_REMOTE は、LibDriver によって起動される ir_remote の全機能ドライバーです。 NEC IR リモートデコード機能を提供します。 LibDriver は MISRA 準拠です。
/ srcディレクトリには、LibDriver IR_REMOTEのソースファイルが含まれています。
/ interfaceディレクトリには、LibDriver IR_REMOTE用のプラットフォームに依存しないGPIOバステンプレートが含まれています。
/ testディレクトリには、チップの必要な機能を簡単にテストできるLibDriver IR_REMOTEドライバーテストプログラムが含まれています。
/ exampleディレクトリには、LibDriver IR_REMOTEプログラミング例が含まれています。
/ docディレクトリには、LibDriver IR_REMOTEオフラインドキュメントが含まれています。
/ datasheetディレクトリには、IR_REMOTEデータシートが含まれています。
/ projectディレクトリには、一般的に使用されるLinuxおよびマイクロコントローラー開発ボードのプロジェクトサンプルが含まれています。 すべてのプロジェクトは、デバッグ方法としてシェルスクリプトを使用しています。詳細については、各プロジェクトのREADME.mdを参照してください。
/ misraはLibDriver misraコードスキャン結果を含む。
/ interfaceディレクトリにあるプラットフォームに依存しないGPIOバステンプレートを参照して、指定したプラットフォームのGPIOバスドライバを完成させます。
/src ディレクトリ、プラットフォームのインターフェイス ドライバー、および独自のドライバーをプロジェクトに追加します。デフォルトのサンプル ドライバーを使用する場合は、/example ディレクトリをプロジェクトに追加します。
/example ディレクトリ内のサンプルを参照して、独自のドライバーを完成させることができます。 デフォルトのプログラミング例を使用したい場合の使用方法は次のとおりです。
#include "driver_ir_remote_basic.h"
volatile uint8_t g_flag;
uint8_t (*g_gpio_irq)(void) = NULL;
uint8_t res;
uint32_t i;
uint16_t timeout;
static void a_receive_callback(ir_remote_t *data)
{
switch (data->status)
{
case IR_REMOTE_STATUS_OK :
{
ir_remote_interface_debug_print("ir_remote: irq ok.\n");
ir_remote_interface_debug_print("ir_remote: add is 0x%02X and cmd is 0x%02X.\n", data->address, data->command);
g_flag = 1;
break;
}
case IR_REMOTE_STATUS_REPEAT :
{
break;
}
case IR_REMOTE_STATUS_ADDR_ERR :
{
ir_remote_interface_debug_print("ir_remote: irq addr error.\n");
break;
}
case IR_REMOTE_STATUS_CMD_ERR :
{
ir_remote_interface_debug_print("ir_remote: irq cmd error.\n");
break;
}
case IR_REMOTE_STATUS_FRAME_INVALID :
{
ir_remote_interface_debug_print("ir_remote: irq frame invalid.\n");
break;
}
default :
{
ir_remote_interface_debug_print("ir_remote: irq unknown status.\n");
break;
}
}
}
...
/* gpio init */
res = gpio_interrupt_init();
if (res != 0)
{
return 1;
}
/* set the irq */
g_gpio_irq = ir_remote_basic_irq_handler;
...
/* basic init */
res = ir_remote_basic_init(a_receive_callback);
if (res != 0)
{
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
}
...
/* loop */
for (i = 0; i < times; i++)
{
/* output */
ir_remote_interface_debug_print("%d/%d.\n", i + 1, times);
/* 5s timeout */
timeout = 500;
/* init 0 */
g_flag = 0;
/* check timeout */
while (timeout != 0)
{
/* check the flag */
if (g_flag != 0)
{
break;
}
/* timeout -- */
timeout--;
/* delay 10ms */
ir_remote_interface_delay_ms(10);
}
/* check the timeout */
if (timeout == 0)
{
/* receive timeout */
ir_remote_interface_debug_print("ir_remote: receive timeout.\n");
(void)ir_remote_basic_deinit();
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 1;
}
....
}
...
/* basic deinit */
(void)ir_remote_basic_deinit();
/* gpio deinit */
(void)gpio_interrupt_deinit();
g_gpio_irq = NULL;
return 0;
オンラインドキュメント: https://www.libdriver.com/docs/ir_remote/index.html。
オフラインドキュメント: /doc/html/index.html。
CONTRIBUTING.mdを参照してください。
著作権(c)2015-今 LibDriver 全著作権所有
MITライセンス(MIT)
このソフトウェアおよび関連するドキュメントファイル(「ソフトウェア」)のコピーを取得した人は、無制限の使用、複製、変更、組み込み、公開、配布、サブライセンスを含む、ソフトウェアを処分する権利を制限なく付与されます。ソフトウェアのライセンスおよび/またはコピーの販売、および上記のようにソフトウェアが配布された人の権利のサブライセンスは、次の条件に従うものとします。
上記の著作権表示およびこの許可通知は、このソフトウェアのすべてのコピーまたは実体に含まれるものとします。
このソフトウェアは「現状有姿」で提供され、商品性、特定目的への適合性、および非侵害の保証を含むがこれらに限定されない、明示または黙示を問わず、いかなる種類の保証もありません。 いかなる場合も、作者または著作権所有者は、契約、不法行為、またはその他の方法で、本ソフトウェアおよび本ソフトウェアの使用またはその他の廃棄に起因または関連して、請求、損害、またはその他の責任を負わないものとします。
お問い合わせくださいlishifenging@outlook.com。