Форум программистов, компьютерный форум, киберфорум
C/C++: WinAPI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 22.03.2017
Сообщений: 3

Нарисовать несколько фигур, перемещающихся по траекториям Лиссажу

22.03.2017, 22:45. Показов 1224. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Не могли бы вы помочь, нужно нарисовать несколько фигур, которые перемещающихся по траекториям Лиссажу. Помогите, пожалуйста!!!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.03.2017, 22:45
Ответы с готовыми решениями:

Реализовать движение разных фигур по разным траекториям
Нужно сделать движение разных фигур по разной траектории...т.е. выбрал фигуру..какой-то квадратик или кружок и выбрал для него...

Нарисовать несколько фигур
Добрый вечер, можете помочь с составлением программ? Я полный профан в этом деле

На экране нарисовать несколько произвольных закрашенных фигур
Добрый вечер, форумчане! Возникла пара вопросов при работе с нетипизированными файлами в Turbo Pascal 7.0 (а также и в 7.1). На...

5
694 / 7068 / 265
Регистрация: 11.08.2016
Сообщений: 3,966
23.03.2017, 14:01
Что не получается? Рисовать фигуры? Делать траектории Лиссажу? Перемещать?
0
0 / 0 / 0
Регистрация: 22.03.2017
Сообщений: 3
23.03.2017, 14:06  [ТС]
Ivandur, Не получается, чтобы они перемещались именно по траектории Лиссажу
0
694 / 7068 / 265
Регистрация: 11.08.2016
Сообщений: 3,966
23.03.2017, 16:41
https://www.cyberforum.ru/cgi-bin/latex.cgi?x\left(t \right)=A\cdot sin\left(at+\delta\right)\\y\left(t \right)=B\cdot cos\left(b\cdot t \right)
На стрелочки не обращай внимания.
0
Заблокирован
25.03.2017, 03:19
Lissajous Figures
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
//
// Lissajous Figures
//
/*-----------------------------------------------------------------------------
    Фигуры Лиссажу - замкнутые траектории, прочерчиваемые
    точкой, совершающей одновременно два гармонических
    колебания в двух взаимно перпендикулярных направлениях.
-----------------------------------------------------------------------------*/
//
// Опции проекта
// [Configuration] General [Character set] "Use Unicode Character Set"
//
 
#include <cmath>
#include <windows.h>
 
#ifndef M_PI
const double M_PI = 3.14159265358979323846;
#endif
 
TCHAR GWndname[] = TEXT("LISSAJOUS_FIGURES");   // Класс,
TCHAR GAppname[] = TEXT("Lissajous Figures");   // заголовок окна.
 
HWND g_hwndStatic[3];
 
void LissajousFigures_01(HDC hDC, RECT Rect)
{
    HPEN hPen;
    HGDIOBJ gdi;
    hPen = CreatePen(PS_SOLID, 3, RGB(0,0,255));
    gdi = SelectObject(hDC, hPen);
    double t, p;
    t = p = 0;
    int x, y;
    x = static_cast<int>((-90.5*sin(3*t)+Rect.right/2));
    y = static_cast<int>((90.5*cos(t)-1.3*cos(2*t)-0.6*cos(3*t)-0.2*cos(4*t)+Rect.bottom/2));
    MoveToEx(hDC, x, y, NULL);
 
    for( p=0; p < M_PI*10; p+=M_PI/36 )
    {
        for( t=0; t < 2*M_PI; t+=M_PI/500 )
        {
            x = static_cast<int>((90.5*sin(3*t)+Rect.right/2));
            y = static_cast<int>((90.5*cos(t)-1.3*cos(2*t)-0.6*cos(3*t)-0.2*cos(4*t)+Rect.bottom/2));
            LineTo(hDC, x, y);
        }
    }
    SelectObject(hDC, gdi);
    SetBkColor(hDC, GetSysColor(COLOR_WINDOW));
    DrawText(hDC, TEXT("x = 5 sin3t,\r\ny = 4 cos(t)-1.3 cos(2t)-0.6 cos(3t)-0.2 cos(4t)"), -1, &Rect, DT_EXTERNALLEADING | DT_NOPREFIX | DT_WORDBREAK);
}
 
