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

Функция kbhit - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Подсчет суммы компонентов классов http://www.cyberforum.ru/cpp/thread37613.html
Люди подскажите плз написал прогу: //--------------------------------------------------------------------------- #include <iostream> #pragma hdrstop using namespace std; //--------------------------------------------------------------------------- #pragma argsused
C++ сравнение двух лиц людей Здравствуйте! подскажите пожалуйста, есть ли в сети готовые библиотеки на Си или С++, которые выдают % схожести одного лица на другое(типа look.com) ? особенно интересно для ембедед. может кто уже занимался.(готов даже купить работающую) Спасибо! http://www.cyberforum.ru/cpp/thread37597.html
C++ Деревья (длина пути ...)
Используя очередь или стэк написать функцию, которая находит в непустом дереве Т длину (число ветвей) пути от корня до ближайшей вершины Е; если Е не входит в Т, за ответ принять -1. Буду очень благодарна за помощь, т.к. п о деревьям мало что понимаю))))
C++ Разработать собственные функции динамического распределения памяти
Разработать собственные функции динамического распределения памяти, используя в качестве “кучи” динамический массив, создаваемый обычной функцией распределения памяти (malloc). Разработанная функция my_malloc должна возвращать указатель на выделенную область, причем в память перед указателем должен быть записан размер выделенной области, необходимый при ее возвращении, либо сохранена другая...
C++ Задание по структурам и классам http://www.cyberforum.ru/cpp/thread36896.html
Есть вот такой код: #include "stdafx.h" #include <iostream> #include <iomanip> #include <conio.h> #include <string.h> #include <fstream> using namespace std; void Choice(); char buff;
C++ Функция с переменным числом параметров Вычисление суммы ряда значений оформить в виде функции с переменным числом параметров. прога вот: В ней не хватает как рас функции с переменным числом параметров Как эту функцию задать?? Подскажите пожалуйста! подробнее

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

Функция kbhit - C++

03.06.2009, 17:09. Просмотров 5189. Ответов 8
Метки (Все метки)

Это опять я
Не работает kbhit
Нужно, чтобы во время рисования кривой Гильберта большого порядка пользователь имел возможность остановить рисование
Вот исходный код
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
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<math.h>
#include<dos.h>
#include <graphics.h>
 
#define del 30 //задержка
 
//Округление вещественных чисел до целых
int round (float a)
{
    return (int) floor (a+0.5);
}
 
//Прототипы функций, используемых до определения
void G2(int,int); void G3(int,int);
 
// Прорисовка линий-связок
//0-вверх, 1-вниз, 2- вправо, 3-влево
void L0 (int n)
{
    linerel (0,-n);
}
void L1 (int n)
{
    linerel (0,n);
}
void L2 (int n)
{
    linerel (n,0);
}
void L3 (int n)
{
    linerel (-n,0);
}
 
//Прорисовка кривых Гильберта остальных порядков, цифры обозначают те же направления
void G0 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G2(i-1,n);    L0(n);
    G0(i-1,n);    L2(n);
    G0(i-1,n);    L1(n);
    G3(i-1,n);    delay(del);
    }
}
void G1 (int i,int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G3(i-1,n);    L1(n);
    G1(i-1,n);    L3(n);
    G1(i-1,n);    L0(n);
    G2(i-1,n);    delay(del);
    }
}
void G2 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G0(i-1,n);    L2(n);
    G2(i-1,n);    L0(n);
    G2(i-1,n);    L3(n);
    G1(i-1,n);    delay(del);
    }
}
void G3 (int i, int n) //i - порядок кривой Гильберта
{
    if (i>0)
    {
    G1(i-1,n);    L3(n);
    G3(i-1,n);    L1(n);
    G3(i-1,n);    L2(n);
    G0(i-1,n);    delay(del);
    }
}
 
 
 void main()
{
    clrscr();
 
 
    /* request auto detection */
   int gdriver = DETECT, gmode, errorcode;
   int x,y;
   int n, i,x0, y0,Hscr,Wscr,s, S;
   float SPr = 80;
 
 
 
       /* initialize graphics mode */
       initgraph(&gdriver, &gmode, "");
 
    Hscr = getmaxy();//Высота экрана
    Wscr = getmaxx();//Ширина экрана
 
    //Приветственное сообщение
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
    setcolor (14) ;
    outtextxy (150,220, "This program draws the Gilbert's curve ");
    setcolor (3);
    outtextxy (150, 300, "Press any key to continue ");
    getch();
    clrscr();
 
    setbkcolor(0);
 
    Again:setfillstyle(1,0);
    bar (0,0, 639,479);
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
    setcolor (14);
    //Вводим исходные данные
    do
    {
       outtextxy (30,30,"Vvedite porjadok krivoi ot 1 do 8");
       char ch = getch();
       i = ch - '0';
 
    }
    while (i<1 || i>8);
    clrscr();
 
    setfillstyle(1,0);
    bar (0,0, 639,479);
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
 
    //Находим сторону квадрата, в который будет вписана кривая и длину каждого деления кривой
    S = round( SPr/100 * Hscr);
    n = round( S/ (pow(2,i) - 1));
 
    //Находим координаты начальной точки кривой.
 
    x0=Wscr/2 - S/2;
    y0=Hscr/2 + S/2;
 
    //Курсор устанавливаем в начальную точку
    moveto(x0, y0);
 
    setcolor (12);
 
    //Рисуем соответствующий вариант кривой Гильберта
    do
    {
        G0(i,n);
    }
    while (!kbhit); // ВОТ ЭТА ШТУКА НЕ РАБОТАЕТ
 
    getch();
 
    setfillstyle(1,0);
    rectangle(1,1,639,479);
    bar(1,1,639,479);
    setcolor (4);
    rectangle(10,10,630,470);
    setcolor (3);
    rectangle(25,25,615,455);
    setcolor (14);
 
    outtextxy(220,235,"[1] -> Continue");
    outtextxy(220,245,"[2] -> Exit");
 
    char ch = getch();
 
    if(ch == '1')  // если продолжить
    {
        goto Again;
    }
 
    else
    closegraph();
 
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru