You can now choose a scraper in the Settings menu.

This commit is contained in:
Aloshi 2013-10-05 21:56:06 -05:00
parent 63d8908061
commit 5d6192613c
9 changed files with 157 additions and 62 deletions

View file

@ -138,7 +138,7 @@ int run_scraper_cmdline()
out << "Alright, let's do this thing!\n"; out << "Alright, let's do this thing!\n";
out << "=============================\n"; out << "=============================\n";
Scraper* scraper = Settings::getInstance()->getScraper(); std::shared_ptr<Scraper> scraper = Settings::getInstance()->getScraper();
for(auto sysIt = systems.begin(); sysIt != systems.end(); sysIt++) for(auto sysIt = systems.begin(); sysIt != systems.end(); sysIt++)
{ {
std::vector<FileData*> files = (*sysIt)->getRootFolder()->getFilesRecursive(true); std::vector<FileData*> files = (*sysIt)->getRootFolder()->getFilesRecursive(true);

View file

@ -4,11 +4,10 @@
#include "platform.h" #include "platform.h"
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include "scrapers/GamesDBScraper.h" #include "scrapers/GamesDBScraper.h"
#include "scrapers/TheArchiveScraper.h"
Settings* Settings::sInstance = NULL; Settings* Settings::sInstance = NULL;
Settings::Settings() : mScraper(NULL) Settings::Settings()
{ {
setDefaults(); setDefaults();
loadFile(); loadFile();
@ -41,10 +40,7 @@ void Settings::setDefaults()
mIntMap["GameListSortIndex"] = 0; mIntMap["GameListSortIndex"] = 0;
if(mScraper) mScraper = std::shared_ptr<Scraper>(new GamesDBScraper());
delete mScraper;
mScraper = new GamesDBScraper(); //TODO
} }
template <typename K, typename V> template <typename K, typename V>
@ -68,6 +64,9 @@ void Settings::saveFile()
saveMap<std::string, int>(doc, mIntMap, "int"); saveMap<std::string, int>(doc, mIntMap, "int");
saveMap<std::string, float>(doc, mFloatMap, "float"); saveMap<std::string, float>(doc, mFloatMap, "float");
pugi::xml_node scraperNode = doc.append_child("scraper");
scraperNode.append_attribute("value").set_value(mScraper->getName());
doc.save_file(path.c_str()); doc.save_file(path.c_str());
} }
@ -92,13 +91,25 @@ void Settings::loadFile()
setInt(node.attribute("name").as_string(), node.attribute("value").as_int()); setInt(node.attribute("name").as_string(), node.attribute("value").as_int());
for(pugi::xml_node node = doc.child("float"); node; node = node.next_sibling()) for(pugi::xml_node node = doc.child("float"); node; node = node.next_sibling())
setFloat(node.attribute("name").as_string(), node.attribute("value").as_float()); setFloat(node.attribute("name").as_string(), node.attribute("value").as_float());
if(doc.child("scraper"))
{
std::shared_ptr<Scraper> scr = createScraperByName(doc.child("scraper").attribute("value").as_string());
if(scr)
mScraper = scr;
}
} }
Scraper* Settings::getScraper() std::shared_ptr<Scraper> Settings::getScraper()
{ {
return mScraper; return mScraper;
} }
void Settings::setScraper(std::shared_ptr<Scraper> scraper)
{
mScraper = scraper;
}
//Print a warning message if the setting we're trying to get doesn't already exist in the map, then return the value in the map. //Print a warning message if the setting we're trying to get doesn't already exist in the map, then return the value in the map.
#define SETTINGS_GETSET(type, mapName, getMethodName, setMethodName) type Settings::getMethodName(const std::string& name) \ #define SETTINGS_GETSET(type, mapName, getMethodName, setMethodName) type Settings::getMethodName(const std::string& name) \
{ \ { \

View file

@ -23,7 +23,8 @@ public:
void setInt(const std::string& name, int value); void setInt(const std::string& name, int value);
void setFloat(const std::string& name, float value); void setFloat(const std::string& name, float value);
Scraper* getScraper(); std::shared_ptr<Scraper> getScraper();
void setScraper(std::shared_ptr<Scraper> scraper);
private: private:
static Settings* sInstance; static Settings* sInstance;
@ -35,7 +36,7 @@ private:
std::map<std::string, bool> mBoolMap; std::map<std::string, bool> mBoolMap;
std::map<std::string, int> mIntMap; std::map<std::string, int> mIntMap;
std::map<std::string, float> mFloatMap; std::map<std::string, float> mFloatMap;
Scraper* mScraper; std::shared_ptr<Scraper> mScraper;
}; };
#endif #endif

