2014-06-25 16:29:58 +00:00
|
|
|
#include "views/SystemView.h"
|
|
|
|
#include "SystemData.h"
|
|
|
|
#include "Renderer.h"
|
|
|
|
#include "Log.h"
|
|
|
|
#include "Window.h"
|
|
|
|
#include "views/ViewController.h"
|
|
|
|
#include "animations/LambdaAnimation.h"
|
|
|
|
#include "SystemData.h"
|
|
|
|
#include "Settings.h"
|
|
|
|
#include "Util.h"
|
|
|
|
|
2017-05-17 12:01:15 +00:00
|
|
|
// buffer values for scrolling velocity (left, stopped, right)
|
|
|
|
const int logoBuffersLeft[] = { -5, -2, -1 };
|
|
|
|
const int logoBuffersRight[] = { 1, 2, 5 };
|
|
|
|
|
2014-06-25 16:29:58 +00:00
|
|
|
SystemView::SystemView(Window* window) : IList<SystemViewData, SystemData*>(window, LIST_SCROLL_STYLE_SLOW, LIST_ALWAYS_LOOP),
|
2017-03-13 21:11:07 +00:00
|
|
|
mViewNeedsReload(true),
|
|
|
|
mSystemInfo(window, "SYSTEM INFO", Font::get(FONT_SIZE_SMALL), 0x33333300, ALIGN_CENTER)
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
|
|
|
mCamOffset = 0;
|
|
|
|
mExtrasCamOffset = 0;
|
|
|
|
mExtrasFadeOpacity = 0.0f;
|
|
|
|
|
|
|
|
setSize((float)Renderer::getScreenWidth(), (float)Renderer::getScreenHeight());
|
|
|
|
populate();
|
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::populate()
|
|
|
|
{
|
|
|
|
mEntries.clear();
|
|
|
|
|
|
|
|
for(auto it = SystemData::sSystemVector.begin(); it != SystemData::sSystemVector.end(); it++)
|
|
|
|
{
|
|
|
|
const std::shared_ptr<ThemeData>& theme = (*it)->getTheme();
|
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
if(mViewNeedsReload)
|
|
|
|
getViewElements(theme);
|
|
|
|
|
2014-06-25 16:29:58 +00:00
|
|
|
Entry e;
|
|
|
|
e.name = (*it)->getName();
|
|
|
|
e.object = *it;
|
|
|
|
|
|
|
|
// make logo
|
|
|
|
if(theme->getElement("system", "logo", "image"))
|
|
|
|
{
|
2017-05-17 12:01:15 +00:00
|
|
|
ImageComponent* logo = new ImageComponent(mWindow, false, false);
|
2017-03-13 21:11:07 +00:00
|
|
|
logo->setMaxSize(Eigen::Vector2f(mCarousel.logoSize.x(), mCarousel.logoSize.y()));
|
2014-06-25 16:29:58 +00:00
|
|
|
logo->applyTheme((*it)->getTheme(), "system", "logo", ThemeFlags::PATH);
|
2017-03-13 21:11:07 +00:00
|
|
|
logo->setPosition((mCarousel.logoSize.x() - logo->getSize().x()) / 2,
|
|
|
|
(mCarousel.logoSize.y() - logo->getSize().y()) / 2); // center
|
2014-06-25 16:29:58 +00:00
|
|
|
e.data.logo = std::shared_ptr<GuiComponent>(logo);
|
|
|
|
|
2017-05-17 12:01:15 +00:00
|
|
|
ImageComponent* logoSelected = new ImageComponent(mWindow, false, false);
|
2017-03-13 21:11:07 +00:00
|
|
|
logoSelected->setMaxSize(Eigen::Vector2f(mCarousel.logoSize.x() * mCarousel.logoScale, mCarousel.logoSize.y() * mCarousel.logoScale));
|
|
|
|
logoSelected->applyTheme((*it)->getTheme(), "system", "logo", ThemeFlags::PATH | ThemeFlags::COLOR);
|
|
|
|
logoSelected->setPosition((mCarousel.logoSize.x() - logoSelected->getSize().x()) / 2,
|
|
|
|
(mCarousel.logoSize.y() - logoSelected->getSize().y()) / 2); // center
|
2014-06-25 16:29:58 +00:00
|
|
|
e.data.logoSelected = std::shared_ptr<GuiComponent>(logoSelected);
|
2017-03-13 21:11:07 +00:00
|
|
|
|
2014-06-25 16:29:58 +00:00
|
|
|
}else{
|
|
|
|
// no logo in theme; use text
|
|
|
|
TextComponent* text = new TextComponent(mWindow,
|
|
|
|
(*it)->getName(),
|
|
|
|
Font::get(FONT_SIZE_LARGE),
|
|
|
|
0x000000FF,
|
|
|
|
ALIGN_CENTER);
|
2017-03-13 21:11:07 +00:00
|
|
|
text->setSize(mCarousel.logoSize);
|
2014-06-25 16:29:58 +00:00
|
|
|
e.data.logo = std::shared_ptr<GuiComponent>(text);
|
|
|
|
|
|
|
|
TextComponent* textSelected = new TextComponent(mWindow,
|
|
|
|
(*it)->getName(),
|
2017-03-13 21:11:07 +00:00
|
|
|
Font::get((int)(FONT_SIZE_LARGE * 1.5)),
|
2014-06-25 16:29:58 +00:00
|
|
|
0x000000FF,
|
|
|
|
ALIGN_CENTER);
|
2017-03-13 21:11:07 +00:00
|
|
|
textSelected->setSize(mCarousel.logoSize);
|
2014-06-25 16:29:58 +00:00
|
|
|
e.data.logoSelected = std::shared_ptr<GuiComponent>(textSelected);
|
|
|
|
}
|
|
|
|
|
2017-04-22 14:15:16 +00:00
|
|
|
// delete any existing extras
|
|
|
|
for (auto extra : e.data.backgroundExtras)
|
|
|
|
delete extra;
|
|
|
|
e.data.backgroundExtras.clear();
|
|
|
|
|
2014-06-25 16:29:58 +00:00
|
|
|
// make background extras
|
2017-04-22 14:15:16 +00:00
|
|
|
e.data.backgroundExtras = ThemeData::makeExtras((*it)->getTheme(), "system", mWindow);
|
|
|
|
|
|
|
|
// sort the extras by z-index
|
|
|
|
std:stable_sort(e.data.backgroundExtras.begin(), e.data.backgroundExtras.end(), [](GuiComponent* a, GuiComponent* b) {
|
|
|
|
return b->getZIndex() > a->getZIndex();
|
|
|
|
});
|
2014-06-25 16:29:58 +00:00
|
|
|
|
|
|
|
this->add(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::goToSystem(SystemData* system, bool animate)
|
|
|
|
{
|
|
|
|
setCursor(system);
|
|
|
|
|
|
|
|
if(!animate)
|
|
|
|
finishAnimation(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool SystemView::input(InputConfig* config, Input input)
|
|
|
|
{
|
|
|
|
if(input.value != 0)
|
|
|
|
{
|
|
|
|
if(config->getDeviceId() == DEVICE_KEYBOARD && input.value && input.id == SDLK_r && SDL_GetModState() & KMOD_LCTRL && Settings::getInstance()->getBool("Debug"))
|
|
|
|
{
|
2017-03-13 21:11:07 +00:00
|
|
|
LOG(LogInfo) << " Reloading all";
|
|
|
|
ViewController::get()->reloadAll();
|
2014-06-25 16:29:58 +00:00
|
|
|
return true;
|
|
|
|
}
|
2017-03-13 21:11:07 +00:00
|
|
|
|
|
|
|
switch (mCarousel.type)
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
2017-03-13 21:11:07 +00:00
|
|
|
case VERTICAL:
|
|
|
|
if (config->isMappedTo("up", input))
|
|
|
|
{
|
|
|
|
listInput(-1);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (config->isMappedTo("down", input))
|
|
|
|
{
|
|
|
|
listInput(1);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case HORIZONTAL:
|
|
|
|
default:
|
|
|
|
if (config->isMappedTo("left", input))
|
|
|
|
{
|
|
|
|
listInput(-1);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (config->isMappedTo("right", input))
|
|
|
|
{
|
|
|
|
listInput(1);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
break;
|
2014-06-25 16:29:58 +00:00
|
|
|
}
|
2017-03-13 21:11:07 +00:00
|
|
|
|
2014-06-25 16:29:58 +00:00
|
|
|
if(config->isMappedTo("a", input))
|
|
|
|
{
|
|
|
|
stopScrolling();
|
2016-03-29 04:03:39 +00:00
|
|
|
ViewController::get()->goToGameList(getSelected());
|
2014-06-25 16:29:58 +00:00
|
|
|
return true;
|
|
|
|
}
|
2016-12-20 20:25:35 +00:00
|
|
|
if (config->isMappedTo("x", input))
|
|
|
|
{
|
|
|
|
ViewController::get()->goToRandomGame();
|
|
|
|
return true;
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
}else{
|
2017-03-13 21:11:07 +00:00
|
|
|
if(config->isMappedTo("left", input) ||
|
|
|
|
config->isMappedTo("right", input) ||
|
|
|
|
config->isMappedTo("up", input) ||
|
|
|
|
config->isMappedTo("down", input))
|
2014-06-25 16:29:58 +00:00
|
|
|
listInput(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
return GuiComponent::input(config, input);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::update(int deltaTime)
|
|
|
|
{
|
|
|
|
listUpdate(deltaTime);
|
|
|
|
GuiComponent::update(deltaTime);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::onCursorChanged(const CursorState& state)
|
|
|
|
{
|
|
|
|
// update help style
|
|
|
|
updateHelpPrompts();
|
|
|
|
|
|
|
|
float startPos = mCamOffset;
|
|
|
|
|
|
|
|
float posMax = (float)mEntries.size();
|
|
|
|
float target = (float)mCursor;
|
|
|
|
|
|
|
|
// what's the shortest way to get to our target?
|
|
|
|
// it's one of these...
|
|
|
|
|
|
|
|
float endPos = target; // directly
|
|
|
|
float dist = abs(endPos - startPos);
|
|
|
|
|
|
|
|
if(abs(target + posMax - startPos) < dist)
|
|
|
|
endPos = target + posMax; // loop around the end (0 -> max)
|
|
|
|
if(abs(target - posMax - startPos) < dist)
|
|
|
|
endPos = target - posMax; // loop around the start (max - 1 -> -1)
|
|
|
|
|
|
|
|
|
|
|
|
// animate mSystemInfo's opacity (fade out, wait, fade back in)
|
|
|
|
|
|
|
|
cancelAnimation(1);
|
|
|
|
cancelAnimation(2);
|
|
|
|
|
|
|
|
const float infoStartOpacity = mSystemInfo.getOpacity() / 255.f;
|
|
|
|
|
|
|
|
Animation* infoFadeOut = new LambdaAnimation(
|
|
|
|
[infoStartOpacity, this] (float t)
|
|
|
|
{
|
|
|
|
mSystemInfo.setOpacity((unsigned char)(lerp<float>(infoStartOpacity, 0.f, t) * 255));
|
|
|
|
}, (int)(infoStartOpacity * 150));
|
|
|
|
|
|
|
|
unsigned int gameCount = getSelected()->getGameCount();
|
|
|
|
|
|
|
|
// also change the text after we've fully faded out
|
|
|
|
setAnimation(infoFadeOut, 0, [this, gameCount] {
|
|
|
|
std::stringstream ss;
|
|
|
|
|
2016-11-08 19:38:10 +00:00
|
|
|
if (getSelected()->getName() == "retropie")
|
|
|
|
ss << "CONFIGURATION";
|
2014-06-25 16:29:58 +00:00
|
|
|
// only display a game count if there are at least 2 games
|
2016-11-08 19:38:10 +00:00
|
|
|
else if(gameCount > 1)
|
2014-06-25 16:29:58 +00:00
|
|
|
ss << gameCount << " GAMES AVAILABLE";
|
|
|
|
|
|
|
|
mSystemInfo.setText(ss.str());
|
|
|
|
}, false, 1);
|
|
|
|
|
|
|
|
// only display a game count if there are at least 2 games
|
|
|
|
if(gameCount > 1)
|
|
|
|
{
|
|
|
|
Animation* infoFadeIn = new LambdaAnimation(
|
|
|
|
[this](float t)
|
|
|
|
{
|
|
|
|
mSystemInfo.setOpacity((unsigned char)(lerp<float>(0.f, 1.f, t) * 255));
|
|
|
|
}, 300);
|
|
|
|
|
|
|
|
// wait 600ms to fade in
|
|
|
|
setAnimation(infoFadeIn, 2000, nullptr, false, 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
// no need to animate transition, we're not going anywhere (probably mEntries.size() == 1)
|
|
|
|
if(endPos == mCamOffset && endPos == mExtrasCamOffset)
|
|
|
|
return;
|
|
|
|
|
|
|
|
Animation* anim;
|
|
|
|
if(Settings::getInstance()->getString("TransitionStyle") == "fade")
|
|
|
|
{
|
|
|
|
float startExtrasFade = mExtrasFadeOpacity;
|
|
|
|
anim = new LambdaAnimation(
|
|
|
|
[startExtrasFade, startPos, endPos, posMax, this](float t)
|
|
|
|
{
|
|
|
|
t -= 1;
|
|
|
|
float f = lerp<float>(startPos, endPos, t*t*t + 1);
|
|
|
|
if(f < 0)
|
|
|
|
f += posMax;
|
|
|
|
if(f >= posMax)
|
|
|
|
f -= posMax;
|
|
|
|
|
|
|
|
this->mCamOffset = f;
|
|
|
|
|
|
|
|
t += 1;
|
|
|
|
if(t < 0.3f)
|
|
|
|
this->mExtrasFadeOpacity = lerp<float>(0.0f, 1.0f, t / 0.3f + startExtrasFade);
|
|
|
|
else if(t < 0.7f)
|
|
|
|
this->mExtrasFadeOpacity = 1.0f;
|
|
|
|
else
|
|
|
|
this->mExtrasFadeOpacity = lerp<float>(1.0f, 0.0f, (t - 0.7f) / 0.3f);
|
|
|
|
|
|
|
|
if(t > 0.5f)
|
|
|
|
this->mExtrasCamOffset = endPos;
|
|
|
|
|
|
|
|
}, 500);
|
|
|
|
}
|
|
|
|
else{ // slide
|
|
|
|
anim = new LambdaAnimation(
|
|
|
|
[startPos, endPos, posMax, this](float t)
|
|
|
|
{
|
|
|
|
t -= 1;
|
|
|
|
float f = lerp<float>(startPos, endPos, t*t*t + 1);
|
|
|
|
if(f < 0)
|
|
|
|
f += posMax;
|
|
|
|
if(f >= posMax)
|
|
|
|
f -= posMax;
|
|
|
|
|
|
|
|
this->mCamOffset = f;
|
|
|
|
this->mExtrasCamOffset = f;
|
|
|
|
}, 500);
|
|
|
|
}
|
|
|
|
|
|
|
|
setAnimation(anim, 0, nullptr, false, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::render(const Eigen::Affine3f& parentTrans)
|
|
|
|
{
|
|
|
|
if(size() == 0)
|
2017-03-13 21:11:07 +00:00
|
|
|
return; // nothing to render
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
Eigen::Affine3f trans = getTransform() * parentTrans;
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-04-22 14:15:16 +00:00
|
|
|
auto systemInfoZIndex = mSystemInfo.getZIndex();
|
|
|
|
auto minMax = std::minmax(mCarousel.zIndex, systemInfoZIndex);
|
|
|
|
|
|
|
|
renderExtras(trans, INT16_MIN, minMax.first);
|
|
|
|
renderFade(trans);
|
|
|
|
|
|
|
|
if (mCarousel.zIndex > mSystemInfo.getZIndex()) {
|
|
|
|
renderInfoBar(trans);
|
|
|
|
} else {
|
|
|
|
renderCarousel(trans);
|
|
|
|
}
|
|
|
|
|
|
|
|
renderExtras(trans, minMax.first, minMax.second);
|
|
|
|
|
|
|
|
if (mCarousel.zIndex > mSystemInfo.getZIndex()) {
|
|
|
|
renderCarousel(trans);
|
|
|
|
} else {
|
|
|
|
renderInfoBar(trans);
|
|
|
|
}
|
|
|
|
|
|
|
|
renderExtras(trans, minMax.second, INT16_MAX);
|
2017-03-13 21:11:07 +00:00
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
std::vector<HelpPrompt> SystemView::getHelpPrompts()
|
|
|
|
{
|
|
|
|
std::vector<HelpPrompt> prompts;
|
|
|
|
if (mCarousel.type == VERTICAL)
|
|
|
|
prompts.push_back(HelpPrompt("up/down", "choose"));
|
|
|
|
else
|
|
|
|
prompts.push_back(HelpPrompt("left/right", "choose"));
|
|
|
|
prompts.push_back(HelpPrompt("a", "select"));
|
2016-12-20 20:25:35 +00:00
|
|
|
prompts.push_back(HelpPrompt("x", "random"));
|
2017-03-13 21:11:07 +00:00
|
|
|
return prompts;
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
HelpStyle SystemView::getHelpStyle()
|
|
|
|
{
|
|
|
|
HelpStyle style;
|
|
|
|
style.applyTheme(mEntries.at(mCursor).object->getTheme(), "system");
|
|
|
|
return style;
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
void SystemView::onThemeChanged(const std::shared_ptr<ThemeData>& theme)
|
|
|
|
{
|
|
|
|
LOG(LogDebug) << "SystemView::onThemeChanged()";
|
|
|
|
mViewNeedsReload = true;
|
|
|
|
populate();
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
// Get the ThemeElements that make up the SystemView.
|
|
|
|
void SystemView::getViewElements(const std::shared_ptr<ThemeData>& theme)
|
|
|
|
{
|
|
|
|
LOG(LogDebug) << "SystemView::getViewElements()";
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
getDefaultElements();
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-04-06 21:24:32 +00:00
|
|
|
if (!theme->hasView("system"))
|
|
|
|
return;
|
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
const ThemeData::ThemeElement* carouselElem = theme->getElement("system", "systemcarousel", "carousel");
|
|
|
|
if (carouselElem)
|
|
|
|
getCarouselFromTheme(carouselElem);
|
|
|
|
|
|
|
|
const ThemeData::ThemeElement* sysInfoElem = theme->getElement("system", "systemInfo", "text");
|
|
|
|
if (sysInfoElem)
|
|
|
|
mSystemInfo.applyTheme(theme, "system", "systemInfo", ThemeFlags::ALL);
|
|
|
|
|
|
|
|
mViewNeedsReload = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Render system carousel
|
|
|
|
void SystemView::renderCarousel(const Eigen::Affine3f& trans)
|
|
|
|
{
|
|
|
|
Eigen::Vector2i clipPos((int)mCarousel.pos.x(), (int)mCarousel.pos.y());
|
|
|
|
Eigen::Vector2i clipSize((int)mCarousel.size.x(), (int)mCarousel.size.y());
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
Renderer::pushClipRect(clipPos, clipSize);
|
|
|
|
|
|
|
|
// background box behind logos
|
2014-06-25 16:29:58 +00:00
|
|
|
Renderer::setMatrix(trans);
|
2017-03-13 21:11:07 +00:00
|
|
|
Renderer::drawRect(mCarousel.pos.x(), mCarousel.pos.y(), mCarousel.size.x(), mCarousel.size.y(), mCarousel.color);
|
|
|
|
|
|
|
|
// draw logos
|
|
|
|
Eigen::Vector2f logoSpacing(0.0, 0.0); // NB: logoSpacing will include the size of the logo itself as well!
|
|
|
|
float xOff = 0.0;
|
|
|
|
float yOff = 0.0;
|
|
|
|
|
|
|
|
switch (mCarousel.type)
|
|
|
|
{
|
|
|
|
case VERTICAL:
|
|
|
|
logoSpacing[1] = ((mCarousel.size.y() - (mCarousel.logoSize.y() * mCarousel.maxLogoCount)) / (mCarousel.maxLogoCount)) + mCarousel.logoSize.y();
|
|
|
|
xOff = mCarousel.pos.x() + (mCarousel.size.x() / 2) - (mCarousel.logoSize.x() / 2);
|
|
|
|
yOff = mCarousel.pos.y() + (mCarousel.size.y() - mCarousel.logoSize.y()) / 2 - (mCamOffset * logoSpacing[1]);
|
|
|
|
break;
|
|
|
|
case HORIZONTAL:
|
|
|
|
default:
|
|
|
|
logoSpacing[0] = ((mCarousel.size.x() - (mCarousel.logoSize.x() * mCarousel.maxLogoCount)) / (mCarousel.maxLogoCount)) + mCarousel.logoSize.x();
|
|
|
|
xOff = mCarousel.pos.x() + (mCarousel.size.x() - mCarousel.logoSize.x()) / 2 - (mCamOffset * logoSpacing[0]);
|
|
|
|
yOff = mCarousel.pos.y() + (mCarousel.size.y() / 2) - (mCarousel.logoSize.y() / 2);
|
|
|
|
break;
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
|
|
|
Eigen::Affine3f logoTrans = trans;
|
2017-03-13 21:11:07 +00:00
|
|
|
int center = (int)(mCamOffset);
|
2017-05-17 12:01:15 +00:00
|
|
|
int logoCount = std::min(mCarousel.maxLogoCount, (int)mEntries.size());
|
2017-03-13 21:11:07 +00:00
|
|
|
|
2017-05-17 12:01:15 +00:00
|
|
|
// Adding texture loading buffers depending on scrolling speed and status
|
|
|
|
int bufferIndex = getScrollingVelocity() + 1;
|
|
|
|
|
|
|
|
for (int i = center - logoCount / 2 + logoBuffersLeft[bufferIndex]; i <= center + logoCount / 2 + logoBuffersRight[bufferIndex]; i++)
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
|
|
|
int index = i;
|
2017-03-13 21:11:07 +00:00
|
|
|
while (index < 0)
|
2014-06-25 16:29:58 +00:00
|
|
|
index += mEntries.size();
|
2017-03-13 21:11:07 +00:00
|
|
|
while (index >= (int)mEntries.size())
|
2014-06-25 16:29:58 +00:00
|
|
|
index -= mEntries.size();
|
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
logoTrans.translation() = trans.translation() + Eigen::Vector3f(i * logoSpacing[0] + xOff, i * logoSpacing [1] + yOff, 0);
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
if (index == mCursor) //Selected System
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
|
|
|
const std::shared_ptr<GuiComponent>& comp = mEntries.at(index).data.logoSelected;
|
|
|
|
comp->setOpacity(0xFF);
|
|
|
|
comp->render(logoTrans);
|
2017-03-13 21:11:07 +00:00
|
|
|
}
|
|
|
|
else { // not selected systems
|
2014-06-25 16:29:58 +00:00
|
|
|
const std::shared_ptr<GuiComponent>& comp = mEntries.at(index).data.logo;
|
|
|
|
comp->setOpacity(0x80);
|
|
|
|
comp->render(logoTrans);
|
|
|
|
}
|
|
|
|
}
|
2017-03-13 21:11:07 +00:00
|
|
|
Renderer::popClipRect();
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
void SystemView::renderInfoBar(const Eigen::Affine3f& trans)
|
|
|
|
{
|
2014-06-25 16:29:58 +00:00
|
|
|
Renderer::setMatrix(trans);
|
|
|
|
mSystemInfo.render(trans);
|
|
|
|
}
|
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
// Draw background extras
|
2017-04-22 14:15:16 +00:00
|
|
|
void SystemView::renderExtras(const Eigen::Affine3f& trans, float lower, float upper)
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
2017-03-13 21:11:07 +00:00
|
|
|
int extrasCenter = (int)mExtrasCamOffset;
|
2017-05-17 12:01:15 +00:00
|
|
|
|
|
|
|
// Adding texture loading buffers depending on scrolling speed and status
|
|
|
|
int bufferIndex = getScrollingVelocity() + 1;
|
2017-05-19 03:04:41 +00:00
|
|
|
|
|
|
|
Renderer::pushClipRect(Eigen::Vector2i(0, 0), mSize.cast<int>());
|
|
|
|
|
2017-05-17 12:01:15 +00:00
|
|
|
for (int i = extrasCenter + logoBuffersLeft[bufferIndex]; i <= extrasCenter + logoBuffersRight[bufferIndex]; i++)
|
2017-03-13 21:11:07 +00:00
|
|
|
{
|
|
|
|
int index = i;
|
|
|
|
while (index < 0)
|
|
|
|
index += mEntries.size();
|
|
|
|
while (index >= (int)mEntries.size())
|
|
|
|
index -= mEntries.size();
|
|
|
|
|
2017-05-19 03:04:41 +00:00
|
|
|
Eigen::Affine3f extrasTrans = trans;
|
|
|
|
if (mCarousel.type == HORIZONTAL)
|
|
|
|
extrasTrans.translate(Eigen::Vector3f((i - mExtrasCamOffset) * mSize.x(), 0, 0));
|
|
|
|
else
|
|
|
|
extrasTrans.translate(Eigen::Vector3f(0, (i - mExtrasCamOffset) * mSize.y(), 0));
|
2017-04-22 14:15:16 +00:00
|
|
|
|
|
|
|
SystemViewData data = mEntries.at(index).data;
|
|
|
|
for(unsigned int j = 0; j < data.backgroundExtras.size(); j++)
|
|
|
|
{
|
|
|
|
GuiComponent* extra = data.backgroundExtras[j];
|
|
|
|
if (extra->getZIndex() >= lower && extra->getZIndex() < upper) {
|
|
|
|
extra->render(extrasTrans);
|
|
|
|
}
|
|
|
|
}
|
2017-03-13 21:11:07 +00:00
|
|
|
}
|
2017-05-19 03:04:41 +00:00
|
|
|
Renderer::popClipRect();
|
2017-04-22 14:15:16 +00:00
|
|
|
}
|
2017-03-13 21:11:07 +00:00
|
|
|
|
2017-04-22 14:15:16 +00:00
|
|
|
void SystemView::renderFade(const Eigen::Affine3f& trans)
|
|
|
|
{
|
2017-03-13 21:11:07 +00:00
|
|
|
// fade extras if necessary
|
|
|
|
if (mExtrasFadeOpacity)
|
|
|
|
{
|
|
|
|
Renderer::setMatrix(trans);
|
|
|
|
Renderer::drawRect(0.0f, 0.0f, mSize.x(), mSize.y(), 0x00000000 | (unsigned char)(mExtrasFadeOpacity * 255));
|
|
|
|
}
|
2014-06-25 16:29:58 +00:00
|
|
|
}
|
|
|
|
|
2017-03-13 21:11:07 +00:00
|
|
|
// Populate the system carousel with the legacy values
|
|
|
|
void SystemView::getDefaultElements(void)
|
2014-06-25 16:29:58 +00:00
|
|
|
{
|
2017-03-13 21:11:07 +00:00
|
|
|
// Carousel
|
|
|
|
mCarousel.type = HORIZONTAL;
|
|
|
|
mCarousel.size.x() = mSize.x();
|
|
|
|
mCarousel.size.y() = 0.2325f * mSize.y();
|
|
|
|
mCarousel.pos.x() = 0.0f;
|
|
|
|
mCarousel.pos.y() = 0.5f * (mSize.y() - mCarousel.size.y());
|
|
|
|
mCarousel.color = 0xFFFFFFD8;
|
2017-05-04 17:49:35 +00:00
|
|
|
mCarousel.logoScale = 1.2f;
|
2017-03-13 21:11:07 +00:00
|
|
|
mCarousel.logoSize.x() = 0.25f * mSize.x();
|
|
|
|
mCarousel.logoSize.y() = 0.155f * mSize.y();
|
|
|
|
mCarousel.maxLogoCount = 3;
|
2017-04-22 14:15:16 +00:00
|
|
|
mCarousel.zIndex = 40;
|
2017-03-13 21:11:07 +00:00
|
|
|
|
|
|
|
// System Info Bar
|
|
|
|
mSystemInfo.setSize(mSize.x(), mSystemInfo.getFont()->getLetterHeight()*2.2f);
|
2017-05-01 02:54:27 +00:00
|
|
|
mSystemInfo.setPosition(0, (mCarousel.pos.y() + mCarousel.size.y() - 0.2f));
|
2017-03-13 21:11:07 +00:00
|
|
|
mSystemInfo.setBackgroundColor(0xDDDDDDD8);
|
2017-05-01 02:54:27 +00:00
|
|
|
mSystemInfo.setRenderBackground(true);
|
2017-03-13 21:11:07 +00:00
|
|
|
mSystemInfo.setFont(Font::get((int)(0.035f * mSize.y()), Font::getDefaultPath()));
|
|
|
|
mSystemInfo.setColor(0x000000FF);
|
2017-04-22 14:15:16 +00:00
|
|
|
mSystemInfo.setZIndex(50);
|
|
|
|
mSystemInfo.setDefaultZIndex(50);
|
2017-03-13 21:11:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void SystemView::getCarouselFromTheme(const ThemeData::ThemeElement* elem)
|
|
|
|
{
|
|
|
|
if (elem->has("type"))
|
|
|
|
mCarousel.type = !(elem->get<std::string>("type").compare("vertical")) ? VERTICAL : HORIZONTAL;
|
|
|
|
if (elem->has("size"))
|
|
|
|
mCarousel.size = elem->get<Eigen::Vector2f>("size").cwiseProduct(mSize);
|
|
|
|
if (elem->has("pos"))
|
|
|
|
mCarousel.pos = elem->get<Eigen::Vector2f>("pos").cwiseProduct(mSize);
|
|
|
|
if (elem->has("color"))
|
|
|
|
mCarousel.color = elem->get<unsigned int>("color");
|
|
|
|
if (elem->has("logoScale"))
|
|
|
|
mCarousel.logoScale = elem->get<float>("logoScale");
|
|
|
|
if (elem->has("logoSize"))
|
|
|
|
mCarousel.logoSize = elem->get<Eigen::Vector2f>("logoSize").cwiseProduct(mSize);
|
|
|
|
if (elem->has("maxLogoCount"))
|
|
|
|
mCarousel.maxLogoCount = std::round(elem->get<float>("maxLogoCount"));
|
2017-04-22 14:15:16 +00:00
|
|
|
if (elem->has("zIndex"))
|
|
|
|
mCarousel.zIndex = elem->get<float>("zIndex");
|
2014-06-25 16:29:58 +00:00
|
|
|
}
|