MAIN.cpp 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. #include "Win32.h"
  2. #include "ID.h"
  3. #include "Function.h"
  4. HWND hWnd = NULL;
  5. //Basic info
  6. static TCHAR szWindowClass[] = _T("ufb");
  7. static TCHAR szTitle[] = TITLE;
  8. HINSTANCE hInst;
  9. LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
  10. int WINAPI WinMain(
  11. _In_ HINSTANCE hInstance,
  12. _In_opt_ HINSTANCE hPrevInstance,
  13. _In_ LPSTR lpCmdLine,
  14. _In_ int nCmdShow
  15. )
  16. {
  17. // Window config
  18. WNDCLASSEX wcex;
  19. wcex.cbSize = sizeof(WNDCLASSEX);
  20. wcex.style = CS_HREDRAW | CS_VREDRAW;
  21. wcex.lpfnWndProc = WndProc;
  22. wcex.cbClsExtra = 0;
  23. wcex.cbWndExtra = 0;
  24. wcex.hInstance = hInstance;
  25. wcex.hIcon = LoadIcon(wcex.hInstance, IDI_APPLICATION);
  26. wcex.hCursor = LoadCursor(NULL, IDC_ARROW);
  27. wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1);
  28. wcex.lpszMenuName = NULL;
  29. wcex.lpszClassName = szWindowClass;
  30. wcex.hIconSm = LoadIcon(wcex.hInstance, IDI_APPLICATION);
  31. Err(RegisterClassEx(&wcex),
  32. _T("Call to RegisterClassEx failed!"));
  33. //Create window
  34. hInst = hInstance;
  35. hWnd = CreateWindowEx(
  36. WS_EX_OVERLAPPEDWINDOW,
  37. szWindowClass, szTitle,
  38. WS_OVERLAPPED | WS_CAPTION | WS_SYSMENU | WS_MINIMIZEBOX,
  39. CW_USEDEFAULT, CW_USEDEFAULT,
  40. 610, 600, NULL, NULL,
  41. hInstance, NULL
  42. );
  43. Err(hWnd,
  44. _T("Call to CreateWindow failed!"));
  45. //Create controls
  46. HWND hLabel_1 = CreateWindow(
  47. L"STATIC", L"基础操作",
  48. WS_VISIBLE | WS_CHILD,
  49. 30, 55, 90, 30,
  50. hWnd, NULL,
  51. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  52. );
  53. HWND hStart = CreateWindow(
  54. L"BUTTON", L"启动",
  55. WS_VISIBLE | WS_CHILD,
  56. 30, 100, 70, 40,
  57. hWnd, (HMENU)ID_START,
  58. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  59. );
  60. HWND hStop = CreateWindow(
  61. L"BUTTON", L"停止",
  62. WS_VISIBLE | WS_CHILD,
  63. 120, 100, 70, 40,
  64. hWnd, (HMENU)ID_STOP,
  65. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  66. );
  67. HWND hStopForce = CreateWindow(
  68. L"BUTTON", L"强行停止",
  69. WS_VISIBLE | WS_CHILD,
  70. 210, 100, 110, 40,
  71. hWnd, (HMENU)ID_STOP_FORCE,
  72. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  73. );
  74. HWND hLabel_2 = CreateWindow(
  75. L"STATIC", L"命令输入",
  76. WS_VISIBLE | WS_CHILD,
  77. 30, 155, 90, 30,
  78. hWnd, NULL,
  79. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  80. );
  81. HWND hCmdKey = CreateWindow(
  82. L"EDIT", NULL,
  83. WS_VISIBLE | WS_CHILD | WS_BORDER | ES_LEFT | ES_MULTILINE | ES_AUTOHSCROLL,
  84. 30, 200, 350, 40,
  85. hWnd, (HMENU)ID_CMD_KEY,
  86. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  87. );
  88. HWND hCmdSend = CreateWindow(
  89. L"BUTTON", L"执行",
  90. WS_VISIBLE | WS_CHILD,
  91. 400, 200, 70, 40,
  92. hWnd, (HMENU)ID_CMD_OK,
  93. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  94. );
  95. HWND hCmdClear = CreateWindow(
  96. L"BUTTON", L"清空",
  97. WS_VISIBLE | WS_CHILD,
  98. 490, 200, 70, 40,
  99. hWnd, (HMENU)ID_CMD_CLEAR,
  100. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  101. );
  102. HWND hLabel_3 = CreateWindow(
  103. L"STATIC", L"快捷命令",
  104. WS_VISIBLE | WS_CHILD,
  105. 30, 255, 90, 30,
  106. hWnd, NULL,
  107. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  108. );
  109. HWND hFCweather = CreateWindow(
  110. L"BUTTON", L"天气控制",
  111. WS_VISIBLE | WS_CHILD,
  112. 30, 300, 110, 40,
  113. hWnd, (HMENU)ID_FC_Weather,
  114. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  115. );
  116. HWND hFCtime = CreateWindow(
  117. L"BUTTON", L"时间控制",
  118. WS_VISIBLE | WS_CHILD,
  119. 160, 300, 110, 40,
  120. hWnd, (HMENU)ID_FC_Time,
  121. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  122. );
  123. //Font
  124. HFONT hFont = CreateFont(
  125. -40,
  126. 0, 0, 0,
  127. FW_NORMAL, FALSE, FALSE, FALSE,
  128. DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS,
  129. ANTIALIASED_QUALITY,
  130. FF_ROMAN,
  131. L"Arial"
  132. );
  133. SendMessage(hWnd, WM_SETFONT, (WPARAM)hFont, TRUE);
  134. //Visibility & Loop
  135. ShowWindow(hWnd,
  136. nCmdShow);
  137. UpdateWindow(hWnd);
  138. MSG msg;
  139. while (GetMessage(&msg, NULL, 0, 0))
  140. {
  141. TranslateMessage(&msg);
  142. DispatchMessage(&msg);
  143. }
  144. return (int)msg.wParam;
  145. }
  146. //Behavior of controls
  147. InitHWND(hTime);
  148. InitHWND(hWeather);
  149. LRESULT CALLBACK TimeProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
  150. LRESULT CALLBACK WeatherProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
  151. LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
  152. {
  153. PAINTSTRUCT ps;
  154. HDC hdc;
  155. TCHAR greeting[] = _T("by xksyu2021\nYou must obey / 您必须遵守 Minecraft EULA.");
  156. switch (message)
  157. {
  158. case WM_PAINT:
  159. hdc = BeginPaint(hWnd, &ps);
  160. TextOut(hdc,
  161. 5, 5,
  162. greeting, _tcslen(greeting));
  163. EndPaint(hWnd, &ps);
  164. break;
  165. case WM_COMMAND:
  166. {
  167. WORD wmId = LOWORD(wParam);
  168. switch (wmId)
  169. {
  170. case ID_START:
  171. StartBDS();
  172. break;
  173. case ID_STOP:
  174. StopBDS();
  175. break;
  176. case ID_STOP_FORCE:
  177. if(MessageBox(hWnd,
  178. L"强制关闭服务器是非常危险的操作!\n是否仍要继续?",TITLE,
  179. MB_OKCANCEL | MB_APPLMODAL | MB_ICONWARNING)
  180. == 1 )
  181. {
  182. ForceStopBDS();
  183. }
  184. break;
  185. case ID_CMD_OK:
  186. {
  187. if (GetWindowTextLength(GetDlgItem(hWnd, ID_CMD_KEY)) > 0)
  188. {
  189. char Command[1024] = { 0 };
  190. GetWindowTextA(GetDlgItem(hWnd, ID_CMD_KEY), Command, 1024);
  191. std::string temp(Command);
  192. temp += "\n";
  193. SendCommand(temp.c_str());
  194. }
  195. break;
  196. }
  197. case ID_CMD_CLEAR:
  198. SetWindowText(GetDlgItem(hWnd, ID_CMD_KEY), _T(" "));
  199. break;
  200. case ID_FC_Weather:
  201. if(!hWeather)
  202. {
  203. HINSTANCE HI_FC_weather = NULL;
  204. hWeather = CreateChildWindow(hWnd,
  205. _T("天气控制"),
  206. 700, 700,
  207. WeatherProc, _T("fc_wea"), HI_FC_weather);
  208. }
  209. break;
  210. case ID_FC_Time:
  211. if (!hTime)
  212. {
  213. HINSTANCE HI_FC_time = NULL;
  214. hTime = CreateChildWindow(hWnd,
  215. _T("时间控制"),
  216. 700, 700,
  217. TimeProc, _T("fc_time"), HI_FC_time);
  218. }
  219. break;
  220. }
  221. }
  222. break;
  223. case WM_DESTROY:
  224. PostQuitMessage(0);
  225. break;
  226. default:
  227. return DefWindowProc(hWnd, message, wParam, lParam);
  228. break;
  229. }
  230. return 0;
  231. }
  232. LRESULT CALLBACK WeatherProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) {
  233. switch (msg) {
  234. case WM_CLOSE:
  235. DestroyWindow(hWnd);
  236. break;
  237. case WM_DESTROY:
  238. hWeather = NULL;
  239. break;
  240. default:
  241. return DefWindowProc(hWnd, msg, wParam, lParam);
  242. }
  243. return 0;
  244. }
  245. LRESULT CALLBACK TimeProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) {
  246. switch (msg) {
  247. case WM_CLOSE:
  248. DestroyWindow(hWnd);
  249. break;
  250. case WM_DESTROY:
  251. hTime = NULL;
  252. break;
  253. default:
  254. return DefWindowProc(hWnd, msg, wParam, lParam);
  255. }
  256. return 0;
  257. }