summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/gui/progressbar.cpp54
-rw-r--r--src/gui/progressbar.h32
-rw-r--r--src/gui/setup.cpp154
-rw-r--r--src/gui/setup.h30
4 files changed, 146 insertions, 124 deletions
diff --git a/src/gui/progressbar.cpp b/src/gui/progressbar.cpp
index aa396a70..5ef5e03f 100644
--- a/src/gui/progressbar.cpp
+++ b/src/gui/progressbar.cpp
@@ -25,13 +25,12 @@
#include "gui.h"
#include "../resources/resourcemanager.h"
-ProgressBar::ProgressBar(float progress, int x, int y, int width, int height, unsigned char red, unsigned green, unsigned char blue) :
-gcn::Widget()
+ProgressBar::ProgressBar(float progress, int x, int y, int width, int height,
+ unsigned char red, unsigned green, unsigned char blue):
+ gcn::Widget(),
+ red(red), green(green), blue(blue)
{
setProgress(progress);
- Red = red;
- Green = green;
- Blue = blue;
setX(x);
setY(y);
setWidth(width);
@@ -66,7 +65,7 @@ gcn::Widget()
colorBar = new Image();
colorBar->create(getWidth() - 8, getHeight() - 8);
- colorBar->fillWithColor(Red, Green, Blue);
+ colorBar->fillWithColor(red, green, blue);
colorBar->setAlpha(0.7f);
}
@@ -79,29 +78,32 @@ ProgressBar::~ProgressBar()
void ProgressBar::draw(gcn::Graphics *graphics)
{
-#ifndef USE_OPENGL
int absx, absy;
getAbsolutePosition(absx, absy);
// We're drawing the bar itself first
// Background
- dBackground->drawPattern(screen, absx+4, absy+4, getWidth()-8, getHeight()-8);
+ dBackground->drawPattern(screen,
+ absx + 4, absy + 4,
+ getWidth() - 8, getHeight() - 8);
+
// The corners
dTopLeftBorder->draw(screen, absx, absy);
- dTopRightBorder->draw(screen, absx+getWidth()-4, absy);
- dBottomLeftBorder->draw(screen, absx, absy+getHeight()-4);
- dBottomRightBorder->draw(screen, absx+getWidth()-4, absy+getHeight()-4);
+ dTopRightBorder->draw(screen, absx + getWidth() - 4, absy);
+ dBottomLeftBorder->draw(screen, absx, absy + getHeight() - 4);
+ dBottomRightBorder->draw(screen,
+ absx+getWidth() - 4, absy+getHeight() - 4);
// The borders
- dTopBorder->drawPattern(screen, absx+4, absy, getWidth()-8, 4);
- dBottomBorder->drawPattern(screen, absx+4, absy+getHeight()-4, getWidth()-8, 4);
- dLeftBorder->drawPattern(screen, absx, absy+4, 4, getHeight()-8);
- dRightBorder->drawPattern(screen, absx+getWidth()-4, absy+4, 4, getHeight()-8);
+ dTopBorder->drawPattern(screen, absx + 4, absy, getWidth() - 8, 4);
+ dBottomBorder->drawPattern(screen, absx + 4, absy + getHeight() - 4,
+ getWidth() - 8, 4);
+ dLeftBorder->drawPattern(screen, absx, absy + 4, 4, getHeight() - 8);
+ dRightBorder->drawPattern(screen, absx + getWidth() - 4, absy + 4,
+ 4, getHeight() - 8);
colorBar->draw(screen, 0, 0, absx + 4, absy + 4,
- int(progress*float(getWidth()-4)), getHeight() - 8);
-
-#endif
+ (int)(progress * float(getWidth() - 4)), getHeight() - 8);
}
void ProgressBar::setProgress(float progress)
@@ -114,17 +116,15 @@ float ProgressBar::getProgress()
return progress;
}
-void ProgressBar::setColor(unsigned char MyRed, unsigned char MyGreen,
- unsigned char MyBlue)
+void ProgressBar::setColor(
+ unsigned char newRed, unsigned char newGreen, unsigned char newBlue)
{
- if ( (Red == MyRed) && (Green == MyGreen) && (Blue == MyBlue) )
- {
- // Nothing
- }
- else
+ if (!(red == newRed) && (green == newGreen) && (blue == newBlue))
{
- Red = MyRed; Green = MyGreen; Blue = MyBlue;
- colorBar->fillWithColor(Red, Green, Blue);
+ red = newRed;
+ green = newGreen;
+ blue = newBlue;
+ colorBar->fillWithColor(red, green, blue);
colorBar->setAlpha(0.7f);
}
}
diff --git a/src/gui/progressbar.h b/src/gui/progressbar.h
index 5da046b7..c8bb22d6 100644
--- a/src/gui/progressbar.h
+++ b/src/gui/progressbar.h
@@ -38,11 +38,12 @@ class ProgressBar : public gcn::Widget {
* Constructor, initializes the progress with the given value.
*/
ProgressBar(float progress = 0.0f, int x = 0, int y = 0,
- int width = 40, int height = 7, unsigned char red = 150, unsigned green = 150,
+ int width = 40, int height = 7,
+ unsigned char red = 150, unsigned green = 150,
unsigned char blue = 150);
/**
- * Destructor
+ * Destructor.
*/
~ProgressBar();
@@ -62,38 +63,47 @@ class ProgressBar : public gcn::Widget {
float getProgress();
/**
- * Change the filling of the progress bar...
+ * Change the filling of the progress bar.
*/
void setColor(
- unsigned char MyRed,
- unsigned char MyGreen,
- unsigned char MyBlue);
+ unsigned char red,
+ unsigned char green,
+ unsigned char blue);
/**
* Get The red value of color
*/
unsigned char getRed()
- { return Red; };
+ {
+ return red;
+ }
/**
* Get The red value of color
*/
unsigned char getGreen()
- { return Green; };
+ {
+ return green;
+ }
/**
* Get The red value of color
*/
unsigned char getBlue()
- { return Blue; };
+ {
+ return blue;
+ }
private:
float progress;
- unsigned char Red, Green, Blue;
+ unsigned char red, green, blue;
+
// Bar Images
Image *dBackground;
- Image *dTopLeftBorder, *dTopRightBorder, *dBottomLeftBorder, *dBottomRightBorder;
+ Image *dTopLeftBorder, *dTopRightBorder, *dBottomLeftBorder;
+ Image *dBottomRightBorder;
Image *dLeftBorder, *dRightBorder, *dTopBorder, *dBottomBorder;
+
// Our color bar
Image *colorBar;
};
diff --git a/src/gui/setup.cpp b/src/gui/setup.cpp
index ea2bb6bf..b43a469c 100644
--- a/src/gui/setup.cpp
+++ b/src/gui/setup.cpp
@@ -41,48 +41,55 @@
SDL_Rect **modes;
-ModeListModel::ModeListModel() {
- int i;
-
- modes = SDL_ListModes(NULL, SDL_FULLSCREEN|SDL_HWSURFACE);
-
- // Check if any modes available
- if(modes == (SDL_Rect **)0) {
- nmode=0;
- puts("No modes");
- }
-
- // Check if modes restricted
- if(modes == (SDL_Rect **)-1)
- puts("Modes restricted");
-
- for(nmode=0;modes[nmode];++nmode);
-
- mode = (char **) calloc(nmode, sizeof(char *));
-
- for(i=0;modes[i];++i) {
- char *temp = (char *)malloc(20 * sizeof(char));
+ModeListModel::ModeListModel()
+{
+ int i;
+
+ modes = SDL_ListModes(NULL, SDL_FULLSCREEN | SDL_HWSURFACE);
+
+ // Check if any modes available
+ if (modes == (SDL_Rect**)0) {
+ nmode = 0;
+ puts("No modes");
+ }
+
+ // Check if modes restricted
+ if (modes == (SDL_Rect**) - 1) {
+ puts("Modes restricted");
+ }
+
+ for (nmode = 0; modes[nmode]; ++nmode);
+
+ mode = (char**)calloc(nmode, sizeof(char*));
+
+ for (i = 0; modes[i]; ++i) {
+ char *temp = (char*)malloc(20 * sizeof(char));
mode[i] = temp;
- if(sprintf(mode[i], "%d x %d", modes[i]->w, modes[i]->h) == -1)
- puts("Cannot allocate mode list");
- }
+ if (sprintf(mode[i], "%d x %d", modes[i]->w, modes[i]->h) == -1)
+ puts("Cannot allocate mode list");
+ }
}
-ModeListModel::~ModeListModel() {
- int i;
-
- // Cleanup
- for(i=0;i<nmode;i++)
- free(mode[i]);
- free(mode);
+ModeListModel::~ModeListModel()
+{
+ int i;
+
+ // Cleanup
+ for (i = 0; i < nmode; i++) {
+ free(mode[i]);
+ }
+
+ free(mode);
}
-int ModeListModel::getNumberOfElements() {
- return nmode;
+int ModeListModel::getNumberOfElements()
+{
+ return nmode;
}
-std::string ModeListModel::getElementAt(int i) {
- return mode[i];
+std::string ModeListModel::getElementAt(int i)
+{
+ return mode[i];
}
Setup::Setup():
@@ -147,7 +154,8 @@ Setup::Setup():
soundCheckBox->setMarked(config.getValue("sound", 0));
}
-Setup::~Setup() {
+Setup::~Setup()
+{
delete modeListModel;
delete modeList;
delete scrollArea;
@@ -159,53 +167,57 @@ Setup::~Setup() {
delete cancelButton;
}
-void Setup::action(const std::string& eventId)
+void Setup::action(const std::string &eventId)
{
- if (eventId == "apply") {
+ if (eventId == "apply")
+ {
setVisible(false);
-
- // Select video mode
+
+ // Select video mode
sel = modeList->getSelected();
-
- if(sel != last_sel) {
- last_sel = sel;
- screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32, SDL_FULLSCREEN | SDL_HWSURFACE);
- }
-
+
+ if (sel != last_sel) {
+ last_sel = sel;
+ screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32,
+ SDL_FULLSCREEN | SDL_HWSURFACE);
+ }
+
// Display settings
if (fsCheckBox->isMarked() && config.getValue("screen", 0) == 0)
{
config.setValue("screen", 1);
- #if __USE_UNIX98
- SDL_WM_ToggleFullScreen(screen);
- #else
- int displayFlags = 0;
- displayFlags |= SDL_FULLSCREEN;
- if ((int)config.getValue("hwaccel", 0)) {
- displayFlags |= SDL_HWSURFACE | SDL_DOUBLEBUF;
- }
- else {
- displayFlags |= SDL_SWSURFACE;
- }
- screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32, displayFlags);
- #endif
+#if __USE_UNIX98
+ SDL_WM_ToggleFullScreen(screen);
+#else
+ int displayFlags = 0;
+ displayFlags |= SDL_FULLSCREEN;
+ if ((int)config.getValue("hwaccel", 0)) {
+ displayFlags |= SDL_HWSURFACE | SDL_DOUBLEBUF;
+ }
+ else {
+ displayFlags |= SDL_SWSURFACE;
+ }
+ screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32,
+ displayFlags);
+#endif
}
else if (!fsCheckBox->isMarked() && config.getValue("screen", 0) == 1)
{
config.setValue("screen", 0);
- #if __USE_UNIX98
- SDL_WM_ToggleFullScreen(screen);
- #else
- int displayFlags = 0;
- if ((int)config.getValue("hwaccel", 0)) {
- displayFlags |= SDL_HWSURFACE | SDL_DOUBLEBUF;
- }
- else {
- displayFlags |= SDL_SWSURFACE;
- }
- screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32, displayFlags);
- #endif
+#if __USE_UNIX98
+ SDL_WM_ToggleFullScreen(screen);
+#else
+ int displayFlags = 0;
+ if ((int)config.getValue("hwaccel", 0)) {
+ displayFlags |= SDL_HWSURFACE | SDL_DOUBLEBUF;
+ }
+ else {
+ displayFlags |= SDL_SWSURFACE;
+ }
+ screen = SDL_SetVideoMode(modes[sel]->w, modes[sel]->h, 32,
+ displayFlags);
+#endif
}
// Sound settings
diff --git a/src/gui/setup.h b/src/gui/setup.h
index e1f28beb..2bfab15e 100644
--- a/src/gui/setup.h
+++ b/src/gui/setup.h
@@ -35,6 +35,16 @@
class ModeListModel : public gcn::ListModel {
public:
/**
+ * Constructor.
+ */
+ ModeListModel();
+
+ /**
+ * Destructor.
+ */
+ virtual ~ModeListModel();
+
+ /**
* Returns the number of elements in container.
*/
int getNumberOfElements();
@@ -44,19 +54,9 @@ class ModeListModel : public gcn::ListModel {
*/
std::string getElementAt(int i);
- /**
- * Constructor.
- */
- ModeListModel();
-
- /**
- * Destructor.
- */
- virtual ~ModeListModel();
-
private:
- int nmode;
- char **mode;
+ int nmode;
+ char **mode;
};
/**
@@ -78,9 +78,9 @@ class Setup : public Window, public gcn::ActionListener {
gcn::Button *applyButton;
gcn::Button *cancelButton;
- // Video selections
- int last_sel, sel;
-
+ // Video selections
+ int last_sel, sel;
+
public:
/**