Subversion Repositories Kolibri OS

Rev

Rev 2749 | Rev 2751 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1114 leency 1
#include "func.h"
2
#include "parser.h"
990 barsuk 3
#include "calc.h"
1114 leency 4
#include "use_library.h"
5
 
2749 leency 6
#define TABLE_VERSION "0.97"
1114 leency 7
 
8
// строки, которые выводит программа
9
const char *sFileSign = "KolibriTable File\n";
10
const char sFilename[] = "Filename: ";
11
const char sSave[] = "Save";
12
const char sLoad[] = "Load";
13
const char sNew[] = "New";
14
 
15
const char er_file_not_found[] = "Cannot open file. ";
16
const char er_format[] = "Error: bad format. ";
17
const char msg_save[] = "File saved. ";
18
const char msg_load[] = "File loaded. ";
19
const char msg_new[] = "Memory cleared. ";
20
 
21
// свой PID
22
Dword myPID = -1;
23
 
24
// начальные размеры
25
#define WND_W 550
26
#define WND_H 400
27
// новые размеры и координаты
28
int wi = WND_W, he = WND_H;
29
int win_x, win_y;
30
 
31
// цвета элементов интерфейса
32
#define GRID_COLOR 0xa0a0a0
33
#define TEXT_COLOR 0x000000
34
#define CELL_COLOR 0xffffff
35
#define SEL_CELL_COLOR 0xe0e0ff
36
#define FIXED_CELL_COLOR 0xe0e0ff
37
#define SEL_FIXED_CELL_COLOR 0x758FC1
38
#define TEXT_SEL_FIXED_COLOR 0xffffff
39
 
40
#define SCROLL_BAR_WIDTH 16
41
#define SCROLL_BAR_HEIGHT 16
42
 
43
// ID кнопок
44
#define FILENAME_BUTTON 0x10
45
#define SAVE_BUTTON 0x11
46
#define LOAD_BUTTON 0x12
47
#define NEW_BUTTON 0x13
48
#define DRAG_BUTTON 0x20
49
 
50
#define SCROLL_LEFT_BUTTON 0x21
51
#define SCROLL_RIGHT_BUTTON 0x22
52
#define SCROLL_UP_BUTTON 0x23
53
#define SCROLL_DOWN_BUTTON 0x24
54
#define SCROLL_WIDTH 0x25
55
#define SCROLL_HEIGHT 0x26
56
 
57
#define COL_BUTTON 0x100
58
#define ROW_BUTTON (COL_BUTTON + 0x100)
59
#define COL_HEAD_BUTTON (ROW_BUTTON + 0x100)
60
#define ROW_HEAD_BUTTON (COL_HEAD_BUTTON + 0x100)
61
#define CELL_BUTTON (ROW_HEAD_BUTTON + 0x100)
62
 
63
 
64
// нижняя панель с кнопками и полем ввода
65
#define MENU_PANEL_HEIGHT 40
66
Dword panel_y = 0;
1218 Lrz 67
Dword mouse_dd;
68
// для поля ввода
1114 leency 69
 
990 barsuk 70
char edit_text[256] = "";
1218 Lrz 71
edit_box cell_box = {0,9*8-5,WND_H - 16-32,0xffffff,0x6a9480,0,0x808080,0,255,(dword)&edit_text,(dword)&mouse_dd,0};
1114 leency 72
 
73
// ячейки - их параметры и текст
74
DWORD def_col_width = 80, def_row_height = 16;
75
DWORD col_count = 200, row_count = 100;
76
DWORD *col_width, *row_height;
77
char ***cells;
78
char ***values;	// значения формул, если есть
79
 
80
bool display_formulas = 0;	// отображать ли формулы вместо значений
81
 
82
// координаты отображаемых столбцов и строк
83
DWORD *col_left, *row_top;
84
 
85
// буфер обмена
86
char ***buffer = NULL;
87
DWORD buf_col, buf_row;
88
DWORD buf_old_x, buf_old_y;
89
 
90
// это координаты ячейки, отображаемой в ЛВ угле
91
DWORD scroll_x = 1, scroll_y = 1;
92
// это выделенная ячейка
93
DWORD sel_x = 1, sel_y = 1;
94
DWORD prev_x = 0, prev_y = 0;	// предыдущая выделенная
95
int was_single_selection = 0;
96
 
97
// конец выделения если выделено несколько ячеек
98
DWORD sel_end_x = sel_x, sel_end_y = sel_y;
99
 
100
// флаг
101
bool sel_moved = 0;
102
bool sel_end_move = 0;
103
bool window_drawall = false;
104
// сколько ячеек помещается в окне по х и у
105
DWORD nx = 0, ny = 0;
106
 
107
// флаг реадктирования ячейки
990 barsuk 108
//bool is_edit = 0;
109
#define ed_focus 2
1114 leency 110
#define is_edit (cell_box.flags & ed_focus)
111
 
112
// редактирование имени файла
113
bool fn_edit = 0;
990 barsuk 114
char fname[256];
1218 Lrz 115
edit_box file_box = {0,9*8-5,WND_H - 16-32,0xffffff,0x6a9480,0,0x808080,0,255,(dword)&fname,(dword)&mouse_dd,0};
1114 leency 116
 
117
// изменение размеров
118
#define SIZE_X 1 // состояние
119
#define SIZE_Y 2
120
#define SIZE_SELECT 3
121
#define SIZE_DRAG 4
1112 barsuk 122
int size_mouse_x, size_mouse_y, size_id, size_state = 0;
123
 
1114 leency 124
int window_is_dragged = 0; // сейчас перетаскивается окно
125
 
126
// растаскивание ячейки при ее тащении за правый нижний угол, с заполнением ячеек
127
int drag_x, drag_y;
128
int old_end_x, old_end_y;
129
 
130
void draw_window();
131
 
990 barsuk 132
//edit_box ebox = {250,14,35,0xffffff,0x6f9480,0,0xAABBCC,0,248,0,2,20,20};
133
 
134
void kos_DrawRegion(Word x, Word y,Word width, Word height, Dword color1, Word invert)
135
{
136
	kos_DrawLine(x,y,x+width-2,y,color1,invert);
137
	kos_DrawLine(x,y+1,x,y+height-1,color1,invert);
138
	kos_DrawLine(x+width-1,y,x+width-1,y+height-2,color1,invert);
139
	kos_DrawLine(x+1,y+height-1,x+width-1,y+height-1,color1,invert);
1114 leency 140
}
141
 
142
void start_edit(int x, int y)
143
{
144
 
145
	int ch = 0;
146
	if (x < scroll_x || x > nx - 1)
147
	{
148
		scroll_x = x;
149
		ch = 1;
150
	}
151
	if (y < scroll_y || y > ny - 1)
152
	{
153
		scroll_y = y;
154
		ch = 1;
155
	}
156
	if (ch)
157
	{
158
		sel_moved = 1;
990 barsuk 159
		draw_window();
160
	}
161
 
1114 leency 162
	file_box.flags &= ~ed_focus;
163
 
164
	cell_box.flags |= ed_focus;
165
	cell_box.left = col_left[x] + 1;
166
	cell_box.top = row_top[y] + 1;
167
	cell_box.width = col_width[x] - 2;
990 barsuk 168
	//cell_box.height= row_height[y];
1114 leency 169
	memset((Byte*)edit_text, 0, sizeof(edit_text));
990 barsuk 170
	if (cells[x][y])
1114 leency 171
	{
172
		strcpy(edit_text, cells[x][y]);
990 barsuk 173
		edit_text[strlen(cells[x][y]) - 1] = '\0';
174
	}
175
	cell_box.pos = cell_box.offset = 0;
1114 leency 176
 
177
	draw_window();
178
}
179
 
