summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYohann Ferreira <bertram@cegetel.net>2005-02-18 06:13:22 +0000
committerYohann Ferreira <bertram@cegetel.net>2005-02-18 06:13:22 +0000
commitcdd4de53578595316c282e32699b075ae925ce1e (patch)
treea2c388c072f2113b7e542b779a58caad62c58c2f
parent828c90b4f858e8e39ac7a11bb2f6100871a02ef9 (diff)
downloadmana-cdd4de53578595316c282e32699b075ae925ce1e.tar.gz
mana-cdd4de53578595316c282e32699b075ae925ce1e.tar.bz2
mana-cdd4de53578595316c282e32699b075ae925ce1e.tar.xz
mana-cdd4de53578595316c282e32699b075ae925ce1e.zip
The Gui v3
-rw-r--r--src/gui/window.cpp92
-rw-r--r--src/gui/window.h6
2 files changed, 70 insertions, 28 deletions
diff --git a/src/gui/window.cpp b/src/gui/window.cpp
index 0cc4c95c..8f9d819e 100644
--- a/src/gui/window.cpp
+++ b/src/gui/window.cpp
@@ -47,9 +47,21 @@ Window::Window(const std::string& text, bool modal, Window *parent):
// Load dialog title bar image
ResourceManager *resman = ResourceManager::getInstance();
- dLeft = resman->getImage("core/graphics/gui/dialog_left.png");
- dMid = resman->getImage("core/graphics/gui/dialog_middle.png");
- dRight = resman->getImage("core/graphics/gui/dialog_right.png");
+ dBorders = resman->getImage("core/graphics/gui/vscroll_grey.png");
+ dBackground = resman->getImage("core/graphics/gui/bg_quad_dis.png");
+ dWindowSurface = 0;
+
+ dWindowSurface = SDL_AllocSurface(SDL_SWSURFACE, 20, 20, (screen->format->BytesPerPixel*8), 0, 0, 0, 0);
+ Uint32 boxColor = SDL_MapRGB(screen->format, 255, 0, 255);
+ SDL_Rect sourceRect;
+ sourceRect.x = sourceRect.y = 0;
+ sourceRect.w = 20;
+ sourceRect.h = 20;
+ if ( dWindowSurface )
+ {
+ SDL_FillRect(dWindowSurface, &sourceRect, boxColor);
+ //SDL_SetAlpha(chatBoxBackground, SDL_SRCALPHA, 120);
+ }
// Register mouse listener
addMouseListener(this);
@@ -74,6 +86,7 @@ Window::~Window()
log("Window::~Window(\"%s\")", caption.c_str());
// Free dialog bitmaps
+ SDL_FreeSurface(dWindowSurface);
//release_bitmap(dLeft);
//release_bitmap(dMid);
//release_bitmap(dRight);
@@ -88,30 +101,59 @@ void Window::setWindowContainer(WindowContainer *wc)
void Window::draw(gcn::Graphics* graphics)
{
- // Draw container background when opaque
- if (mOpaque) {
- graphics->setColor(getBaseColor());
- graphics->fillRectangle(gcn::Rectangle(0, titlebarHeight,
- getDimension().width,
- getDimension().height - titlebarHeight));
- }
- // Draw line around window
- graphics->setColor(titlebarColor);
- graphics->drawRectangle(gcn::Rectangle(0, titlebarHeight - 1,
- getWidth(), getHeight() - titlebarHeight + 1));
-
- // Skinned dialog render
+ // Resize the Window Image if it's has to be done
+ if ( (dWindowSurface->w != getWidth()) || (dWindowSurface->h != getHeight()) )
+ {
+ SDL_FreeSurface(dWindowSurface);
+ dWindowSurface = SDL_AllocSurface(SDL_SWSURFACE | SDL_SRCCOLORKEY | SDL_SRCALPHA, getWidth(), getHeight(),
+ (screen->format->BytesPerPixel*8), 0, 0, 0, 0);
+ SDL_Rect sourceRect;
+ sourceRect.x = sourceRect.y = 0;
+ sourceRect.w = getWidth();
+ sourceRect.h = getHeight();
+ if ( dWindowSurface )
+ {
+ // Draw the background
+ dBackground->drawPattern(dWindowSurface, 0, 0, getWidth(), getHeight());
+ // Draw the borders
+ dBorders->draw(dWindowSurface, 0, 0, 0, 0, 4, 4); // Top-Left
+ dBorders->draw(dWindowSurface, 7, 0, getWidth()-3, 0, 4, 4); // Top-Right
+ dBorders->draw(dWindowSurface, 7, 15, getWidth()-3, getHeight()-3, 4, 4); // Bottom-Right
+ dBorders->draw(dWindowSurface, 0, 15, 0, getHeight()-3, 4, 4); // Bottom-Left
+
+ // Upper Border
+ Image *dTemp = dBorders->getSubImage(4,0,1,3);
+ dTemp->drawPattern(dWindowSurface, 4, 0, getWidth()-4-3, 3);
+ delete dTemp;
+ // Left Border
+ dTemp = dBorders->getSubImage(0,4,3,1);
+ dTemp->drawPattern(dWindowSurface, 0, 4, 3, getHeight()-4-3);
+ delete dTemp;
+ // Right Border
+ dTemp = dBorders->getSubImage(8,4,3,1);
+ dTemp->drawPattern(dWindowSurface, getWidth()-2, 4, 3, getHeight()-4-3);
+ delete dTemp;
+ // Bottom Border
+ dTemp = dBorders->getSubImage(8,15,1,3);
+ dTemp->drawPattern(dWindowSurface, 4, getHeight()-2, getWidth()-4-3, 3);
+ delete dTemp;
+
+ SDL_SetAlpha(dWindowSurface, SDL_SRCALPHA, 160);
+ }
+
+ }
+
int x, y;
- getAbsolutePosition(x, y);
-
- // Draw title bar
- dLeft->draw(screen, x, y);
- dMid->drawPattern(screen,
- x + dLeft->getWidth(), y,
- getWidth() - dLeft->getWidth() - dRight->getWidth(),
- dMid->getHeight());
- dRight->draw(screen, x + getWidth() - dRight->getWidth(), y);
+ getAbsolutePosition(x, y);
+
+ // Draw the window image
+ SDL_Rect screenRect;
+ screenRect.w = getWidth();
+ screenRect.h = getHeight();
+ screenRect.x = x;
+ screenRect.y = y;
+ if ( dWindowSurface ) SDL_BlitSurface(dWindowSurface, NULL, screen, &screenRect);
// Draw title
graphics->setFont(getFont());
diff --git a/src/gui/window.h b/src/gui/window.h
index 9e5efa14..2e9fb034 100644
--- a/src/gui/window.h
+++ b/src/gui/window.h
@@ -49,9 +49,9 @@ class Window : public gcn::Container, public gcn::MouseListener
gcn::Color titlebarColor; /**< Title bar color */
int titlebarHeight; /**< Height of title bar */
- Image *dLeft; /**< Left side of title bar */
- Image *dMid; /**< Middle of title bar */
- Image *dRight; /**< Right side of title bar */
+ Image *dBackground; /**< Left side of title bar */
+ Image *dBorders; /**< Middle of title bar */
+ SDL_Surface *dWindowSurface; /**< The Window Surface */
/** The window container windows add themselves to. */
static WindowContainer* windowContainer;