void LissajousFigures_02(HDC hDC, RECT Rect)
{
    HPEN hPen;
    HGDIOBJ gdi;
    hPen = CreatePen(PS_SOLID, 2, RGB(255,0,0));
    gdi = SelectObject(hDC, hPen);
    double t, p;
    t = p = 0;
    int x, y;
    x = static_cast<int>((-80.5*sin(t)+Rect.right/2));
    y = static_cast<int>((80.5*cos(3*t)+Rect.bottom/2));
    MoveToEx(hDC, x, y, NULL);
 
    for( p=0; p < M_PI*10; p+=M_PI/36 )
    {
        for( t=0; t < 2*M_PI; t+=M_PI/500 )
        {
            x = static_cast<int>((80.5*sin(t)+Rect.right/2));
            y = static_cast<int>((80.5*cos(3*t)+Rect.bottom/2));
            LineTo(hDC, x, y);
        }
    }
    SelectObject(hDC, gdi);
    SetBkColor(hDC, GetSysColor(COLOR_WINDOW));
    TextOut(hDC, 4, 2, TEXT("x = sin(t), y = cos(3t)"), 23);
}
 
void LissajousFigures_03(HDC hDC, RECT Rect)
{
    HPEN hPen;
    HGDIOBJ gdi;
    hPen = CreatePen(PS_SOLID, 2, RGB(153,0,0));
    gdi = SelectObject(hDC, hPen);
    double t, p;
    t = p = 0;
    int x, y;
    x = static_cast<int>((80.5*2*cos(t)+Rect.right/2));
    y = static_cast<int>((80.5*cos(t+4)+Rect.bottom/2));
    MoveToEx(hDC, x, y, NULL);
 
    for( p=0; p < M_PI*10; p+=M_PI/36 )
    {
        for( t=0; t < 2*M_PI; t+=M_PI/500 )
        {
            x = static_cast<int>((80.5*2*cos(t)+Rect.right/2));
            y = static_cast<int>((80.5*cos(t+4)+Rect.bottom/2));
            LineTo(hDC, x, y);
        }
    }
    SelectObject(hDC, gdi);
    SetBkColor(hDC, GetSysColor(COLOR_WINDOW));
    TextOut(hDC, 4, 2, TEXT("x = 2 cos(t), y = cos(t+4)"), 26);
}
 
void OnPaint(HWND hWnd)
{
    PAINTSTRUCT ps;
    HDC hDC;
    hDC = BeginPaint(hWnd, &ps);
    RECT rect;
    GetClientRect(hWnd, &rect);
    
    GetClientRect(g_hwndStatic[0], &rect);
    LissajousFigures_01(GetDC(g_hwndStatic[0]), rect);
 
    RECT Rect2;
    GetClientRect(g_hwndStatic[1], &Rect2);
    LissajousFigures_02(GetDC(g_hwndStatic[1]), Rect2); 
 
    RECT Rect3;
    GetClientRect(g_hwndStatic[2], &Rect3);
    LissajousFigures_03(GetDC(g_hwndStatic[2]), Rect3); 
 
    ValidateRect(hWnd, NULL);
    EndPaint(hWnd, &ps);
}
 
//
// WndProc
//
LRESULT CALLBACK WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
    LRESULT retval = 0;
    switch( uMsg ) {
    case WM_CREATE:
    {
        LPCREATESTRUCT lpCreateStruct;
        lpCreateStruct = reinterpret_cast<LPCREATESTRUCT>(lParam);
        for( int i = 0; i < 4; ++i ) {
            g_hwndStatic[i] = CreateWindowEx(0, TEXT("Static"), TEXT(""), SS_NOTIFY | WS_CHILD | WS_VISIBLE | WS_BORDER, 0, 0, 0, 0, hWnd, (HMENU)(UINT_PTR)i+1, lpCreateStruct->hInstance, LPVOID(0));
            if( NULL == g_hwndStatic[i] ) {
                MessageBox(HWND_DESKTOP, TEXT("Cannot CreateWindow "Static""), GAppname, MB_OK | MB_ICONSTOP | MB_SETFOREGROUND | MB_TOPMOST);
                return -1;
            }
        }
    }
    return 1;
    
    case WM_WINDOWPOSCHANGING:
    case WM_WINDOWPOSCHANGED:
    {
        RECT rc;
        HDWP hDWP;
        if( hDWP = BeginDeferWindowPos(3) ) {
            GetClientRect(hWnd, &rc);
            hDWP = DeferWindowPos(hDWP, g_hwndStatic[0], NULL, 2, 2, rc.right/2, rc.bottom/2, SWP_NOZORDER | SWP_NOREDRAW);
            hDWP = DeferWindowPos(hDWP, g_hwndStatic[1], NULL, 2, rc.bottom/2, rc.right/2, rc.bottom/2, SWP_NOZORDER | SWP_NOREDRAW);
            hDWP = DeferWindowPos(hDWP, g_hwndStatic[2], NULL, rc.right/2, 2, rc.right/2, rc.bottom/2, SWP_NOZORDER | SWP_NOREDRAW);
            EndDeferWindowPos(hDWP);
            RedrawWindow(hWnd, NULL, NULL, RDW_INVALIDATE | RDW_ALLCHILDREN | RDW_ERASE | RDW_NOFRAME | RDW_UPDATENOW);
        }
    }
    break;
 
    case WM_PAINT:
        OnPaint(hWnd);
        break;
    case WM_CLOSE:
        DestroyWindow(hWnd);
        break;
    case WM_DESTROY:
        PostQuitMessage(0);
        break;
    default:
        retval = DefWindowProc(hWnd, uMsg, wParam, lParam);
        break;
    }
    return retval;
}
 