180
void stop_edit()
181
{
182
	if (is_edit)
183
	{
184
		cell_box.flags &= ~ed_focus;
185
		if (cells[sel_x][sel_y])
186
			freemem(cells[sel_x][sel_y]);
187
		if (strlen(edit_text) > 0)
188
		{
189
			cells[sel_x][sel_y] = (char*)allocmem(strlen(edit_text)+1);
190
			strcpy(cells[sel_x][sel_y], edit_text);
191
		}
192
		else
193
			cells[sel_x][sel_y] = NULL;
194
		//memset((Byte*)edit_text,0, 256);
990 barsuk 195
		calculate_values();
1114 leency 196
	}
197
}
198
 
199
void cancel_edit()
200
{
201
	if (!is_edit)
202
		return;
203
	cell_box.flags &= ~ed_focus;
204
	memset((Byte*)edit_text,0, 256);
990 barsuk 205
	draw_window();
1114 leency 206
}
207
 
208
void check_sel()
209
{
210
	DWORD sx0=scroll_x, sy0=scroll_y;
211
 
212
	if (sel_x >= nx - 1  /*&& sel_x < col_count - nx + scroll_x + 1*/)
213
		//if (sel_x == nx)
214
			scroll_x++;
215
		//else
216
		//	scroll_x = sel_x;
217
	if (sel_y >= ny - 1 /*&& sel_y < row_count - ny + scroll_y */)
218
		//if (sel_y == ny)
219
			scroll_y++;
220
		//else
221
		//	scroll_y = sel_y;
222
 
223
	if (sel_x < scroll_x)
224
		scroll_x = sel_x;
225
	if (sel_y < scroll_y)
226
		scroll_y = sel_y;
227
 
228
	if (sx0 != scroll_x || sy0 != scroll_y)
229
		sel_moved = 0;			// надо перерисовать все
230
 
231
}
232
 
233
// сдвинуть выделение
234
void move_sel(DWORD new_x, DWORD new_y)
235
{
236
	sel_moved = 1;
237
	stop_edit();
238
	prev_x = sel_x;
239
	prev_y = sel_y;
240
	sel_x = new_x;
241
	if (sel_x < 1)
242
		sel_x = 1;
243
	if (sel_x > col_count - 1)
244
		sel_x = col_count - 1;
245
	sel_end_x = sel_x;
246
	sel_y = new_y;
247
	if (sel_y < 1)
248
		sel_y = 1;
249
	if (sel_y > row_count - 1)
250
		sel_y = row_count - 1;
251
	sel_end_y = sel_y;
252
	check_sel();
253
	draw_window();
254
}
255
 
256
void draw_custom_button(int x0, int y0, int sx, int sy, int blue_border)
257
{
258
	int x1 = x0 + sx;
259
	int y1 = y0 + sy;
260
 
261
	if (blue_border) kos_DrawRegion(x0-1, y0-1, sx+3, sy+3, 0x94aece, 0);
262
 
263
	// серый прямоугольник
264
 
265
	kos_DrawBar(x0 + 1, y0 + 1, sx - 1, sy - 1, 0xe4dfe1);
266
 
267
	// две белые линии: сверху и слева
268
 
269
	kos_DrawLine(x0, y0, x1, y0, 0xffffff, 0);
270
	kos_DrawLine(x0, y0, x0, y1, 0xffffff, 0);
271
 
272
	// две серые линии: снизу и справа
273
	kos_DrawLine(x0, y1, x1, y1, 0xc7c7c7, 0);
274
	kos_DrawLine(x1, y0, x1, y1, 0xc7c7c7, 0);
275
}
276
 
277
// x - между low и high ? - необязательно low
278
bool is_between(Dword x, Dword low, Dword high)
279
{
280
	return ((low= low && x <= high):(x >= high && x <= low));
281
}
282
 
283
void clear_cell_slow(int px, int py)
284
{
285
	int i;
286
	int x0 = col_width[0];
287
	for (i = scroll_x; i < px; i++)
288
	{
289
		x0 += col_width[i];
290
	}
291
	int x1 = x0;
292
	x1 += col_width[px];
293
	int y0 = row_height[0];
294
	for (i = scroll_y; i < py; i++)
295
	{
296
		y0 += row_height[i];
297
	}
298
	int y1 = y0;
299
	y1 += row_height[py];
300
	kos_DrawBar(x0 + 1, y0 + 1, x1 - x0 - 1, y1 - y0 - 1, 0xffffff);
301
}
302
 
303
//debug
304
const int debugcolor[10]={0xff0000,0x00ff00,0x0000ff,0xffff00,0x00ffff,0xff00ff,0x800000,0x008000,0x000080,0x800080};
305
int debugc=0;
306
 
307
// рисование ячеек
308
#define is_x_changed(v) ((v) == sel_x || (v) == prev_x)
309
#define is_y_changed(v) ((v) == sel_y || (v) == prev_y)
310
 
