2017-05-09 11:36:49 +08:00
|
|
|
#include "stdafx.h"
|
|
|
|
|
#include "DecodeTestWin.h"
|
2018-10-02 20:00:34 +08:00
|
|
|
#include "ir_decode.h"
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
|
|
#ifdef _DEBUG
|
|
|
|
|
#define new DEBUG_NEW
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
// global variable definition
|
|
|
|
|
long binary_length = 0;
|
|
|
|
|
UINT8 *binary_content = NULL;
|
|
|
|
|
|
|
|
|
|
CWinApp theApp;
|
|
|
|
|
HINSTANCE hInDecodeDll = NULL;
|
|
|
|
|
|
2018-10-02 20:00:34 +08:00
|
|
|
t_remote_ac_status ac_status;
|
2017-05-09 11:36:49 +08:00
|
|
|
UINT16 user_data[USER_DATA_SIZE] = { 0 };
|
|
|
|
|
|
2018-10-02 20:00:34 +08:00
|
|
|
typedef INT8(*lp_ir_file_open) (const UINT8 category, const UINT8 sub_category, const char* file_name);
|
|
|
|
|
typedef INT8(*lp_ir_binary_open) (const UINT8 category, const UINT8 sub_category, UINT8* binary, UINT16 binary_length);
|
|
|
|
|
typedef INT8(*lp_ir_decode) (UINT8 key_code, UINT16* user_data, t_remote_ac_status* ac_status, BOOL change_wind_direction);
|
|
|
|
|
typedef INT8(*lp_ir_close) (void);
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
typedef INT8(*lp_get_temperature_range) (UINT8 ac_mode, INT8* temp_min, INT8* temp_max);
|
|
|
|
|
typedef INT8(*lp_get_supported_mode) (UINT8* supported_mode);
|
|
|
|
|
typedef INT8(*lp_get_supported_wind_speed) (UINT8 ac_mode, UINT8* supported_wind_speed);
|
|
|
|
|
typedef INT8(*lp_get_supported_swing) (UINT8 ac_mode, UINT8* supported_swing);
|
|
|
|
|
typedef INT8(*lp_get_supported_wind_direction) (UINT8* supported_wind_direction);
|
|
|
|
|
|
2018-10-02 20:00:34 +08:00
|
|
|
lp_ir_file_open IRFileOpen;
|
|
|
|
|
lp_ir_binary_open IRBinaryOpen;
|
|
|
|
|
lp_ir_decode IRDecode;
|
|
|
|
|
lp_ir_close IRClose;
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
lp_get_supported_mode GetSupportedMode;
|
|
|
|
|
lp_get_supported_swing GetSupportedSwing;
|
|
|
|
|
lp_get_supported_wind_speed GetSupportedWindSpeed;
|
|
|
|
|
lp_get_supported_wind_direction GetSupportedWindDirection;
|
|
|
|
|
lp_get_temperature_range GetTemperatureRange;
|
|
|
|
|
|
|
|
|
|
INT8 decode_as_ac(char* file_name)
|
|
|
|
|
{
|
|
|
|
|
// keyboard input
|
|
|
|
|
int in_char = 0;
|
|
|
|
|
int count = 0;
|
|
|
|
|
BOOL op_match = TRUE;
|
|
|
|
|
UINT8 function_code = AC_FUNCTION_MAX;
|
|
|
|
|
|
|
|
|
|
// get status
|
|
|
|
|
UINT8 supported_mode = 0x00;
|
|
|
|
|
INT8 min_temperature = 0;
|
|
|
|
|
INT8 max_temperature = 0;
|
|
|
|
|
UINT8 supported_speed = 0x00;
|
|
|
|
|
UINT8 supported_swing = 0x00;
|
|
|
|
|
|
|
|
|
|
BOOL need_control = TRUE;
|
|
|
|
|
|
|
|
|
|
// init air conditioner status
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_display = 0;
|
|
|
|
|
ac_status.ac_sleep = 0;
|
|
|
|
|
ac_status.ac_timer = 0;
|
|
|
|
|
ac_status.ac_power = AC_POWER_OFF;
|
|
|
|
|
ac_status.ac_mode = AC_MODE_COOL;
|
|
|
|
|
ac_status.ac_temp = AC_TEMP_20;
|
|
|
|
|
ac_status.ac_wind_dir = AC_SWING_ON;
|
|
|
|
|
ac_status.ac_wind_speed = AC_WS_AUTO;
|
|
|
|
|
|
|
|
|
|
if (IR_DECODE_FAILED == IRFileOpen(0, 0, file_name))
|
2017-05-09 11:36:49 +08:00
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
IRClose();
|
2017-05-09 11:36:49 +08:00
|
|
|
return IR_DECODE_FAILED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
in_char = getchar();
|
|
|
|
|
op_match = TRUE;
|
|
|
|
|
need_control = TRUE;
|
|
|
|
|
switch (in_char)
|
|
|
|
|
{
|
|
|
|
|
case 'w':
|
|
|
|
|
case 'W':
|
|
|
|
|
// temperature plus
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_temp = (t_ac_temperature)((ac_status.ac_temp == AC_TEMP_30) ? AC_TEMP_30 : (ac_status.ac_temp + 1));
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_TEMPERATURE_UP;
|
|
|
|
|
break;
|
|
|
|
|
case 's':
|
|
|
|
|
case 'S':
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_temp = (t_ac_temperature)((ac_status.ac_temp == AC_TEMP_16) ? AC_TEMP_16 : (ac_status.ac_temp - 1));
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_TEMPERATURE_DOWN;
|
|
|
|
|
// temperature minus
|
|
|
|
|
break;
|
|
|
|
|
case 'a':
|
|
|
|
|
case 'A':
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_wind_speed = (t_ac_wind_speed) (ac_status.ac_wind_speed + 1);
|
|
|
|
|
ac_status.ac_wind_speed = (t_ac_wind_speed) (ac_status.ac_wind_speed % AC_WS_MAX);
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_WIND_SPEED;
|
|
|
|
|
// wind speed loop
|
|
|
|
|
break;
|
|
|
|
|
case 'd':
|
|
|
|
|
case 'D':
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_wind_dir = (t_ac_swing)((ac_status.ac_wind_dir == 0) ? 1 : 0);
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_WIND_SWING;
|
|
|
|
|
// wind swing loop
|
|
|
|
|
break;
|
|
|
|
|
case 'q':
|
|
|
|
|
case 'Q':
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_mode = (t_ac_mode)(ac_status.ac_mode + 1);
|
|
|
|
|
ac_status.ac_mode = (t_ac_mode) (ac_status.ac_mode % AC_MODE_MAX);
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_MODE;
|
|
|
|
|
break;
|
|
|
|
|
case '1':
|
|
|
|
|
// turn on
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_power = AC_POWER_ON;
|
2017-05-09 11:36:49 +08:00
|
|
|
function_code = AC_FUNCTION_POWER;
|
|
|
|
|
break;
|
|
|
|
|
case '2':
|
|
|
|
|
// turn off
|
2018-10-02 20:00:34 +08:00
|
|
|
ac_status.ac_power = AC_POWER_OFF;
|
2017-05-09 11:36:49 +08:00
|
|
|
// FUNCTION MAX refers to power off
|
|
|
|
|
// function_code = AC_FUNCTION_POWER;
|
|
|
|
|
break;
|
|
|
|
|
case '3':
|
|
|
|
|
if (IR_DECODE_SUCCEEDED == GetSupportedMode(&supported_mode))
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("supported mode = %02X\n", supported_mode);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
need_control = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case '4':
|
2018-10-02 20:00:34 +08:00
|
|
|
if (IR_DECODE_SUCCEEDED == GetSupportedSwing(ac_status.ac_mode, &supported_swing))
|
2017-05-09 11:36:49 +08:00
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("supported swing in %d = %02X\n", ac_status.ac_mode, supported_swing);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
need_control = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
case '5':
|
2018-10-02 20:00:34 +08:00
|
|
|
if (IR_DECODE_SUCCEEDED == GetSupportedWindSpeed(ac_status.ac_mode, &supported_speed))
|
2017-05-09 11:36:49 +08:00
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("supported wind speed in %d = %02X\n", ac_status.ac_mode, supported_speed);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
need_control = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case '6':
|
2018-10-02 20:00:34 +08:00
|
|
|
if (IR_DECODE_SUCCEEDED == GetTemperatureRange(ac_status.ac_mode, &min_temperature, &max_temperature))
|
2017-05-09 11:36:49 +08:00
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("supported temperature range in mode %d = %d, %d\n",
|
|
|
|
|
ac_status.ac_mode, min_temperature, max_temperature);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
need_control = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
op_match = FALSE;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (TRUE == op_match && TRUE == need_control)
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("switch AC to power = %d, mode = %d, temp = %d, speed = %d, swing = %d\n",
|
|
|
|
|
ac_status.ac_power,
|
|
|
|
|
ac_status.ac_mode,
|
|
|
|
|
ac_status.ac_temp,
|
|
|
|
|
ac_status.ac_wind_speed,
|
|
|
|
|
ac_status.ac_wind_dir
|
2017-05-09 11:36:49 +08:00
|
|
|
);
|
2018-10-02 20:00:34 +08:00
|
|
|
IRDecode(function_code, user_data, &ac_status, TRUE);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
} while ('0' != in_char);
|
|
|
|
|
|
2018-10-02 20:00:34 +08:00
|
|
|
IRClose();
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
// free binary buffer
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_free(binary_content);
|
2017-05-09 11:36:49 +08:00
|
|
|
binary_length = 0;
|
|
|
|
|
|
|
|
|
|
return IR_DECODE_SUCCEEDED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
INT8 decode_as_tv(char *file_name, UINT8 irda_hex_encode)
|
|
|
|
|
{
|
|
|
|
|
// keyboard input
|
|
|
|
|
int in_char = 0;
|
|
|
|
|
int key_code = -1;
|
|
|
|
|
int count = 0;
|
|
|
|
|
|
2018-10-02 20:00:34 +08:00
|
|
|
if (IR_DECODE_FAILED == IRFileOpen(1, 1, file_name))
|
2017-05-09 11:36:49 +08:00
|
|
|
{
|
|
|
|
|
return IR_DECODE_FAILED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
in_char = getchar();
|
|
|
|
|
if (in_char >= '0' && in_char <= '9')
|
|
|
|
|
{
|
|
|
|
|
key_code = in_char - '0';
|
2018-10-02 20:00:34 +08:00
|
|
|
IRDecode(key_code, user_data, NULL, FALSE);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
else if (in_char >= 'a' && in_char <= 'f')
|
|
|
|
|
{
|
|
|
|
|
key_code = 10 + (in_char - 'a');
|
2018-10-02 20:00:34 +08:00
|
|
|
IRDecode(key_code, user_data, NULL, FALSE);
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
else if (in_char == 'q')
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
IRClose();
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// do nothing
|
|
|
|
|
}
|
|
|
|
|
} while ('Q' != in_char);
|
|
|
|
|
|
|
|
|
|
// free binary buffer
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_free(binary_content);
|
2017-05-09 11:36:49 +08:00
|
|
|
binary_length = 0;
|
|
|
|
|
|
|
|
|
|
return IR_DECODE_SUCCEEDED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
|
{
|
|
|
|
|
int nRetCode = 0;
|
|
|
|
|
|
|
|
|
|
HMODULE hModule = ::GetModuleHandle(nullptr);
|
|
|
|
|
|
|
|
|
|
if (hModule != nullptr)
|
|
|
|
|
{
|
|
|
|
|
if (!AfxWinInit(hModule, nullptr, ::GetCommandLine(), 0))
|
|
|
|
|
{
|
|
|
|
|
wprintf(L"error: MFC failed to initialize\n");
|
|
|
|
|
nRetCode = 1;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
hInDecodeDll = LoadLibrary(_T("ir_decoder.dll"));
|
|
|
|
|
if (NULL != hInDecodeDll)
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("load library successfully\n");
|
|
|
|
|
IRFileOpen = (lp_ir_file_open)GetProcAddress(hInDecodeDll, "ir_file_open");
|
|
|
|
|
IRBinaryOpen = (lp_ir_binary_open)GetProcAddress(hInDecodeDll, "ir_binary_open");
|
|
|
|
|
IRDecode = (lp_ir_decode)GetProcAddress(hInDecodeDll, "ir_decode");
|
|
|
|
|
IRClose = (lp_ir_close)GetProcAddress(hInDecodeDll, "ir_close");
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
GetSupportedMode = (lp_get_supported_mode)GetProcAddress(hInDecodeDll, "get_supported_mode");
|
|
|
|
|
GetSupportedSwing = (lp_get_supported_swing)GetProcAddress(hInDecodeDll, "get_supported_swing");
|
|
|
|
|
GetSupportedWindSpeed = (lp_get_supported_wind_speed)GetProcAddress(hInDecodeDll, "get_supported_wind_speed");
|
|
|
|
|
GetSupportedWindDirection = (lp_get_supported_wind_direction)GetProcAddress(hInDecodeDll, "get_supported_wind_direction");
|
|
|
|
|
GetTemperatureRange = (lp_get_temperature_range)GetProcAddress(hInDecodeDll, "get_temperature_range");
|
|
|
|
|
|
|
|
|
|
char function = '0';
|
|
|
|
|
UINT8 irda_hex_encode = 0;
|
|
|
|
|
|
|
|
|
|
if (4 != argc)
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("number of args error !\n");
|
2017-05-09 11:36:49 +08:00
|
|
|
return -1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function = argv[1][0];
|
|
|
|
|
irda_hex_encode = (UINT8)(argv[3][0] - '0');
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("decode functionality = %c\n", function);
|
2017-05-09 11:36:49 +08:00
|
|
|
|
|
|
|
|
switch (function)
|
|
|
|
|
{
|
|
|
|
|
case '0':
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("decode binary file as AC\n");
|
2017-05-09 11:36:49 +08:00
|
|
|
decode_as_ac(argv[2]);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case '1':
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("decode binary file as TV : %d\n", irda_hex_encode);
|
2017-05-09 11:36:49 +08:00
|
|
|
decode_as_tv(argv[2], irda_hex_encode);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("decode functionality error !\n");
|
2017-05-09 11:36:49 +08:00
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FreeLibrary(hInDecodeDll);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2018-10-02 20:00:34 +08:00
|
|
|
ir_printf("load library failed\n");
|
2017-05-09 11:36:49 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
wprintf(L"error: GetModuleHandle failed\n");
|
|
|
|
|
nRetCode = 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
system("pause");
|
|
|
|
|
|
|
|
|
|
return nRetCode;
|
|
|
|
|
}
|