Вывод в Windows Forms
04.04.2017, 19:11. Показов 1966. Ответов 0
Здравствуйте! Есть готовый проект (код частично написан с применением ООП) на C++, написанный в Visual Studio 2017. Возможно ли как-то вывод информацию не в консоль, а в окно Windows Form? Помогите пожалуйста)
Добавлено через 44 минуты
Кликните здесь для просмотра всего текста
| 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
| #include <iostream>
#include <windows.h>
using namespace std;
extern void printMenu();
extern void printCatalog();
extern void findMineral();
extern void addMineral();
extern int getNumber(int iMin, int iMax);
extern bool dataToFile(string filename);
extern bool dataFromFile(string filename);
BOOL SetConsoleAttrib(HANDLE _ConsoleOut, WORD wAttrib)
{
SetConsoleTextAttribute(_ConsoleOut, wAttrib);
CONSOLE_SCREEN_BUFFER_INFO csbi = {0};
GetConsoleScreenBufferInfo(_ConsoleOut, &csbi);
DWORD dw(0);
COORD cr = {0, 0};
return FillConsoleOutputAttribute(_ConsoleOut, wAttrib, csbi.dwSize.X * csbi.dwSize.Y, cr, &dw);
}
int main()
{
SetConsoleOutputCP(1251);
SetConsoleCP(1251);
bool exit = false;
dataFromFile("database");
while (true) {
printMenu();
HANDLE H = GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleAttrib(H, BACKGROUND_RED | BACKGROUND_GREEN | BACKGROUND_BLUE | BACKGROUND_INTENSITY);
switch (getNumber(1, 4)) {
case 1:
printCatalog();
break;
case 2:
findMineral();
break;
case 3:
addMineral();
break;
case 4:
exit = true;
break;
}
if (exit)
break;
}
dataToFile("database");
return 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
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
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
| #include <iostream>
#include <conio.h>
#include <string>
#include <windows.h>
#include <fstream>
#include <vector>
#include <algorithm>
#include "Mineral.h"
int Mineral::cmpfield;
vector <Mineral> pers;
void printMenu() {
std::cout << "1. Показать справочник\n";
std::cout << "2. Поиск\n";
std::cout << "3. Добавить\n";
std::cout << "4. Выход" << std::endl;
}
int getNumber(int iMin, int iMax) {
int number = iMin - 1;
while (true) {
cin >> number;
if ((number >= iMin) && (number <= iMax))
break;
else {
cout << "Повторите ввод" << endl;
cin.clear();
while (cin.get() != '\n') {
}
}
}
return number;
}
void sortCatalog(int field) {
Mineral::setCmpF(field);
sort(pers.begin(), pers.end());
}
void printCatalogPage(size_t pagenum) {
system("cls");
cout << "------------------------------------------------------------------------------------------------------------------------\n";
cout << " Название | Название (англ.) | Описание\n";
cout << "------------------------------------------------------------------------------------------------------------------------\n";
COORD point;
DWORD dw;
HANDLE H = GetStdHandle(STD_OUTPUT_HANDLE);
point.X = 0;
point.Y = 0;
FillConsoleOutputAttribute(H, BACKGROUND_RED | BACKGROUND_INTENSITY, 150, point, &dw);
point.Y = 1;
FillConsoleOutputAttribute(H, BACKGROUND_RED | BACKGROUND_INTENSITY, 150, point, &dw);
point.Y = 2;
FillConsoleOutputAttribute(H, BACKGROUND_RED | BACKGROUND_INTENSITY, 150, point, &dw);
size_t endh = pagenum * 10 + 10;
if (endh > pers.size())
endh = pers.size();
for (size_t n = (pagenum * 10); n < endh; n++) {
pers[n].Print();
}
cout << "------------------------------------------------------------------------------------------------------------------------\n";
cout << "Страница: " << pagenum + 1 << std::endl;
cout << "ESC - выход 1 - сортировка по названию 2 - по названию (англ.) PgUp - страница вверх PgDn - вниз" << endl;
}
void printCatalog() {
size_t s = pers.size() / 10;
bool stop = false;
size_t curpage = 0;
while (!stop) {
printCatalogPage(curpage);
int cmd = _getch();
if (cmd == 224)
cmd = _getch() + 1000;
switch (cmd) {
case 49:
sortCatalog(0);
curpage = 0;
break;
case 50:
sortCatalog(1);
curpage = 0;
break;
case 1073:
curpage--;
if (curpage > s)
curpage = 0;
break;
case 1081:
curpage++;
if (curpage > s)
curpage = s;
break;
case 27:
system("cls");
stop = true;
break;
}
}
}
int tolower_rus(int ch)
{
string alf = "АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЬЫЪЭЮЯ";
string alfl = "абвгдеёжзийклмнопрстуфхцчшщьыъэюя";
int pos = -1;
for (unsigned int i = 0; i < alf.size(); i++) {
if (alf[i] == ch) {
pos = i;
break;
}
}
if (pos == -1)
return ch;
return alfl[pos];
}
bool Match(string expr2, string val2) {
string expr = expr2;
string val = val2;
unsigned int i;
unsigned int j;
size_t ml;
size_t mv;
for (i = 0; i < expr.size(); i++) {
expr[i] = tolower_rus(expr[i]);
expr[i] = tolower(expr[i]);
}
for (i = 0; i < val.size(); i++) {
val[i] = tolower_rus(val[i]);
val[i] = tolower(val[i]);
}
i = 0;
j = 0;
ml = expr2.size();
mv = val2.size();
while (j < mv && i < ml) {
if (expr[i] == val[j]) {
i++;
j++;
}
else {
return false;
}//посимвольное не совпадение
}
if (j < mv)
return false;//выражение закончилось раньше чем строка
if (i < ml)
return false;//строка закончилась раньше чем выражение
return true;
}
void findMineral() {
system("cls");
cout << "Критерий поиска\n";
cout << "1. Название\n";
cout << "2. Название (англ.)\n";
cout << "3. Назад\n";
int vybor = getNumber(1, 3);
if (vybor < 3) {
string key;
string vkey;
bool found = false;
switch (vybor) {
case 1:
cout << "Введите название: ";
break;
case 2:
cout << "Введите название (англ.): ";
break;
case 3:
system("cls");
break;
}
cin >> key;
system("cls");
unsigned int n = 0;
cout << "------------------------------------------------------------------------------------------------------------------------\n";
cout << " Название | Название (англ.) | Описание\n";
cout << "------------------------------------------------------------------------------------------------------------------------\n";
while (n < pers.size()) {
switch (vybor) {
case 1:
vkey = pers[n].GetName();
break;
case 2:
vkey = pers[n].GetNameEN();
break;
case 3:
vkey = pers[n].GetDescription();
break;
}
if (Match(key, vkey)) {
found = true;
pers[n].Print();
}
n++;
}
if (!found)
cout << "Минерала с названием '" << key << "' нет\n";
cout << "------------------------------------------------------------------------------------------------------------------------\n";
}
}
void addMineral() {
system("cls");
string sbuf;
Mineral bufPers;
cout << "Название: ";
cin >> sbuf;
bufPers.SetName(sbuf);
cout << endl;
cout << "Название (англ.): ";
cin >> sbuf;
bufPers.SetNameEN(sbuf);
cout << endl;
cout << "Описание: ";
cin >> sbuf;
bufPers.SetDescription(sbuf);
pers.push_back(bufPers);
}
bool dataToFile(string filename) {
MineralS sf;
ofstream fout(filename.c_str(), ios_base::out | ios_base::binary);
if (fout.is_open()) {
size_t size = pers.size();
fout.write((char *)&size, sizeof(int));
for (size_t i = 0; i < size; i++) {
memset(&sf, 0, sizeof(MineralS));
pers[i].toFileS(&sf);
fout.write((char *)&sf, sizeof(MineralS));
}
fout.close();
return true;
}
return false;
}
bool dataFromFile(string filename) {
int size;
MineralS sf;
ifstream fin(filename.c_str());
if (fin.is_open()) {
pers.clear();
fin.read((char*)&size, sizeof(int));
for (int i = 0; i < size; i++) {
Mineral tmp;
fin.read((char*)&sf, sizeof(MineralS));
tmp.fromFileS(&sf);
pers.push_back(tmp);
}
fin.close();
return true;
}
return false;
} |
|
Кликните здесь для просмотра всего текста
| 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
| #include "Mineral.h"
Mineral::Mineral() {}
Mineral::~Mineral() {}
string Mineral::GetName() {
return mineName;
}
string Mineral::GetNameEN() {
return mineNameEN;
}
string Mineral::GetDescription() {
return mineDescription;
}
void Mineral::SetName(string name) {
mineName = name;
}
void Mineral::SetNameEN(string nameEN) {
mineNameEN = nameEN;
}
void Mineral::SetDescription(string description) {
mineDescription = description;
}
void Mineral::Print() {
printf(" %-29.29s| %-29.29s| %-56.56s\n", mineName.c_str(), mineNameEN.c_str(), mineDescription.c_str());
}
void Mineral::toFileS(MineralS *sf) {
size_t size = mineName.size();
if (size > 29)
size = 29;
memcpy((void *)sf->Name, (void *)mineName.c_str(), size + 1);
size = mineNameEN.size();
if (size > 29)
size = 29;
memcpy((void *)sf->NameEN, (void *)mineNameEN.c_str(), size + 1);
size = mineDescription.size();
if (size > 255)
size = 255;
memcpy((void *)sf->Description, (void *)mineDescription.c_str(), size + 1);
}
void Mineral::fromFileS(MineralS *sf) {
mineName = sf->Name;
mineNameEN = sf->NameEN;
mineDescription = sf->Description;
}
bool Mineral::operator<(Mineral a) {
switch (Mineral::cmpfield) {
case 0:
return mineName < a.mineName;
case 1:
return mineNameEN < a.mineNameEN;
}
return false;
}
bool Mineral::operator>(Mineral a) {
switch (Mineral::cmpfield) {
case 0:
return mineName > a.mineName;
case 1:
return mineNameEN > a.mineNameEN;
}
return false;
}
bool Mineral::operator==(Mineral a) {
switch (Mineral::cmpfield) {
case 0:
return mineName == a.mineName;
case 1:
return mineNameEN == a.mineNameEN;
}
return false;
}
void Mineral::setCmpF(int cf) {
cmpfield = cf;
}
int Mineral::getCmpF() {
return cmpfield;
} |
|
| 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
| #ifndef __MINERAL_H__
#define __MINERAL_H_
#include <string>
using namespace std;
struct MineralS
{
char Name[30];
char NameEN[30];
char Description[256];
};
class Mineral {
public:
Mineral();
~Mineral();
string GetName();
string GetNameEN();
string GetDescription();
void SetName(string name);
void SetNameEN(string nameEN);
void SetDescription(string description);
void Print();
void toFileS(MineralS *sf);
void fromFileS(MineralS *sf);
bool operator<(Mineral a);
bool operator>(Mineral a);
bool operator==(Mineral a);
static void setCmpF(int cf);
static int getCmpF();
private:
string mineName;
string mineNameEN;
string mineDescription;
static int cmpfield;
};
#endif |
|
Добавлено через 1 минуту
Кликните здесь для просмотра всего текста
| 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
| #ifndef __MINERAL_H__
#define __MINERAL_H_
#include <string>
using namespace std;
struct MineralS
{
char Name[30];
char NameEN[30];
char Description[256];
};
class Mineral {
public:
Mineral();
~Mineral();
string GetName();
string GetNameEN();
string GetDescription();
void SetName(string name);
void SetNameEN(string nameEN);
void SetDescription(string description);
void Print();
void toFileS(MineralS *sf);
void fromFileS(MineralS *sf);
bool operator<(Mineral a);
bool operator>(Mineral a);
bool operator==(Mineral a);
static void setCmpF(int cf);
static int getCmpF();
private:
string mineName;
string mineNameEN;
string mineDescription;
static int cmpfield;
};
#endif |
|
0
|