311
void draw_grid()
312
{
313
	int i,j;
314
	long x0 = 0, y0 = 0, x = 0, y = 0, dx, popravka;
315
	DWORD text_color;
316
	//int lx, ly;
317
 
318
//	sprintf(debuf, "%U,%U", scroll_x, scroll_y);
319
//	rtlDebugOutString(debuf);
320
 
321
	nx=ny=0;
322
 
323
	// очистить область около выделенной ячейки
324
	if (sel_moved)
325
	{
326
		clear_cell_slow(sel_x, sel_y);
327
		clear_cell_slow(prev_x, prev_y);
328
	}
329
	else
330
	{
331
		// очистить всю область ячеек
332
		//kos_DrawBar(col_width[0]+1, row_height[0]+1, wi - SCROLL_BAR_WIDTH-col_width[0]-1, he - SCROLL_BAR_HEIGHT-row_height[0]-1, 0xffffff);
333
	}
334
 
335
	col_left[0] = 0;
336
	// ячейки - заголовки столбцов + вертикальные линии
337
	x = col_width[0];
338
	nx = 1;
339
	for (i = 1; i < col_count; i++)
340
	{
341
		col_left[i] = -1;
342
		if (i >= scroll_x)
343
		{
344
			{
345
				if (!sel_moved || is_x_changed(i))
346
					kos_DrawLine(x-x0, 0, x-x0, row_height[0], GRID_COLOR, 0);
347
			// и заголовок ячейки по х
348
				text_color = TEXT_COLOR;
349
				dx = (col_width[i]-6)/2;
350
				int dy = (row_height[0] - 8) / 2 + 1;
351
				int cur_width = col_width[i] - 1;
352
				if (cur_width + x - x0 > wi - SCROLL_BAR_WIDTH)
353
					cur_width = wi - SCROLL_BAR_WIDTH - x + x0;
354
				if (!sel_moved || (is_x_changed(i)))
355
					if (is_between(i,sel_x,sel_end_x))
356
					{
357
						kos_DrawBar(x - x0 + 1,0,cur_width,row_height[0],SEL_FIXED_CELL_COLOR); //0x0000CC
358
						text_color = TEXT_SEL_FIXED_COLOR;
359
					}
360
					else
361
					{
362
						kos_DrawBar(x - x0 + 1,0,cur_width,row_height[0],FIXED_CELL_COLOR);
363
						text_color = TEXT_COLOR;
364
					}
365
				if (!sel_moved || (is_x_changed(i))) kos_WriteTextToWindow(x-x0+2+dx,dy,0,text_color,cells[i][0],strlen(cells[i][0]));
366
 
367
				// есть кнопка стоблца и еще кнопка изменения ширины
368
				if (x - x0 + col_width[i] <= wi - col_width[0])
2749 leency 369
				{
370
					//kos_DeleteButton(COL_HEAD_BUTTON+i);
1114 leency 371
					kos_DefineButton(x-x0+5,0,cur_width - 10,row_height[0]-1,0x60000000+COL_HEAD_BUTTON+i,0);
2749 leency 372
				}
1114 leency 373
				//kos_DefineButton(x-x0+col_width[i]-10,0,15,row_height[0]-1,0x60000000+COL_SIZE_BUTTON+i,0);
374
				col_left[i] = x - x0;
375
			}
376
			if (x - x0 > wi - col_width[0])
377
			{
378
				x += col_width[i];
379
				nx++;
380
				break;
381
			}
382
		}
383
		else
384
		{
385
			x0 += col_width[i];
386
		}
387
		x += col_width[i];
388
		nx++;
389
	}
390
 
391
	//kos_DefineButton(0,0,0,0,0x80000000+COL_HEAD_BUTTON+i,0);
392
 
393
	for (j = i + 1; j < col_count; j++)
394
		col_left[j] = wi;
395
	//if (!sel_moved || (is_x_changed(nx))) kos_DrawLine(x - x0, 0, x - x0, he, GRID_COLOR, 0);
396
 
397
	// ячейки - заголовки строк + горизонт. линии
398
	y = row_height[0];
399
	ny = 1;
400
	row_top[0] = 0;
401
	for (i = 1; i < row_count && y - y0 < he - 10; i++)
402
	{
403
		row_top[i] = -1;
404
		if (i >= scroll_y)
405
		{
406
			{
407
				if (!sel_moved || (is_y_changed(i)))
408
					kos_DrawLine(0, y - y0, wi - SCROLL_BAR_WIDTH, y - y0, GRID_COLOR, 0);
409
				// и заголовок ячейки по y
410
				text_color = TEXT_COLOR;
411
				dx = (col_width[0]-6 * strlen(cells[0][i]))/2;	// optimize this, change strlen
412
				int dy = (row_height[i] - 8) / 2 + 1;
413
				if (!sel_moved || (is_y_changed(i)))
414
					if (is_between(i,sel_y,sel_end_y))
415
					{
416
						kos_DrawBar(0,y-y0+1,col_width[0],row_height[i] - 1,SEL_FIXED_CELL_COLOR);
417
						text_color = TEXT_SEL_FIXED_COLOR;
418
					}
419
					else
420
					{
421
						kos_DrawBar(0,y-y0+1,col_width[0],row_height[i] - 1,FIXED_CELL_COLOR);
422
						text_color = TEXT_COLOR;
423
					}
424
 
425
				if (!sel_moved || (is_y_changed(i)))
426
					kos_WriteTextToWindow(2+dx,y-y0+dy,0,text_color,cells[0][i],strlen(cells[0][i]));
427
 
2749 leency 428
 
1114 leency 429
				kos_DefineButton(0,y-y0+5,col_width[0]-1,row_height[i]-6,0x60000000+ROW_HEAD_BUTTON+i,0);
430
				//kos_DefineButton(0,y-y0+row_height[i]-5,col_width[0]-1,10,0x60000000+ROW_SIZE_BUTTON+i,0);
431
				row_top[i] = y - y0;
432
			}
433
		}
434
		else
435
		{
436
			y0 += row_height[i];
437
		}
438
		y += row_height[i];
439
		ny++;
440
	}
441
 
442
	kos_DefineButton(0,0,0,0,0x80000000+ROW_HEAD_BUTTON+ny-1,0);
443
 
444
	for (j = i + 1; j < row_count; j++)
445
		row_top[j] = he;
446
	if (!sel_moved || (is_y_changed(ny)))
447
		kos_DrawLine(0, y - y0, wi - SCROLL_BAR_WIDTH, y - y0, GRID_COLOR, 0);
448
 
449
	if (!sel_moved || (is_x_changed(0) && is_y_changed(0)))
450
		kos_DrawBar(0,0,col_width[0],row_height[0],FIXED_CELL_COLOR);
451
	// ЛВ ячейка
452
 
453
	//sprintf(debuf, "%U, %U; %U, %U", x0, y0, nx, ny);
454
	//rtlDebugOutString(debuf);
455
 
456
//	popravka = (y - y0 < he - 10);
457
	//sprintf(debuf, "%U, %U", scroll_y, ny);
458
	//rtlDebugOutString(debuf);
459
 
460
 
461
	// сами ячейки
462
 
463
	y = row_height[0];
464
	for (i = scroll_y; i < ny; i++)
465
	{
466
		x = col_width[0];
467
		if (!sel_moved)
468
			kos_DrawBar(col_width[0]+1, y+1, wi - SCROLL_BAR_WIDTH-col_width[0]-1, row_height[i]-1, 0xffffff);
469
		for (j = scroll_x; j < nx-1; j++)
470
		{
471
			if (!sel_moved || is_x_changed(j) || is_y_changed(i))
472
				kos_DrawLine(col_left[j], row_top[i], col_left[j], row_height[i], GRID_COLOR, 0);
473
 
474
			// заголовки уже нарисованы - пропускаем их
475
			if (i && j)
476
			{
477
				//kos_DrawBar(x+1, y+1, col_width[i]-1, row_height[i]-1, 0xffffff);
478
 
479
				//rtlDebugOutString(cap);
480
				//if (j >= sel_x && j <= sel_end_x && i >= sel_y && i <= sel_end_y)
481
				if (is_between(j,sel_x,sel_end_x) && is_between(i, sel_y, sel_end_y)	// (j,i) - выделена
482
					&& ((!sel_moved) || (is_x_changed(j) && is_y_changed(i))))			// и ее нужно нарисовать
483
				{
484
					if (i == sel_y && j == sel_x)		// рамка
485
					{
486
						kos_DrawBar(x,y,col_width[j],2,TEXT_COLOR);	// up
487
						kos_DrawBar(x,y,2,row_height[i],TEXT_COLOR);	// left
488
						kos_DrawBar(x,y+row_height[i]-2,col_width[j]-2-3,2,TEXT_COLOR);				// bottom
489
						kos_DrawBar(x+col_width[j]-2,y, 2,row_height[i]-2-3,TEXT_COLOR);				// right
490
 
491
						kos_DrawBar(x+col_width[j]-4,y+row_height[i]-4,4,4,TEXT_COLOR);
492
						//kos_DefineButton(x+col_width[j]-2,y+row_height[i]-2,4,4,0x60000000+DRAG_BUTTON,0x000000);
493
						drag_x = x + col_width[j] - 4;
494
						drag_y = y + row_height[i] - 4;
495
					}
496
					else
497
						kos_DrawBar(x + 1,y + 1,col_width[j] - 2,row_height[i] - 2,SEL_CELL_COLOR);	//	выделена но не основная(серая)
498
 
499
				}
500
				//kos_DefineButton(x,y,col_width[j]-1,row_height[i]-1,0x60000000+CELL_BUTTON+((i << 8) + j),0);
501
 
502
				char *text;
503
				if (values[j][i] && values[j][i][0] == '#')
504
				{
505
					text = cells[j][i];
506
					kos_DrawRegion(x+1, y+1, col_width[j]-1, row_height[i]-1, 0xff0000, 0);
507
				}
508
				else
509
					text = (values[j][i] && !display_formulas ? values[j][i] : cells[j][i]);
510
 
511
				int dy = (row_height[i] - 8) / 2 + 1;
512
 
513
				if (text)
514
					if (strlen(text) < col_width[j]/6)
515
						kos_WriteTextToWindow(x+2,y+dy,0,text_color,text,strlen(text));
516
					else
517
						kos_WriteTextToWindow(x+2,y+dy,0,text_color,text,col_width[j]/6);
518
 
519
			}
520
			if (!sel_moved || is_x_changed(j) || is_y_changed(i))
521
				kos_DrawLine(col_left[j]+col_width[j], row_top[i], col_left[j]+col_width[j], row_height[i], GRID_COLOR, 0);
522
			x += col_width[j];
523
		}
524
		y += row_height[i];
525
	}
526
 
527
	// Scrolls:
528
	// horizontal
529
 
530
	//if (!sel_moved) kos_DrawBar(0, he - SCROLL_BAR_HEIGHT, wi - SCROLL_BAR_WIDTH, SCROLL_BAR_HEIGHT, FIXED_CELL_COLOR);
531
	//if (!sel_moved) kos_DrawBar(scroll_x * wi / col_count, he - SCROLL_BAR_HEIGHT, wi / col_count, SCROLL_BAR_HEIGHT, SEL_FIXED_CELL_COLOR);
532
	if (!sel_moved)
533
	{
534
		// горизонталь
535
		kos_DrawBar(17, he - SCROLL_BAR_HEIGHT, wi - SCROLL_BAR_WIDTH - 32, SCROLL_BAR_HEIGHT, 0xced0d0);
990 barsuk 536
		// синие линии
1114 leency 537
		kos_DrawRegion(0, he - SCROLL_BAR_HEIGHT, wi - SCROLL_BAR_WIDTH, SCROLL_BAR_HEIGHT+1, 0x94aece, 0);
538
		// левая кнопка
539
		draw_custom_button(1, he - SCROLL_BAR_HEIGHT + 1, 14, 14, 1);
540
		kos_WriteTextToWindow(6, he - SCROLL_BAR_HEIGHT + 5, 0, 0, "\x1B", 1);
541
		// правая
542
		draw_custom_button(wi - SCROLL_BAR_WIDTH * 2 + 1, he - SCROLL_BAR_HEIGHT + 1, 14, 14, 1);
543
		kos_WriteTextToWindow(wi - SCROLL_BAR_WIDTH * 2 + 6, he - SCROLL_BAR_HEIGHT + 5, 0, 0, "\x1A", 1);
544
		// ползунок
545
		int tmp_w = (nx - scroll_x) * (wi - SCROLL_BAR_WIDTH - 2 * 14 - 14) / (col_count + 1);
546
		if (tmp_w < 16)
547
			tmp_w = 16;
548
		draw_custom_button(17 + (scroll_x - 1) * (wi - SCROLL_BAR_WIDTH - 2 * 14 - 14) / (col_count + 1), he - SCROLL_BAR_HEIGHT + 1,
549
			tmp_w, 14, 1);
550
 
551
#define sw(x,y) y,x
552
// не пинайте меня за это, было лень переставлять руками...
553
 
554
		// вертикаль
555
		kos_DrawBar(sw(17, wi - SCROLL_BAR_WIDTH), sw(he - SCROLL_BAR_HEIGHT - 33, SCROLL_BAR_WIDTH), 0xced0d0);
990 barsuk 556
		// синие линии
557
		kos_DrawRegion(sw(0, wi - SCROLL_BAR_WIDTH), sw(he - SCROLL_BAR_HEIGHT, SCROLL_BAR_WIDTH+1), 0x94aece, 0); // up
1114 leency 558
 
559
		// верхняя кнопка
560
		draw_custom_button(sw(1, wi - SCROLL_BAR_WIDTH + 1), 14, 14, 1);
561
		kos_WriteTextToWindow(sw(5, wi - SCROLL_BAR_WIDTH + 6), 0, 0, "\x18", 1);
562
		// нижняя
563
		draw_custom_button(sw(he - SCROLL_BAR_HEIGHT * 2 + 1, wi - SCROLL_BAR_WIDTH + 1), 14, 14, 1);
564
		//draw_custom_button(sw(he - SCROLL_BAR_HEIGHT * 2 + 1, wi - SCROLL_BAR_WIDTH + 1), 14, 14, 1);
565
		kos_WriteTextToWindow(sw(he - SCROLL_BAR_HEIGHT * 2 + 5, wi - SCROLL_BAR_WIDTH + 6), 0, 0, "\x19", 1);
566
		// ползунок
567
		int tmp_h = (ny - scroll_y) * (he - SCROLL_BAR_HEIGHT - 2 * 14 - 14) / (row_count + 1);
568
		if (tmp_h < 16)
569
			tmp_h = 16;
570
		draw_custom_button(sw(17 + (scroll_y - 1) * (he - SCROLL_BAR_HEIGHT - 2 * 14 - 14) / (row_count + 1), wi - SCROLL_BAR_WIDTH + 1),
571
			sw(tmp_h, 14), 1);
572
	}
573
#define NO_DRAW 0x60000000
574
	kos_DefineButton(1, he - SCROLL_BAR_HEIGHT + 1, 14, 14, NO_DRAW + SCROLL_LEFT_BUTTON,0);
575
	kos_DefineButton(wi - SCROLL_BAR_WIDTH * 2 + 2, he - SCROLL_BAR_HEIGHT + 1, 14, 14, NO_DRAW + SCROLL_RIGHT_BUTTON,0);
576
	kos_DefineButton(17, he - SCROLL_BAR_HEIGHT + 1,  (wi - SCROLL_BAR_WIDTH - 2 * 14), 14, NO_DRAW + SCROLL_WIDTH,0);
577
 
578
	kos_DefineButton(sw(1, wi - SCROLL_BAR_WIDTH + 1), 14, 14, NO_DRAW + SCROLL_UP_BUTTON,0);
579
	kos_DefineButton(sw(he - SCROLL_BAR_HEIGHT * 2 + 2, wi - SCROLL_BAR_WIDTH + 1), 14, 14, NO_DRAW + SCROLL_DOWN_BUTTON,0);
580
	kos_DefineButton(sw(17, wi - SCROLL_BAR_WIDTH + 1),  sw((he - SCROLL_BAR_HEIGHT - 2 * 14), 14), NO_DRAW + SCROLL_HEIGHT,0);
581
 
582
}
583
 
584
// очень быстрое рисование сетки, в процессе изменения размеров ячеек
585
void draw_size_grid()
586
{
587
	//rtlDebugOutString("draw size grid");
588
 
589
	if (size_state == SIZE_X)
590
	{
591
		int x, x0, i;
592
 
593
		x = col_width[0];
594
		x0 = 0;
595
		for (i = 1; i < col_count && x - x0 + col_width[i] < wi - 10; i++)
596
		{
597
			if (i >= scroll_x)
598
			{
599
				if (i >= size_id)
600
					kos_DrawLine(x - x0, 0, x - x0, he, 0, 1);
601
			}
602
			else
603
				x0 += col_width[i];
604
			x += col_width[i];
605
		}
606
		kos_DrawLine(x - x0, 0, x - x0, he, 0, 1);
607
	}
608
	else
609
	{
610
		int y, y0, i;
611
 
612
		y = row_height[0];
613
		y0 = 0;
614
		for (i = 1; i < col_count && y - y0 + row_height[i] < he - 10; i++)
615
		{
616
			if (i >= scroll_y)
617
			{
618
				if (i >= size_id)
619
					kos_DrawLine(0, y - y0, wi, y - y0, 0, 1);
620
			}
621
			else
622
				y0 += row_height[i];
623
			y += row_height[i];
624
		}
625
		kos_DrawLine(0, y - y0, wi, y - y0, 0, 1);
626
	}
627
 
628
}
629
 
630
 
631
// быстрое рисование выделенной области при выделении мышью
632
#define DCOLOR 0
633
//0xff0000
634
#define DINVERT 1
635
void draw_drag()
636
{
637
	// собственно, 4 инверсные линии
638
 
639
	int k0 = min(sel_x, sel_end_x);
640
	int k1 = max(sel_x, sel_end_x);
641
	int n0 = min(sel_y, sel_end_y);
642
	int n1 = max(sel_y, sel_end_y);
643
 
644
	DWORD x0 = col_left[k0] - 1;
645
	DWORD x1 = col_left[k1] + col_width[k1] + 1;
646
	DWORD y0 = row_top[n0] - 1;
647
	DWORD y1 = row_top[n1] + row_height[n1] + 1;
648
	if (x0 > wi - 1) x0 = wi - 1;
649
	if (x1 > wi - 1) x1 = wi - 1;
650
	if (y0 > he - 1) y0 = he - 1;
651
	if (y1 > he - 1) y1 = he - 1;
652
 
653
	//sprintf(debuf,"drag %U %U %U %U",k0,k1,n0,n1);
990 barsuk 654
	//rtlDebugOutString(debuf);
655
 
1114 leency 656
	kos_DrawLine(x0, y0, x0, y1, DCOLOR, DINVERT);
657
	kos_DrawLine(x0, y0, x1, y0, DCOLOR, DINVERT);
658
	kos_DrawLine(x1, y0, x1, y1, DCOLOR, DINVERT);
659
	kos_DrawLine(x0, y1, x1, y1, DCOLOR, DINVERT);
660
}
661
 
662
void draw_window()
663
{
664
	double xx0=0.0, yy0=0.0;
665
	sProcessInfo info;
666
	void *p;
667
 
668
	if (sel_end_move)
669
		sel_moved = 0;
670
 
671
	memset((Byte*)&info, 0, 1024);
672
 
673
	kos_ProcessInfo(&info, 0xFFFFFFFF);
674
	p = info.rawData + 42;			// magic
675
	wi = *(Dword *)(p);
676
	he = *(Dword *)((Byte *)p + 4);
677
	win_x = *(Dword *)((Byte *)p - 8);
678
	win_y = *(Dword *)((Byte *)p - 4);
679
 
680
	myPID = *(Dword*)((Byte *)p - 12);
681
 
682
	if (wi == 0)
683
		wi = WND_W;
684
	if (he == 0)
685
		he = WND_H;
686
 
687
	he -= kos_GetSkinHeight() + MENU_PANEL_HEIGHT; // доступная высота окна
688
	wi -= 10;
689
 
690
	if (window_drawall==true){
691
		kos_WindowRedrawStatus(1);
692
		kos_DefineAndDrawWindow(10,40,WND_W,WND_H,0x33,0x40FFFFFF,0,0,(Dword)"Table v" TABLE_VERSION);
2749 leency 693
		kos_WindowRedrawStatus(2);
1114 leency 694
 
2749 leency 695
		if (info.rawData[70]&0x04) return; //ничего не делать если окно схлопнуто в заголовок
1114 leency 696
 
697
		if (he < 100) kos_ChangeWindow( -1, -1, -1, 180 );
698
		if (wi < 340) kos_ChangeWindow( -1, -1, 350, -1 );
699
 
2749 leency 700
	}
1114 leency 701
 
702
//	edit_box_draw((dword)&ebox);
703
	int y = he + kos_GetSkinHeight() - 10;
704
 
705
	if (!sel_moved)
706
	{
707
		kos_DrawBar(wi-15,he - kos_GetSkinHeight() +7,16,16,0xe4dfe1);
708
		kos_DrawBar(0,he - kos_GetSkinHeight() + 23,wi + 1,MENU_PANEL_HEIGHT-5,0xe4dfe1);
709
		kos_WriteTextToWindow(3 + 1, y + 3, 0x80 , 0x000000, (char*)sFilename, strlen(sFilename));
710
	}
711
 
712
	//DWORD fn_line_color = fn_edit ? 0x000000 : 0xc0c0c0;
713
	//kos_DrawRegion(61, y - 2, 102, 18, fn_line_color, 0);
714
 
715
	// дальше editbox width = 100
716
 
990 barsuk 717
	// border around edit box
1114 leency 718
	file_box.left = 64;
719
	file_box.top = y - 1;
720
	file_box.width = 98;
721
		//editbox_h = 18;
722
 
723
	// сохранить
724
	kos_DefineButton(20 + 160, y - 5, 60, 20, SAVE_BUTTON, 0xd0d0d0);
725
	kos_WriteTextToWindow(22 + 160 + (60 - strlen(sSave) * 6) / 2, y + 2, 0, 0x000000, (char*)sSave, strlen(sSave));
726
 
727
	// загрузить
728
	kos_DefineButton(90 + 160, y - 5, 60, 20, LOAD_BUTTON, 0xd0d0d0);
729
	kos_WriteTextToWindow(92 + 160 + (60 - strlen(sLoad) * 6) / 2, y + 2, 0, 0x000000, (char*)sLoad, strlen(sLoad));
730
 
731
	// создать. только эту кнопу воткнуть некуда о_О
732
	/*
733
	kos_DefineButton(90 + 160 + 70, y - 5, 60, 20, NEW_BUTTON, 0xd0d0d0);
734
	kos_WriteTextToWindow(92 + 160 + 10 + 70, y + 2, 0, 0x000000, (char*)sNew, strlen(sNew));
735
	*/
990 barsuk 736
	panel_y = y;
737
 
738
	if ((void*)edit_box_draw != NULL)
739
	{
740
		if (is_edit)
741
			edit_box_draw((DWORD)&cell_box);
742
		edit_box_draw((DWORD)&file_box);
1114 leency 743
	}
744
 
745
	draw_grid();
746
	window_drawall=false;
747
	sel_moved = 0;
748
}
749
 
750
 
