mirror of
git://projects.qi-hardware.com/gmenu2x.git
synced 2024-11-26 17:43:10 +02:00
BrowseDialog: Code layout cleanup.
No functional changes, except for fetching "topBarHeight" only once.
This commit is contained in:
parent
58d6077e5c
commit
46f2edbc76
@ -58,10 +58,11 @@ bool BrowseDialog::exec()
|
|||||||
|
|
||||||
fl->browse();
|
fl->browse();
|
||||||
|
|
||||||
|
const int topBarHeight = gmenu2x->skinConfInt["topBarHeight"];
|
||||||
rowHeight = gmenu2x->font->getHeight() + 1; // gp2x=15+1 / pandora=19+1
|
rowHeight = gmenu2x->font->getHeight() + 1; // gp2x=15+1 / pandora=19+1
|
||||||
numRows = (gmenu2x->resY-gmenu2x->skinConfInt["topBarHeight"]-20)/rowHeight;
|
numRows = (gmenu2x->resY - topBarHeight - 20) / rowHeight;
|
||||||
clipRect = (SDL_Rect){0, gmenu2x->skinConfInt["topBarHeight"]+1, gmenu2x->resX-9, gmenu2x->resY-gmenu2x->skinConfInt["topBarHeight"]-25};
|
clipRect = (SDL_Rect) { 0, topBarHeight + 1, gmenu2x->resX - 9, gmenu2x->resY - topBarHeight - 25 };
|
||||||
touchRect = (SDL_Rect){2, gmenu2x->skinConfInt["topBarHeight"]+4, gmenu2x->resX-12, clipRect.h};
|
touchRect = (SDL_Rect) { 2, topBarHeight + 4, gmenu2x->resX - 12, clipRect.h };
|
||||||
|
|
||||||
selected = 0;
|
selected = 0;
|
||||||
close = false;
|
close = false;
|
||||||
@ -113,10 +114,13 @@ void BrowseDialog::handleInput()
|
|||||||
action = getAction(button);
|
action = getAction(button);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ts.available() && ts.pressed() && !ts.inRect(touchRect)) ts_pressed = false;
|
if (ts.available() && ts.pressed() && !ts.inRect(touchRect)) {
|
||||||
|
ts_pressed = false;
|
||||||
|
}
|
||||||
|
|
||||||
if (action == BrowseDialog::ACT_SELECT && (*fl)[selected] == "..")
|
if (action == BrowseDialog::ACT_SELECT && (*fl)[selected] == "..") {
|
||||||
action = BrowseDialog::ACT_GOUP;
|
action = BrowseDialog::ACT_GOUP;
|
||||||
|
}
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case BrowseDialog::ACT_CLOSE:
|
case BrowseDialog::ACT_CLOSE:
|
||||||
quit();
|
quit();
|
||||||
@ -171,8 +175,9 @@ void BrowseDialog::directoryUp()
|
|||||||
string path = fl->getPath();
|
string path = fl->getPath();
|
||||||
string::size_type p = path.rfind("/");
|
string::size_type p = path.rfind("/");
|
||||||
|
|
||||||
if (p == path.size() - 1)
|
if (p == path.size() - 1) {
|
||||||
p = path.rfind("/", p - 1);
|
p = path.rfind("/", p - 1);
|
||||||
|
}
|
||||||
|
|
||||||
if (p == string::npos || path.compare(0, 1, "/") != 0 || path.length() < 2) {
|
if (p == string::npos || path.compare(0, 1, "/") != 0 || path.length() < 2) {
|
||||||
quit();
|
quit();
|
||||||
@ -185,8 +190,9 @@ void BrowseDialog::directoryUp()
|
|||||||
void BrowseDialog::directoryEnter()
|
void BrowseDialog::directoryEnter()
|
||||||
{
|
{
|
||||||
string path = fl->getPath();
|
string path = fl->getPath();
|
||||||
if (path[path.size()-1] != '/')
|
if (path[path.size()-1] != '/') {
|
||||||
path += "/";
|
path += "/";
|
||||||
|
}
|
||||||
|
|
||||||
setPath(path + fl->at(selected));
|
setPath(path + fl->at(selected));
|
||||||
|
|
||||||
@ -210,7 +216,6 @@ void BrowseDialog::paint()
|
|||||||
unsigned int i, iY;
|
unsigned int i, iY;
|
||||||
unsigned int firstElement, lastElement;
|
unsigned int firstElement, lastElement;
|
||||||
unsigned int offsetY;
|
unsigned int offsetY;
|
||||||
Surface *icon;
|
|
||||||
|
|
||||||
gmenu2x->bg->blit(gmenu2x->s, 0, 0);
|
gmenu2x->bg->blit(gmenu2x->s, 0, 0);
|
||||||
drawTitleIcon("icons/explorer.png", true);
|
drawTitleIcon("icons/explorer.png", true);
|
||||||
@ -222,37 +227,43 @@ void BrowseDialog::paint()
|
|||||||
// TODO(MtH): I have no idea what the right value of firstElement would be,
|
// TODO(MtH): I have no idea what the right value of firstElement would be,
|
||||||
// but originally it was undefined and that is never a good idea.
|
// but originally it was undefined and that is never a good idea.
|
||||||
firstElement = 0;
|
firstElement = 0;
|
||||||
if (selected>firstElement+numRows-1)
|
if (selected>firstElement+numRows - 1) {
|
||||||
firstElement = selected-numRows + 1;
|
firstElement = selected-numRows + 1;
|
||||||
else if (selected < firstElement)
|
} else if (selected < firstElement) {
|
||||||
firstElement = selected;
|
firstElement = selected;
|
||||||
|
}
|
||||||
|
|
||||||
//Selection
|
//Selection
|
||||||
iY = selected-firstElement;
|
const int topBarHeight = gmenu2x->skinConfInt["topBarHeight"];
|
||||||
iY = gmenu2x->skinConfInt["topBarHeight"]+1+(iY*rowHeight);
|
iY = topBarHeight + 1 + (selected - firstElement) * rowHeight;
|
||||||
gmenu2x->s->box(2, iY, gmenu2x->resX-12, rowHeight-1, gmenu2x->skinConfColors[COLOR_SELECTION_BG]);
|
gmenu2x->s->box(2, iY, gmenu2x->resX - 12, rowHeight - 1,
|
||||||
|
gmenu2x->skinConfColors[COLOR_SELECTION_BG]);
|
||||||
|
|
||||||
lastElement = firstElement + numRows;
|
lastElement = firstElement + numRows;
|
||||||
if (lastElement > fl->size())
|
if (lastElement > fl->size())
|
||||||
lastElement = fl->size();
|
lastElement = fl->size();
|
||||||
|
|
||||||
offsetY = gmenu2x->skinConfInt["topBarHeight"]+1;
|
offsetY = topBarHeight + 1;
|
||||||
|
|
||||||
//Files & Directories
|
//Files & Directories
|
||||||
gmenu2x->s->setClipRect(clipRect);
|
gmenu2x->s->setClipRect(clipRect);
|
||||||
for (i = firstElement; i < lastElement; i++) {
|
for (i = firstElement; i < lastElement; i++) {
|
||||||
|
Surface *icon;
|
||||||
if (fl->isDirectory(i)) {
|
if (fl->isDirectory(i)) {
|
||||||
if ((*fl)[i]=="..")
|
if ((*fl)[i] == "..") {
|
||||||
icon = iconGoUp;
|
icon = iconGoUp;
|
||||||
else
|
} else {
|
||||||
icon = iconFolder;
|
icon = iconFolder;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
icon = iconFile;
|
icon = iconFile;
|
||||||
}
|
}
|
||||||
icon->blit(gmenu2x->s, 5, offsetY);
|
icon->blit(gmenu2x->s, 5, offsetY);
|
||||||
gmenu2x->s->write(gmenu2x->font, (*fl)[i], 24, offsetY + 8, ASFont::HAlignLeft, ASFont::VAlignMiddle);
|
gmenu2x->s->write(gmenu2x->font, (*fl)[i], 24, offsetY + 8,
|
||||||
|
ASFont::HAlignLeft, ASFont::VAlignMiddle);
|
||||||
|
|
||||||
if (ts.available() && ts.pressed() && ts.inRect(touchRect.x, offsetY + 3, touchRect.w, rowHeight)) {
|
if (ts.available() && ts.pressed()
|
||||||
|
&& ts.inRect(touchRect.x, offsetY + 3, touchRect.w, rowHeight)) {
|
||||||
ts_pressed = true;
|
ts_pressed = true;
|
||||||
selected = i;
|
selected = i;
|
||||||
}
|
}
|
||||||
@ -261,6 +272,7 @@ void BrowseDialog::paint()
|
|||||||
}
|
}
|
||||||
gmenu2x->s->clearClipRect();
|
gmenu2x->s->clearClipRect();
|
||||||
|
|
||||||
gmenu2x->drawScrollBar(numRows,fl->size(),firstElement,clipRect.y,clipRect.h);
|
gmenu2x->drawScrollBar(
|
||||||
|
numRows,fl->size(), firstElement, clipRect.y, clipRect.h);
|
||||||
gmenu2x->s->flip();
|
gmenu2x->s->flip();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user