Subversion Repositories Kolibri OS

Rev

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

Rev Author Line No. Line
5598 pavelyakov 1
#ifndef INCLUDE_DRAW_BUF_H
2
#define INCLUDE_DRAW_BUF_H
5676 pavelyakov 3
#print "[include ]\n"
4486 leency 4
 
5598 pavelyakov 5
#ifndef INCLUDE_KOLIBRI_H
6
#include "../lib/kolibri.h"
7
#endif
8
 
6672 leency 9
unsigned buf_data;
4475 leency 10
 
5519 leency 11
 
4475 leency 12
struct DrawBufer {
6672 leency 13
	unsigned bufx, bufy, bufw, bufh;
5678 leency 14
	byte zoom;
4475 leency 15
 
16
	void Init();
4666 leency 17
	void Show();
4475 leency 18
	void Fill();
19
	void Skew();
20
	void DrawBar();
4666 leency 21
	void PutPixel();
4475 leency 22
	void AlignCenter();
23
	void AlignRight();
24
};
25
 
4666 leency 26
void DrawBufer::Init(int i_bufx, i_bufy, i_bufw, i_bufh)
4475 leency 27
{
6672 leency 28
	if (!zoom) zoom = 1;
4475 leency 29
	bufx = i_bufx;
30
	bufy = i_bufy;
5678 leency 31
	bufw = i_bufw * zoom;
32
	bufh = i_bufh * zoom;
4475 leency 33
	free(buf_data);
5519 leency 34
	buf_data = malloc(bufw * bufh * 4 + 8);
4475 leency 35
	ESDWORD[buf_data] = bufw;
4666 leency 36
	ESDWORD[buf_data+4] = bufh;
37
}
38
 
6672 leency 39
void DrawBufer::Fill(unsigned fill_color)
4475 leency 40
{
6672 leency 41
	unsigned i;
42
	unsigned max_i = bufw * bufh * 4 + buf_data + 8;
4486 leency 43
	for (i=buf_data+8; i
4475 leency 44
}
45
 
6672 leency 46
void DrawBufer::DrawBar(unsigned x, y, w, h, color)
4475 leency 47
{
48
	int i, j;
49
	for (j=0; j
50
	{
4486 leency 51
		for (i = y+j*bufw+x*4+8+buf_data; i
4475 leency 52
	}
53
}
54
 
6672 leency 55
void DrawBufer::PutPixel(unsigned x, y, color)
4666 leency 56
{
57
	int pos = y*bufw+x*4+8+buf_data;
58
	ESDWORD[pos] = color;
59
}
60
 
4475 leency 61
char shift[]={8,8,4,4};
6672 leency 62
void DrawBufer::Skew(unsigned x, y, w, h)
4475 leency 63
{
64
	int i, j;
65
	for (j=0; j<=3; j++)
66
	{
67
		for (i = y+j*bufw+x+w+h*4; i>y+j*bufw+x+h-12*4 ; i-=4)
68
								ESDWORD[buf_data+i+8] = ESDWORD[-shift[j]+buf_data+i+8];
69
	}
70
}
71
 
6672 leency 72
void DrawBufer::AlignRight(unsigned x,y,w,h, content_width)
4475 leency 73
{
74
	int i, j, l;
75
	int content_left = w - content_width / 2;
76
	for (j=0; j
77
	{
78
		for (i=j*w+w-x*4, l=j*w+content_width+x*4; (i>=j*w+content_left*4) && (l>=j*w*4); i-=4, l-=4)
79
		{
80
			ESDWORD[buf_data+8+i] >< ESDWORD[buf_data+8+l];
81
		}
82
	}
83
}
84
 
6672 leency 85
void DrawBufer::AlignCenter(unsigned x,y,w,h, content_width)
4475 leency 86
{
87
	int i, j, l;
88
	int content_left = w - content_width / 2;
89
	for (j=0; j
90
	{
91
		for (i=j*w+content_width+content_left*4, l=j*w+content_width+x*4; (i>=j*w+content_left*4) && (l>=j*w*4); i-=4, l-=4)
92
		{
93
			ESDWORD[buf_data+8+i] >< ESDWORD[buf_data+8+l];
94
		}
95
	}
96
}
97
 
5678 leency 98
/*
5519 leency 99
void DrawBufer::Zoom2x()
100
{
101
	int i, s;
6672 leency 102
	unsigned point_x, max_i, zline_w, s_inc;
4475 leency 103
 
5519 leency 104
	point_x = 0;
105
	max_i = bufw * bufh * 4 + buf_data+8;
5678 leency 106
	s_inc = zoom * 4;
5519 leency 107
	zline_w = zbufw * 4;
108
 
109
	for (i=buf_data+8, s=zbuf_data+8; i
110
		ESDWORD[s] = ESDWORD[i];
111
		ESDWORD[s+4] = ESDWORD[i];
112
		ESDWORD[s+zline_w] = ESDWORD[i];
113
		ESDWORD[s+zline_w+4] = ESDWORD[i];
5678 leency 114
		if (zoom==3)
5519 leency 115
		{
116
			ESDWORD[s+8] = ESDWORD[i];
117
			ESDWORD[zline_w+s+8] = ESDWORD[i];
118
			ESDWORD[zline_w*2+s] = ESDWORD[i];
119
			ESDWORD[zline_w*2+s+4] = ESDWORD[i];
120
			ESDWORD[zline_w*2+s+8] = ESDWORD[i];
121
		}
122
 
123
		point_x++;
124
		if (point_x >= bufw)
125
		{
5678 leency 126
			s += zoom - 1 * zline_w;
5519 leency 127
			point_x = 0;
128
		}
129
	}
130
}
5678 leency 131
*/
5519 leency 132
 
133
 
134
void DrawBufer::Show()
135
{
5678 leency 136
	PutPaletteImage(buf_data+8, bufw, bufh, bufx, bufy, 32, 0);
5519 leency 137
}
5598 pavelyakov 138
 
139
#endif