751
void process_mouse()
752
{
753
	Dword mouse_btn, ckeys, shift, ctrl;
2749 leency 754
	int mouse_x, mouse_y, i, dx = 0, dy = 0;
1114 leency 755
	int redraw = 0;
756
 
757
	Dword mySlot = kos_GetSlotByPID(myPID);
758
	if (kos_GetActiveSlot() != mySlot)
759
		return;
760
 
990 barsuk 761
	edit_box_mouse((dword)&cell_box);
762
	edit_box_mouse((dword)&file_box);
763
 
1114 leency 764
	int vert, hor;
765
	kos_GetScrollInfo(vert, hor);
766
 
767
	//sprintf(debuf, "scroll %U %U", vert, hor);
768
	//rtlDebugOutString(debuf);
769
 
2749 leency 770
 
1114 leency 771
	if (vert != 0) //труъ перерисовка!
772
	{
2749 leency 773
		if (!((sel_end_y + vert) >= (row_count-1))) //заглушка
1114 leency 774
		move_sel(sel_x, sel_y + vert);
775
		return;
776
	}
777
 
778
	kos_GetMouseState(mouse_btn, mouse_x, mouse_y);
779
	mouse_x -= 5;
1112 barsuk 780
	mouse_y -= kos_GetSkinHeight();
781
 
1114 leency 782
	mouse_btn &= 0x0001;
783
 
784
	ckeys = kos_GetSpecialKeyState();
785
	shift = ckeys & 0x3;
786
 
2749 leency 787
 
1112 barsuk 788
	if (mouse_y < 0 && mouse_btn)	// т.к. мышка на заголовке окна
789
	{
790
		window_is_dragged = 1;
791
		return;
792
	}
793
	if (window_is_dragged)
794
	{
795
		if (mouse_btn)
796
			return;
797
		else
798
			window_is_dragged = 0;
799
	}
800
 
1114 leency 801
	if (!size_state && !mouse_btn)
802
		return;
803
	if (mouse_btn && !size_state)		// LMB down
804
	{
805
		//rtlDebugOutString("lmb down and not resize");
806
 
807
		if (mouse_x >= drag_x && mouse_x <= drag_x + 4 && mouse_y >= drag_y && mouse_y <= drag_y + 4)
808
		{
809
			size_state = SIZE_DRAG;
810
			old_end_x = sel_end_x;
811
			old_end_y = sel_end_y;
812
		}
813
		else if (mouse_y <= row_height[0])
814
		{
815
			//rtlDebugOutString("can resize cols");
816
			int kx = -1, i;
817
			for (i = 0; i < col_count - 1; i++)
818
			if (mouse_x >= col_left[i] + col_width[i] - 5 &&
819
				mouse_x <= col_left[i + 1] + 5)
990 barsuk 820
			{
1114 leency 821
				kx = i; break;
822
			}
823
			if (kx != -1)
824
			{
825
				//sprintf(debuf,"size x %U",k);
826
				//rtlDebugOutString(debuf);
827
				size_id = kx;
828
				size_state = SIZE_X;
829
			}
830
		}
831
		else if (mouse_x <= col_width[0])
832
		{
833
			int ky = -1;
834
			for (i = 0; i < row_count - 1; i++)
835
			if (mouse_y >= row_top[i] + row_height[i] - 5 &&
836
				mouse_y <= row_top[i + 1] + 5)
837
			{
838
				ky = i; break;
839
			}
840
			if (ky != -1)
841
			{
842
				size_id = ky;
843
				size_state = SIZE_Y;
844
			}
845
		}
846
		else		// кликнута ячейка
847
		if (mouse_x <= col_left[nx - 1] &&  mouse_y <= row_top[ny - 1])
848
		{
849
			was_single_selection = sel_x == sel_end_x && sel_y == sel_end_y;
850
			int kx = -1, i;
851
			for (i = 0; i < col_count - 1; i++)
852
			if (mouse_x >= col_left[i] &&
853
				mouse_x <= col_left[i] + col_width[i])
854
			{
855
				kx = i; break;
856
			}
857
			int ky = -1;
858
			for (i = 0; i < row_count - 1; i++)
859
			if (mouse_y >= row_top[i] &&
860
				mouse_y <= row_top[i] + row_height[i])
861
			{
862
				ky = i; break;
863
			}
864
			if (kx != -1 && ky != -1)
865
			{
990 barsuk 866
				if (!shift)
1114 leency 867
				{
990 barsuk 868
					move_sel(kx, ky);
1112 barsuk 869
					//return;
1114 leency 870
				}
871
				else
872
				{
1112 barsuk 873
					sel_end_x = kx;
1114 leency 874
					sel_end_y = ky;
875
				}
876
				size_state = SIZE_SELECT;
877
			}
878
		}
879
		if (size_state)
880
		{
881
			size_mouse_x = mouse_x;
882
			size_mouse_y = mouse_y;
883
		}
884
		return;
885
	}
886
	else if (!mouse_btn && size_state)
887
	{
888
		sel_moved = 0;		// чтобы была тру перерисовка
889
		//rtlDebugOutString("resize end");
890
 
891
		if (size_state == SIZE_DRAG)
892
		{
893
			fill_cells(sel_x, sel_y, sel_end_x, sel_end_y, old_end_x, old_end_y);
894
		}
895
 
896
		//sel_moved = (size_state == SIZE_SELECT && sel_x == sel_end_x && sel_y == sel_end_y && was_single_selection);
897
		size_state = 0;
990 barsuk 898
		draw_window();		// все сдвинулось - надо обновиться
1114 leency 899
		return;
900
	}
901
	if (size_state == SIZE_X && mouse_x != size_mouse_x)
902
	{
903
		draw_size_grid();
904
		col_width[size_id] += mouse_x - size_mouse_x;
905
		if (col_width[size_id] < 15)
906
			col_width[size_id] = 15;
907
		else if (col_width[size_id] > wi / 2)
908
			col_width[size_id] = wi / 2;
909
		draw_size_grid();
910
	}
911
	if (size_state == SIZE_Y && mouse_y != size_mouse_y)
912
	{
913
		draw_size_grid();
914
		row_height[size_id] += mouse_y - size_mouse_y;
915
		if (row_height[size_id] < 15)
916
			row_height[size_id] = 15;
917
		else if (row_height[size_id] > he / 2)
918
			row_height[size_id] = he / 2;
919
		draw_size_grid();
920
	}
921
	if ((size_state == SIZE_SELECT || size_state == SIZE_DRAG) && (mouse_x != size_mouse_x || mouse_y != size_mouse_y))
922
	{
923
		draw_drag();
924
		int kx = -1, i;
925
		for (i = 0; i < col_count - 1; i++)
926
			if (mouse_x >= col_left[i] &&
927
				mouse_x <= col_left[i + 1])
928
			{
929
				//sprintf(debuf, "yyy %U",col_left[i+1]);
930
				//rtlDebugOutString(debuf);
931
				kx = i; break;
932
			}
933
		int ky = -1;
934
		for (i = 0; i < row_count - 1; i++)
935
			if (mouse_y >= row_top[i] &&
936
				mouse_y <= row_top[i + 1])
937
			{
938
				ky = i; break;
939
			}
940
		if (kx != -1) sel_end_x = kx;
941
		if (kx != -1) sel_end_y = ky;
942
		if (size_state == SIZE_DRAG)
943
		{
944
			if (abs(sel_end_x - sel_x) > 0)
945
			{
946
				sel_end_y = old_end_y;
947
			}
948
			else if (abs(sel_end_y - sel_y) > 0)
949
			{
950
				sel_end_x = old_end_x;
951
			}
952
		}
953
		draw_drag();
954
	}
955
	size_mouse_x = mouse_x;
956
	size_mouse_y = mouse_y;
957
}
958
 
959
void process_key()
960
{
961
	Dword mouse_btn, ckeys, shift, ctrl;
2749 leency 962
	int mouse_x, mouse_y, dx = 0, dy = 0;
1114 leency 963
 
964
	// key pressed, read it
965
	Byte keyCode;
966
	ckeys = kos_GetSpecialKeyState();
967
	shift = ckeys & 0x3;
968
	ctrl = ckeys & 0x0c;
969
	//if (ctrl)
970
	//	rtlDebugOutString("control pressed!");
971
	dx = 0, dy = 0;
972
	sel_moved = 0;
973
	sel_end_move = 0;
990 barsuk 974
	kos_GetKey(keyCode);
975
 
976
	__asm
977
	{
978
		mov ah, keyCode
979
	}
980
	edit_box_key((dword)&cell_box);
981
	edit_box_key((dword)&file_box);
982
 
1114 leency 983
 
984
	switch (keyCode)
985
	{
986
		case 178:			// стрелки
987
			//dx = 0;
988
			dy = -1;
989
			break;
990
		case 176:
991
			dx = -1;
992
			//dy = 0;
993
			break;
994
		case 179:
995
			dx = 1;
996
			//dy = 0;
997
			break;
998
		case 177:
999
			//dx = 0;
1000
			dy = 1;
1001
			break;
1002
		/*
1003
		case 183:
1004
			if (sel_y < row_count-(ny - scroll_y))	// page down
1005
				dy = ny - scroll_y;
1006
			else
1007
				dy = row_count-(ny - scroll_y) - sel_y;
1008
			dx = 0;
1009
			redraw = 1;
1010
			break;
1011
		case 184:
1012
			if (sel_y > ny - scroll_y)		// page up
1013
				dy= - (ny - scroll_y);
1014
			else
1015
				dy = - (ny - scroll_y) + sel_y;
1016
			dx = 0;
1017
			redraw = 1;
1018
			break;
1019
		*/
1020
		case 180: //home
1021
			dx = -sel_x + 1;
1022
			dy = 0;
1023
			draw_grid(); //draw_window();
1024
			break;
1025
		case 181: //end
1026
			dx = col_count - (nx - scroll_x) - 1 - sel_x;
1027
			dy = 0;
1028
			draw_grid(); //draw_window();
1029
			break;
1030
		case 27:		// escape
1031
			cancel_edit();
1032
			break;
1033
		case 182:			// delete
1034
			{
1035
				int i,j,n0,n1,k0,k1;
1036
				n0 = min(sel_x, sel_end_x);
1037
				n1 = max(sel_x, sel_end_x);
1038
				k0 = min(sel_y, sel_end_y);
1039
				k1 = max(sel_y, sel_end_y);
1040
 
1041
				for (i = n0; i <= n1; i++)
1042
					for (j = k0; j <= k1; j++)
1043
					{
1044
						if (cells[i][j])
1045
						{
1046
							freemem(cells[i][j]);
1047
							cells[i][j] = NULL;
1048
						}
1049
					}
990 barsuk 1050
				calculate_values();
1114 leency 1051
				draw_grid();
1052
				break;
1053
			}
1054
		case 0x0D:			// enter
1055
			if (is_edit)
1056
			{
1057
				stop_edit();
990 barsuk 1058
				draw_window();
1059
			}
1114 leency 1060
			break;
1061
		case 22:	// contol-v
1062
			{
1063
				if (ctrl)
1064
				{
1065
					//rtlDebugOutString("control-v!");
1066
					int i, j, x0, y0;
1067
					x0 = min(sel_x, sel_end_x);
1068
					y0 = min(sel_y, sel_end_y);
1069
					int delta_x = x0 - buf_old_x;
1070
					int delta_y = y0 - buf_old_y;
1071
 
1072
					for (i = 0; i < buf_col; i++)
1073
						for (j = 0; j < buf_row; j++)
1074
						{
1075
							if (i + x0 >= col_count || j + y0 >= row_count)
1076
								continue;
1077
							if (cells[i + x0][j + y0])
1078
								freemem(cells[i + x0][j + y0]);
1079
							if (buffer[i][j])
1080
							{
1081
								cf_x0 = buf_old_x; cf_y0 = buf_old_y;
1082
								cf_x1 = buf_old_x + buf_col;
1083
								cf_y1 = buf_old_y + buf_row;
1084
								cells[i + x0][j + y0] = change_formula(buffer[i][j], delta_x, delta_y);
1085
								//cells[i + x0][j + y0] = (char*)allocmem(strlen(buffer[i][j]));
1086
								//strcpy(cells[i + x0][j + y0], buffer[i][j]);
1087
							}
1088
							else
1089
								cells[i + x0][j + y0] = NULL;
1090
						}
1091
 
1092
					calculate_values();
1093
					draw_window();
1094
					break;
1095
				}
1096
			}
1097
			case 24:	// control-x
1098
			case 03:	// control-c
1099
			{
1100
				if (ctrl)
1101
				{
1102
					//rtlDebugOutString("control-c!");
1103
					int i, j, x0, y0;
1104
 
1105
					freeBuffer();
1106
 
1107
					buf_col = abs(sel_end_x - sel_x) + 1;
1108
					buf_row = abs(sel_end_y - sel_y) + 1;
1109
					x0 = min(sel_x, sel_end_x);
1110
					y0 = min(sel_y, sel_end_y);
1111
					buf_old_x = x0;
1112
					buf_old_y = y0;
1113
 
1114
					//sprintf(debuf, "%U %U %U %U", buf_col, buf_row, x0, y0);
1115
					//rtlDebugOutString(debuf);
1116
 
1117
					buffer = (char***)allocmem(buf_col * sizeof(char**));
1118
					for (i = 0; i < buf_col; i++)
1119
					{
1120
						buffer[i] = (char**)allocmem(buf_row * sizeof(char*));
1121
						for (j = 0; j < buf_row; j++)
1122
						{
1123
							if (cells[i + x0][j + y0])
1124
							{
1125
								if (keyCode == 03)	// ctrl-c
1126
								{
1127
									buffer[i][j] = (char*)allocmem(strlen(cells[i + x0][j + y0]));
1128
									strcpy(buffer[i][j], cells[i + x0][j + y0]);
1129
								}
1130
								else
1131
								{
1132
									buffer[i][j] = cells[i + x0][j + y0];
1133
									cells[i + x0][j + y0] = NULL;
1134
								}
1135
							}
1136
							else
1137
								buffer[i][j] = NULL;
1138
						}
1139
					}
1140
					if (keyCode == 24)
1141
						calculate_values();
1142
					draw_window();
1143
					break;
1144
				}
1145
			}
1146
		case 06:		// control-f
1147
			{
1148
				display_formulas = !display_formulas;
1149
				draw_grid(); //draw_window();
1150
				break;
1151
			}
990 barsuk 1152
		default:
1114 leency 1153
 
1154
			if (!is_edit && !(file_box.flags & ed_focus))
1155
			{
990 barsuk 1156
				start_edit(sel_x, sel_y);
1157
				if (keyCode == 8)
1158
				{
1159
					cell_box.pos = strlen(edit_text);
1160
				}
1161
				else
1162
				{
1163
					__asm
1164
					{
1165
						mov ah, keyCode
1166
					}
1167
					edit_box_key((dword)&cell_box);
1114 leency 1168
				}
990 barsuk 1169
			}
1170
			if (is_edit)
1171
				edit_box_draw((dword)&cell_box);
1114 leency 1172
			break;
1173
	}
1174
	if (dx != 0)
1175
	{
1176
		if (shift)
1177
		{
1178
			sel_end_x += dx;
1179
			if (sel_end_x <= 1)
1180
				sel_end_x = 1;
1181
			else if (sel_end_x >= col_count)
1182
				sel_end_x = col_count - 1;
1183
		//	sprintf(debuf,"sel end x change. sel end %U %U",sel_end_x,sel_end_y);
1184
		//	rtlDebugOutString(debuf);
1185
			sel_moved = sel_end_move = 1;
990 barsuk 1186
			//stop_edit();
1114 leency 1187
			//draw_grid();
1188
		}
1189
		else
1190
		{
1191
		}
1192
	}
1193
	if (dy != 0)
1194
	{
1195
		if (shift)
1196
		{
1197
			sel_end_y += dy;
1198
			if (sel_end_y <= 1)
1199
				sel_end_y = 1;
1200
			else if (sel_end_y >= row_count)
1201
				sel_end_y = row_count - 1;
1202
		//	sprintf(debuf,"sel end y change. sel end %U %U",sel_end_x,sel_end_y);
1203
		//	rtlDebugOutString(debuf);
1204
			sel_moved = sel_end_move = 1;
990 barsuk 1205
			//stop_edit();
1114 leency 1206
			//draw_grid();
1207
		}
1208
	}
1209
	/*
1210
	if (sel_end_x < sel_x)
1211
	{
1212
		Dword tmp = sel_end_x; sel_end_x = sel_x; sel_x = tmp;
1213
	}
1214
	if (sel_end_y < sel_y)
1215
	{
1216
		Dword tmp = sel_end_y; sel_end_y = sel_y; sel_y = tmp;
1217
	}
1218
	*/
990 barsuk 1219
	if ((dx || dy))
1220
	{
1114 leency 1221
		if (!shift)
1222
		{
2749 leency 1223
			if ((sel_end_x + dx) >= (col_count-1)) {dx=0;} //заглушка
1224
			else if ((sel_end_y + dy) >= (row_count-1)) {dy=0;}
1225
			else {
1114 leency 1226
			move_sel(sel_x + dx, sel_y + dy);
2749 leency 1227
			}
990 barsuk 1228
		}
1229
		else
1230
		{
1231
			sel_moved = 0;
1232
			stop_edit();
1233
			draw_grid();
1234
		}
1114 leency 1235
	}
1236
}
1237
 
1238
 
1239
void process_button()
1240
{
1241
	Dword mouse_btn, ckeys, shift, ctrl;
1242
	int mouse_x, mouse_y, i, p, dx = 0, dy = 0;
1243
	int redraw = 0;
1244
 
1245
	Dword button;
1246
	kos_GetButtonID(button);
1247
 
1248
	/*
1249
	sprintf(debuf, "button %U", button);
1250
	rtlDebugOutString(debuf);
1251
	//*/
1252
 
1253
	switch (button)
1254
	{
1255
	case 1:
1256
		kos_ExitApp();
1257
 
1258
	case SCROLL_LEFT_BUTTON:
1259
		//rtlDebugOutString("scroll left btn");
1260
		stop_edit();
1261
		scroll_x--;
1262
		if (scroll_x <= 0)
1263
			scroll_x = 1;
1264
		sel_moved = 0;
1265
		/*if (sel_x > nx - 1)
1266
		{
1267
			nx - 1;
1268
			sel_end_x = sel_x;
1269
		}*/
1270
		draw_window();
1271
		return;
1272
 
1273
	case SCROLL_RIGHT_BUTTON:
1274
		//rtlDebugOutString("scroll right btn");
1275
		stop_edit();
1276
		scroll_x++;
1277
		if (scroll_x >= col_count - 1)
1278
			scroll_x = col_count - 1;
1279
		sel_moved = 0;/*
1280
		if (sel_x < scroll_x)
1281
		{
1282
			sel_x = scroll_x;
1283
			sel_end_x = sel_x;
1284
		}*/
1285
		draw_window();
1286
		return;
1287
 
1288
	case SCROLL_WIDTH:
1289
		{
1290
			//rtlDebugOutString("scroll width btn");
1291
			stop_edit();
1292
			kos_GetMouseState(mouse_btn, mouse_x, mouse_y);
1293
			mouse_x -= 5;
1294
			mouse_y -= kos_GetSkinHeight();
1295
 
1296
			// всего: wi - SCROLL_BAR_WIDTH - 2 * 14
1297
 
1298
			int tmp_w = (nx - scroll_x) * (wi - SCROLL_BAR_WIDTH - 3 * 14) / (col_count + 1);
1299
			if (tmp_w < 16)
1300
				tmp_w = 16;
1301
			scroll_x = (mouse_x - 14 - tmp_w / 2) * (col_count + 1) / (wi - SCROLL_BAR_WIDTH - 3 * 14) + 1;
1302
			if (scroll_x <= 0)
1303
				scroll_x = 1;
1304
			else if (scroll_x >= col_count - 1)
1305
				scroll_x = col_count - 1;
1306
			sel_moved = 0;
1307
			draw_window();
1308
			return;
1309
		}
1310
 
1311
	case SCROLL_UP_BUTTON:
1312
		stop_edit();
1313
		scroll_y--;
1314
		if (scroll_y <= 0)
1315
			scroll_y = 1;
1316
		sel_moved = 0;
990 barsuk 1317
		//draw_window();
1318
		draw_grid();
1114 leency 1319
		/*
1320
		if (sel_y > ny - 1)
1321
		{
1322
			sel_y = ny - 1;
1323
			sel_end_y = sel_y;
1324
		}*/
1325
		return;
1326
 
1327
	case SCROLL_DOWN_BUTTON:
1328
		stop_edit();
1329
		scroll_y++;
1330
		if (scroll_y >= row_count - 1)
1331
			scroll_y = row_count - 1;
1332
		sel_moved = 0;/*
1333
		if (sel_y < scroll_y)
1334
		{
1335
			sel_y = scroll_y;
1336
			sel_end_y = sel_y;
1337
		}*/
1338
		draw_grid();
1339
		return;
1340
 
1341
	case SCROLL_HEIGHT:
1342
		{
1343
			stop_edit();
1344
			kos_GetMouseState(mouse_btn, mouse_x, mouse_y);
1345
			mouse_x -= 5;
1346
			mouse_y -= kos_GetSkinHeight();
1347
			int tmp_h = (ny - scroll_y) * (he - SCROLL_BAR_HEIGHT - 2 * 14) / row_count;
1348
			if (tmp_h < 16)
1349
				tmp_h = 16;
1350
			scroll_y = (mouse_y - 2 * 14) * (row_count + 1) / (he - SCROLL_BAR_HEIGHT - 3 * 14) + 1;
1351
			if (scroll_y <= 0)
1352
				scroll_y = 1;
1353
			else if (scroll_y >= row_count - 1)
1354
				scroll_y = row_count - 1;
1355
			sel_moved = 0;
1356
			draw_grid();
1357
			return;
1358
		}
1359
 
1360
	case NEW_BUTTON:	// clear the table
1361
		reinit();
1362
		draw_window();
1363
		break;
1364
 
1365
	case FILENAME_BUTTON:
1366
		sel_moved = 1;
1367
		stop_edit();
1368
		fn_edit = 1;
1369
		strcpy(edit_text, fname);
1370
		draw_window();
1371
		break;
1372
 
1373
	case SAVE_BUTTON:
1374
		stop_edit();
1375
		kos_DrawBar(320, panel_y, wi - 320 - 10, 10, 0xe4dfe1);
1376
		if (SaveFile(fname))
1377
			kos_WriteTextToWindow(320, panel_y, 0, 0x000000, (char*)msg_save, strlen(msg_save));
1378
		break;
1379
 
1380
	case LOAD_BUTTON:
1381
		stop_edit();
1382
		int r = LoadFile(fname);
1383
		kos_DrawBar(320, panel_y, wi - 320 - 10, 10, 0xe4dfe1);
1384
		if (r > 0)
1385
		{
1386
			calculate_values();
1387
			sel_moved = 0;
1388
			draw_window();
1389
			kos_WriteTextToWindow(320, panel_y,0,0x000000,(char*)msg_load, strlen(msg_load));
1390
		}
1391
		else if (r == -1)
1392
			kos_WriteTextToWindow(320, panel_y,0,0x000000,(char*)er_file_not_found,strlen(er_file_not_found));
1393
		else if (r == -2)
1394
			kos_WriteTextToWindow(320, panel_y,0,0x000000,(char*)er_format,strlen(er_format));
1395
		break;
1396
	}
1397
	if (button >= COL_HEAD_BUTTON && button < ROW_HEAD_BUTTON)
1398
	{
1399
		sel_end_x = sel_x = button - COL_HEAD_BUTTON;
1400
		sel_y = 1;
1401
		sel_end_y = row_count - 1;
1402
		stop_edit();
1403
		draw_window();
1404
		return;
1405
	}
1406
	else if (button >= ROW_HEAD_BUTTON && button < CELL_BUTTON)
1407
	{
1408
		sel_end_y = sel_y = button - ROW_HEAD_BUTTON;
1409
		sel_x = 1;
1410
		sel_end_x = col_count - 1;
1411
		stop_edit();
1412
		draw_window();
1413
		return;
1414
	}
1415
 
1416
}
1417
 
1418
void kos_Main()
1419
{
990 barsuk 1420
	kos_InitHeap();
1421
	load_edit_box();
1114 leency 1422
	init();
2749 leency 1423
 
1114 leency 1424
	for (;;)
1425
	{
2750 leency 1426
		switch (kos_WaitForEventTimeout(10))
1114 leency 1427
		{
990 barsuk 1428
		case 0:
1114 leency 1429
			process_mouse();
990 barsuk 1430
			break;
1114 leency 1431
		case 1:
1432
			window_drawall=true;
1433
			draw_window();
1434
			break;
1435
		case 2:
1436
			process_key();
1437
			break;
1438
		case 3:
1439
			process_button();
1440
			break;
990 barsuk 1441
		//case 6:
1442
		//	draw_window();
1114 leency 1443
		//	break;
1444
		}
1445
	}
1446
}
1447