GuiScraperMulti now reports the number of games scraped.

Added proper horizontal padding to GuiMsgBox.
This commit is contained in:
Aloshi 2014-03-28 20:58:45 -05:00
parent 391e299f79
commit 6f64e647b9
3 changed files with 28 additions and 17 deletions

View file

@ -5,6 +5,8 @@
#include "../components/MenuComponent.h" // for makeButtonGrid #include "../components/MenuComponent.h" // for makeButtonGrid
#include "../Util.h" #include "../Util.h"
#define HORIZONTAL_PADDING_PX 20
GuiMsgBox::GuiMsgBox(Window* window, const std::string& text, GuiMsgBox::GuiMsgBox(Window* window, const std::string& text,
const std::string& name1, const std::function<void()>& func1, const std::string& name1, const std::function<void()>& func1,
const std::string& name2, const std::function<void()>& func2, const std::string& name2, const std::function<void()>& func2,
@ -15,7 +17,8 @@ GuiMsgBox::GuiMsgBox(Window* window, const std::string& text,
float minWidth = Renderer::getScreenWidth() * 0.3f; // minimum width float minWidth = Renderer::getScreenWidth() * 0.3f; // minimum width
mMsg = std::make_shared<TextComponent>(mWindow, text, Font::get(FONT_SIZE_MEDIUM), 0x777777FF, TextComponent::ALIGN_CENTER); mMsg = std::make_shared<TextComponent>(mWindow, text, Font::get(FONT_SIZE_MEDIUM), 0x777777FF, TextComponent::ALIGN_CENTER);
mGrid.setEntry(mMsg, Eigen::Vector2i(0, 0), false, false);
// create the buttons // create the buttons
mButtons.push_back(std::make_shared<ButtonComponent>(mWindow, name1, name1, std::bind(&GuiMsgBox::deleteMeAndCall, this, func1))); mButtons.push_back(std::make_shared<ButtonComponent>(mWindow, name1, name1, std::bind(&GuiMsgBox::deleteMeAndCall, this, func1)));
if(!name2.empty()) if(!name2.empty())
@ -40,25 +43,20 @@ GuiMsgBox::GuiMsgBox(Window* window, const std::string& text,
// put the buttons into a ComponentGrid // put the buttons into a ComponentGrid
mButtonGrid = makeButtonGrid(mWindow, mButtons); mButtonGrid = makeButtonGrid(mWindow, mButtons);
mGrid.setEntry(mMsg, Eigen::Vector2i(0, 0), false, true);
mGrid.setEntry(mButtonGrid, Eigen::Vector2i(0, 1), true, false, Eigen::Vector2i(1, 1), GridFlags::BORDER_TOP); mGrid.setEntry(mButtonGrid, Eigen::Vector2i(0, 1), true, false, Eigen::Vector2i(1, 1), GridFlags::BORDER_TOP);
if(mMsg->getSize().x() > width) // decide final width
if(mMsg->getSize().x() < width && mButtonGrid->getSize().x() < width)
{ {
mMsg->setSize(width, 0); // mMsg and buttons are narrower than width
}else{ width = std::max(mButtonGrid->getSize().x(), mMsg->getSize().x());
// mMsg is narrower than width width = std::max(width, minWidth);
// are buttons?
if(mButtonGrid->getSize().x() < width)
{
width = std::max(mButtonGrid->getSize().x(), mMsg->getSize().x());
width = std::max(width, minWidth);
}
} }
// now that we know width, we can find height
mMsg->setSize(width, 0); // mMsg->getSize.y() now returns the proper length
const float msgHeight = std::max(Font::get(FONT_SIZE_LARGE)->getHeight(), mMsg->getSize().y()); const float msgHeight = std::max(Font::get(FONT_SIZE_LARGE)->getHeight(), mMsg->getSize().y());
setSize(width, msgHeight + mButtonGrid->getSize().y()); setSize(width + HORIZONTAL_PADDING_PX*2, msgHeight + mButtonGrid->getSize().y());
// center for good measure // center for good measure
setPosition((Renderer::getScreenWidth() - mSize.x()) / 2.0f, (Renderer::getScreenHeight() - mSize.y()) / 2.0f); setPosition((Renderer::getScreenWidth() - mSize.x()) / 2.0f, (Renderer::getScreenHeight() - mSize.y()) / 2.0f);
@ -81,9 +79,13 @@ bool GuiMsgBox::input(InputConfig* config, Input input)
void GuiMsgBox::onSizeChanged() void GuiMsgBox::onSizeChanged()
{ {
mGrid.setSize(mSize); mGrid.setSize(mSize);
mBackground.fitTo(mSize, Eigen::Vector3f::Zero(), Eigen::Vector2f(-32, -32));
mGrid.setRowHeightPerc(1, mButtonGrid->getSize().y() / mSize.y()); mGrid.setRowHeightPerc(1, mButtonGrid->getSize().y() / mSize.y());
// update messagebox size
mMsg->setSize(mSize.x() - HORIZONTAL_PADDING_PX*2, mGrid.getRowHeight(0));
mGrid.onSizeChanged();
mBackground.fitTo(mSize, Eigen::Vector3f::Zero(), Eigen::Vector2f(-32, -32));
} }
void GuiMsgBox::deleteMeAndCall(const std::function<void()>& func) void GuiMsgBox::deleteMeAndCall(const std::function<void()>& func)

View file

@ -21,6 +21,7 @@ GuiScraperMulti::GuiScraperMulti(Window* window, const std::queue<ScraperSearchP
mTotalGames = mSearchQueue.size(); mTotalGames = mSearchQueue.size();
mCurrentGame = 0; mCurrentGame = 0;
mTotalSuccessful = 0;
// set up grid // set up grid
mTitle = std::make_shared<TextComponent>(mWindow, "SCRAPING IN PROGRESS", Font::get(FONT_SIZE_LARGE), 0x555555FF, TextComponent::ALIGN_CENTER); mTitle = std::make_shared<TextComponent>(mWindow, "SCRAPING IN PROGRESS", Font::get(FONT_SIZE_LARGE), 0x555555FF, TextComponent::ALIGN_CENTER);
@ -94,6 +95,7 @@ void GuiScraperMulti::acceptResult(const ScraperSearchResult& result)
mSearchQueue.pop(); mSearchQueue.pop();
mCurrentGame++; mCurrentGame++;
mTotalSuccessful++;
doNextSearch(); doNextSearch();
} }
@ -106,7 +108,13 @@ void GuiScraperMulti::skip()
void GuiScraperMulti::finish() void GuiScraperMulti::finish()
{ {
mWindow->pushGui(new GuiMsgBox(mWindow, "SCRAPING COMPLETE!", std::stringstream ss;
if(mTotalSuccessful == 0)
ss << "NO GAMES SUCCESSFULLY SCRAPED.";
else
ss << mTotalSuccessful << " GAME" << ((mTotalSuccessful > 1) ? "S" : "") << "SUCCESSFULLY SCRAPED!";
mWindow->pushGui(new GuiMsgBox(mWindow, ss.str(),
"OK", [&] { delete this; })); "OK", [&] { delete this; }));
} }

View file

@ -27,6 +27,7 @@ private:
unsigned int mTotalGames; unsigned int mTotalGames;
unsigned int mCurrentGame; unsigned int mCurrentGame;
unsigned int mTotalSuccessful;
std::queue<ScraperSearchParams> mSearchQueue; std::queue<ScraperSearchParams> mSearchQueue;
NinePatchComponent mBackground; NinePatchComponent mBackground;