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

Движение прямоугольника по треугольному контуру. Как изменить цвет при смене направления? - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Создать абстрактный базовый класс с виртуальными методами вычисления функции y в заданной точке х http://www.cyberforum.ru/cpp-beginners/thread744844.html
создать абстрактный базовый класс function с виртуальными методами вычисления ф-ции y=f(x) в заданной точке х и вывода результата на экран. определить производные классы Ellipse Hyperbola с...
C++ Программа, сортирующая слова в порядке частоты встречаемости Задание: Напишите программу, которая печатает отдельные слова, поступающие на ввод, отсортированными в порядке частоты встречаемости. Входные данные представить в виде двоичного дерева, узел... http://www.cyberforum.ru/cpp-beginners/thread744843.html
Deprecated in C++11, Function objects C++
У меня возник небольшой вопрос по поводу некоторых функциональных объектов в С++11. Вот здесь http://en.cppreference.com/w/cpp/utility/functional такие классы как unary_function, binary_function и...
Написать программу, определяющую местоположение улитки C++
Каждый солнечный день улитка, сидящая на дереве, поднимается вверх на 2 см, а каждый пасмурный день опускается вниз на 1 см. В начале наблюдения улитка находилась в А см от земли на В метровом...
C++ замена предложений http://www.cyberforum.ru/cpp-beginners/thread744800.html
Всем доброго времени суток!!! есть задача: Написать программу, которая считывает текст из файла и выводит не экран сначала предложения, начинающиеся с однобуквенных слов, а затем все остальные....
C++ Дан массив A[N] .Записать в массив В элементы массива, имеющие четные индексы, а в массив С элементы, имеющие нечетные индексы. Дан массив A .Записать в массив В элементы массива, имеющие четные индексы, а в массив С элементы, имеющие нечетные индексы. Заранее Благодарен. подробнее

Показать сообщение отдельно
Kirimi
0 / 0 / 0
Регистрация: 24.12.2012
Сообщений: 7

Движение прямоугольника по треугольному контуру. Как изменить цвет при смене направления? - C++

24.12.2012, 22:41. Просмотров 459. Ответов 0
Метки (Все метки)

Здравствуйте. Помогите пожалуйста с лабораторной работой.
Движение прямоугольника по треугольному контуру,
цвет прямоугольника должен меняться при смене направления движения. Подскажите пожалуйста, как сделать эту смену цвета.

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
//Движение прямоугольника по треугольному контуру.
//Динамические объекты.
#include <conio.h>
#include <graphics.h>
#include <iostream.h>
#include <process.h>
#include <string.h>
#include <dos.h>
 
class graphworld
  {int driver,mode,grerror,colb,bkcl;
   char path[80];
   public:
     graphworld();
     void closegraphworld();
  };
 
graphworld::graphworld()
  {strcpy(path,"c:\\turboc30\\bgi");
   driver=0;
   initgraph(&driver,&mode,path);
   grerror=graphresult();
   if(grerror!=grOk)
     {cout<<"\nОшибка открытия графического режима";
      abort;
     }
   setcolor(RED);
   setbkcolor(BLACK);
   cleardevice();
  }
 
void graphworld::closegraphworld()
     {cleardevice();
      closegraph();
     }
 
class location
   {protected:
      int x,y;
    public:
      location(int initx,int inity);
      int getx();
      int gety();
   };
 
location::location(int initx, int inity)
  {x=initx;
   y=inity;
  }
 
int location::getx()
  {return x;
  }
 
int location::gety()
  {return y;
  }
 
class point:public location
  {protected:
     int visible;
     void setvisible(int pr);
   public:
     point(int initx,int inity);
     ~point();
     virtual void show();
     virtual void hide();
     int getvisible();
     void moveto(int nx,int ny);
   };
 
point::point(int initx,int inity):location(initx,inity)
       {
       }
 
point::~point()
       {hide();
       }
 
void point::moveto(int nx,int ny)
     {hide();
      x=nx;
      y=ny;
      show();
     }
 
void point::setvisible(int pr)
     {visible=pr;
     }
 
void point::show()
     {putpixel(x,y,getcolor());
      setvisible(1);
     }
 
void point::hide()
     {putpixel(x,y,getbkcolor());
      setvisible(0);
     }
 
class pramoug:public point
   {int dx,dy;
    public:
      pramoug(int initx,int inity,int initdx,int initdy);
     ~pramoug();
     void show();
     void hide();
   };
 
pramoug::pramoug(int initx,int inity,int initdx,int initdy): point(initx,inity)
     {dx=initdx;
      dy=initdy;
     }
 
void pramoug::show()
     {line(x,y,x,y+dy);
      line(x,y+dy,x+dx,y+dy);
      line(x+dx,y+dy,x+dx,y);
      line(x,y,x+dx,y);
     }
 
void pramoug::hide()
     {int r;
      r=getcolor();
      setcolor(getbkcolor());
      line(x,y,x,y+dy);
      line(x,y+dy,x+dx,y+dy);
      line(x+dx,y+dy,x+dx,y);
      line(x,y,x+dx,y);
      setcolor(r);
     }
 
pramoug::~pramoug()
     {hide();
     }
 
void main(void)
{graphworld world;
 pramoug *pt;
 int x,y;
 getch();
 cleardevice();
 x = 150;
 y = 100;
 pt = new pramoug(x,y,200,100);
 delay(750);
 pt -> show();
 do
   {do
      {x += 3; y++;
       pt -> moveto(x,y);
       delay(5);
      }
    while(!(y >= 200));
    do
      {x--; y++;
       pt -> moveto(x,y);
       delay(5);
      }
    while(!(y >= 400));
    do
      {x--; y -= 3;
       pt -> moveto(x,y);
       delay(5);
      }
    while(!(y <= 100));
   }
 while(!(kbhit()));
 delete pt;
 getch();
 world.closegraphworld();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru