Visual C++ (MFC)

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;
    }

}