Advertisement
VladSmirN

lab1_OC2

Oct 13th, 2021
1,198
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 9.90 KB | None | 0 0
  1. #include <iostream>
  2. #include <windows.h>
  3. #include <tchar.h>
  4. #include <stdio.h>
  5. #include <fstream>
  6. LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
  7. WNDCLASS w;
  8. int WIDTH_WINDOW = 320;
  9. int HEIGHT_WINDOW = 240;
  10. INT N =10;
  11. int  deltaLineColor[3] = { 10,10,10 };
  12. COLORREF lineColor = RGB(0, 255, 0);
  13. COLORREF colorBackground = RGB(0, 0, 255);
  14. COLORREF colorCircle = RGB(255, 0, 0);
  15. int grid[105][105];
  16. const int idVoidCell = 0;
  17. const int idСrossCell = 1;
  18. const int idСircleCell = 2;
  19. int INDENT = 30;
  20. HBRUSH hBrush;
  21. HWND hWnd;
  22. HDC hdc;
  23. void setIndent() {
  24.     RECT rect;
  25.     rect = { 0 };
  26.  
  27.     GetWindowRect(hWnd, &rect);
  28.     //std::cout << rect.bottom - rect.top << std::endl;
  29.     //std::cout << rect.right - rect.left << std::endl;
  30.    
  31.     INDENT = int (  min(0.85*(rect.bottom - rect.top)/ N, 0.85 * (rect.right - rect.left) / N));
  32. }
  33. void drawCross( int x = 0, int y = 0) {
  34.  
  35.     hdc = GetDC(hWnd);
  36.  
  37.     HPEN hPen;
  38.     hPen = CreatePen(1, 4, RGB(5, 2555, 0));
  39.     SelectObject(hdc, hPen);
  40.  
  41.     MoveToEx(hdc, x * INDENT, y * INDENT, NULL);
  42.     LineTo(hdc, (x * INDENT) + INDENT, (y * INDENT) + INDENT);
  43.  
  44.     MoveToEx(hdc, x * INDENT + INDENT, y * INDENT, NULL);
  45.     LineTo(hdc, x * INDENT, y * INDENT + INDENT);
  46.  
  47.  
  48.     DeleteObject(hPen);
  49.     ReleaseDC(hWnd, hdc);
  50.  
  51.  
  52. }
  53. void drawCircle( int x = 0, int y = 0) {
  54.    
  55.     hdc = GetDC(hWnd);
  56.  
  57.     hBrush = CreateSolidBrush(colorCircle); //задаём сплошную кисть, закрашенную цветом RGB
  58.     SelectObject(hdc, hBrush); //делаем кисть активной
  59.  
  60.     Ellipse(hdc, x * INDENT, y * INDENT, x * INDENT + INDENT, y * INDENT + INDENT);
  61.  
  62.     ReleaseDC(hWnd, hdc);
  63. }
  64. void drawField() {
  65.  
  66.      
  67.     //закрасить фон
  68.      
  69.     hBrush = CreateSolidBrush(colorBackground);
  70.     SetClassLongPtr(hWnd, GCL_HBRBACKGROUND, (LONG)hBrush);
  71.     InvalidateRect(hWnd, NULL, TRUE);
  72.  
  73.     PAINTSTRUCT ps;
  74.     HPEN hPen;
  75.     hPen = CreatePen(PS_DASHDOT, 2, lineColor);
  76.     hdc = BeginPaint(hWnd, &ps);
  77.     int i;
  78.  
  79.     for (i = 1; i <= N; i++) {
  80.  
  81.  
  82.         MoveToEx(hdc, 0, i * INDENT, NULL);
  83.         SelectObject(hdc, hPen);
  84.         LineTo(hdc, N * INDENT, i * INDENT);
  85.  
  86.         MoveToEx(hdc, i * INDENT, 0, NULL);
  87.         SelectObject(hdc, hPen);
  88.         LineTo(hdc, i * INDENT, N * INDENT);
  89.  
  90.     }
  91.  
  92.  
  93.     for (int i = 0; i < N; ++i)
  94.         for (int j = 0; j < N; ++j)
  95.             switch (grid[i][j])
  96.             {
  97.             case idСrossCell:
  98.                 drawCross(i, j);
  99.                 break;
  100.             case idСircleCell:
  101.                 drawCircle(i, j);
  102.                 break;
  103.             default:
  104.                 break;
  105.             }
  106.        
  107.  
  108.     EndPaint(hWnd, &ps);
  109.     DeleteObject(hPen);
  110.      
  111. }
  112. void saveConfig() {
  113.     RECT rect;
  114.     rect = { 0 };
  115.     GetWindowRect(hWnd, &rect);
  116.     std::ofstream config;
  117.     config.open("config.txt");
  118.     config << N <<std::endl;
  119.     config << rect.right - rect.left<<" "  << rect.bottom - rect.top << std::endl;
  120.     config << int(GetRValue(colorBackground)) << " " << int(GetGValue(colorBackground)) << " " << int(GetBValue(colorBackground)) << std::endl;
  121.     config << int(GetRValue(lineColor)) << " " << int(GetGValue(lineColor)) << " " << int(GetBValue(lineColor)) << std::endl;
  122.     config.close();
  123. }
  124. void loadConfig() {
  125.     std::ifstream config;
  126.     config.open("config.txt");
  127.     config >> N ;
  128.     config >> WIDTH_WINDOW >> HEIGHT_WINDOW;
  129.     int R, G, B;
  130.     config >> R >> G >> B;
  131.     colorBackground = RGB(R, G, B);
  132.     config >> R >> G >> B;
  133.     lineColor = RGB(R, G, B);
  134.     config.close();
  135. }
  136. void RunNotepad(void)
  137. {
  138.     STARTUPINFO sInfo;
  139.     PROCESS_INFORMATION pInfo;
  140.  
  141.     ZeroMemory(&sInfo, sizeof(STARTUPINFO));
  142.  
  143.  
  144.     CreateProcess(_T("C:\\Windows\\Notepad.exe"),
  145.         NULL, NULL, NULL, FALSE, 0, NULL, NULL, &sInfo, &pInfo);
  146. }
  147. int   main(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpszCmdLine, int nCmdShow) {
  148.      
  149.     MSG lpMsg;
  150.     loadConfig();
  151.     //получение данных из аргументов
  152.     LPWSTR* szArglist;
  153.     int nArgs;
  154.     szArglist = CommandLineToArgvW(GetCommandLineW(), &nArgs);
  155.     if (nArgs > 1)
  156.         N = _wtoi(szArglist[1]);
  157.  
  158.     LocalFree(szArglist);
  159.  
  160.     if (N > 100)N = 100;
  161.     for (int i = 0; i < N; ++i)
  162.         for (int j = 0; j < N; ++j)
  163.             grid[i][j]= idVoidCell;
  164.        
  165.     w.lpszClassName = L"MyAppClass"; //имя программы
  166.     w.hInstance = hInstance; //идентификатор текущего приложения
  167.     w.lpfnWndProc = WndProc; //указатель на функцию окна
  168.     w.hCursor = LoadCursor(NULL, IDC_ARROW); //загружаем курсор
  169.     w.hIcon = 0;
  170.     w.lpszMenuName = 0;
  171.  
  172.     hBrush = CreateSolidBrush(colorBackground);
  173.     w.hbrBackground = hBrush;
  174.  
  175.  
  176.     w.style = CS_HREDRAW | CS_VREDRAW;
  177.     w.cbClsExtra = 0;
  178.     w.cbWndExtra = 0;
  179.  
  180.     //Если не удалось зарегистрировать класс окна - выходим
  181.     if (!RegisterClass(&w))
  182.         return 0;
  183.  
  184.     //Создадим окно в памяти, заполнив аргументы CreateWindow
  185.     hWnd = CreateWindow(L"MyAppClass", //Имя программы
  186.         L"Грфические возможности Win32 API", //Заголовок окна
  187.         WS_OVERLAPPEDWINDOW, //Стиль окна - перекрывающееся
  188.         CW_USEDEFAULT, //положение окна на экране по х
  189.         CW_USEDEFAULT, //положение по у
  190.         WIDTH_WINDOW, //ширина
  191.         HEIGHT_WINDOW, //высота
  192.         HWND_DESKTOP, //идентификатор родительского окна
  193.         (HMENU)NULL, //идентификатор меню
  194.         (HINSTANCE)hInstance, //идентификатор экземпляра программы
  195.         (HINSTANCE)NULL); //отсутствие дополнительных параметров
  196.  
  197.     //Выводим окно из памяти на экран
  198.     ShowWindow(hWnd, nCmdShow);
  199.  
  200.     //Обновим содержимое окна
  201.     UpdateWindow(hWnd);
  202.  
  203.  
  204.     //Цикл обработки сообщений
  205.  
  206.     while (GetMessage(&lpMsg, NULL, 0, 0)) {
  207.         TranslateMessage(&lpMsg);
  208.         DispatchMessage(&lpMsg);
  209.     }
  210.  
  211.     //return(lpMsg.wParam);
  212.  
  213.     DestroyWindow(hWnd);
  214.     UnregisterClass(L"MyAppClass", hInstance);
  215.     DeleteObject(hBrush);
  216.    
  217.     return 0;
  218. }
  219.  
  220. //Функция окна
  221. LRESULT CALLBACK WndProc(HWND hWnd, UINT messg, WPARAM wParam, LPARAM lParam) {
  222.     HDC hdc; //создаём контекст устройства
  223.     PAINTSTRUCT ps; //создаём экземпляр структуры графического вывода
  224.     (RegisterHotKey(hWnd,1,MOD_CONTROL, 0x51));
  225.     (RegisterHotKey(hWnd,2,MOD_SHIFT,0x43));
  226.  
  227.  
  228.     setIndent();
  229.     int x = 0, y = 0;
  230.  
  231.     //Цикл обработки сообщений
  232.     switch (messg) {
  233.     case WM_LBUTTONDOWN:
  234.  
  235.         x = LOWORD(lParam);//координаты с которыми нажата мышь - аргументы WndProc
  236.         y = HIWORD(lParam);
  237.  
  238.         x /= INDENT;
  239.         y /= INDENT;
  240.         if (x <= N && y <= N && idСircleCell != grid[x][y]) {
  241.             grid[x][y] = idСircleCell;
  242.             SendMessage(hWnd, WM_PAINT, ' ', 1L);
  243.         }
  244.         break;
  245.     case WM_RBUTTONDOWN:
  246.  
  247.         x = LOWORD(lParam);//координаты с которыми нажата мышь - аргументы WndProc
  248.         y = HIWORD(lParam);
  249.          
  250.         x /= INDENT;
  251.         y /= INDENT;
  252.         if (x <= N && y <= N && idСrossCell != grid[x][y] ) {
  253.             grid[x][y] = idСrossCell;
  254.             SendMessage(hWnd, WM_PAINT, ' ', 1L);
  255.         }
  256.          
  257.         break;
  258.  
  259.         //сообщение рисования
  260.     case WM_PAINT:
  261.         drawField();
  262.    
  263.         break;
  264.     case WM_MOUSEWHEEL:
  265.  
  266.          
  267.         int p;
  268.         switch (rand() % 3) {
  269.  
  270.         case 0:      
  271.             p = int(GetRValue(lineColor)) + deltaLineColor[0];
  272.             if (p >= 255 || p <0)  deltaLineColor[0]*=-1;
  273.             lineColor = RGB(int(GetRValue(lineColor))+   deltaLineColor[0] , int(GetGValue(lineColor)), int(GetBValue(lineColor)));
  274.             break;
  275.         case 1:
  276.             p = int(GetGValue(lineColor)) + deltaLineColor[1];
  277.             if (p >= 255 || p < 0)  deltaLineColor[1] *= -1;
  278.             lineColor = RGB(int(GetRValue(lineColor)) , int(GetGValue(lineColor))+ deltaLineColor[1], int(GetBValue(lineColor)));
  279.             break;
  280.         case 2:
  281.  
  282.             p = int(GetBValue(lineColor)) + deltaLineColor[2];
  283.             if (p >= 255 || p < 0)  deltaLineColor[2] *= -1;
  284.             lineColor = RGB(int(GetRValue(lineColor)), int(GetGValue(lineColor)) , int(GetBValue(lineColor))+ deltaLineColor[2]);
  285.             break;
  286.         }
  287.        
  288.         SendMessage(hWnd, WM_PAINT, ' ', 1L);
  289.        
  290.        
  291.         break;
  292.  
  293.     case WM_KEYUP:
  294.  
  295.         if (wParam == VK_RETURN) {
  296.             PAINTSTRUCT ps;
  297.             colorBackground = RGB( rand() % 255 , rand() % 255, rand() % 255);
  298.  
  299.             hBrush = CreateSolidBrush(colorBackground);
  300.             SetClassLongPtr(hWnd, GCL_HBRBACKGROUND, (LONG)hBrush);
  301.             InvalidateRect(hWnd, NULL, TRUE);
  302.  
  303.             return 0;
  304.         }
  305.         if (wParam == VK_ESCAPE) {
  306.             DestroyWindow(hWnd);
  307.  
  308.         }
  309.  
  310.         break;
  311.     case WM_HOTKEY:
  312.  
  313.         if (wParam == 1)
  314.         {
  315.             DestroyWindow(hWnd);
  316.         }
  317.         if (wParam == 2) {
  318.             RunNotepad();
  319.         }
  320.         break;
  321.  
  322.  
  323.  
  324.     case WM_DESTROY:
  325.         saveConfig();
  326.         PostQuitMessage(0);       /* send a WM_QUIT to the message queue */
  327.         break;
  328.  
  329.  
  330.     default:
  331.         return(DefWindowProc(hWnd, messg, wParam, lParam)); //освобождаем очередь приложения от нераспознаных
  332.     }
  333.     return 0;
  334. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement