From bcff8dfd58fc93ff9d326fcdcafe1fbd8efd7240 Mon Sep 17 00:00:00 2001
From: dimok321 <15055714+dimok789@users.noreply.github.com>
Date: Wed, 13 May 2009 15:56:16 +0000
Subject: [PATCH] *Added MP3 functions and MP3 Menu DON'T USE IT ITS STILL
BUGGY. DON'T MAKE ISSUES ABOUT IT.
---
Makefile | 3 +-
gui.pnproj | 2 +-
gui.pnps | 2 +-
source/libwiigui/gui_customoptionbrowser.h | 4 +-
source/menu.cpp | 141 ++++++++++++++++++++-
source/menu.h | 3 +-
source/mp3s.c | 131 +++++++++++++++++++
source/mp3s.h | 22 ++++
8 files changed, 298 insertions(+), 10 deletions(-)
create mode 100644 source/mp3s.c
create mode 100644 source/mp3s.h
diff --git a/Makefile b/Makefile
index a4277eac..aafc8e0e 100644
--- a/Makefile
+++ b/Makefile
@@ -31,13 +31,12 @@ LDFLAGS = -g $(MACHDEP) -Wl,-Map,$(notdir $@).map,--section-start,.init=0x80a00
#---------------------------------------------------------------------------------
# any extra libraries we wish to link with the project
#---------------------------------------------------------------------------------
-LIBS := -lfat -lpngu -lpng -lmetaphrasis -lm -lz -lwiiuse -lbte -lasnd -logc -ltremor -lfreetype
+LIBS := -lfat -lpngu -lpng -lmetaphrasis -lm -lz -lwiiuse -lmad -lbte -lasnd -logc -ltremor -lfreetype
#---------------------------------------------------------------------------------
# list of directories containing libraries, this must be the top level containing
# include and lib
#---------------------------------------------------------------------------------
LIBDIRS := $(DEVKITPPC)/lib $(CURDIR)
-
#---------------------------------------------------------------------------------
# no real need to edit anything past this point unless you need to add additional
# rules for different file extensions
diff --git a/gui.pnproj b/gui.pnproj
index 57e0c7ea..706f4bf5 100644
--- a/gui.pnproj
+++ b/gui.pnproj
@@ -1 +1 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/gui.pnps b/gui.pnps
index 4d76a3fe..adbc903b 100644
--- a/gui.pnps
+++ b/gui.pnps
@@ -1 +1 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/source/libwiigui/gui_customoptionbrowser.h b/source/libwiigui/gui_customoptionbrowser.h
index 2ea016bb..8e992225 100644
--- a/source/libwiigui/gui_customoptionbrowser.h
+++ b/source/libwiigui/gui_customoptionbrowser.h
@@ -7,8 +7,8 @@ class customOptionList {
value = new char * [size];
for (int i = 0; i < size; i++)
{
- name[i] = new char[30];
- value[i] = new char[20];
+ name[i] = new char[40];
+ value[i] = new char[40];
}
length = size;
};
diff --git a/source/menu.cpp b/source/menu.cpp
index 84fbca9c..243ee24e 100644
--- a/source/menu.cpp
+++ b/source/menu.cpp
@@ -39,6 +39,7 @@
#include "cfg.h"
#include "libwiigui/gui_customoptionbrowser.h"
#include "libwiigui/gui_gamebrowser.h"
+#include "mp3s.h"
#define MAX_CHARACTERS 38
@@ -3412,7 +3413,7 @@ static int MenuSettings()
tabBtn.SetImage(&tab1Img);
-
+
GuiButton page1Btn(40, 96);
page1Btn.SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
page1Btn.SetPosition(-202, 90);
@@ -3532,7 +3533,7 @@ static int MenuSettings()
page2Btn.SetTrigger(2, &trigR);
page3Btn.SetTrigger(1, &trigMinus);
page3Btn.SetTrigger(2, &trigL);
-
+
mainWindow->Append(&w);
mainWindow->Append(&optionBrowser2);
@@ -3590,7 +3591,7 @@ static int MenuSettings()
mainWindow->Append(&page1Btn);
mainWindow->Append(&page3Btn);
- sprintf(options2.name[0], " ");
+ sprintf(options2.name[0], "MP3 Menu");
sprintf(options2.name[1], " ");
sprintf(options2.name[2], " ");
sprintf(options2.name[3], "Under");
@@ -3600,6 +3601,8 @@ static int MenuSettings()
sprintf(options2.name[7], " ");
sprintf(options2.name[8], " ");
+
+
}
while(menu == MENU_NONE)
{
@@ -3980,6 +3983,18 @@ static int MenuSettings()
sprintf(options2.value[6], " ");
sprintf(options2.value[7], " ");
sprintf(options2.value[8], " ");
+
+ ret = optionBrowser2.GetClickedOption();
+
+ switch(ret) {
+
+ case 0:
+ menu = MENU_MP3;
+ pageToDisplay = 0;
+ break;
+
+ }
+
}
if(shutdown == 1)
@@ -4045,6 +4060,7 @@ static int MenuSettings()
// mainWindow->Remove(&page2Btn);
w.Remove(&backBtn);
w.Remove(&lockBtn);
+ w.Remove(&tabBtn);
char entered[20] = "";
int result = OnScreenKeyboard(entered, 20,0);
// mainWindow->Append(&page1Btn);
@@ -4052,6 +4068,7 @@ static int MenuSettings()
mainWindow->Append(&optionBrowser2);
w.Append(&backBtn);
w.Append(&lockBtn);
+ w.Append(&tabBtn);
if ( result == 1 )
{
if (!strcmp(entered, Settings.unlockCode)) //if password correct
@@ -4375,6 +4392,8 @@ int GameSettings(struct discHdr * header)
return retVal;
}
+
+
/****************************************************************************
* MenuCheck
***************************************************************************/
@@ -4487,6 +4506,119 @@ static int MenuCheck()
return menu;
}
+int MenuMp3()
+{
+ int menu = MENU_NONE, cnt = 0;
+ int ret = 0;
+ int scrollon, i = 0;
+
+ GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM, vol);
+ GuiSound btnClick(button_click2_pcm, button_click2_pcm_size, SOUND_PCM, vol);
+
+ GuiTrigger trigA;
+ trigA.SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
+
+ customOptionList options2(500);
+ char mp3path[30] = "SD:/mp3/";
+ char fullpath[100];
+ int countmp3 = GetFiles(mp3path);
+
+ for (cnt = 0; cnt < countmp3; cnt++) {
+ snprintf(options2.value[cnt], 30, "%s", mp3files[cnt]);
+ sprintf (options2.name[cnt],"%i.", cnt+1);
+ }
+ options2.length = cnt;
+
+ GuiImageData btnOutline(settings_menu_button_png);
+ if(cnt < 9) {
+ scrollon = 0;
+ } else {
+ scrollon = 1;
+ }
+ GuiCustomOptionBrowser optionBrowser4(396, 280, &options2, CFG.theme_path, "bg_options_settings", bg_options_settings_png, scrollon);
+ optionBrowser4.SetPosition(0, 90);
+ optionBrowser4.SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
+ optionBrowser4.SetCol2Position(65);
+
+ GuiText cancelBtnTxt("Back", 22, (GXColor){0, 0, 0, 255});
+ cancelBtnTxt.SetMaxWidth(btnOutline.GetWidth()-30);
+ GuiImage cancelBtnImg(&btnOutline);
+ if (Settings.wsprompt == yes){
+ cancelBtnImg.SetWidescreen(CFG.widescreen);}
+ GuiButton cancelBtn(btnOutline.GetWidth(), btnOutline.GetHeight());
+ cancelBtn.SetScale(0.9);
+ cancelBtn.SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
+ cancelBtn.SetPosition(180, 400);
+ cancelBtn.SetLabel(&cancelBtnTxt);
+ cancelBtn.SetImage(&cancelBtnImg);
+ cancelBtn.SetSoundOver(&btnSoundOver);
+ cancelBtn.SetTrigger(&trigA);
+ cancelBtn.SetEffectGrow();
+
+ GuiText playBtnTxt("Play", 22, (GXColor){0, 0, 0, 255});
+ cancelBtnTxt.SetMaxWidth(btnOutline.GetWidth()-30);
+ GuiImage playBtnImg(&btnOutline);
+ if (Settings.wsprompt == yes){
+ cancelBtnImg.SetWidescreen(CFG.widescreen);}
+ GuiButton playBtn(btnOutline.GetWidth(), btnOutline.GetHeight());
+ playBtn.SetScale(0.9);
+ playBtn.SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
+ playBtn.SetPosition(-180, 400);
+ playBtn.SetLabel(&playBtnTxt);
+ playBtn.SetImage(&playBtnImg);
+ playBtn.SetSoundOver(&btnSoundOver);
+ playBtn.SetTrigger(&trigA);
+ playBtn.SetEffectGrow();
+
+ HaltGui();
+ GuiWindow w(screenwidth, screenheight);
+ w.Append(&cancelBtn);
+ w.Append(&playBtn);
+ mainWindow->Append(&optionBrowser4);
+ mainWindow->Append(&w);
+
+ ResumeGui();
+
+ while(menu == MENU_NONE)
+ {
+ if (cancelBtn.GetState() == STATE_CLICKED)
+ {
+ menu = MENU_DISCLIST;
+ CloseMp3();
+ bgMusic->Play();
+ break;
+ }
+
+ ret = optionBrowser4.GetClickedOption();
+
+ for(i = 0; i < countmp3; i++) {
+ if(i == ret) {
+ sprintf(fullpath,"%s%s", mp3path,mp3files[ret]);
+ PlayMp3(fullpath);
+ SetMp3Volume(127);
+ }
+ }
+
+ if (playBtn.GetState() == STATE_CLICKED) {
+
+ ret = optionBrowser4.GetSelectedOption();
+ sprintf(fullpath,"%s%s", mp3path,mp3files[ret]);
+ //bgMusic->Stop();
+ PlayMp3(fullpath);
+ SetMp3Volume(127);
+ playBtn.ResetState();
+ }
+ }
+
+ HaltGui();
+ mainWindow->Remove(&optionBrowser4);
+ mainWindow->Remove(&w);
+ ResumeGui();
+ return menu;
+
+
+return menu;
+}
/****************************************************************************
* MainMenu
***************************************************************************/
@@ -4549,6 +4681,9 @@ int MainMenu(int menu)
case MENU_DISCLIST:
currentMenu = MenuDiscList();
break;
+ case MENU_MP3:
+ currentMenu = MenuMp3();
+ break;
default: // unrecognized menu
currentMenu = MenuCheck();
break;
diff --git a/source/menu.h b/source/menu.h
index 7e8bd317..e8b280fc 100644
--- a/source/menu.h
+++ b/source/menu.h
@@ -24,7 +24,8 @@ enum
MENU_FORMAT,
MENU_INSTALL,
MENU_CHECK,
- MENU_GAME_SETTINGS
+ MENU_GAME_SETTINGS,
+ MENU_MP3
};
#endif
diff --git a/source/mp3s.c b/source/mp3s.c
new file mode 100644
index 00000000..44ada7d8
--- /dev/null
+++ b/source/mp3s.c
@@ -0,0 +1,131 @@
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+#include
+
+#include "mp3s.h"
+
+char filename[80];
+
+//Files
+FILE* pFile;
+
+
+s32 my_reader(void *fp,void *dat, s32 size)
+{
+ return fread(dat, 1, size, fp);
+}
+
+
+void StopMp3()
+{
+ if(MP3Player_IsPlaying()) {
+ MP3Player_Stop();
+ }
+}
+
+void CloseMp3() {
+
+ if(MP3Player_IsPlaying()) {
+ MP3Player_Stop();
+ }
+ fclose(pFile);
+}
+
+void SetMp3Volume(u32 vol)
+{
+ MP3Player_Volume(vol);
+}
+
+int PlayMp3(char * path) {
+
+ if(!MP3Player_IsPlaying()) {
+ MP3Player_Init();
+ } else {
+ StopMp3();
+ }
+
+ pFile = fopen (path, "r");
+ MP3Player_PlayFile(pFile, my_reader, NULL);
+ return 1;
+}
+
+/*
+int PlayMp3(char * path)
+{
+
+
+ if(!MP3Player_IsPlaying()) {
+ MP3Player_Init();
+ } else {
+ MP3Player_Stop();
+ }
+ long lSize = 0;
+ char * buffermp3 = NULL;
+ size_t resultmp3;
+
+ pFile = fopen (path, "r");
+
+ //Check that pFile exist
+ if (pFile!=NULL)
+ {
+ // obtain file size:
+ fseek (pFile , 0 , SEEK_END);
+ lSize = ftell (pFile);
+ rewind (pFile);
+
+ // allocate memory to contain the whole file:
+ buffermp3 = (char*) malloc (sizeof(char)*lSize);
+ if (buffermp3 == NULL) {fputs (" Memory error",stderr); exit (2);}
+
+ // copy the file into the buffer:
+ resultmp3 = fread (buffermp3,1,lSize,pFile);
+ if (resultmp3 != lSize) {fputs (" Reading error",stderr); exit (3);}
+
+
+ fclose (pFile);
+ }
+
+ if (buffermp3 != NULL)
+ {
+ MP3Player_PlayBuffer(buffermp3,lSize,NULL);
+ return 1;
+ }
+
+return 0;
+}
+*/
+
+int GetFiles(char * mp3path)
+{
+int countmp3 = 0;
+
+struct stat st;
+DIR_ITER* dir;
+dir = diropen (mp3path);
+
+if (dir == NULL) //If empty
+ {
+ return 0;
+ }
+ else
+ {
+ while (dirnext(dir,filename,&st) == 0)
+ {
+ if ((st.st_mode & S_IFDIR) == 0)
+ {
+ // st.st_mode & S_IFDIR indicates a directory
+ sprintf(mp3files[countmp3], "%s", filename);
+ countmp3++;
+ }
+ }
+ }
+return countmp3;
+}
diff --git a/source/mp3s.h b/source/mp3s.h
new file mode 100644
index 00000000..4a2f7804
--- /dev/null
+++ b/source/mp3s.h
@@ -0,0 +1,22 @@
+#ifndef _MP3S_H_
+#define _MP3S_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+char mp3files[500][30];
+
+void StopMp3();
+void SetMp3Volume(u32 vol);
+int PlayMp3(char * path);
+int OpenMp3(char * path);
+void CloseMp3();
+int GetFiles(char * mp3path);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif