From b0f36b0a912d1108bc226d0b5993eca4d5c83721 Mon Sep 17 00:00:00 2001 From: Aloshi Date: Sat, 19 Apr 2014 18:18:17 -0500 Subject: [PATCH] Adjusted design of ScraperSearchComponent in "auto" mode. "Select" now closes the game options menu if it's already open. --- src/components/ScraperSearchComponent.cpp | 37 ++++++++++++++++------- src/components/ScraperSearchComponent.h | 2 ++ src/guis/GuiGamelistOptions.cpp | 2 +- 3 files changed, 29 insertions(+), 12 deletions(-) diff --git a/src/components/ScraperSearchComponent.cpp b/src/components/ScraperSearchComponent.cpp index 339076bb4..5a6bf5091 100644 --- a/src/components/ScraperSearchComponent.cpp +++ b/src/components/ScraperSearchComponent.cpp @@ -85,14 +85,17 @@ void ScraperSearchComponent::onSizeChanged() return; // column widths - mGrid.setColWidthPerc(0, 0.01f); + if(mSearchType == ALWAYS_ACCEPT_FIRST_RESULT) + mGrid.setColWidthPerc(0, 0.02f); // looks better when this is higher in auto mode + else + mGrid.setColWidthPerc(0, 0.01f); + mGrid.setColWidthPerc(1, 0.25f); mGrid.setColWidthPerc(2, 0.25f); - mGrid.setColWidthPerc(3, 0.49f); - + // row heights if(mSearchType == ALWAYS_ACCEPT_FIRST_RESULT) // show name - mGrid.setRowHeightPerc(0, (mResultName->getFont()->getHeight()) / mGrid.getSize().y()); // result name + mGrid.setRowHeightPerc(0, (mResultName->getFont()->getHeight() * 1.6f) / mGrid.getSize().y()); // result name else mGrid.setRowHeightPerc(0, 0.0825f); // hide name but do padding @@ -105,6 +108,22 @@ void ScraperSearchComponent::onSizeChanged() mResultThumbnail->setMaxSize(mGrid.getColWidth(1) * boxartCellScale, mGrid.getRowHeight(1)); // metadata + resizeMetadata(); + + if(mSearchType != ALWAYS_ACCEPT_FIRST_RESULT) + mDescContainer->setSize(mGrid.getColWidth(1)*boxartCellScale + mGrid.getColWidth(2), mResultDesc->getFont()->getHeight() * 3); + else + mDescContainer->setSize(mGrid.getColWidth(3)*boxartCellScale, mResultDesc->getFont()->getHeight() * 8); + + mResultDesc->setSize(mDescContainer->getSize().x(), 0); // make desc text wrap at edge of container + + mGrid.onSizeChanged(); + + mBusyAnim.setSize(mSize); +} + +void ScraperSearchComponent::resizeMetadata() +{ mMD_Grid->setSize(mGrid.getColWidth(2), mGrid.getRowHeight(1)); if(mMD_Grid->getSize().y() > mMD_Pairs.size()) { @@ -143,13 +162,6 @@ void ScraperSearchComponent::onSizeChanged() // make result font follow label font mResultDesc->setFont(Font::get(fontHeight, FONT_PATH_REGULAR)); } - - mDescContainer->setSize(mGrid.getColWidth(1)*boxartCellScale + mGrid.getColWidth(2), mResultDesc->getFont()->getHeight() * 3); - mResultDesc->setSize(mDescContainer->getSize().x(), 0); // make desc text wrap at edge of container - - mGrid.onSizeChanged(); - - mBusyAnim.setSize(mSize); } void ScraperSearchComponent::updateViewStyle() @@ -167,6 +179,9 @@ void ScraperSearchComponent::updateViewStyle() // show name mGrid.setEntry(mResultName, Vector2i(1, 0), false, true, Vector2i(2, 1), GridFlags::BORDER_TOP); + // need a border on the bottom left + mGrid.setEntry(std::make_shared(mWindow), Vector2i(0, 2), false, false, Vector2i(3, 1), GridFlags::BORDER_BOTTOM); + // show description on the right mGrid.setEntry(mDescContainer, Vector2i(3, 0), false, false, Vector2i(1, 3), GridFlags::BORDER_TOP | GridFlags::BORDER_BOTTOM); mResultDesc->setSize(mDescContainer->getSize().x(), 0); // make desc text wrap at edge of container diff --git a/src/components/ScraperSearchComponent.h b/src/components/ScraperSearchComponent.h index c943aa548..612bb1e85 100644 --- a/src/components/ScraperSearchComponent.h +++ b/src/components/ScraperSearchComponent.h @@ -51,6 +51,8 @@ private: void updateThumbnail(); void updateInfoPane(); + void resizeMetadata(); + void onSearchError(const std::string& error); void onSearchDone(const std::vector& results); diff --git a/src/guis/GuiGamelistOptions.cpp b/src/guis/GuiGamelistOptions.cpp index 658be0d7d..8beaadc77 100644 --- a/src/guis/GuiGamelistOptions.cpp +++ b/src/guis/GuiGamelistOptions.cpp @@ -59,7 +59,7 @@ void GuiGamelistOptions::openMetaDataEd() bool GuiGamelistOptions::input(InputConfig* config, Input input) { - if(config->isMappedTo("b", input) && input.value) + if((config->isMappedTo("b", input) || config->isMappedTo("select", input)) && input.value) { delete this; return true;