View file

@ -419,6 +419,18 @@ void ComponentListComponent::update(int deltaTime)
void ComponentListComponent::render(const Eigen::Affine3f& parentTrans) void ComponentListComponent::render(const Eigen::Affine3f& parentTrans)
{ {
Eigen::Affine3f trans = parentTrans * getTransform(); Eigen::Affine3f trans = parentTrans * getTransform();
//draw cursor
if(cursorValid())
{
ComponentEntry* entry = getCell(mCursor.x(), mCursor.y());
Eigen::Affine3f entryTrans = trans * entry->component->getTransform();
Renderer::setMatrix(entryTrans);
Renderer::drawRect(0, 0, 4, 4, 0xFF0000FF);
Renderer::drawRect(0, 0, (int)entry->component->getSize().x(), (int)entry->component->getSize().y(), 0x0000AA22);
}
for(auto iter = mEntries.begin(); iter != mEntries.end(); iter++) for(auto iter = mEntries.begin(); iter != mEntries.end(); iter++)
{ {
(*iter)->component->render(trans); (*iter)->component->render(trans);
@ -444,16 +456,7 @@ void ComponentListComponent::render(const Eigen::Affine3f& parentTrans)
pos[0] += getColumnWidth(x); pos[0] += getColumnWidth(x);
}*/ }*/
//draw cursor
if(cursorValid())
{
ComponentEntry* entry = getCell(mCursor.x(), mCursor.y());
Eigen::Affine3f entryTrans = trans * entry->component->getTransform();
Renderer::setMatrix(entryTrans);
Renderer::drawRect(0, 0, 4, 4, 0xFF0000FF);
Renderer::drawRect(0, 0, (int)entry->component->getSize().x(), (int)entry->component->getSize().y(), 0x0000AA22);
}
} }
void ComponentListComponent::textInput(const char* text) void ComponentListComponent::textInput(const char* text)

View file

@ -65,7 +65,7 @@ GuiSettingsMenu::GuiSettingsMenu(Window* window) : GuiComponent(window),
scrapers.push_back(std::shared_ptr<Scraper>(new GamesDBScraper())); scrapers.push_back(std::shared_ptr<Scraper>(new GamesDBScraper()));
scrapers.push_back(std::shared_ptr<Scraper>(new TheArchiveScraper())); scrapers.push_back(std::shared_ptr<Scraper>(new TheArchiveScraper()));
mScraperOptList.populate(scrapers, [&] (const std::shared_ptr<Scraper>& s) { mScraperOptList.populate(scrapers, [&] (const std::shared_ptr<Scraper>& s) {
return mScraperOptList.makeEntry(s->getName(), 0x00FF00FF, s); return mScraperOptList.makeEntry(s->getName(), 0x00FF00FF, s, s->getName() == Settings::getInstance()->getScraper()->getName());
} ); } );
mList.setEntry(Vector2i(1, 3), Vector2i(1, 1), &mScraperOptList, true, ComponentListComponent::AlignCenter); mList.setEntry(Vector2i(1, 3), Vector2i(1, 1), &mScraperOptList, true, ComponentListComponent::AlignCenter);
@ -131,5 +131,8 @@ void GuiSettingsMenu::applyStates()
s->setBool("DISABLESOUNDS", mDisableSoundsSwitch.getState()); s->setBool("DISABLESOUNDS", mDisableSoundsSwitch.getState());
if(mScraperOptList.getSelected().size() > 0)
s->setScraper(mScraperOptList.getSelected()[0]->object);
s->saveFile(); s->saveFile();
} }

View file

@ -5,7 +5,7 @@
#include <vector> #include <vector>
#include <functional> #include <functional>
#include "../Renderer.h" #include "../Renderer.h"
#include "../Window.h" #include "NinePatchComponent.h"
//Used to display a list of options. //Used to display a list of options.
//Can select one or multiple options. //Can select one or multiple options.
@ -14,8 +14,8 @@ template<typename T>
class OptionListComponent : public GuiComponent class OptionListComponent : public GuiComponent
{ {
public: public:
OptionListComponent(Window* window) : GuiComponent(window), OptionListComponent(Window* window, bool multiSelect = false) : GuiComponent(window),
mClosedCallback(nullptr), mCursor(0), mScrollOffset(0) mCursor(0), mScrollOffset(0), mMultiSelect(multiSelect), mEditing(false), mBox(window, ":/textbox.png")
{ {
} }
@ -28,11 +28,6 @@ public:
}; };
void setClosedCallback(std::function<void(std::vector<const ListEntry*>)> callback)
{
mClosedCallback = callback;
}
bool input(InputConfig* config, Input input) bool input(InputConfig* config, Input input)
{ {
if(input.value != 0) if(input.value != 0)
@ -43,63 +38,120 @@ public:
return true; return true;
} }
if(config->isMappedTo("a", input)) if(config->isMappedTo("a", input))
{
if(mEditing)
{ {
select(mCursor); select(mCursor);
if(!mMultiSelect)
close();
}else{
open();
}
return true; return true;
} }
if(mEntries.size() > 1) if(mEditing && mEntries.size() > 1)
{ {
if(config->isMappedTo("up", input)) if(config->isMappedTo("up", input))
{ {
if(mCursor > 0) if(mCursor > 0)
{
mCursor--; mCursor--;
return true; return true;
} }
}
if(config->isMappedTo("down", input)) if(config->isMappedTo("down", input))
{ {
if(mCursor < mEntries.size() - 1) if(mCursor < mEntries.size() - 1)
{
mCursor++; mCursor++;
return true; return true;
} }
} }
} }
}
return GuiComponent::input(config, input); return GuiComponent::input(config, input);
} }
void render(const Eigen::Affine3f& parentTrans) void render(const Eigen::Affine3f& parentTrans)
{ {
Eigen::Affine3f trans = parentTrans * getTransform();
std::shared_ptr<Font> font = getFont(); std::shared_ptr<Font> font = getFont();
Renderer::pushClipRect(Eigen::Vector2i((int)trans.translation().x(), (int)trans.translation().y()), //draw the option list
Eigen::Vector2i((int)getSize().x(), (int)getSize().y())); if(mEditing)
{
Eigen::Affine3f trans = parentTrans * getTransform();
for(unsigned int i = mScrollOffset; i < mTextCaches.size(); i++) unsigned int renderCount = mTextCaches.size() - mScrollOffset;
float height = (float)renderCount * font->getHeight();
trans.translate(Eigen::Vector3f(0, -height / 2 + font->getHeight() * 0.5f, 0));
mBox.fitTo(Eigen::Vector2f(mSize.x(), height));
mBox.render(trans);
Renderer::setMatrix(trans);
Renderer::drawRect(0, 0, (int)getSize().x(), (int)height, 0xFFFFFFFF);
for(unsigned int i = mScrollOffset; i < renderCount; i++)
{ {
Renderer::setMatrix(trans); Renderer::setMatrix(trans);
char rectOpacity = 0x00;
if(i == mCursor) if(i == mCursor)
Renderer::drawRect(0, 0, (int)mSize.x(), font->getHeight(), 0x000000FF); rectOpacity += 0x22;
if(mEntries.at(i).selected)
rectOpacity += 0x44;
Renderer::drawRect(0, 0, (int)mSize.x(), font->getHeight(), 0x00000000 | rectOpacity);
Renderer::setMatrix(trans);
font->renderTextCache(mTextCaches.at(i)); font->renderTextCache(mTextCaches.at(i));
trans = trans.translate(Eigen::Vector3f(0, (float)font->getHeight(), 0)); trans = trans.translate(Eigen::Vector3f(0, (float)font->getHeight(), 0));
} }
}else{
Renderer::setMatrix(parentTrans * getTransform());
Renderer::popClipRect(); unsigned int color = 0x000000FF;
trans = parentTrans * getTransform(); if(mMultiSelect)
renderChildren(trans); {
//draw "# selected"
unsigned int selectedCount = 0;
for(auto it = mEntries.begin(); it != mEntries.end(); it++)
{
if(it->selected)
selectedCount++;
} }
ListEntry makeEntry(const std::string& name, unsigned int color, T obj) const std::stringstream ss;
ss << selectedCount << " selected";
font->drawText(ss.str(), Eigen::Vector2f(0, 0), color);
}else{
//draw selected option
bool found = false;
for(auto it = mEntries.begin(); it != mEntries.end(); it++)
{ {
ListEntry e = {name, color, false, obj}; if(it->selected)
{
font->drawText(it->text, Eigen::Vector2f(0, 0), color);
found = true;
break;
}
}
if(!found)
font->drawText("Not set", Eigen::Vector2f(0, 0), color);
}
}
renderChildren(parentTrans * getTransform());
}
ListEntry makeEntry(const std::string& name, unsigned int color, T obj, bool selected = false) const
{
ListEntry e = {name, color, selected, obj};
return e; return e;
} }
@ -138,14 +190,22 @@ private:
if(i >= mEntries.size()) if(i >= mEntries.size())
return; return;
if(!mMultiSelect)
for(auto it = mEntries.begin(); it != mEntries.end(); it++)
it->selected = false;
mEntries.at(i).selected = !mEntries.at(i).selected; mEntries.at(i).selected = !mEntries.at(i).selected;
updateTextCaches(); updateTextCaches();
} }
void close() void close()
{ {
if(mClosedCallback) mEditing = false;
mClosedCallback(getSelected()); }
void open()
{
mEditing = true;
} }
void updateTextCaches() void updateTextCaches()
@ -159,7 +219,7 @@ private:
TextCache* cache; TextCache* cache;
std::shared_ptr<Font> font = getFont(); std::shared_ptr<Font> font = getFont();
Eigen::Vector2f newSize = getSize(); Eigen::Vector2f newSize = getSize();
newSize[1] = 0; newSize[1] = (float)font->getHeight();
for(unsigned int i = 0; i < mEntries.size(); i++) for(unsigned int i = 0; i < mEntries.size(); i++)
{ {
cache = font->buildTextCache(mEntries.at(i).text, 0, 0, mEntries.at(i).color); cache = font->buildTextCache(mEntries.at(i).text, 0, 0, mEntries.at(i).color);
@ -167,23 +227,24 @@ private:
if(cache->metrics.size.x() > newSize.x()) if(cache->metrics.size.x() > newSize.x())
newSize[0] = cache->metrics.size.x(); newSize[0] = cache->metrics.size.x();
newSize[1] += cache->metrics.size.y();
} }
setSize(newSize); setSize(newSize);
} }
std::shared_ptr<Font> getFont() std::shared_ptr<Font> getFont()
{ {
return Font::get(FONT_SIZE_SMALL); return Font::get(FONT_SIZE_MEDIUM);
} }
std::function<void(std::vector<const ListEntry*>)> mClosedCallback;
unsigned int mCursor; unsigned int mCursor;
unsigned int mScrollOffset; unsigned int mScrollOffset;
bool mMultiSelect;
bool mEditing;
NinePatchComponent mBox;
std::vector<ListEntry> mEntries; std::vector<ListEntry> mEntries;
std::vector<TextCache*> mTextCaches; std::vector<TextCache*> mTextCaches;
}; };

View file

@ -6,6 +6,9 @@
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <boost/regex.hpp> #include <boost/regex.hpp>
#include "GamesDBScraper.h"
#include "TheArchiveScraper.h"
std::vector<MetaDataList> Scraper::getResults(ScraperSearchParams params) std::vector<MetaDataList> Scraper::getResults(ScraperSearchParams params)
{ {
std::shared_ptr<HttpReq> req = makeHttpReq(params); std::shared_ptr<HttpReq> req = makeHttpReq(params);
@ -157,3 +160,14 @@ std::string getSaveAsPath(const std::string& subdirectory, const std::string& na
path += name + ext; path += name + ext;
return path; return path;
} }
std::shared_ptr<Scraper> createScraperByName(const std::string& name)
{
if(name == "TheGamesDB")
return std::shared_ptr<Scraper>(new GamesDBScraper());
else if(name == "TheArchive")
return std::shared_ptr<Scraper>(new TheArchiveScraper());
return nullptr;
}

View file

@ -30,6 +30,8 @@ private:
virtual std::vector<MetaDataList> parseReq(ScraperSearchParams params, std::shared_ptr<HttpReq>) = 0; virtual std::vector<MetaDataList> parseReq(ScraperSearchParams params, std::shared_ptr<HttpReq>) = 0;
}; };
std::shared_ptr<Scraper> createScraperByName(const std::string& name);
//About the same as "~/.emulationstation/downloaded_images/[subdirectory]/[name].[url's extension]". //About the same as "~/.emulationstation/downloaded_images/[subdirectory]/[name].[url's extension]".
//Will create the "downloaded_images" and "subdirectory" directories if they do not exist. //Will create the "downloaded_images" and "subdirectory" directories if they do not exist.
std::string getSaveAsPath(const std::string& subdirectory, const std::string& name, const std::string& url); std::string getSaveAsPath(const std::string& subdirectory, const std::string& name, const std::string& url);

View file

@ -4,7 +4,7 @@
#include "../Log.h" #include "../Log.h"
#include "../pugiXML/pugixml.hpp" #include "../pugiXML/pugixml.hpp"
const char* TheArchiveScraper::getName() { return "TheArchiveVG"; } const char* TheArchiveScraper::getName() { return "TheArchive"; }
std::shared_ptr<HttpReq> TheArchiveScraper::makeHttpReq(ScraperSearchParams params) std::shared_ptr<HttpReq> TheArchiveScraper::makeHttpReq(ScraperSearchParams params)
{ {