mirror of
https://github.com/Fledge68/WiiFlow_Lite.git
synced 2024-12-17 23:41:53 +01:00
-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:
parent
4af2936db7
commit
365eb5a217
BIN
out/boot.dol
BIN
out/boot.dol
Binary file not shown.
Before Width: | Height: | Size: 3.3 MiB After Width: | Height: | Size: 3.3 MiB |
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user