summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorpixel <pixel>2003-04-13 17:03:09 +0000
committerpixel <pixel>2003-04-13 17:03:09 +0000
commitebc6bb16f895b7c192b9f4c42d1fc4feb41e271c (patch)
treec8d15fe476d561a22cd1f5803f89fe7727c7e6dd /lib
parent102649b120a762b760cf618d6a61bdabb910f945 (diff)
broken... but well... who cares...
Diffstat (limited to 'lib')
-rw-r--r--lib/shape.cc133
1 files changed, 121 insertions, 12 deletions
diff --git a/lib/shape.cc b/lib/shape.cc
index 84e89fd..de2a498 100644
--- a/lib/shape.cc
+++ b/lib/shape.cc
@@ -21,7 +21,16 @@ mogltk::fillwalker::~fillwalker() {
void mogltk::fillwalker::step(int x, int y) {
}
-mogltk::fill::fill() : minX(INT_MAX), minY(INT_MAX), maxX(INT_MIN), maxY(INT_MIN), cached(0), header(0) {
+mogltk::segwalker::segwalker() {
+}
+
+mogltk::segwalker::~segwalker() {
+}
+
+mogltk::segwalker::setup(int x1, int y1, int x2, int y2) {
+}
+
+mogltk::fill::fill() : minX(INT_MAX), minY(INT_MAX), maxX(INT_MIN), maxY(INT_MIN), cached(0), scached(0), header(0) {
}
mogltk::fill::~fill() {
@@ -30,19 +39,34 @@ mogltk::fill::~fill() {
if (cached)
delete cached;
+
+ if (scached)
+ delete scached;
}
void mogltk::fill::walk(fillwalker * w) {
header->walk(w);
}
+void mogltk::fill::swalk(segwalker * s) {
+ std::vector<struct segment>::iterator i;
+
+ for (i = segments.begin(); i != segments.end(); i++) {
+ s->setup(i->x1, i->y1, i->x2, i->y2);
+ }
+}
+
void mogltk::fill::insert(int x, int y) {
- printm(M_INFO, "Inserting %i %i\n", x, y);
if (cached) {
delete cached;
cached = 0;
}
+ if (scached) {
+ delete scached;
+ scached = 0;
+ }
+
if (!header) {
new sline(y, this);
}
@@ -65,7 +89,12 @@ void mogltk::fill::insert(int x1, int y1, int x2, int y2) {
int dx, dy, y;
double x, i, i2;
- printm(M_INFO, "Adding line (%i, %i)-(%i, %i)\n", x1, y1, x2, y2);
+ struct segment s;
+ s.x1 = x1;
+ s.y1 = y2;
+ s.x2 = x2;
+ s.y2 = y2;
+ segments.push_back(s);
if (y1 == y2)
return;
@@ -105,6 +134,10 @@ mogltk::texture * mogltk::fill::GetTexture() {
return cached;
}
+mogltk::texture * mogltk::fill::GetSTexture() {
+ return scached;
+}
+
mogltk::texture * mogltk::fill::Talloc() {
if (cached)
return cached;
@@ -118,6 +151,19 @@ mogltk::texture * mogltk::fill::Talloc() {
return cached;
}
+mogltk::texture * mogltk::fill::STalloc() {
+ if (scached)
+ return scached;
+
+ int x; int y;
+
+ for (x = 1; x < (maxX - minX); x <<= 1);
+ for (y = 1; y < (maxY - minY); y <<= 1);
+
+ scached = new texture(x, y, true);
+ return scached;
+}
+
mogltk::fill::sline::sline(int _y, fill * _header) : y(_y), header(_header), pheader(0) {
if (!header->header) {
header->header = this;
@@ -244,13 +290,22 @@ mogltk::fill::sline * mogltk::fill::sline::look(int _y) {
return next->look(_y);
}
+mogltk::shape(SDL_Surface * _surf) : surf(_surf) {
+ if (!tex)
+ tex = mogltk::engine::base_o->GetSurface();
+}
+
+SDL_Surface * mogltk::GetSurf() {
+ return Surf;
+}
+
void mogltk::shape::box(int x1, int y1, int x2, int y2, ColorP c) {
ENTER;
SDL_Rect rect;
rect.x = x1; rect.y = y1; rect.w = x2 - x1 + 1; rect.h = y2 - y1 + 1;
- SDL_FillRect(mogltk::engine::base_o->getsurface(), &rect, c.toSDL());
+ SDL_FillRect(Surf, &rect, c.toSDL(Surf));
LEAVE;
}
@@ -412,10 +467,9 @@ void mogltk::shape::line(int x1, int y1, int x2, int y2, ColorP c) {
void mogltk::shape::pixel(int x, int y, ColorP c) {
ENTER;
- SDL_Surface * surface = mogltk::engine::base_o->getsurface();
int bpp = surface->format->BytesPerPixel;
- Uint8 *p = (Uint8 *)surface->pixels + y * surface->pitch + x * bpp;
- Uint32 pixel = c.toSDL();
+ Uint8 *p = (Uint8 *)Surf->pixels + y * Surf->pitch + x * bpp;
+ Uint32 pixel = c.toSDL(Surf);
switch(bpp) {
case 1:
@@ -487,7 +541,7 @@ mogltk::fill * mogltk::shape::fcircle(int x0, int y0, int r) {
int rI = 6;
mogltk::fill * f = new fill();
bool t = false;
- int ox, oy;
+ int ox = 0, oy = 0;
while (x <= y) {
/*
@@ -585,7 +639,62 @@ void mogltk::shape::fdraw(fill * f, ColorP c, int sx, int sy) {
SDL_Rect r;
r.x = f->GetMinX() + sx;
r.y = f->GetMinY() + sy;
- SDL_BlitSurface(f->GetTexture()->GetSurface(), 0, mogltk::engine::base_o->getsurface(), &r);
+ SDL_BlitSurface(f->GetTexture()->GetSurface(), 0, Surf, &r);
+
+ f->last = c.c;
+ LEAVE;
+}
+
+mogltk::segdrawer::segdrawer(fill * _f, texture * _t, ColorP _c) : f(_f), t(_t), c(_c) {
+}
+
+mogltk::segdrawer::~segdrawer() {
+}
+
+void mogltk::segdrawer::step(int x1, int y1, int x2, int y2) {
+ if (oldy != y) {
+ oldx = -1;
+ }
+ if (oldx == -1) {
+ oldx = x;
+ } else {
+// s->hline(oldx, x, y, c);
+ Uint32 * p = t->GetPixels();
+ int i,
+ first = t->GetWidth() * (y - f->GetMinY()) + oldx - f->GetMinX(),
+ last = first - oldx + x;
+ SDL_PixelFormat * format = t->GetFormat();
+
+ for (i = first; i <= last; i++) {
+ p[i] = c.toSDL(format);
+ }
+
+ oldx = -1;
+ }
+ oldy = y;
+}
+
+void mogltk::shape::sdraw(fill * f, ColorP c, int sx, int sy) {
+ ENTER;
+ if (!f->GetSTexture()) {
+ segdrawer * w = new segdrawer(f, f->STalloc(), c);
+ f->swalk(w);
+ delete w;
+ f->last = c.c;
+ }
+ SDL_PixelFormat * format = f->GetSTexture()->GetFormat();
+
+ if (f->last == c.c) {
+ Uint32 * p = f->GetSTexture()->GetPixels();
+ int i, n = f->GetSTexture()->GetWidth() * f->GetSTexture()->GetHeight();
+ for (i = 0; i < n; i++)
+ if (p[i] & 0xff000000)
+ p[i] = c.toSDL(format);
+ }
+ SDL_Rect r;
+ r.x = f->GetMinX() + sx;
+ r.y = f->GetMinY() + sy;
+ SDL_BlitSurface(f->GetSTexture()->GetSurface(), 0, Surf, &r);
f->last = c.c;
LEAVE;
@@ -745,8 +854,8 @@ void mogltk::shape::button(int x1, int y1, int x2, int y2,
}
bool mogltk::shape::Enter() {
- if (SDL_MUSTLOCK(mogltk::engine::base_o->getsurface())) {
- SDL_LockSurface(mogltk::engine::base_o->getsurface());
+ if (SDL_MUSTLOCK(Surf)) {
+ SDL_LockSurface(Surf);
return true;
} else {
return false;
@@ -755,7 +864,7 @@ bool mogltk::shape::Enter() {
void mogltk::shape::Leave(bool locked) {
if (locked)
- SDL_UnlockSurface(mogltk::engine::base_o->getsurface());
+ SDL_UnlockSurface(Surf);
}
void mogltk::shape::tbox(texture *, int x1, int y1, int x2, int y2, int tx, int ty, double f, ColorP c) {