-added flow=x for new_source sourceflow buttons. set x to the number of the flow layout you want to use. if the line is not added then we just use sourceflows last_cf_mode.

This commit is contained in:
Fledge68 2018-10-01 16:01:43 -05:00
parent 4af2936db7
commit 365eb5a217
4 changed files with 73 additions and 29 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.3 MiB

After

Width:  |  Height:  |  Size: 3.3 MiB

View File

@ -1075,6 +1075,8 @@ private:
bool _Boot(); bool _Boot();
void _Paths(); void _Paths();
void _sourceFlow(); void _sourceFlow();
int _getSrcFlow();
void _setSrcFlow(int version);
void _mainLoopCommon(bool withCF = false, bool adjusting = false); void _mainLoopCommon(bool withCF = false, bool adjusting = false);
void _netInit(); void _netInit();
void _loadDefaultFont(void); void _loadDefaultFont(void);

View File

@ -530,6 +530,7 @@ int CMenu::main(void)
} }
if(!BTN_B_HELD) if(!BTN_B_HELD)
{ {
/* move coverflow */
if(BTN_UP_REPEAT || RIGHT_STICK_UP) if(BTN_UP_REPEAT || RIGHT_STICK_UP)
CoverFlow.up(); CoverFlow.up();
else if(BTN_RIGHT_REPEAT || RIGHT_STICK_RIGHT) else if(BTN_RIGHT_REPEAT || RIGHT_STICK_RIGHT)
@ -538,6 +539,12 @@ int CMenu::main(void)
CoverFlow.down(); CoverFlow.down();
else if(BTN_LEFT_REPEAT || RIGHT_STICK_LEFT) else if(BTN_LEFT_REPEAT || RIGHT_STICK_LEFT)
CoverFlow.left(); CoverFlow.left();
else if(BTN_MINUS_PRESSED)
CoverFlow.pageUp();
else if(BTN_PLUS_PRESSED)
CoverFlow.pageDown();
/* change coverflow layout/mode */
else if(BTN_1_PRESSED || BTN_2_PRESSED) else if(BTN_1_PRESSED || BTN_2_PRESSED)
{ {
s8 direction = BTN_1_PRESSED ? 1 : -1; s8 direction = BTN_1_PRESSED ? 1 : -1;
@ -546,32 +553,31 @@ int CMenu::main(void)
_loadCFLayout(cfVersion); _loadCFLayout(cfVersion);
CoverFlow.applySettings(); CoverFlow.applySettings();
} }
else if(BTN_MINUS_PRESSED)
CoverFlow.pageUp();
else if(BTN_PLUS_PRESSED)
CoverFlow.pageDown();
} }
else // Button B Held else // Button B Held
{ {
bheld = true; bheld = true;
const char *domain = _domainFromView(); const char *domain = _domainFromView();
//Search by Alphabet
/* b+down or up = move to previous or next cover in sort order */
if(BTN_DOWN_PRESSED || BTN_UP_PRESSED) if(BTN_DOWN_PRESSED || BTN_UP_PRESSED)
{ {
bUsed = true; bUsed = true;
int sorting = m_cfg.getInt(domain, "sort", SORT_ALPHA); int sorting = m_cfg.getInt(domain, "sort", SORT_ALPHA);
/* if for some reason domain sort value is not legal set it to alpha */
if(sorting != SORT_ALPHA && sorting != SORT_PLAYERS && sorting != SORT_WIFIPLAYERS && sorting != SORT_GAMEID) if(sorting != SORT_ALPHA && sorting != SORT_PLAYERS && sorting != SORT_WIFIPLAYERS && sorting != SORT_GAMEID)
{ {
CoverFlow.setSorting((Sorting)SORT_ALPHA); CoverFlow.setSorting((Sorting)SORT_ALPHA);
m_cfg.setInt(domain, "sort", SORT_ALPHA); m_cfg.setInt(domain, "sort", SORT_ALPHA);
sorting = SORT_ALPHA; sorting = SORT_ALPHA;
} }
/* move coverflow */
wchar_t c[2] = {0, 0}; wchar_t c[2] = {0, 0};
BTN_UP_PRESSED ? CoverFlow.prevLetter(c) : CoverFlow.nextLetter(c); BTN_UP_PRESSED ? CoverFlow.prevLetter(c) : CoverFlow.nextLetter(c);
/* set sort text and display it */
curLetter.clear(); curLetter.clear();
curLetter = wstringEx(c); curLetter = wstringEx(c);
m_showtimer = 120; m_showtimer = 120;
if(sorting == SORT_ALPHA) if(sorting == SORT_ALPHA)
{ {
@ -585,22 +591,22 @@ int CMenu::main(void)
m_btnMgr.show(m_mainLblNotice); m_btnMgr.show(m_mainLblNotice);
} }
} }
else if(BTN_LEFT_PRESSED) else if(BTN_LEFT_PRESSED)// b+left = previous song
{ {
bUsed = true; bUsed = true;
MusicPlayer.Previous(); MusicPlayer.Previous();
} }
else if(BTN_RIGHT_PRESSED) else if(BTN_RIGHT_PRESSED)// b+right = next song
{ {
bUsed = true; bUsed = true;
MusicPlayer.Next(); MusicPlayer.Next();
} }
/* change sorting with btn B and + */ /* b+plus = change sort mode */
else if(BTN_PLUS_PRESSED && !m_locked && (m_current_view < 8 || m_sourceflow))// <8 excludes plugins and homebrew else if(BTN_PLUS_PRESSED && !m_locked && (m_current_view < 8 || m_sourceflow))// <8 excludes plugins and homebrew
{ {
bUsed = true; bUsed = true;
u8 sort = 0; u8 sort = 0;
if(m_sourceflow) if(m_sourceflow)// change sourceflow sort mode
{ {
sort = m_cfg.getInt(SOURCEFLOW_DOMAIN, "sort", SORT_ALPHA); sort = m_cfg.getInt(SOURCEFLOW_DOMAIN, "sort", SORT_ALPHA);
if(sort == SORT_ALPHA) if(sort == SORT_ALPHA)
@ -608,12 +614,13 @@ int CMenu::main(void)
else else
sort = SORT_ALPHA; sort = SORT_ALPHA;
} }
else else // change all other coverflow sort mode
sort = loopNum((m_cfg.getInt(domain, "sort", 0)) + 1, SORT_MAX); sort = loopNum((m_cfg.getInt(domain, "sort", 0)) + 1, SORT_MAX);
m_cfg.setInt(domain, "sort", sort); m_cfg.setInt(domain, "sort", sort);
/* set coverflow to new sorting */ /* set coverflow to new sorting */
_initCF(); _initCF();
/* set text to display */ /* set sort mode text and display it */
wstringEx curSort ; wstringEx curSort ;
if(sort == SORT_ALPHA) if(sort == SORT_ALPHA)
curSort = m_loc.getWString(m_curLanguage, "alphabetically", L"Alphabetically"); curSort = m_loc.getWString(m_curLanguage, "alphabetically", L"Alphabetically");
@ -633,12 +640,14 @@ int CMenu::main(void)
m_btnMgr.setText(m_mainLblNotice, curSort); m_btnMgr.setText(m_mainLblNotice, curSort);
m_btnMgr.show(m_mainLblNotice); m_btnMgr.show(m_mainLblNotice);
} }
/* b+minus = select random game or boot random game */
else if(BTN_MINUS_PRESSED && !CoverFlow.empty()) else if(BTN_MINUS_PRESSED && !CoverFlow.empty())
{ {
_hideMain(); _hideMain();
srand(time(NULL)); srand(time(NULL));
u16 place = (rand() + rand() + rand()) % CoverFlow.size(); u16 place = (rand() + rand() + rand()) % CoverFlow.size();
if(m_cfg.getBool("GENERAL", "random_select", false))
if(m_cfg.getBool("GENERAL", "random_select", false))// random select a game
{ {
CoverFlow.setSelected(place); CoverFlow.setSelected(place);
_game(false); _game(false);
@ -655,14 +664,13 @@ int CMenu::main(void)
else else
CoverFlow.cancel(); CoverFlow.cancel();
} }
else /* WiiFlow should boot a random game */ else // boot a random game
{ {
gprintf("Lets boot the random game number %u\n", place); gprintf("Lets boot the random game number %u\n", place);
const dir_discHdr *gameHdr = CoverFlow.getSpecificHdr(place); const dir_discHdr *gameHdr = CoverFlow.getSpecificHdr(place);
if(gameHdr != NULL) if(gameHdr != NULL)
_launch(gameHdr); _launch(gameHdr);
/* Shouldnt happen */ _showCF(false);// this shouldn't happen
_showCF(false);
} }
} }
} }
@ -1055,7 +1063,9 @@ void CMenu::exitHandler(int ExitTo)
int CMenu::_getCFVersion() int CMenu::_getCFVersion()
{ {
if(m_current_view == COVERFLOW_PLUGIN && !m_sourceflow) if(m_sourceflow)
return _getSrcFlow();
else if(m_current_view == COVERFLOW_PLUGIN)
{ {
m_plugin.GetEnabledPlugins(m_cfg, &enabledPluginsCount); m_plugin.GetEnabledPlugins(m_cfg, &enabledPluginsCount);
if(enabledPluginsCount == 1) if(enabledPluginsCount == 1)
@ -1074,7 +1084,9 @@ int CMenu::_getCFVersion()
void CMenu::_setCFVersion(int version) void CMenu::_setCFVersion(int version)
{ {
if(m_current_view == COVERFLOW_PLUGIN && !m_sourceflow) if(m_sourceflow)
_setSrcFlow(version);
else if(m_current_view == COVERFLOW_PLUGIN)
{ {
m_plugin.GetEnabledPlugins(m_cfg, &enabledPluginsCount); m_plugin.GetEnabledPlugins(m_cfg, &enabledPluginsCount);
if(enabledPluginsCount == 1) if(enabledPluginsCount == 1)
@ -1082,17 +1094,12 @@ void CMenu::_setCFVersion(int version)
for(u8 i = 0; m_plugin.PluginExist(i); ++i) for(u8 i = 0; m_plugin.PluginExist(i); ++i)
{ {
if(m_plugin.GetEnableStatus(m_cfg, m_plugin.getPluginMagic(i))) if(m_plugin.GetEnableStatus(m_cfg, m_plugin.getPluginMagic(i)))
{
m_cfg.setInt("PLUGIN_CFVERSION", m_plugin.PluginMagicWord, version); m_cfg.setInt("PLUGIN_CFVERSION", m_plugin.PluginMagicWord, version);
return;
}
} }
} }
else if(strlen(single_sourcebtn)) else if(strlen(single_sourcebtn))
{
m_cfg.setInt("PLUGIN_CFVERSION", single_sourcebtn, version); m_cfg.setInt("PLUGIN_CFVERSION", single_sourcebtn, version);
return;
}
} }
else
m_cfg.setInt(_domainFromView(), "last_cf_mode", version); m_cfg.setInt(_domainFromView(), "last_cf_mode", version);
} }

View File

@ -27,6 +27,8 @@ int numPages;
vector<string> magicNums; vector<string> magicNums;
char btn_selected[16]; char btn_selected[16];
char current_btn[16]; char current_btn[16];
int curflow = 1;
bool sm_tier = false;
void CMenu::_sourceFlow() void CMenu::_sourceFlow()
{ {
@ -97,6 +99,11 @@ void CMenu::_sourceFlow()
const char *fn = m_source.getString(btn_selected, "magic", "").c_str(); const char *fn = m_source.getString(btn_selected, "magic", "").c_str();
if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn))) if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn)))
{ {
if(strcmp(fn, SOURCE_FILENAME) == 0)
sm_tier = false;
else
sm_tier = true;
curflow = m_source.getInt(btn_selected, "flow", m_cfg.getInt(SOURCEFLOW_DOMAIN, "last_cf_mode", 1));
m_source.unload(); m_source.unload();
m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn)); m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn));
/* get max source button # */ /* get max source button # */
@ -125,6 +132,18 @@ void CMenu::_sourceFlow()
_setSrcOptions(); _setSrcOptions();
} }
int CMenu::_getSrcFlow(void)
{
return curflow;
}
void CMenu::_setSrcFlow(int version)
{
curflow = version;
if(!sm_tier)
m_cfg.setInt(SOURCEFLOW_DOMAIN, "last_cf_mode", version);
}
void CMenu::_hideSource(bool instant) void CMenu::_hideSource(bool instant)
{ {
m_btnMgr.hide(m_sourceLblTitle, instant); m_btnMgr.hide(m_sourceLblTitle, instant);
@ -439,6 +458,11 @@ bool CMenu::_Source()
const char *fn = m_source.getString(btn_selected, "magic", "").c_str(); const char *fn = m_source.getString(btn_selected, "magic", "").c_str();
if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn))) if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn)))
{ {
if(strcmp(fn, SOURCE_FILENAME) == 0)
sm_tier = false;
else
sm_tier = true;
curflow = m_source.getInt(btn_selected, "flow", m_cfg.getInt(SOURCEFLOW_DOMAIN, "last_cf_mode", 1));
m_source.unload(); m_source.unload();
m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn)); m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn));
exitSource = false; exitSource = false;
@ -520,6 +544,11 @@ bool CMenu::_Source()
const char *fn = m_source.getString(btn_selected, "magic", "").c_str(); const char *fn = m_source.getString(btn_selected, "magic", "").c_str();
if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn))) if(fsop_FileExist(fmt("%s/%s", m_sourceDir.c_str(), fn)))
{ {
if(strcmp(fn, SOURCE_FILENAME) == 0)
sm_tier = false;
else
sm_tier = true;
curflow = m_source.getInt(btn_selected, "flow", m_cfg.getInt(SOURCEFLOW_DOMAIN, "last_cf_mode", 1));
m_source.unload(); m_source.unload();
m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn)); m_source.load(fmt("%s/%s", m_sourceDir.c_str(), fn));
exitSource = false; exitSource = false;
@ -664,16 +693,19 @@ void CMenu::_initSourceMenu()
{ {
memset(single_sourcebtn, 0, 16); memset(single_sourcebtn, 0, 16);
m_use_source = false; m_use_source = false;
themeName = m_cfg.getString("GENERAL", "theme", "default").c_str(); themeName = m_cfg.getString("GENERAL", "theme", "default").c_str();
if(!m_source.load(fmt("%s/%s/%s", m_sourceDir.c_str(), themeName, SOURCE_FILENAME))) if(!m_source.load(fmt("%s/%s/%s", m_sourceDir.c_str(), themeName, SOURCE_FILENAME)))// check for source_menu/theme/source_menu.ini
{ {
if(!m_source.load(fmt("%s/%s", m_sourceDir.c_str(), SOURCE_FILENAME))) if(!m_source.load(fmt("%s/%s", m_sourceDir.c_str(), SOURCE_FILENAME)))// check for source_menu/source_menu.ini
return; return;// no source_menu.ini so no init source menu just return.
} }
else else // if source_menu/theme/source_menu.ini found then change m_sourceDir to source_menu/theme/
m_sourceDir = fmt("%s/%s", m_sourceDir.c_str(), themeName); m_sourceDir = fmt("%s/%s", m_sourceDir.c_str(), themeName);
/* let wiiflow know source_menu.ini found and we will be using it */
m_use_source = true; m_use_source = true;
/* get max source button # */ /* get max source button # */
m_max_source_btn = 0; m_max_source_btn = 0;
const char *srcDomain = m_source.firstDomain().c_str(); const char *srcDomain = m_source.firstDomain().c_str();
@ -690,6 +722,9 @@ void CMenu::_initSourceMenu()
srcDomain = m_source.nextDomain().c_str(); srcDomain = m_source.nextDomain().c_str();
} }
sm_tier = false;
curflow = m_cfg.getInt(SOURCEFLOW_DOMAIN, "last_cf_mode", 1);
_addUserLabels(m_sourceLblUser, ARRAY_SIZE(m_sourceLblUser), "SOURCE"); _addUserLabels(m_sourceLblUser, ARRAY_SIZE(m_sourceLblUser), "SOURCE");
m_sourceBg = _texture("SOURCE/BG", "texture", theme.bg, false); m_sourceBg = _texture("SOURCE/BG", "texture", theme.bg, false);
m_sourceLblTitle = _addTitle("SOURCE/TITLE", theme.titleFont, L"", 0, 10, 640, 60, theme.titleFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE); m_sourceLblTitle = _addTitle("SOURCE/TITLE", theme.titleFont, L"", 0, 10, 640, 60, theme.titleFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE);