MAIN.cpp 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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), szTitle,
  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. 530, 560, NULL, NULL,
  41. hInstance, NULL
  42. );
  43. Err(hWnd, szTitle,
  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 hLabel_3 = CreateWindow(
  96. L"STATIC", L"快捷命令",
  97. WS_VISIBLE | WS_CHILD,
  98. 30, 255, 90, 30,
  99. hWnd, NULL,
  100. (HINSTANCE)GetWindowLongPtr(hWnd, GWLP_HINSTANCE), NULL
  101. );
  102. //Font
  103. HFONT hFont = CreateFont(
  104. -40,
  105. 0, 0, 0,
  106. FW_NORMAL, FALSE, FALSE, FALSE,
  107. DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS,
  108. ANTIALIASED_QUALITY,
  109. FF_ROMAN,
  110. L"Arial"
  111. );
  112. SendMessage(hWnd, WM_SETFONT, (WPARAM)hFont, TRUE);
  113. //Visibility & Loop
  114. ShowWindow(hWnd,
  115. nCmdShow);
  116. UpdateWindow(hWnd);
  117. MSG msg;
  118. while (GetMessage(&msg, NULL, 0, 0))
  119. {
  120. TranslateMessage(&msg);
  121. DispatchMessage(&msg);
  122. }
  123. return (int)msg.wParam;
  124. }
  125. //Behavior of controls
  126. LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
  127. {
  128. PAINTSTRUCT ps;
  129. HDC hdc;
  130. TCHAR greeting[] = _T("by xksyu2021\nYou must obey Minecraft EULA.");
  131. switch (message)
  132. {
  133. case WM_PAINT:
  134. hdc = BeginPaint(hWnd, &ps);
  135. TextOut(hdc,
  136. 5, 5,
  137. greeting, _tcslen(greeting));
  138. EndPaint(hWnd, &ps);
  139. break;
  140. case WM_COMMAND:
  141. {
  142. WORD wmId = LOWORD(wParam);
  143. switch (wmId)
  144. {
  145. case ID_START:
  146. StartBDS();
  147. break;
  148. case ID_STOP:
  149. StopBDS();
  150. break;
  151. case ID_STOP_FORCE:
  152. if(MessageBox(hWnd,
  153. L"强制关闭服务器是非常危险的操作!\n是否仍要继续?",TITLE,
  154. MB_OKCANCEL | MB_APPLMODAL | MB_ICONWARNING)
  155. == 1 )
  156. {
  157. ForceStopBDS();
  158. }
  159. break;
  160. }
  161. }
  162. break;
  163. case WM_DESTROY:
  164. PostQuitMessage(0);
  165. break;
  166. default:
  167. return DefWindowProc(hWnd, message, wParam, lParam);
  168. break;
  169. }
  170. return 0;
  171. }
  172. LRESULT CALLBACK WeatherProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) {
  173. switch (msg) {
  174. case WM_CLOSE:
  175. DestroyWindow(hWnd);
  176. break;
  177. case WM_DESTROY:
  178. PostQuitMessage(0);
  179. break;
  180. default:
  181. return DefWindowProc(hWnd, msg, wParam, lParam);
  182. }
  183. return 0;
  184. }