//
// Entry point.
//
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE, LPSTR, int)
{
    HWND hWnd=HWND_DESKTOP;
    WNDCLASSEX wcex = {
        sizeof(WNDCLASSEX), CS_VREDRAW | CS_HREDRAW, WndProc, 0, 0, hInstance,
        LoadIcon(NULL, IDI_APPLICATION), LoadCursor(NULL, IDC_ARROW),
        (HBRUSH)(COLOR_WINDOW + 1), NULL, GWndname, NULL,
    };
    ATOM Atom = RegisterClassEx(&wcex);
    if( NULL == Atom ) {
        Atom = RegisterClass((LPWNDCLASS)&wcex.style);
        if( NULL == Atom ) {
            MessageBox(hWnd, TEXT("Cannot RegisterClass"), GAppname, MB_OK | MB_ICONSTOP | MB_SETFOREGROUND | MB_TOPMOST);
            return EXIT_FAILURE;
        }
    }
    hWnd = CreateWindowEx(WS_EX_WINDOWEDGE, MAKEINTATOM(Atom), GAppname, WS_OVERLAPPEDWINDOW,
        ((GetSystemMetrics(SM_CXSCREEN) - 800) / 2), ((GetSystemMetrics(SM_CYSCREEN) - 600) / 2),
        800, 600, HWND_DESKTOP, NULL, hInstance, NULL);
    if( NULL == hWnd ) {
        MessageBox(HWND_DESKTOP, TEXT("Cannot CreateWindow"), GAppname, MB_OK | MB_ICONSTOP | MB_SETFOREGROUND | MB_TOPMOST);
        return EXIT_FAILURE;
    }
 
    ShowWindow(hWnd, SW_NORMAL);
    //ShowWindow(hWnd, SW_MAXIMIZE);
    UpdateWindow(hWnd);
 
    MSG Msg;
    ZeroMemory(&Msg, sizeof(MSG));
    while( GetMessage(&Msg, NULL, 0, 0) > 0 ) {
        TranslateMessage(&Msg);
        DispatchMessage(&Msg);
    }
    
    return (int)Msg.wParam;
}


Lissajous_Figures.zip
1
0 / 0 / 0
Регистрация: 22.03.2017
Сообщений: 3
25.03.2017, 14:04  [ТС]
stamp, Спасибо большое, разобралась)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.03.2017, 14:04
Помогаю со студенческими работами здесь

Программа рисования фигур Лиссажу
Всем привет,только начал изучать программу,помогите сделать задание в Delphi Разработать программу рисования фигур Лиссажу, описываемых...

Нарисовать фигуру Лиссажу
Помогите срочно ребят,Нужно нарисовать фигуру Лиссажу в C#,центр которой находжится в начале координат.

Даны несколько фигур. При пересечении этих фигур образуются области, обозначенные цифрами на рисунке к каж
Даны несколько фигур. При пересечении этих фигур образуются области, обозначенные цифрами на рисунке к каждому варианту. Необходимо...

Нарисовать десять фигур
Нарисовать картинку, которая должна иметь содержание и 10 фигур.

Нарисовать рыбу из простейших фигур
Нужно было решить задание: нарисовать рыбу из простейших фигур в паскале. Сначала я решила поискать в интернете,но, увы, ничего подходящего...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru