Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Написать программу, содержащую два потока, каждый из которых управляет движением одного из двух шаров - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Сбалансированное бинарное дерево поиска http://www.cyberforum.ru/cpp-beginners/thread1608122.html
Очень нужна помощь. Дали код для примера с деревом. Хоть и с комментариями, но не до конца понятен. Не могли бы подсказать: 1) какой порядок обхода в здесь представлен? Я так понимаю, что...
C++ Некомпилируется код с Opengl glut #include <windows.h> #include <gl\gl.h> #include <gl\glu.h> void RenderScene(void) { glClear(GL_COLOR_BOFFER_BIT); glFlush(); } void StupRC(void) http://www.cyberforum.ru/cpp-beginners/thread1608104.html
C++ Объясните вывод препроцессора
Обьясните, толковые люди, но подробно, почему вывод будет HelloWorldXY ? #include <iostream> #define X Hello #define Y World #define _CONCAT(A,B) #A #B #define CONCAT(A,B) _CONCAT(A,B)
Классы и агрегация C++
Всем привет. Ребята, может кто дать рабочие примеры агрегации в классах) Буду очень благодарен, а то гугл особых результатов не принес
C++ Программа, меняющая местами столбцы заданной матрицы в зависимости от суммы элементов столбца http://www.cyberforum.ru/cpp-beginners/thread1608085.html
Здравствуйте , помогите , пожалуйста :/ Задача состоит в том, чтобы написать такую программу, которая бы меняла местами столбцы матрицы, в зависимости от суммы элементов столбца. В порядке...
C++ Как изъять массив из функции после изменения? Добрый вечер, есть проблема... Есть функция в которую я передаю 4 параметра типа int, 2 массива и 2 их размера, мне нужно парные элементы из первого записать в пустой второй и потом как то изъять... подробнее

Показать сообщение отдельно
Геомеханик
623 / 430 / 310
Регистрация: 26.06.2015
Сообщений: 971
10.12.2015, 13:53
Вот набросал для windows.
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
#include <windows.h>
#include <math.h>
#define MAX_TS  2
#define TMR_ID  333
#ifdef _MSC_VER
#pragma warning(disable:4244)
#endif
int create_form(HINSTANCE hinst, LPCTSTR cln, LPCTSTR cap);
DWORD WINAPI thread_draw(LPVOID arg);
 
volatile BOOL g_done = FALSE;
HDC     g_hdc = NULL;
HBITMAP g_bmp = NULL;
SIZE    g_scr = {0L,0L};
 
struct circle {
    POINT  pos;
    LONG   coord;
    int    rad;
    BOOL   dir;
    double vel;
 
    circle(void){}
    circle(int x, int y, int r, BOOL d, double v){
        pos.x = x, pos.y = y;
        coord = 0L;
        rad   = r;
        dir   = d;
        vel   = 1.0 / v;
    }
};
 
int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE, LPSTR, int){
    return create_form(hInstance, TEXT("Cyberforum"), TEXT("Движение шаров"));
}
 
//функция потока
DWORD WINAPI thread_draw(LPVOID arg){
    circle* p = (circle*)arg;
    double  elaps;
    LONG    x, y, cent;
 
    cent = (p->dir) ? g_scr.cx : g_scr.cy;
    cent = cent / 2L - p->rad;
 
    while(! g_done){
        elaps = (double)GetTickCount() * p->vel;
 
        if(p->dir){
            x = p->pos.x + cent * sin(elaps);
            y = p->pos.y;
        } else {
            x = p->pos.x;
            y = p->pos.y + cent * cos(elaps);
        }
        InterlockedExchange(&p->coord, MAKELONG(x, y));
        Sleep(10);
    }
    return 0;
}
 
