diff --git a/laba12/laba12.sln b/laba12/laba12.sln new file mode 100644 index 0000000..3ba1f93 --- /dev/null +++ b/laba12/laba12.sln @@ -0,0 +1,41 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.11.35312.102 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "laba12", "laba12\laba12.vcxproj", "{278697C1-8267-4002-A6E3-575668249540}" +EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "tasks", "tasks\tasks.vcxproj", "{978BB971-DFED-43C7-AC2F-5B4EC25AD06A}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|x64 = Debug|x64 + Debug|x86 = Debug|x86 + Release|x64 = Release|x64 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {278697C1-8267-4002-A6E3-575668249540}.Debug|x64.ActiveCfg = Debug|x64 + {278697C1-8267-4002-A6E3-575668249540}.Debug|x64.Build.0 = Debug|x64 + {278697C1-8267-4002-A6E3-575668249540}.Debug|x86.ActiveCfg = Debug|Win32 + {278697C1-8267-4002-A6E3-575668249540}.Debug|x86.Build.0 = Debug|Win32 + {278697C1-8267-4002-A6E3-575668249540}.Release|x64.ActiveCfg = Release|x64 + {278697C1-8267-4002-A6E3-575668249540}.Release|x64.Build.0 = Release|x64 + {278697C1-8267-4002-A6E3-575668249540}.Release|x86.ActiveCfg = Release|Win32 + {278697C1-8267-4002-A6E3-575668249540}.Release|x86.Build.0 = Release|Win32 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Debug|x64.ActiveCfg = Debug|x64 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Debug|x64.Build.0 = Debug|x64 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Debug|x86.ActiveCfg = Debug|Win32 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Debug|x86.Build.0 = Debug|Win32 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Release|x64.ActiveCfg = Release|x64 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Release|x64.Build.0 = Release|x64 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Release|x86.ActiveCfg = Release|Win32 + {978BB971-DFED-43C7-AC2F-5B4EC25AD06A}.Release|x86.Build.0 = Release|Win32 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {562643C0-D421-43E2-965D-12DFE785BF4E} + EndGlobalSection +EndGlobal diff --git a/laba12/laba12/Resource.h b/laba12/laba12/Resource.h new file mode 100644 index 0000000..77fc245 --- /dev/null +++ b/laba12/laba12/Resource.h @@ -0,0 +1,30 @@ +//{{NO_DEPENDENCIES}} +// Включаемый файл, созданный в Microsoft Visual C++. +// Используется laba12.rc + +#define IDS_APP_TITLE 103 + +#define IDR_MAINFRAME 128 +#define IDD_LABA12_DIALOG 102 +#define IDD_ABOUTBOX 103 +#define IDM_ABOUT 104 +#define IDM_EXIT 105 +#define IDI_LABA12 107 +#define IDI_SMALL 108 +#define IDC_LABA12 109 +#define IDC_MYICON 2 +#ifndef IDC_STATIC +#define IDC_STATIC -1 +#endif +// Следующие стандартные значения для новых объектов +// +#ifdef APSTUDIO_INVOKED +#ifndef APSTUDIO_READONLY_SYMBOLS + +#define _APS_NO_MFC 130 +#define _APS_NEXT_RESOURCE_VALUE 129 +#define _APS_NEXT_COMMAND_VALUE 32771 +#define _APS_NEXT_CONTROL_VALUE 1000 +#define _APS_NEXT_SYMED_VALUE 110 +#endif +#endif diff --git a/laba12/laba12/framework.h b/laba12/laba12/framework.h new file mode 100644 index 0000000..a8f6dc8 --- /dev/null +++ b/laba12/laba12/framework.h @@ -0,0 +1,15 @@ +// header.h: включаемый файл для стандартных системных включаемых файлов +// или включаемые файлы для конкретного проекта +// + +#pragma once + +#include "targetver.h" +#define WIN32_LEAN_AND_MEAN // Исключите редко используемые компоненты из заголовков Windows +// Файлы заголовков Windows +#include +// Файлы заголовков среды выполнения C +#include +#include +#include +#include diff --git a/laba12/laba12/laba12.cpp b/laba12/laba12/laba12.cpp new file mode 100644 index 0000000..2d70e64 --- /dev/null +++ b/laba12/laba12/laba12.cpp @@ -0,0 +1,253 @@ +// laba12.cpp : Определяет точку входа для приложения. +// + +#include "framework.h" +#include "laba12.h" + +#define MAX_LOADSTRING 100 + +// Глобальные переменные: +HINSTANCE hInst; // текущий экземпляр +WCHAR szTitle[MAX_LOADSTRING]; // Текст строки заголовка +WCHAR szWindowClass[MAX_LOADSTRING]; // имя класса главного окна + +// Отправить объявления функций, включенных в этот модуль кода: +ATOM MyRegisterClass(HINSTANCE hInstance); +BOOL InitInstance(HINSTANCE, int); +LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); +INT_PTR CALLBACK About(HWND, UINT, WPARAM, LPARAM); + +int APIENTRY wWinMain(_In_ HINSTANCE hInstance, + _In_opt_ HINSTANCE hPrevInstance, + _In_ LPWSTR lpCmdLine, + _In_ int nCmdShow) +{ + UNREFERENCED_PARAMETER(hPrevInstance); + UNREFERENCED_PARAMETER(lpCmdLine); + + // TODO: Разместите код здесь. + + // Инициализация глобальных строк + LoadStringW(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING); + LoadStringW(hInstance, IDC_LABA12, szWindowClass, MAX_LOADSTRING); + MyRegisterClass(hInstance); + + // Выполнить инициализацию приложения: + if (!InitInstance (hInstance, nCmdShow)) + { + return FALSE; + } + + HACCEL hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_LABA12)); + + MSG msg; + + // Цикл основного сообщения: + while (GetMessage(&msg, nullptr, 0, 0)) + { + if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) + { + TranslateMessage(&msg); + DispatchMessage(&msg); + } + } + + return (int) msg.wParam; +} + + + +// +// ФУНКЦИЯ: MyRegisterClass() +// +// ЦЕЛЬ: Регистрирует класс окна. +// +ATOM MyRegisterClass(HINSTANCE hInstance) +{ + WNDCLASSEXW wcex; + + wcex.cbSize = sizeof(WNDCLASSEX); + + wcex.style = CS_HREDRAW | CS_VREDRAW; + wcex.lpfnWndProc = WndProc; + wcex.cbClsExtra = 0; + wcex.cbWndExtra = 0; + wcex.hInstance = hInstance; + wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_LABA12)); + wcex.hCursor = LoadCursor(nullptr, IDC_ARROW); + wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+1); + wcex.lpszMenuName = MAKEINTRESOURCEW(IDC_LABA12); + wcex.lpszClassName = szWindowClass; + wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL)); + + return RegisterClassExW(&wcex); +} + +// +// ФУНКЦИЯ: InitInstance(HINSTANCE, int) +// +// ЦЕЛЬ: Сохраняет маркер экземпляра и создает главное окно +// +// КОММЕНТАРИИ: +// +// В этой функции маркер экземпляра сохраняется в глобальной переменной, а также +// создается и выводится главное окно программы. +// +BOOL InitInstance(HINSTANCE hInstance, int nCmdShow) +{ + hInst = hInstance; // Сохранить маркер экземпляра в глобальной переменной + + HWND hWnd = CreateWindowW(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW, + CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, nullptr, nullptr, hInstance, nullptr); + + if (!hWnd) + { + return FALSE; + } + + ShowWindow(hWnd, nCmdShow); + UpdateWindow(hWnd); + + return TRUE; +} + + + +void Image1(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[4] = { + cx, cy - 20, + cx + 20, cy + 20, + cx - 20, cy + 20, + cx, cy - 20 + }; + Polyline(hdc, p, 4); + DeleteObject(hPen); +} + +void Image2(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx, cy - 20, + cx + 20, cy, + cx, cy + 20, + cx - 20, cy, + cx, cy - 20 + }; + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + +void Image3(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx, cy - 20, + cx + 20, cy, + cx + 40, cy - 20, + cx + 20, cy + 20, + cx, cy - 20 + }; + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + +// +// ФУНКЦИЯ: WndProc(HWND, UINT, WPARAM, LPARAM) +// +// ЦЕЛЬ: Обрабатывает сообщения в главном окне. +// +// WM_COMMAND - обработать меню приложения +// WM_PAINT - Отрисовка главного окна +// WM_DESTROY - отправить сообщение о выходе и вернуться +// +// +LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) +{ + switch (message) + { + case WM_COMMAND: + { + int wmId = LOWORD(wParam); + // Разобрать выбор в меню: + switch (wmId) + { + case IDM_ABOUT: + DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About); + break; + case IDM_EXIT: + DestroyWindow(hWnd); + break; + default: + return DefWindowProc(hWnd, message, wParam, lParam); + } + } + break; + case WM_PAINT: + { + PAINTSTRUCT ps; + HDC hdc = BeginPaint(hWnd, &ps); + // TODO: Добавьте сюда любой код прорисовки, использующий HDC... + + Image1(hdc, 40, 40, RGB(255, 0, 0)); + Image1(hdc, 140, 40, RGB(0, 255, 0)); + Image1(hdc, 240, 40, RGB(0, 0, 255)); + Image1(hdc, 240, 240, RGB(255, 255, 0)); + Image1(hdc, 40, 240, RGB(255, 0, 255)); + EndPaint(hWnd, &ps); + } + break; + HDC hdc = BeginPaint(hWnd, &ss); + Image2(hdc, 40, 40, RGB(255, 0, 0)); + Image2(hdc, 140, 40, RGB(0, 255, 0)); + Image2(hdc, 240, 40, RGB(0, 0, 255)); + Image2(hdc, 240, 240, RGB(255, 255, 0)); + Image2(hdc, 40, 240, RGB(255, 0, 255)); + EndPaint(hWnd, &ss); + } + HDC hdc = BeginPaint(hWnd, &ds); + Image3(hdc, 40, 40, RGB(255, 0, 0)); + Image3(hdc, 140, 40, RGB(0, 255, 0)); + Image3(hdc, 240, 40, RGB(0, 0, 255)); + Image3(hdc, 240, 240, RGB(255, 255, 0)); + Image3(hdc, 40, 240, RGB(255, 0, 255)); + EndPaint(hWnd, &ds); +} +break; +} + case WM_DESTROY: + PostQuitMessage(0); + break; + default: + return DefWindowProc(hWnd, message, wParam, lParam); + } + return 0; +} + +// Обработчик сообщений для окна "О программе". +INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) +{ + UNREFERENCED_PARAMETER(lParam); + switch (message) + { + case WM_INITDIALOG: + return (INT_PTR)TRUE; + + case WM_COMMAND: + if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL) + { + EndDialog(hDlg, LOWORD(wParam)); + return (INT_PTR)TRUE; + } + break; + } + return (INT_PTR)FALSE; +} diff --git a/laba12/laba12/laba12.h b/laba12/laba12/laba12.h new file mode 100644 index 0000000..d00d47e --- /dev/null +++ b/laba12/laba12/laba12.h @@ -0,0 +1,3 @@ +#pragma once + +#include "resource.h" diff --git a/laba12/laba12/laba12.ico b/laba12/laba12/laba12.ico new file mode 100644 index 0000000..b3ec03b Binary files /dev/null and b/laba12/laba12/laba12.ico differ diff --git a/laba12/laba12/laba12.rc b/laba12/laba12/laba12.rc new file mode 100644 index 0000000..70b9500 Binary files /dev/null and b/laba12/laba12/laba12.rc differ diff --git a/laba12/laba12/laba12.vcxproj b/laba12/laba12/laba12.vcxproj new file mode 100644 index 0000000..acf5b9b --- /dev/null +++ b/laba12/laba12/laba12.vcxproj @@ -0,0 +1,148 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + + 17.0 + Win32Proj + {278697c1-8267-4002-a6e3-575668249540} + laba12 + 10.0 + + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + + + + + + + + + + + + + + + + + + + + Level3 + true + WIN32;_DEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + + + + + Level3 + true + true + true + WIN32;NDEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + true + true + + + + + Level3 + true + _DEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + + + + + Level3 + true + true + true + NDEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + true + true + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/laba12/laba12/laba12.vcxproj.filters b/laba12/laba12/laba12.vcxproj.filters new file mode 100644 index 0000000..c3b0d7c --- /dev/null +++ b/laba12/laba12/laba12.vcxproj.filters @@ -0,0 +1,49 @@ + + + + + {4FC737F1-C7A5-4376-A066-2A32D752A2FF} + cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx + + + {93995380-89BD-4b04-88EB-625FBE52EBFB} + h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd + + + {67DA6AB6-F800-4c08-8B7A-83BB121AAD01} + rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms + + + + + Файлы заголовков + + + Файлы заголовков + + + Файлы заголовков + + + Файлы заголовков + + + + + Исходные файлы + + + + + Файлы ресурсов + + + + + Файлы ресурсов + + + Файлы ресурсов + + + \ No newline at end of file diff --git a/laba12/laba12/small.ico b/laba12/laba12/small.ico new file mode 100644 index 0000000..b3ec03b Binary files /dev/null and b/laba12/laba12/small.ico differ diff --git a/laba12/laba12/targetver.h b/laba12/laba12/targetver.h new file mode 100644 index 0000000..d90003d --- /dev/null +++ b/laba12/laba12/targetver.h @@ -0,0 +1,6 @@ +#pragma once + +// // При включении SDKDDKVer.h будет задана самая новая из доступных платформ Windows. +// Если вы планируете сборку приложения для предыдущей версии платформы Windows, включите WinSDKVer.h и +// задайте желаемую платформу в макросе _WIN32_WINNT, прежде чем включать SDKDDKVer.h. +#include diff --git a/laba12/tasks/Resource.h b/laba12/tasks/Resource.h new file mode 100644 index 0000000..ef57768 --- /dev/null +++ b/laba12/tasks/Resource.h @@ -0,0 +1,30 @@ +//{{NO_DEPENDENCIES}} +// Включаемый файл, созданный в Microsoft Visual C++. +// Используется tasks.rc + +#define IDS_APP_TITLE 103 + +#define IDR_MAINFRAME 128 +#define IDD_TASKS_DIALOG 102 +#define IDD_ABOUTBOX 103 +#define IDM_ABOUT 104 +#define IDM_EXIT 105 +#define IDI_TASKS 107 +#define IDI_SMALL 108 +#define IDC_TASKS 109 +#define IDC_MYICON 2 +#ifndef IDC_STATIC +#define IDC_STATIC -1 +#endif +// Следующие стандартные значения для новых объектов +// +#ifdef APSTUDIO_INVOKED +#ifndef APSTUDIO_READONLY_SYMBOLS + +#define _APS_NO_MFC 130 +#define _APS_NEXT_RESOURCE_VALUE 129 +#define _APS_NEXT_COMMAND_VALUE 32771 +#define _APS_NEXT_CONTROL_VALUE 1000 +#define _APS_NEXT_SYMED_VALUE 110 +#endif +#endif diff --git a/laba12/tasks/framework.h b/laba12/tasks/framework.h new file mode 100644 index 0000000..a8f6dc8 --- /dev/null +++ b/laba12/tasks/framework.h @@ -0,0 +1,15 @@ +// header.h: включаемый файл для стандартных системных включаемых файлов +// или включаемые файлы для конкретного проекта +// + +#pragma once + +#include "targetver.h" +#define WIN32_LEAN_AND_MEAN // Исключите редко используемые компоненты из заголовков Windows +// Файлы заголовков Windows +#include +// Файлы заголовков среды выполнения C +#include +#include +#include +#include diff --git a/laba12/tasks/small.ico b/laba12/tasks/small.ico new file mode 100644 index 0000000..b3ec03b Binary files /dev/null and b/laba12/tasks/small.ico differ diff --git a/laba12/tasks/targetver.h b/laba12/tasks/targetver.h new file mode 100644 index 0000000..d90003d --- /dev/null +++ b/laba12/tasks/targetver.h @@ -0,0 +1,6 @@ +#pragma once + +// // При включении SDKDDKVer.h будет задана самая новая из доступных платформ Windows. +// Если вы планируете сборку приложения для предыдущей версии платформы Windows, включите WinSDKVer.h и +// задайте желаемую платформу в макросе _WIN32_WINNT, прежде чем включать SDKDDKVer.h. +#include diff --git a/laba12/tasks/tasks.cpp b/laba12/tasks/tasks.cpp new file mode 100644 index 0000000..5461ea4 --- /dev/null +++ b/laba12/tasks/tasks.cpp @@ -0,0 +1,375 @@ +// tasks.cpp : Определяет точку входа для приложения. +// + +#include "framework.h" +#include "tasks.h" + +#define MAX_LOADSTRING 100 +//обчные треугольники (разноцветные +void Im0(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[4] = { + cx, cy + 20, + cx + 20, cy - 20, + cx - 20, cy - 20, + cx, cy + 20 + }; + + Polyline(hdc, p, 4); + DeleteObject(hPen); +} +//ромбы +void Im1(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[4]; + p[0].x = cx; + p[0].y = cy - 20; + p[1].x = cx + 20; + p[1].y = cy + 20; + p[2].x = cx - 20; + p[2].y = cy + 20; + p[3].x = cx; + p[3].y = cy - 20; + + Polyline(hdc, p, 4); + DeleteObject(hPen); +} + +void Im2(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5]; + p[0].x = cx; + p[0].y = cy - 20; + p[1].x = cx + 20; + p[1].y = cy; + p[2].x = cx; + p[2].y = cy + 20; + p[3].x = cx - 20; + p[3].y = cy; + p[4].x = cx; + p[4].y = cy - 20; + + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + +void Im3(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx + 20, cy - 20, + cx, cy + 20, + cx - 20, cy - 20, + cx, cy, + cx + 20, cy - 20, + }; + + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + +void Im4(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx + 20, cy - 20, + cx, cy + 20, + cx - 20, cy - 20, + cx, cy, + cx + 20, cy - 20, + }; + + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + + +struct Image { + int x; + int y; + int vx; + int vy; + COLORREF color; +}; + +// Глобальные переменные: +HINSTANCE hInst; // текущий экземпляр +WCHAR szTitle[MAX_LOADSTRING]; // Текст строки заголовка +WCHAR szWindowClass[MAX_LOADSTRING]; // имя класса главного окна + +// Отправить объявления функций, включенных в этот модуль кода: +ATOM MyRegisterClass(HINSTANCE hInstance); +BOOL InitInstance(HINSTANCE, int); +LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); +INT_PTR CALLBACK About(HWND, UINT, WPARAM, LPARAM); + +struct Image im1 = { 200, 200, 10, 0, RGB(128, 128, 0) }; + +struct Image im2 = { 400, 100, -10, 0, RGB(45, 100, 87) }; + +struct Image im3 = { 100, 200, 0, 10, RGB(0, 100, 98) }; + +struct Image im4 = { 120, 500, 0, -10, RGB(255, 100, 0) }; + +struct Image im5[3] = { + {500, 100, 10, 5, RGB(150, 100, 100)}, + {500, 100, 0, 10, RGB(150, 100, 100)}, + {500, 100, -10, 5, RGB(150, 100, 100)}, +}; + + +int APIENTRY wWinMain(_In_ HINSTANCE hInstance, + _In_opt_ HINSTANCE hPrevInstance, + _In_ LPWSTR lpCmdLine, + _In_ int nCmdShow) +{ + UNREFERENCED_PARAMETER(hPrevInstance); + UNREFERENCED_PARAMETER(lpCmdLine); + + // TODO: Разместите код здесь. + + // Инициализация глобальных строк + LoadStringW(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING); + LoadStringW(hInstance, IDC_TASKS, szWindowClass, MAX_LOADSTRING); + MyRegisterClass(hInstance); + + // Выполнить инициализацию приложения: + if (!InitInstance (hInstance, nCmdShow)) + { + return FALSE; + } + + HACCEL hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_TASKS)); + + MSG msg; + + // Цикл основного сообщения: + while (GetMessage(&msg, nullptr, 0, 0)) + { + if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) + { + TranslateMessage(&msg); + DispatchMessage(&msg); + } + } + + return (int) msg.wParam; +} + + + +// +// ФУНКЦИЯ: MyRegisterClass() +// +// ЦЕЛЬ: Регистрирует класс окна. +// +ATOM MyRegisterClass(HINSTANCE hInstance) +{ + WNDCLASSEXW wcex; + + wcex.cbSize = sizeof(WNDCLASSEX); + + wcex.style = CS_HREDRAW | CS_VREDRAW; + wcex.lpfnWndProc = WndProc; + wcex.cbClsExtra = 0; + wcex.cbWndExtra = 0; + wcex.hInstance = hInstance; + wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_TASKS)); + wcex.hCursor = LoadCursor(nullptr, IDC_ARROW); + wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+1); + wcex.lpszMenuName = MAKEINTRESOURCEW(IDC_TASKS); + wcex.lpszClassName = szWindowClass; + wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL)); + + return RegisterClassExW(&wcex); +} + +// +// ФУНКЦИЯ: InitInstance(HINSTANCE, int) +// +// ЦЕЛЬ: Сохраняет маркер экземпляра и создает главное окно +// +// КОММЕНТАРИИ: +// +// В этой функции маркер экземпляра сохраняется в глобальной переменной, а также +// создается и выводится главное окно программы. +// +BOOL InitInstance(HINSTANCE hInstance, int nCmdShow) +{ + hInst = hInstance; // Сохранить маркер экземпляра в глобальной переменной + + HWND hWnd = CreateWindowW(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW, + CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, nullptr, nullptr, hInstance, nullptr); + + if (!hWnd) + { + return FALSE; + } + + ShowWindow(hWnd, nCmdShow); + UpdateWindow(hWnd); + + return TRUE; +} + + + +void Image1(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[4] = { + cx, cy - 20, + cx + 20, cy + 20, + cx - 20, cy + 20, + cx, cy - 20 + }; + Polyline(hdc, p, 4); + DeleteObject(hPen); +} + +void Image2(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx, cy - 20, + cx + 20, cy, + cx, cy + 20, + cx - 20, cy, + cx, cy - 20 + }; + Polyline(hdc, p, 5); + DeleteObject(hPen); +} + +void Image3(HDC hdc, int cx, int cy, COLORREF color) { + HPEN hPen; + hPen = CreatePen(PS_SOLID, 2, color); + SelectObject(hdc, hPen); + + POINT p[5] = { + cx, cy - 20, + cx + 20, cy, + cx + 40, cy - 20, + cx + 20, cy + 20, + cx, cy - 20 + }; + Polyline(hdc, p, 5); + DeleteObject(hPen); +} +// +// ФУНКЦИЯ: WndProc(HWND, UINT, WPARAM, LPARAM) +// +// ЦЕЛЬ: Обрабатывает сообщения в главном окне. +// +// WM_COMMAND - обработать меню приложения +// WM_PAINT - Отрисовка главного окна +// WM_DESTROY - отправить сообщение о выходе и вернуться +// +// +LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam) +{ + switch (message) { + case WM_CREATE: + SetTimer(hWnd, 1, 500, 0); + break; + + case WM_TIMER: + + im1.x += im1.vx; + im1.y += im1.vy; + im2.x += im2.vx; + im2.y += im2.vy; + im3.x += im3.vx; + im3.y += im3.vy; + im4.x += im4.vx; + im4.y += im4.vy; + + im5[0].x += im5[0].vx; + im5[0].y += im5[0].vy; + + im5[1].x += im5[1].vx; + im5[1].y += im5[1].vy; + + im5[2].x += im5[2].vx; + im5[2].y += im5[2].vy; + + InvalidateRect(hWnd, NULL, TRUE); + break; + case WM_COMMAND: + { + int wmId = LOWORD(wParam); + switch (wmId) { + case IDM_ABOUT: + DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About); + break; + case IDM_EXIT: + DestroyWindow(hWnd); + break; + default: + return DefWindowProc(hWnd, message, wParam, lParam); + } + } + break; + case WM_PAINT: + { + PAINTSTRUCT ps; + HDC hdc = BeginPaint(hWnd, &ps); + + Im0(hdc, im1.x, im1.y, im1.color); + Im1(hdc, im2.x, im2.y, im2.color); + Im2(hdc, im3.x, im3.y, im1.color); + Im3(hdc, im4.x, im4.y, im1.color); + Im4(hdc, im5[0].x, im5[0].y, im5[0].color); + Im4(hdc, im5[1].x, im5[1].y, im5[1].color); + Im4(hdc, im5[2].x, im5[2].y, im5[2].color); + + + EndPaint(hWnd, &ps); + } + break; + case WM_DESTROY: + PostQuitMessage(0); + break; + default: + return DefWindowProc(hWnd, message, wParam, lParam); + } + return 0; +} + + +// Обработчик сообщений для окна "О программе". +INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) +{ + UNREFERENCED_PARAMETER(lParam); + switch (message) + { + case WM_INITDIALOG: + return (INT_PTR)TRUE; + + case WM_COMMAND: + if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL) + { + EndDialog(hDlg, LOWORD(wParam)); + return (INT_PTR)TRUE; + } + break; + } + return (INT_PTR)FALSE; +} diff --git a/laba12/tasks/tasks.h b/laba12/tasks/tasks.h new file mode 100644 index 0000000..d00d47e --- /dev/null +++ b/laba12/tasks/tasks.h @@ -0,0 +1,3 @@ +#pragma once + +#include "resource.h" diff --git a/laba12/tasks/tasks.ico b/laba12/tasks/tasks.ico new file mode 100644 index 0000000..b3ec03b Binary files /dev/null and b/laba12/tasks/tasks.ico differ diff --git a/laba12/tasks/tasks.rc b/laba12/tasks/tasks.rc new file mode 100644 index 0000000..d0fe88b Binary files /dev/null and b/laba12/tasks/tasks.rc differ diff --git a/laba12/tasks/tasks.vcxproj b/laba12/tasks/tasks.vcxproj new file mode 100644 index 0000000..fe3f614 --- /dev/null +++ b/laba12/tasks/tasks.vcxproj @@ -0,0 +1,148 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + x64 + + + Release + x64 + + + + 17.0 + Win32Proj + {978bb971-dfed-43c7-ac2f-5b4ec25ad06a} + tasks + 10.0 + + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + Application + true + v143 + Unicode + + + Application + false + v143 + true + Unicode + + + + + + + + + + + + + + + + + + + + + + Level3 + true + WIN32;_DEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + + + + + Level3 + true + true + true + WIN32;NDEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + true + true + + + + + Level3 + true + _DEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + + + + + Level3 + true + true + true + NDEBUG;_WINDOWS;%(PreprocessorDefinitions) + true + + + Windows + true + true + true + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/laba12/tasks/tasks.vcxproj.filters b/laba12/tasks/tasks.vcxproj.filters new file mode 100644 index 0000000..63a1f2c --- /dev/null +++ b/laba12/tasks/tasks.vcxproj.filters @@ -0,0 +1,49 @@ + + + + + {4FC737F1-C7A5-4376-A066-2A32D752A2FF} + cpp;c;cc;cxx;c++;cppm;ixx;def;odl;idl;hpj;bat;asm;asmx + + + {93995380-89BD-4b04-88EB-625FBE52EBFB} + h;hh;hpp;hxx;h++;hm;inl;inc;ipp;xsd + + + {67DA6AB6-F800-4c08-8B7A-83BB121AAD01} + rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms + + + + + Файлы заголовков + + + Файлы заголовков + + + Файлы заголовков + + + Файлы заголовков + + + + + Исходные файлы + + + + + Файлы ресурсов + + + + + Файлы ресурсов + + + Файлы ресурсов + + + \ No newline at end of file