VCのイベントメッセージルーチンは次の書式になります。
LRESULT CAioDlg::DefWindowProc(UINT message, WPARAM wParam, LPARAM lParam)
message
メッセージ番号が渡されます。
wParam
下位2バイトにIDが渡されます。上位2バイトにはイベントを発生したカウンタのチャネルが渡されます。
lParam
イベントごとに固有のパラメータが渡されます。
メッセージ処理例1
イベントを使用するデバイスが1つしか存在しない場合、IDによるデバイスの判断は特に必要ありません。
以下のコードはイベントが発生したときにメッセージボックスを表示する例です。
switch( message ){
case AIOM_CNTE_DATA_NUM:
AfxMessageBox("比較カウント一致", MB_OK, 0);
break;
case AIOM_CNTE_ORERR:
AfxMessageBox("カウントオーバーラン", MB_OK, 0);
break;
case AIOM_CNTE_ERR:
AfxMessageBox("カウント動作エラー", MB_OK, 0);
break;
}
メッセージ処理例2
複数のデバイスでイベントを使用する場合、どのデバイスから発生したイベントかを判断する必要があります。
以下のコードは、2つのデバイス(ID1とID2)でイベントを使用する例です。
if ( wParam = ID1 ){
switch( message ){
case AIOM_CNTE_DATA_NUM:
AfxMessageBox("ID1:比較カウント一致",
MB_OK, 0);
break;
case AIOM_CNTE_ORERR:
AfxMessageBox("ID1:カウントオーバーラン",
MB_OK, 0);
break;
case AIOM_CNTE_ERR:
AfxMessageBox("ID1:カウント動作エラー",
MB_OK, 0);
break;
}
}
else{
switch( message ){
case AIOM_CNTE_DATA_NUM:
AfxMessageBox("ID2:比較カウント一致",
MB_OK, 0);
break;
case AIOM_CNTE_ORERR:
AfxMessageBox("ID2:カウントオーバーラン",
MB_OK, 0);
break;
case AIOM_CNTE_ERR:
AfxMessageBox("ID2:カウント動作エラー",
MB_OK, 0);
break;
}
}