//обработчик
LRESULT CALLBACK WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam){
    int   x, y;
    HDC   hdc;
    RECT  rc;
    LONG  pos;
    DWORD i, id;
    HGDIOBJ old;
    circle* pc;
    static HANDLE thds[MAX_TS];
    static HBRUSH brush[MAX_TS];
    static circle cirs[MAX_TS];
 
    switch(msg){
    case WM_CREATE:
        hdc = GetDC(hwnd);
        GetClientRect(hwnd, &rc);
        g_scr.cx = rc.right;
        g_scr.cy = rc.bottom;
        cirs[0]  = circle((g_scr.cx - 20)/2, (g_scr.cy - 20)/2 + 10, 20, FALSE, 1100.);
        cirs[1]  = circle((g_scr.cx - 30)/2 + 15, (g_scr.cy - 30)/2, 30, TRUE, 940.);
        brush[0] = CreateSolidBrush(RGB(0, 0xFF, 0));
        brush[1] = CreateSolidBrush(RGB(0xFF, 0xFF, 0));
 
        for(i = 0; i < MAX_TS; ++i){
            thds[i] = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)thread_draw, 
                                  (LPVOID)&cirs[i], 0, &id);
            if(thds[i] == NULL){
                //PostQuitMessage(0);
                //return 0;
            }
        }
        g_hdc = CreateCompatibleDC(hdc);
        g_bmp = CreateCompatibleBitmap(hdc, g_scr.cx, g_scr.cy);
        SelectObject(g_hdc, g_bmp);
        ReleaseDC(hwnd, hdc);
        SetTimer(hwnd, TMR_ID, 30, NULL);
        break;
    case WM_ERASEBKGND:
        PatBlt(g_hdc, 0, 0, g_scr.cx, g_scr.cy, BLACKNESS);
 
        for(i = 0; i < MAX_TS; ++i){
            pc  = &cirs[i];
            pos = pc->coord;
            x   = (int)LOWORD(pos);
            y   = (int)HIWORD(pos); 
            old = SelectObject(g_hdc, brush[i]);
            Ellipse(g_hdc, x - pc->rad, y - pc->rad, x + pc->rad, y + pc->rad);
            SelectObject(g_hdc, old);
        }
        BitBlt((HDC)wParam, 0, 0, g_scr.cx, g_scr.cy, g_hdc, 0, 0, SRCCOPY);
        return 1;
    case WM_TIMER:
        InvalidateRect(hwnd, NULL, TRUE);
        break;
    case WM_DESTROY:
        KillTimer(hwnd, TMR_ID);
        g_done = TRUE;
        WaitForMultipleObjects(MAX_TS, thds, TRUE, INFINITE);
        for(i = 0; i < MAX_TS; ++i){
            DeleteObject(brush[i]);
            CloseHandle(thds[i]);
        }
        DeleteObject(g_bmp);
        DeleteDC(g_hdc);
        PostQuitMessage(0);
        break;
    default:
        return DefWindowProc(hwnd, msg, wParam, lParam);
    }
    return 0;
}
 
//создание формы
int create_form(HINSTANCE hinst, LPCTSTR cln, LPCTSTR cap){
    MSG   msg;
    HWND  hwnd;
    WNDCLASSEX wcl = {0};
    wcl.cbSize        = sizeof(wcl); 
    wcl.lpfnWndProc   = (WNDPROC)WndProc;
    wcl.hInstance     = hinst;
    wcl.hCursor       = LoadCursor(NULL, IDC_ARROW);
    wcl.lpszClassName = cln;
    if(! RegisterClassEx(&wcl)) 
        return FALSE;
 
    hwnd  = CreateWindowEx(0, cln, cap, WS_OVERLAPPEDWINDOW & ~(WS_SIZEBOX | WS_MAXIMIZEBOX), 
                           CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hinst, NULL);
    if(hwnd == NULL) {
        UnregisterClass(cln, hinst);
        return FALSE;
    }
    ShowWindow(hwnd, SW_SHOW);
    UpdateWindow(hwnd);
 
    while(GetMessage(&msg, NULL, 0, 0)){
        TranslateMessage(&msg);
        DispatchMessage(&msg);
    }
    UnregisterClass(cln, hinst);
    return 0;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru