IRControl.cpp 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418
  1. // IRControl.cpp : 定义 DLL 应用程序的导出函数。
  2. //
  3. #include "stdafx.h"
  4. #include "IRControl.h"
  5. #include "RedRatProcess.h"
  6. #ifdef __MAKE_PYD__
  7. #include "Python.h"
  8. #endif
  9. #ifdef _DEBUG
  10. #define new DEBUG_NEW
  11. #endif
  12. #ifdef __CONSOLE__
  13. // 唯一的应用程序对象
  14. CWinApp theApp;
  15. using namespace std;
  16. int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
  17. {
  18. int nRetCode = 0;
  19. // 初始化 MFC 并在失败时显示错误
  20. if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
  21. {
  22. // TODO: 更改错误代码以符合您的需要
  23. _tprintf(_T("错误: MFC 初始化失败\n"));
  24. nRetCode = 1;
  25. }
  26. else
  27. {
  28. // TODO: 在此处为应用程序的行为编写代码。
  29. // 连接服务器;
  30. if (!Connect(_T("127.0.0.1"), 40000))
  31. return 0;
  32. // 获取设备列表,以逗号分隔;
  33. std::string devices = getDeviceNames();
  34. // 加载指定目录的xml信号集文件;
  35. if ( !loadSignalDataSet("D:\\SAT\\resource\\RCU\\product\\ARTEL_WZ_RC311_2841.xml") )
  36. {
  37. TRACE("加载信号集文件失败\r");
  38. }
  39. else
  40. {
  41. TRACE("加载信号集文件成功\r");
  42. }
  43. Sleep(500);
  44. // 获取信号数据集,以\n分隔;
  45. std::string signals = getSignalsName();
  46. TRACE(signals.c_str());
  47. // 发送单信号;
  48. if ( sendSignal("HOME", 1, 1000) )
  49. {
  50. TRACE("发送单信号成功\n");
  51. }
  52. else
  53. {
  54. TRACE("发送单信号失败\n");
  55. }
  56. // 发送多信号;
  57. if (sendSignals("HOME;right;right;down;up;HOME", 2))
  58. {
  59. TRACE("发送多信号成功\n");
  60. }
  61. else
  62. {
  63. TRACE("发送多信号失败\n");
  64. }
  65. // 发送重复信号;//重复信号必须小于256
  66. if (sendRepeatsSignal("right", 2))
  67. {
  68. TRACE("发送多信号成功\n");
  69. }
  70. else
  71. {
  72. TRACE("发送多信号失败\n");
  73. }
  74. CloseApp();
  75. }
  76. return nRetCode;
  77. }
  78. #endif
  79. static CRedRatProcess g_IRControl;
  80. #ifndef __MAKE_PYD__
  81. // 定义 DLL 的导出函数和变量。
  82. int nIRControl = 100;
  83. IRCONTROL_API DWORD IsAppRunning(LPCTSTR lpszAppDir)
  84. {
  85. return CRedRatProcess::IsAppRunning(lpszAppDir);
  86. }
  87. IRCONTROL_API bool StartIRApp(LPCTSTR lpszAppDir, LPCTSTR lpSignalXml, DWORD dwPort)
  88. {
  89. if (!CRedRatProcess::StartApp(lpszAppDir, lpSignalXml, dwPort))
  90. return false;
  91. return true;
  92. }
  93. IRCONTROL_API bool CloseApp()
  94. {
  95. return CRedRatProcess::CloseApp();
  96. }
  97. IRCONTROL_API bool Connect(LPCTSTR lpServer, int port)
  98. {
  99. // 创建连接;
  100. if (!g_IRControl.InitSocket())
  101. {
  102. Global::WriteTextLog(_T("创建TCP连接失败"));
  103. //g_IRControl.CloseApp();
  104. return false;
  105. }
  106. if (!lpServer || lpServer[0] == '\0' || port < 0)
  107. return false;
  108. //if (!g_IRControl.SelectConnect(lpServer, port, 5000))
  109. if (!g_IRControl.Connect(lpServer, port))
  110. {
  111. Global::WriteTextLog(_T("连接服务器失败"));
  112. //g_IRControl.CloseApp();
  113. return false;
  114. }
  115. return true;
  116. }
  117. IRCONTROL_API void DisConnect()
  118. {
  119. g_IRControl.DisConnect();
  120. }
  121. IRCONTROL_API LPCTSTR getDeviceNames()
  122. {
  123. static std::string devices;
  124. std::vector<std::string> vtDevices;
  125. if ( g_IRControl.getDeviceNameList(vtDevices) )
  126. {
  127. devices.clear();
  128. for ( std::vector<std::string>::iterator dv = vtDevices.begin(); dv != vtDevices.end(); dv++)
  129. {
  130. devices.append(*dv + _T(";"));
  131. }
  132. return devices.c_str();
  133. }
  134. return _T("");
  135. }
  136. IRCONTROL_API LPCTSTR getSignalsName()
  137. {
  138. static std::string signals;
  139. signals = g_IRControl.getSignalsName();
  140. return signals.c_str();
  141. }
  142. IRCONTROL_API bool loadSignalDataSet(LPCTSTR lpDatasetXml)
  143. {
  144. if (!lpDatasetXml || lpDatasetXml[0] == '\0')
  145. return false;
  146. return g_IRControl.loadSignalDataSet(lpDatasetXml);
  147. }
  148. IRCONTROL_API bool sendSignal(LPCTSTR lpSignal, int send_times, int sleep_time)
  149. {
  150. if (!lpSignal || lpSignal[0] == '\0')
  151. return false;
  152. return g_IRControl.sendSignal(lpSignal, send_times, sleep_time);
  153. }
  154. IRCONTROL_API bool sendSignals(LPCTSTR lpSignals, int sleep_time)
  155. {
  156. if (!lpSignals || lpSignals[0] == '\0')
  157. return false;
  158. std::string signals = lpSignals;
  159. std::vector<std::string> vtSignals;
  160. int npos = -1;
  161. while (true)
  162. {
  163. npos = signals.find_first_of(';');
  164. if (npos == std::string::npos)
  165. break;
  166. vtSignals.push_back(signals.substr(0, npos));
  167. signals = signals.substr(npos + 1);
  168. }
  169. vtSignals.push_back(signals);
  170. return g_IRControl.sendSignals(vtSignals, sleep_time);
  171. }
  172. IRCONTROL_API bool sendRepeatsSignal(LPCTSTR lpSignal, int repeat_time)
  173. {
  174. if (!lpSignal || lpSignal[0] == '\0')
  175. return false;
  176. return g_IRControl.sendRepeatsSignal(lpSignal, repeat_time);
  177. }
  178. #else
  179. static PyObject* IsAppRunning(PyObject* self, PyObject* args)
  180. {
  181. // 应用程序路径;
  182. const char* pszExePath = NULL;
  183. if (!PyArg_ParseTuple(args, "s", &pszExePath))
  184. return NULL;
  185. // 返回进程Id;
  186. return Py_BuildValue("i", CRedRatProcess::IsAppRunning(pszExePath));
  187. }
  188. static PyObject* StartApp(PyObject* self, PyObject* args)
  189. {
  190. // 应用程序路径;
  191. const char* pszExePath = NULL;
  192. const char* pszDataset = NULL;
  193. unsigned int port = 0;
  194. if (!PyArg_ParseTuple(args, "ssI", &pszExePath, &pszDataset, &port))
  195. return NULL;
  196. return Py_BuildValue("b", CRedRatProcess::StartApp(pszExePath, pszDataset, port));
  197. }
  198. static PyObject* StopApp(PyObject* self, PyObject* args)
  199. {
  200. return Py_BuildValue("b", CRedRatProcess::CloseApp()); // 返回None;
  201. }
  202. //描述:连接设备,默认连接索引为0的设备;
  203. static PyObject* ConnectDevice(PyObject* self, PyObject* args)
  204. {
  205. unsigned int port = 0;
  206. const char* pszServer = NULL;
  207. if (!PyArg_ParseTuple(args, "sI", &pszServer, &port))
  208. return NULL;
  209. // 创建连接;
  210. if (!g_IRControl.InitSocket())
  211. {
  212. Global::WriteTextLog(_T("创建TCP连接失败"));
  213. g_IRControl.CloseApp();
  214. return Py_BuildValue("b", false);
  215. }
  216. if (!pszServer || pszServer[0] == '\0' || port < 0)
  217. return Py_BuildValue("b", false);
  218. if (!g_IRControl.SelectConnect(pszServer, port, 5000))
  219. {
  220. Global::WriteTextLog(_T("连接服务器失败"));
  221. g_IRControl.CloseApp();
  222. return Py_BuildValue("b", false);
  223. }
  224. return Py_BuildValue("b", true);
  225. }
  226. static PyObject* DisconnectDevice(PyObject* self, PyObject* args)
  227. {
  228. g_IRControl.DisConnect();
  229. return Py_BuildValue("");
  230. }
  231. static PyObject* getDeviceNames(PyObject* self, PyObject* args)
  232. {
  233. std::string devices;
  234. std::vector<std::string> vtDevices;
  235. if (g_IRControl.getDeviceNameList(vtDevices))
  236. {
  237. for (std::vector<std::string>::iterator dv = vtDevices.begin(); dv != vtDevices.end(); dv++ )
  238. {
  239. devices.append(*dv + _T(";"));
  240. }
  241. return Py_BuildValue("s", devices.c_str());
  242. }
  243. return Py_BuildValue("s", "");
  244. }
  245. static PyObject* loadSignalDataSet(PyObject* self, PyObject* args)
  246. {
  247. const char* pszDatasetXml = NULL;
  248. if (!PyArg_ParseTuple(args, "s", &pszDatasetXml))
  249. return NULL;
  250. if ( !pszDatasetXml || pszDatasetXml[0] == '\0')
  251. return Py_BuildValue("b", false);
  252. if (!g_IRControl.loadSignalDataSet(std::string(pszDatasetXml)) )
  253. {
  254. Global::WriteTextLog(_T("加载信号数据集失败"));
  255. g_IRControl.CloseApp();
  256. return Py_BuildValue("b", false);
  257. }
  258. return Py_BuildValue("b", true);
  259. }
  260. static PyObject* getSignalsName(PyObject* self, PyObject* args)
  261. {
  262. std::string data = g_IRControl.getSignalsName();
  263. return Py_BuildValue("s", data.c_str());
  264. }
  265. static PyObject* sendSignal(PyObject* self, PyObject* args)
  266. {
  267. const char* pszSignal = NULL;
  268. int send_times = 1, sleep_time = 1000;
  269. if (!PyArg_ParseTuple(args, "sii", &pszSignal, &send_times, &sleep_time))
  270. return NULL;
  271. if (!pszSignal || pszSignal[0] == '\0')
  272. return Py_BuildValue("b", false);
  273. return Py_BuildValue("b", g_IRControl.sendSignal(pszSignal, send_times, sleep_time));
  274. }
  275. static PyObject* sendSignals(PyObject* self, PyObject* args)
  276. {
  277. const char* pszSignal = NULL;
  278. int sleep_time = 1000;
  279. if (!PyArg_ParseTuple(args, "si", &pszSignal, &sleep_time))
  280. return NULL;
  281. if (!pszSignal || pszSignal[0] == '\0')
  282. return Py_BuildValue("b", false);
  283. std::string signals = pszSignal;
  284. std::vector<std::string> vtSignals;
  285. int npos = -1;
  286. while (true)
  287. {
  288. npos = signals.find_first_of(';');
  289. if (npos == std::string::npos)
  290. break;
  291. vtSignals.push_back(signals.substr(0, npos));
  292. signals = signals.substr(npos + 1);
  293. }
  294. vtSignals.push_back(signals);
  295. return Py_BuildValue("b", g_IRControl.sendSignals(vtSignals, sleep_time));
  296. }
  297. static PyObject* sendRepeatsSignal(PyObject* self, PyObject* args)
  298. {
  299. const char* pszSignal = NULL;
  300. int repeat_time = 2;
  301. if (!PyArg_ParseTuple(args, "si", &pszSignal, &repeat_time))
  302. return NULL;
  303. if (!pszSignal || pszSignal[0] == '\0')
  304. return Py_BuildValue("b", false);
  305. return Py_BuildValue("b", g_IRControl.sendRepeatsSignal(pszSignal, repeat_time));
  306. }
  307. static PyObject* sendDurationSignal(PyObject* self, PyObject* args)
  308. {
  309. const char* pszSignal = NULL;
  310. int duration_time = 2;
  311. if (!PyArg_ParseTuple(args, "si", &pszSignal, &duration_time))
  312. return NULL;
  313. if (!pszSignal || pszSignal[0] == '\0')
  314. return Py_BuildValue("b", false);
  315. return Py_BuildValue("b", g_IRControl.sendDurationSignal(pszSignal, duration_time));
  316. }
  317. // 描述方法,暴露给python的函数;
  318. static PyMethodDef IRControl_Methods[] = {
  319. {"IsAppRunning",IsAppRunning,METH_VARARGS,"程序是否在运行"},
  320. {"StartApp", StartApp, METH_VARARGS, "启动进程"},
  321. {"StopApp", StopApp, METH_VARARGS, "关闭进程"},
  322. {"ConnectDevice", ConnectDevice, METH_VARARGS, "连接设备"},
  323. {"DisconnectDevice", DisconnectDevice, METH_VARARGS, "断开设备"},
  324. {"getDeviceNames", getDeviceNames, METH_VARARGS, "获取设备列表,逗号分隔"},
  325. {"loadSignalDataSet", loadSignalDataSet, METH_VARARGS, "加载指定目录的信号数据集XML文件"},
  326. {"getSignalsName", getSignalsName, METH_VARARGS, "获取默认信号数据集信号列表"},
  327. {"sendSignal", sendSignal, METH_VARARGS, "发送单个信号"},
  328. {"sendSignals", sendSignals, METH_VARARGS, "发送多个信号,以分号为分隔符"},
  329. {"sendRepeatsSignal", sendRepeatsSignal, METH_VARARGS, "发送重复信号"},
  330. {"sendDurationSignal", sendDurationSignal, METH_VARARGS, "发送时叠信号"},
  331. {NULL,NULL}
  332. };
  333. // 初始模块;//格式:init<模块名称>
  334. PyMODINIT_FUNC initIRControl()
  335. {
  336. // 初始化pyd函数列表;
  337. PyObject* m, * d;
  338. m = Py_InitModule("IRControl", IRControl_Methods);
  339. d = PyModule_GetDict(m);
  340. }
  341. #endif