add sound effects

This commit is contained in:
dborth 2009-04-05 03:11:38 +00:00
parent 98ed387f26
commit 78d82f5ebd
12 changed files with 519 additions and 123 deletions

View File

@ -4,9 +4,10 @@
* *
* Tantric January 2009 * Tantric January 2009
* *
* imagelist.h * filelist.h
* *
* Contains a list of all of the images in the images/ folder * Contains a list of all of the files stored in the images/, fonts/, and
* sounds/ folders
***************************************************************************/ ***************************************************************************/
#ifndef _FILELIST_H_ #ifndef _FILELIST_H_
@ -20,9 +21,18 @@ extern const u32 font_ttf_size;
extern const u8 bg_music_ogg[]; extern const u8 bg_music_ogg[];
extern const u32 bg_music_ogg_size; extern const u32 bg_music_ogg_size;
extern const u8 enter_ogg[];
extern const u32 enter_ogg_size;
extern const u8 exit_ogg[];
extern const u32 exit_ogg_size;
extern const u8 button_over_pcm[]; extern const u8 button_over_pcm[];
extern const u32 button_over_pcm_size; extern const u32 button_over_pcm_size;
extern const u8 button_click_pcm[];
extern const u32 button_click_pcm_size;
extern const u8 logo_png[]; extern const u8 logo_png[];
extern const u32 logo_png_size; extern const u32 logo_png_size;

View File

@ -530,8 +530,8 @@ InitGCVideo ()
// widescreen fix // widescreen fix
if(CONF_GetAspectRatio()) if(CONF_GetAspectRatio())
{ {
vmode->viWidth = 678; vmode->viWidth = VI_MAX_WIDTH_PAL-12;
vmode->viXOrigin = (VI_MAX_WIDTH_PAL - 678) / 2; vmode->viXOrigin = ((VI_MAX_WIDTH_PAL - vmode->viWidth) / 2) + 2;
} }
#endif #endif

View File

@ -1,16 +1,35 @@
/**************************************************************************** /*!\mainpage libwiigui Documentation
* FCE Ultra 0.98.12
* Nintendo Wii/Gamecube Port
* *
* Tantric February 2009 * \section Introduction
* libwiigui is a GUI library for the Wii, created to help structure the
* design of a complicated GUI interface, and to enable an author to create
* a sophisticated, feature-rich GUI. It was originally conceived and written
* after I started to design a GUI for Snes9x GX, and found libwiisprite and
* GRRLIB inadequate for the purpose. It uses GX for drawing, and makes use
* of PNGU for displaying images and FreeTypeGX for text. It was designed to
* be flexible and is easy to modify - don't be afraid to change the way it
* works or expand it to suit your GUI's purposes! If you do, and you think
* your changes might benefit others, please share them so they might be
* added to the project!
* *
* gui.h * \section Quickstart
* * Start from the supplied template example. For more advanced uses, see the
* GUI class definitions * source code for Snes9x GX, FCE Ultra GX, and Visual Boy Advance GX.
***************************************************************************/
#ifndef GUI_H * \section Contact
#define GUI_H * If you have any suggestions for the library or documentation, or want to
* contribute, please visit the libwiigui website:
* http://code.google.com/p/libwiigui/
* \section Credits
* This library was wholly designed and written by Tantric. Thanks to the
* authors of PNGU and FreeTypeGX, of which this library makes use. Thanks
* also to the authors of GRRLIB and libwiisprite for laying the foundations.
*
*/
#ifndef LIBWIIGUI_H
#define LIBWIIGUI_H
#include <gccore.h> #include <gccore.h>
#include <malloc.h> #include <malloc.h>
@ -82,233 +101,478 @@ enum
extern FreeTypeGX *fontSystem; extern FreeTypeGX *fontSystem;
//!Sound conversion and playback. A wrapper for other sound libraries - ASND, libmad, ltremor, etc
class GuiSound class GuiSound
{ {
public: public:
//!Constructor
//!\param s Pointer to the sound data
//!\param l Length of sound data
//!\param t Sound format type (SOUND_PCM or SOUND_OGG)
GuiSound(const u8 * s, int l, int t); GuiSound(const u8 * s, int l, int t);
//!Destructor
~GuiSound(); ~GuiSound();
//!Start sound playback
void Play(); void Play();
//!Stop sound playback
void Stop(); void Stop();
//!Pause sound playback
void Pause(); void Pause();
//!Resume sound playback
void Resume(); void Resume();
//!Checks if the sound is currently playing
//!\return true if sound is playing, false otherwise
bool IsPlaying();
//!Set sound volume
//!\param v Sound volume (0-100)
void SetVolume(int v); void SetVolume(int v);
//!Set the sound to loop playback (only applies to OGG)
//!\param l Loop (true to loop)
void SetLoop(bool l);
protected: protected:
const u8 * sound; const u8 * sound; //!< Pointer to the sound data
int type; int type; //!< Sound format type (SOUND_PCM or SOUND_OGG)
s32 length; s32 length; //!< Length of sound data
s32 voice; s32 voice; //!< Currently assigned ASND voice channel
s32 volume; s32 volume; //!< Sound volume (0-100)
bool loop; //!< Loop sound playback
}; };
//!Primary Gui class
class GuiElement class GuiElement
{ {
public: public:
//!Constructor
GuiElement(); GuiElement();
//!Destructor
~GuiElement(); ~GuiElement();
//!Set the element's parent
//!\param e Pointer to parent element
void SetParent(GuiElement * e); void SetParent(GuiElement * e);
//!Gets the current leftmost coordinate of the element
//!Considers horizontal alignment, x offset, width, and parent element's GetLeft() / GetWidth() values
//!\return left coordinate
int GetLeft(); int GetLeft();
//!Gets the current topmost coordinate of the element
//!Considers vertical alignment, y offset, height, and parent element's GetTop() / GetHeight() values
//!\return top coordinate
int GetTop(); int GetTop();
//!Gets the current width of the element. Does not currently consider the scale
//!\return width
int GetWidth(); int GetWidth();
//!Gets the height of the element. Does not currently consider the scale
//!\return height
int GetHeight(); int GetHeight();
//!Sets the size (width/height) of the element
//!\param w Width of element
//!\param h Height of element
void SetSize(int w, int h); void SetSize(int w, int h);
//!Checks whether or not the element is visible
//!\return true if visible, false otherwise
bool IsVisible(); bool IsVisible();
//!Checks whether or not the element is selectable
//!\return true if selectable, false otherwise
bool IsSelectable(); bool IsSelectable();
//!Checks whether or not the element is clickable
//!\return true if clickable, false otherwise
bool IsClickable(); bool IsClickable();
//!Sets whether or not the element is selectable
//!\param s Selectable
void SetSelectable(bool s); void SetSelectable(bool s);
//!Sets whether or not the element is clickable
//!\param c Clickable
void SetClickable(bool c); void SetClickable(bool c);
//!Gets the element's current state
//!\return state
int GetState(); int GetState();
//!Sets the element's alpha value
//!\param a alpha value
void SetAlpha(int a); void SetAlpha(int a);
//!Gets the element's alpha value
//!Considers alpha, alphaDyn, and the parent element's GetAlpha() value
//!\return alpha
int GetAlpha(); int GetAlpha();
//!Sets the element's scale
//!\param s scale (1 is 100%)
void SetScale(float s); void SetScale(float s);
//!Gets the element's current scale
//!Considers scale, scaleDyn, and the parent element's GetScale() value
float GetScale(); float GetScale();
//!Set a new GuiTrigger for the element
//!\param t Pointer to GuiTrigger
void SetTrigger(GuiTrigger * t); void SetTrigger(GuiTrigger * t);
//!\overload
//!\param i Index of trigger array to set
//!\param t Pointer to GuiTrigger
void SetTrigger(u8 i, GuiTrigger * t); void SetTrigger(u8 i, GuiTrigger * t);
//!Checks whether rumble was requested by the element
//!\return true is rumble was requested, false otherwise
bool Rumble(); bool Rumble();
//!Sets whether or not the element is requesting a rumble event
//!\param r true if requesting rumble, false if not
void SetRumble(bool r); void SetRumble(bool r);
//!Set an effect for the element
//!\param e Effect to enable
//!\param a Amount of the effect (usage varies on effect)
//!\param t Target amount of the effect (usage varies on effect)
void SetEffect(int e, int a, int t=0); void SetEffect(int e, int a, int t=0);
//!Sets an effect to be enabled on wiimote cursor over
//!\param e Effect to enable
//!\param a Amount of the effect (usage varies on effect)
//!\param t Target amount of the effect (usage varies on effect)
void SetEffectOnOver(int e, int a, int t=0); void SetEffectOnOver(int e, int a, int t=0);
//!Shortcut to SetEffectOnOver(EFFECT_SCALE, 4, 110)
void SetEffectGrow(); void SetEffectGrow();
//!Gets the current element effects
//!\return element effects
int GetEffect(); int GetEffect();
//!Checks whether the specified coordinates are within the element's boundaries
//!\param x X coordinate
//!\param y Y coordinate
//!\return true if contained within, false otherwise
bool IsInside(int x, int y); bool IsInside(int x, int y);
//!Sets the element's position
//!\param x X coordinate
//!\param y Y coordinate
void SetPosition(int x, int y); void SetPosition(int x, int y);
//!Updates the element's effects (dynamic values)
//!Called by Draw(), used for animation purposes
void UpdateEffects(); void UpdateEffects();
//!Sets a function to called after after Update()
//!Callback function can be used to response to changes in the state of the element, and/or update the element's attributes
void SetUpdateCallback(UpdateCallback u); void SetUpdateCallback(UpdateCallback u);
//!Checks whether the element is in focus
//!\return true if element is in focus, false otherwise
int IsFocused(); int IsFocused();
//!Sets the element's visibility
//!\param v Visibility (true = visible)
virtual void SetVisible(bool v); virtual void SetVisible(bool v);
//!Sets the element's focus
//!\param v Focus (true = in focus)
virtual void SetFocus(int f); virtual void SetFocus(int f);
//!Sets the element's state
//!\param v State (STATE_DEFAULT, STATE_SELECTED, STATE_CLICKED, STATE_DISABLED)
virtual void SetState(int s); virtual void SetState(int s);
//!Resets the element's state to STATE_DEFAULT
virtual void ResetState(); virtual void ResetState();
//!Gets whether or not the element is in STATE_SELECTED
//!\return true if selected, false otherwise
virtual int GetSelected(); virtual int GetSelected();
//!Sets the element's alignment respective to its parent element
//!\param hor Horizontal alignment (ALIGN_LEFT, ALIGN_RIGHT, ALIGN_CENTRE)
//!\param vert Vertical alignment (ALIGN_TOP, ALIGN_BOTTOM, ALIGN_MIDDLE)
virtual void SetAlignment(int hor, int vert); virtual void SetAlignment(int hor, int vert);
//!Called constantly to allow the element to respond to the current input data
//!\param t Pointer to a GuiTrigger, containing the current input data from PAD/WPAD
virtual void Update(GuiTrigger * t); virtual void Update(GuiTrigger * t);
//!Called constantly to redraw the element
virtual void Draw(); virtual void Draw();
protected: protected:
bool visible; bool visible; //!< Visibility of the element. If false, Draw() is skipped
int focus; // -1 = cannot focus, 0 = not focused, 1 = focused int focus; //!< Element focus (-1 = focus disabled, 0 = not focused, 1 = focused)
int width; int width; //!< Element width
int height; int height; //!< Element height
int xoffset; int xoffset; //!< Element X offset
int yoffset; int yoffset; //!< Element Y offset
int xoffsetDyn; int xoffsetDyn; //!< Element X offset, dynamic (added to xoffset value for animation effects)
int yoffsetDyn; int yoffsetDyn; //!< Element Y offset, dynamic (added to yoffset value for animation effects)
int alpha; int alpha; //!< Element alpha value (0-255)
f32 scale; f32 scale; //!< Element scale (1 = 100%)
int alphaDyn; int alphaDyn; //!< Element alpha, dynamic (multiplied by alpha value for blending/fading effects)
f32 scaleDyn; f32 scaleDyn; //!< Element scale, dynamic (multiplied by alpha value for blending/fading effects)
bool rumble; bool rumble; //!< Wiimote rumble (on/off) - set to on when this element requests a rumble event
int effects; int effects; //!< Currently enabled effect(s). 0 when no effects are enabled
int effectAmount; int effectAmount; //!< Effect amount. Used by different effects for different purposes
int effectTarget; int effectTarget; //!< Effect target amount. Used by different effects for different purposes
int effectsOver; int effectsOver; //!< Effects to enable when wiimote cursor is over this element. Copied to effects variable on over event
int effectAmountOver; int effectAmountOver; //!< EffectAmount to set when wiimote cursor is over this element
int effectTargetOver; int effectTargetOver; //!< EffectTarget to set when wiimote cursor is over this element
int alignmentHor; // LEFT, RIGHT, CENTRE int alignmentHor; //!< Horizontal element alignment, respective to parent element (LEFT, RIGHT, CENTRE)
int alignmentVert; // TOP, BOTTOM, MIDDLE int alignmentVert; //!< Horizontal element alignment, respective to parent element (TOP, BOTTOM, MIDDLE)
int state; // DEFAULT, SELECTED, CLICKED, DISABLED int state; //!< Element state (DEFAULT, SELECTED, CLICKED, DISABLED)
bool selectable; // is SELECTED a valid state? bool selectable; //!< Whether or not this element selectable (can change to SELECTED state)
bool clickable; // is CLICKED a valid state? bool clickable; //!< Whether or not this element is clickable (can change to CLICKED state)
GuiTrigger * trigger[2]; GuiTrigger * trigger[2]; //!< GuiTriggers (input actions) that this element responds to
GuiElement * parentElement; GuiElement * parentElement; //!< Parent element
UpdateCallback updateCB; UpdateCallback updateCB; //!< Callback function to call when this element is updated
}; };
//!Groups elements into one window in which they can be managed. //!Allows GuiElements to be grouped together into a "window"
class GuiWindow : public GuiElement class GuiWindow : public GuiElement
{ {
public: public:
//!Constructor //!Constructor
GuiWindow(); GuiWindow();
//!\overload
//!\param w Width of window
//!\param h Height of window
GuiWindow(int w, int h); GuiWindow(int w, int h);
//!Destructor. //!Destructor
~GuiWindow(); ~GuiWindow();
//!Appends a GuiElement to the GuiWindow
//!Appends a element at the end, thus drawing it at last. //!\param e The GuiElement to append. If it is already in the GuiWindow, it is removed first
//!\param element The element to append. If it is already in the list, it gets removed first.
void Append(GuiElement* e); void Append(GuiElement* e);
//!Inserts a element into the manager. //!Inserts a GuiElement into the GuiWindow at the specified index
//!\param element The element to insert. If it is already in the list, it gets removed first. //!\param e The GuiElement to insert. If it is already in the GuiWindow, it is removed first
//!\param index The new index of the element. //!\param i Index in which to insert the element
void Insert(GuiElement* e, u32 index); void Insert(GuiElement* e, u32 i);
//!Removes a element from the list. //!Removes the specified GuiElement from the GuiWindow
//!\param element A element that is in the list. //!\param e GuiElement to be removed
void Remove(GuiElement* e); void Remove(GuiElement* e);
//!Clears the whole GuiWindow from all GuiElement. //!Removes all GuiElements
void RemoveAll(); void RemoveAll();
//!Returns the GuiElement at the specified index
//!Returns a element at a specified index. //!\param index The index of the element
//!\param index The index from where to poll the element. //!\return A pointer to the element at the index, NULL on error (eg: out of bounds)
//!\return A pointer to the element at the index. NULL if index is out of bounds.
GuiElement* GetGuiElementAt(u32 index) const; GuiElement* GetGuiElementAt(u32 index) const;
//!Returns the size of the list of elements. //!Returns the size of the list of elements
//!\return The size of the current elementlist. //!\return The size of the current element list
u32 GetSize(); u32 GetSize();
//!Sets the visibility of the window
//!\param v visibility (true = visible)
void SetVisible(bool v); void SetVisible(bool v);
//!Resets the window's state to STATE_DEFAULT
void ResetState(); void ResetState();
//!Sets the window's state
//!\param s State
void SetState(int s); void SetState(int s);
//!Gets the index of the GuiElement inside the window that is currently selected
//!\return index of selected GuiElement
int GetSelected(); int GetSelected();
//!Sets the window focus
//!\param f Focus
void SetFocus(int f); void SetFocus(int f);
//!Change the focus to the specified element
//!This is intended for the primary GuiWindow only
//!\param e GuiElement that should have focus
void ChangeFocus(GuiElement * e); void ChangeFocus(GuiElement * e);
//!Changes window focus to the next focusable window or element
//!If no element is in focus, changes focus to the first available element
//!If B or 1 button is pressed, changes focus to the next available element
//!This is intended for the primary GuiWindow only
//!\param t Pointer to a GuiTrigger, containing the current input data from PAD/WPAD
void ToggleFocus(GuiTrigger * t); void ToggleFocus(GuiTrigger * t);
//!Moves the selected element to the element to the left or right
//!\param d Direction to move (-1 = left, 1 = right)
void MoveSelectionHor(int d); void MoveSelectionHor(int d);
//!Moves the selected element to the element above or below
//!\param d Direction to move (-1 = up, 1 = down)
void MoveSelectionVert(int d); void MoveSelectionVert(int d);
//!Draws all the elements in this GuiWindow
//!Draws all the elements in this GuiWindow.
void Draw(); void Draw();
//!Updates the window and all elements contains within
//!Allows the GuiWindow and all elements to respond to the input data specified
//!\param t Pointer to a GuiTrigger, containing the current input data from PAD/WPAD
void Update(GuiTrigger * t); void Update(GuiTrigger * t);
protected: protected:
std::vector<GuiElement*> _elements; std::vector<GuiElement*> _elements; //!< Contains all elements within the GuiWindow
}; };
//!Converts image data into GX-useable RGBA8
//!Currently designed for use only with PNG files
class GuiImageData class GuiImageData
{ {
public: public:
//!Constructor
//!Converts the image data to RGBA8 - expects PNG format
//!\param i Image data
GuiImageData(const u8 * i); GuiImageData(const u8 * i);
//!Destructor
~GuiImageData(); ~GuiImageData();
//!Gets a pointer to the image data
//!\return pointer to image data
u8 * GetImage(); u8 * GetImage();
//!Gets the image width
//!\return image width
int GetWidth(); int GetWidth();
//!Gets the image height
//!\return image height
int GetHeight(); int GetHeight();
protected: protected:
u8 * data; u8 * data; //!< Image data
int height; int height; //!< Height of image
int width; int width; //!< Width of image
}; };
//!Display, manage, and manipulate images in the Gui
class GuiImage : public GuiElement class GuiImage : public GuiElement
{ {
public: public:
//!Constructor
//!\param img Pointer to GuiImageData element
GuiImage(GuiImageData * img); GuiImage(GuiImageData * img);
//!\overload
//!Sets up a new image from the image data specified
//!\param img
//!\param w Image width
//!\param h Image height
GuiImage(u8 * img, int w, int h); GuiImage(u8 * img, int w, int h);
//!\overload
//!Creates an image filled with the specified color
//!\param w Image width
//!\param h Image height
//!\param c Image color
GuiImage(int w, int h, GXColor c); GuiImage(int w, int h, GXColor c);
//!Destructor
~GuiImage(); ~GuiImage();
//!Sets the image rotation angle for drawing
//!\param a Angle (in degrees)
void SetAngle(float a); void SetAngle(float a);
//!Sets the number of times to draw the image horizontally
//!\param t Number of times to draw the image
void SetTile(int t); void SetTile(int t);
//!Constantly called to draw the image
void Draw(); void Draw();
//!Gets the image data
//!\return pointer to image data
u8 * GetImage(); u8 * GetImage();
//!Sets up a new image using the GuiImageData object specified
//!\param img Pointer to GuiImageData object
void SetImage(GuiImageData * img); void SetImage(GuiImageData * img);
//!\overload
//!\param img Pointer to image data
//!\param w Width
//!\param h Height
void SetImage(u8 * img, int w, int h); void SetImage(u8 * img, int w, int h);
//!Gets the pixel color at the specified coordinates of the image
//!\param x X coordinate
//!\param y Y coordinate
GXColor GetPixel(int x, int y); GXColor GetPixel(int x, int y);
//!Sets the pixel color at the specified coordinates of the image
//!\param x X coordinate
//!\param y Y coordinate
//!\param color Pixel color
void SetPixel(int x, int y, GXColor color); void SetPixel(int x, int y, GXColor color);
//!Directly modifies the image data to create a color-striped effect
//!Alters the RGB values by the specified amount
//!\param s Amount to increment/decrement the RGB values in the image
void ColorStripe(int s); void ColorStripe(int s);
//!Sets a stripe effect on the image, overlaying alpha blended rectangles
//!Does not alter the image data
//!\param s Alpha amount to draw over the image
void SetStripe(int s); void SetStripe(int s);
protected: protected:
int imgType; int imgType; //!< Type of image data (IMAGE_TEXTURE, IMAGE_COLOR, IMAGE_DATA)
u8 * image; u8 * image; //!< Poiner to image data. May be shared with GuiImageData data
f32 imageangle; f32 imageangle; //!< Angle to draw the image
int tile; int tile; //!< Number of times to draw (tile) the image horizontally
int stripe; int stripe; //!< Alpha value (0-255) to apply a stripe effect to the texture
}; };
//!Display, manage, and manipulate text in the Gui
class GuiText : public GuiElement class GuiText : public GuiElement
{ {
public: public:
//!Constructor
//!\param t Text
//!\param s Font size
//!\param c Font color
GuiText(const char * t, int s, GXColor c); GuiText(const char * t, int s, GXColor c);
//!\overload
//!\Assumes SetPresets() has been called to setup preferred text attributes
//!\param t Text
GuiText(const char * t); GuiText(const char * t);
//!Destructor
~GuiText(); ~GuiText();
//!Sets the text of the GuiText element
//!\param t Text
void SetText(const char * t); void SetText(const char * t);
//!Sets up preset values to be used by GuiText(t)
//!Useful when printing multiple text elements, all with the same attributes set
//!\param sz Font size
//!\param c Font color
//!\param w Maximum width of texture image (for text wrapping)
//!\param s Font size
//!\param h Text alignment (horizontal)
//!\param v Text alignment (vertical)
void SetPresets(int sz, GXColor c, int w, u16 s, int h, int v); void SetPresets(int sz, GXColor c, int w, u16 s, int h, int v);
//!Sets the font size
//!\param s Font size
void SetFontSize(int s); void SetFontSize(int s);
//!Sets the maximum width of the drawn texture image
//!If the text exceeds this, it is wrapped to the next line
//!\param w Maximum width
void SetMaxWidth(int w); void SetMaxWidth(int w);
//!Sets the font color
//!\param c Font color
void SetColor(GXColor c); void SetColor(GXColor c);
//!Sets the FreeTypeGX style attributes
//!\param s Style attributes
void SetStyle(u16 s); void SetStyle(u16 s);
//!Sets the text alignment
//!\param hor Horizontal alignment (ALIGN_LEFT, ALIGN_RIGHT, ALIGN_CENTRE)
//!\param vert Vertical alignment (ALIGN_TOP, ALIGN_BOTTOM, ALIGN_MIDDLE)
void SetAlignment(int hor, int vert); void SetAlignment(int hor, int vert);
//!Constantly called to draw the text
void Draw(); void Draw();
protected: protected:
wchar_t* text; wchar_t* text; //!< Unicode text value
int size; int size; //!< Font size
int maxWidth; int maxWidth; //!< Maximum width of the generated text object (for text wrapping)
u16 style; u16 style; //!< FreeTypeGX style attributes
GXColor color; GXColor color; //!< Font color
}; };
//!Display, manage, and manipulate buttons in the Gui
//!Buttons can have images, icons, text, and sound set (all of which are optional)
class GuiButton : public GuiElement class GuiButton : public GuiElement
{ {
public: public:
//!Constructor
//!\param w Width
//!\param h Height
GuiButton(int w, int h); GuiButton(int w, int h);
//!Destructor
~GuiButton(); ~GuiButton();
//!Sets the button's image
//!\param i Pointer to GuiImage object
void SetImage(GuiImage* i); void SetImage(GuiImage* i);
//!Sets the button's image on over
//!\param i Pointer to GuiImage object
void SetImageOver(GuiImage* i); void SetImageOver(GuiImage* i);
//!Sets the button's icon
//!\param i Pointer to GuiImage object
void SetIcon(GuiImage* i); void SetIcon(GuiImage* i);
//!Sets the button's icon on over
//!\param i Pointer to GuiImage object
void SetIconOver(GuiImage* i); void SetIconOver(GuiImage* i);
//!Sets the button's label
//!\param t Pointer to GuiText object
void SetLabel(GuiText* t); void SetLabel(GuiText* t);
void SetLabelOver(GuiText* t); //!\overload
//!\param t Pointer to GuiText object
//!\param n Index of label to set
void SetLabel(GuiText* t, int n); void SetLabel(GuiText* t, int n);
//!Sets the button's label on over (eg: different colored text)
//!\param t Pointer to GuiText object
void SetLabelOver(GuiText* t);
//!\overload
//!\param t Pointer to GuiText object
//!\param n Index of label to set
void SetLabelOver(GuiText* t, int n); void SetLabelOver(GuiText* t, int n);
//!Sets the sound to play on over
//!\param s Pointer to GuiSound object
void SetSoundOver(GuiSound * s); void SetSoundOver(GuiSound * s);
//!Sets the sound to play on click
//!\param s Pointer to GuiSound object
void SetSoundClick(GuiSound * s); void SetSoundClick(GuiSound * s);
//!Constantly called to draw the GuiButton
void Draw(); void Draw();
//!Constantly called to allow the GuiButton to respond to updated input data
//!\param t Pointer to a GuiTrigger, containing the current input data from PAD/WPAD
void Update(GuiTrigger * t); void Update(GuiTrigger * t);
protected: protected:
GuiImage * image; GuiImage * image; //!< Button image
GuiImage * imageOver; GuiImage * imageOver; //!< Button image on wiimote cursor over
GuiImage * icon; GuiImage * icon; //!< Button icon (drawn after button image)
GuiImage * iconOver; GuiImage * iconOver; //!< Button icon on wiimote cursor over
GuiText * label[3]; GuiText * label[3]; //!< Label(s) to display
GuiText * labelOver[3]; GuiText * labelOver[3]; //!< Label(s) to display on wiimote cursor over
GuiSound * soundOver; GuiSound * soundOver; //!< Sound to play on wiimote cursor over
GuiSound * soundClick; GuiSound * soundClick; //!< Sound to play on click
}; };
//!Display a list of files
class GuiFileBrowser : public GuiElement class GuiFileBrowser : public GuiElement
{ {
public: public:
@ -352,6 +616,8 @@ class GuiFileBrowser : public GuiElement
GuiImageData * scrollbarBox; GuiImageData * scrollbarBox;
GuiImageData * scrollbarBoxOver; GuiImageData * scrollbarBoxOver;
GuiSound * btnSoundOver;
GuiSound * btnSoundClick;
GuiTrigger * trigA; GuiTrigger * trigA;
}; };
@ -361,6 +627,7 @@ typedef struct _optionlist {
char value[MAX_OPTIONS][150]; char value[MAX_OPTIONS][150];
} OptionList; } OptionList;
//!Display a list of menu options
class GuiOptionBrowser : public GuiElement class GuiOptionBrowser : public GuiElement
{ {
public: public:
@ -407,6 +674,8 @@ class GuiOptionBrowser : public GuiElement
GuiImageData * scrollbarBox; GuiImageData * scrollbarBox;
GuiImageData * scrollbarBoxOver; GuiImageData * scrollbarBoxOver;
GuiSound * btnSoundOver;
GuiSound * btnSoundClick;
GuiTrigger * trigA; GuiTrigger * trigA;
}; };
@ -420,6 +689,7 @@ typedef struct _savelist {
int files[2][100]; int files[2][100];
} SaveList; } SaveList;
//!Display a list of game save files, with screenshots and file information
class GuiSaveBrowser : public GuiElement class GuiSaveBrowser : public GuiElement
{ {
public: public:
@ -468,6 +738,8 @@ class GuiSaveBrowser : public GuiElement
GuiImageData * scrollbarBox; GuiImageData * scrollbarBox;
GuiImageData * scrollbarBoxOver; GuiImageData * scrollbarBoxOver;
GuiSound * btnSoundOver;
GuiSound * btnSoundClick;
GuiTrigger * trigA; GuiTrigger * trigA;
}; };
@ -475,6 +747,7 @@ typedef struct _keytype {
char ch, chShift; char ch, chShift;
} Key; } Key;
//!On-screen keyboard
class GuiKeyboard : public GuiWindow class GuiKeyboard : public GuiWindow
{ {
public: public:
@ -516,6 +789,7 @@ class GuiKeyboard : public GuiWindow
GuiImageData * keyLarge; GuiImageData * keyLarge;
GuiImageData * keyLargeOver; GuiImageData * keyLargeOver;
GuiSound * keySoundOver; GuiSound * keySoundOver;
GuiSound * keySoundClick;
GuiTrigger * trigA; GuiTrigger * trigA;
}; };

View File

@ -30,6 +30,9 @@ GuiFileBrowser::GuiFileBrowser(int w, int h)
else else
trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
btnSoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
btnSoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
bgGameSelection = new GuiImageData(bg_game_selection_png); bgGameSelection = new GuiImageData(bg_game_selection_png);
bgGameSelectionImg = new GuiImage(bgGameSelection); bgGameSelectionImg = new GuiImage(bgGameSelection);
bgGameSelectionImg->SetParent(this); bgGameSelectionImg->SetParent(this);
@ -64,6 +67,8 @@ GuiFileBrowser::GuiFileBrowser(int w, int h)
arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP); arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP);
arrowUpBtn->SetSelectable(false); arrowUpBtn->SetSelectable(false);
arrowUpBtn->SetTrigger(trigA); arrowUpBtn->SetTrigger(trigA);
arrowUpBtn->SetSoundOver(btnSoundOver);
arrowUpBtn->SetSoundClick(btnSoundClick);
arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight()); arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight());
arrowDownBtn->SetParent(this); arrowDownBtn->SetParent(this);
@ -72,6 +77,8 @@ GuiFileBrowser::GuiFileBrowser(int w, int h)
arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM); arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM);
arrowDownBtn->SetSelectable(false); arrowDownBtn->SetSelectable(false);
arrowDownBtn->SetTrigger(trigA); arrowDownBtn->SetTrigger(trigA);
arrowDownBtn->SetSoundOver(btnSoundOver);
arrowDownBtn->SetSoundClick(btnSoundClick);
scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight()); scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight());
scrollbarBoxBtn->SetParent(this); scrollbarBoxBtn->SetParent(this);
@ -95,6 +102,7 @@ GuiFileBrowser::GuiFileBrowser(int w, int h)
gameList[i]->SetImageOver(gameListBg[i]); gameList[i]->SetImageOver(gameListBg[i]);
gameList[i]->SetPosition(2,30*i+3); gameList[i]->SetPosition(2,30*i+3);
gameList[i]->SetTrigger(trigA); gameList[i]->SetTrigger(trigA);
gameList[i]->SetSoundClick(btnSoundClick);
} }
} }
@ -127,6 +135,8 @@ GuiFileBrowser::~GuiFileBrowser()
delete scrollbarBox; delete scrollbarBox;
delete scrollbarBoxOver; delete scrollbarBoxOver;
delete btnSoundOver;
delete btnSoundClick;
delete trigA; delete trigA;
for(int i=0; i<PAGESIZE; i++) for(int i=0; i<PAGESIZE; i++)

View File

@ -100,6 +100,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keyLargeOver = new GuiImageData(keyboard_largekey_over_png); keyLargeOver = new GuiImageData(keyboard_largekey_over_png);
keySoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM); keySoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
keySoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
trigA = new GuiTrigger; trigA = new GuiTrigger;
if(GCSettings.WiimoteOrientation) if(GCSettings.WiimoteOrientation)
@ -115,6 +116,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keyBack->SetImageOver(keyBackOverImg); keyBack->SetImageOver(keyBackOverImg);
keyBack->SetLabel(keyBackText); keyBack->SetLabel(keyBackText);
keyBack->SetSoundOver(keySoundOver); keyBack->SetSoundOver(keySoundOver);
keyBack->SetSoundClick(keySoundClick);
keyBack->SetTrigger(trigA); keyBack->SetTrigger(trigA);
keyBack->SetPosition(10*42+40, 0*42+80); keyBack->SetPosition(10*42+40, 0*42+80);
keyBack->SetEffectGrow(); keyBack->SetEffectGrow();
@ -128,6 +130,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keyCaps->SetImageOver(keyCapsOverImg); keyCaps->SetImageOver(keyCapsOverImg);
keyCaps->SetLabel(keyCapsText); keyCaps->SetLabel(keyCapsText);
keyCaps->SetSoundOver(keySoundOver); keyCaps->SetSoundOver(keySoundOver);
keyCaps->SetSoundClick(keySoundClick);
keyCaps->SetTrigger(trigA); keyCaps->SetTrigger(trigA);
keyCaps->SetPosition(0, 2*42+80); keyCaps->SetPosition(0, 2*42+80);
keyCaps->SetEffectGrow(); keyCaps->SetEffectGrow();
@ -141,6 +144,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keyShift->SetImageOver(keyShiftOverImg); keyShift->SetImageOver(keyShiftOverImg);
keyShift->SetLabel(keyShiftText); keyShift->SetLabel(keyShiftText);
keyShift->SetSoundOver(keySoundOver); keyShift->SetSoundOver(keySoundOver);
keyShift->SetSoundClick(keySoundClick);
keyShift->SetTrigger(trigA); keyShift->SetTrigger(trigA);
keyShift->SetPosition(21, 3*42+80); keyShift->SetPosition(21, 3*42+80);
keyShift->SetEffectGrow(); keyShift->SetEffectGrow();
@ -152,6 +156,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keySpace->SetImage(keySpaceImg); keySpace->SetImage(keySpaceImg);
keySpace->SetImageOver(keySpaceOverImg); keySpace->SetImageOver(keySpaceOverImg);
keySpace->SetSoundOver(keySoundOver); keySpace->SetSoundOver(keySoundOver);
keySpace->SetSoundClick(keySoundClick);
keySpace->SetTrigger(trigA); keySpace->SetTrigger(trigA);
keySpace->SetPosition(0, 4*42+80); keySpace->SetPosition(0, 4*42+80);
keySpace->SetAlignment(ALIGN_CENTRE, ALIGN_TOP); keySpace->SetAlignment(ALIGN_CENTRE, ALIGN_TOP);
@ -171,6 +176,7 @@ GuiKeyboard::GuiKeyboard(char * t, u16 max)
keyBtn[i][j]->SetImage(keyImg[i][j]); keyBtn[i][j]->SetImage(keyImg[i][j]);
keyBtn[i][j]->SetImageOver(keyImgOver[i][j]); keyBtn[i][j]->SetImageOver(keyImgOver[i][j]);
keyBtn[i][j]->SetSoundOver(keySoundOver); keyBtn[i][j]->SetSoundOver(keySoundOver);
keyBtn[i][j]->SetSoundClick(keySoundClick);
keyBtn[i][j]->SetTrigger(trigA); keyBtn[i][j]->SetTrigger(trigA);
keyBtn[i][j]->SetLabel(keyTxt[i][j]); keyBtn[i][j]->SetLabel(keyTxt[i][j]);
keyBtn[i][j]->SetPosition(j*42+21*i+40, i*42+80); keyBtn[i][j]->SetPosition(j*42+21*i+40, i*42+80);
@ -210,6 +216,7 @@ GuiKeyboard::~GuiKeyboard()
delete keyLarge; delete keyLarge;
delete keyLargeOver; delete keyLargeOver;
delete keySoundOver; delete keySoundOver;
delete keySoundClick;
delete trigA; delete trigA;
for(int i=0; i<4; i++) for(int i=0; i<4; i++)

View File

@ -31,6 +31,9 @@ GuiOptionBrowser::GuiOptionBrowser(int w, int h, OptionList * l)
else else
trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
btnSoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
btnSoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
bgOptions = new GuiImageData(bg_options_png); bgOptions = new GuiImageData(bg_options_png);
bgOptionsImg = new GuiImage(bgOptions); bgOptionsImg = new GuiImage(bgOptions);
bgOptionsImg->SetParent(this); bgOptionsImg->SetParent(this);
@ -64,6 +67,8 @@ GuiOptionBrowser::GuiOptionBrowser(int w, int h, OptionList * l)
arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP); arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP);
arrowUpBtn->SetSelectable(false); arrowUpBtn->SetSelectable(false);
arrowUpBtn->SetTrigger(trigA); arrowUpBtn->SetTrigger(trigA);
arrowUpBtn->SetSoundOver(btnSoundOver);
arrowUpBtn->SetSoundClick(btnSoundClick);
arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight()); arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight());
arrowDownBtn->SetParent(this); arrowDownBtn->SetParent(this);
@ -72,6 +77,8 @@ GuiOptionBrowser::GuiOptionBrowser(int w, int h, OptionList * l)
arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM); arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM);
arrowDownBtn->SetSelectable(false); arrowDownBtn->SetSelectable(false);
arrowDownBtn->SetTrigger(trigA); arrowDownBtn->SetTrigger(trigA);
arrowDownBtn->SetSoundOver(btnSoundOver);
arrowDownBtn->SetSoundClick(btnSoundClick);
scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight()); scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight());
scrollbarBoxBtn->SetParent(this); scrollbarBoxBtn->SetParent(this);
@ -99,6 +106,7 @@ GuiOptionBrowser::GuiOptionBrowser(int w, int h, OptionList * l)
optionBtn[i]->SetImageOver(optionBg[i]); optionBtn[i]->SetImageOver(optionBg[i]);
optionBtn[i]->SetPosition(0,30*i+3); optionBtn[i]->SetPosition(0,30*i+3);
optionBtn[i]->SetTrigger(trigA); optionBtn[i]->SetTrigger(trigA);
optionBtn[i]->SetSoundClick(btnSoundClick);
} }
} }
@ -131,6 +139,8 @@ GuiOptionBrowser::~GuiOptionBrowser()
delete scrollbarBoxOver; delete scrollbarBoxOver;
delete trigA; delete trigA;
delete btnSoundOver;
delete btnSoundClick;
for(int i=0; i<PAGESIZE; i++) for(int i=0; i<PAGESIZE; i++)
{ {

View File

@ -38,6 +38,9 @@ GuiSaveBrowser::GuiSaveBrowser(int w, int h, SaveList * s, int a)
else else
trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A); trigA->SetSimpleTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
btnSoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
btnSoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
gameSave = new GuiImageData(button_gamesave_png); gameSave = new GuiImageData(button_gamesave_png);
gameSaveOver = new GuiImageData(button_gamesave_over_png); gameSaveOver = new GuiImageData(button_gamesave_over_png);
gameSaveBlank = new GuiImageData(button_gamesave_blank_png); gameSaveBlank = new GuiImageData(button_gamesave_blank_png);
@ -68,6 +71,8 @@ GuiSaveBrowser::GuiSaveBrowser(int w, int h, SaveList * s, int a)
arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP); arrowUpBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP);
arrowUpBtn->SetSelectable(false); arrowUpBtn->SetSelectable(false);
arrowUpBtn->SetTrigger(trigA); arrowUpBtn->SetTrigger(trigA);
arrowUpBtn->SetSoundOver(btnSoundOver);
arrowUpBtn->SetSoundClick(btnSoundClick);
arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight()); arrowDownBtn = new GuiButton(arrowDownImg->GetWidth(), arrowDownImg->GetHeight());
arrowDownBtn->SetParent(this); arrowDownBtn->SetParent(this);
@ -76,6 +81,8 @@ GuiSaveBrowser::GuiSaveBrowser(int w, int h, SaveList * s, int a)
arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM); arrowDownBtn->SetAlignment(ALIGN_RIGHT, ALIGN_BOTTOM);
arrowDownBtn->SetSelectable(false); arrowDownBtn->SetSelectable(false);
arrowDownBtn->SetTrigger(trigA); arrowDownBtn->SetTrigger(trigA);
arrowDownBtn->SetSoundOver(btnSoundOver);
arrowDownBtn->SetSoundClick(btnSoundClick);
scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight()); scrollbarBoxBtn = new GuiButton(scrollbarBoxImg->GetWidth(), scrollbarBoxImg->GetHeight());
scrollbarBoxBtn->SetParent(this); scrollbarBoxBtn->SetParent(this);
@ -117,6 +124,8 @@ GuiSaveBrowser::GuiSaveBrowser(int w, int h, SaveList * s, int a)
saveBtn[i]->SetState(STATE_DISABLED); saveBtn[i]->SetState(STATE_DISABLED);
saveBtn[i]->SetEffectGrow(); saveBtn[i]->SetEffectGrow();
saveBtn[i]->SetVisible(false); saveBtn[i]->SetVisible(false);
saveBtn[i]->SetSoundOver(btnSoundOver);
saveBtn[i]->SetSoundClick(btnSoundClick);
} }
} }
@ -148,6 +157,8 @@ GuiSaveBrowser::~GuiSaveBrowser()
delete scrollbarBox; delete scrollbarBox;
delete scrollbarBoxOver; delete scrollbarBoxOver;
delete btnSoundOver;
delete btnSoundClick;
delete trigA; delete trigA;
for(int i=0; i<SAVELISTSIZE; i++) for(int i=0; i<SAVELISTSIZE; i++)

View File

@ -21,6 +21,7 @@ GuiSound::GuiSound(const u8 * snd, s32 len, int t)
type = t; type = t;
voice = -1; voice = -1;
volume = 100; volume = 100;
loop = false;
} }
/** /**
@ -28,6 +29,10 @@ GuiSound::GuiSound(const u8 * snd, s32 len, int t)
*/ */
GuiSound::~GuiSound() GuiSound::~GuiSound()
{ {
#ifndef NO_SOUND
if(type == SOUND_OGG)
StopOgg();
#endif
} }
void GuiSound::Play() void GuiSound::Play()
@ -41,13 +46,16 @@ void GuiSound::Play()
vol = 255*(volume/100.0)*(GCSettings.SFXVolume/100.0); vol = 255*(volume/100.0)*(GCSettings.SFXVolume/100.0);
voice = ASND_GetFirstUnusedVoice(); voice = ASND_GetFirstUnusedVoice();
if(voice >= 0) if(voice >= 0)
ASND_SetVoice(voice, VOICE_MONO_8BIT, 8000, 0, ASND_SetVoice(voice, VOICE_STEREO_16BIT, 48000, 0,
(u8 *)sound, length, vol, vol, NULL); (u8 *)sound, length, vol, vol, NULL);
break; break;
case SOUND_OGG: case SOUND_OGG:
voice = 0; voice = 0;
PlayOgg(mem_open((char *)sound, length), 0, OGG_INFINITE_TIME); if(loop)
PlayOgg(mem_open((char *)sound, length), 0, OGG_INFINITE_TIME);
else
PlayOgg(mem_open((char *)sound, length), 0, OGG_ONE_TIME);
SetVolumeOgg(255*(volume/100.0)); SetVolumeOgg(255*(volume/100.0));
break; break;
} }
@ -111,6 +119,14 @@ void GuiSound::Resume()
#endif #endif
} }
bool GuiSound::IsPlaying()
{
if(ASND_StatusVoice(voice) == SND_WORKING || ASND_StatusVoice(voice) == SND_WAITING)
return true;
else
return false;
}
void GuiSound::SetVolume(int vol) void GuiSound::SetVolume(int vol)
{ {
#ifndef NO_SOUND #ifndef NO_SOUND
@ -133,3 +149,8 @@ void GuiSound::SetVolume(int vol)
} }
#endif #endif
} }
void GuiSound::SetLoop(bool l)
{
loop = l;
}

View File

@ -51,6 +51,8 @@ static GuiImage * bgImg = NULL;
static GuiImage * bgTopImg = NULL; static GuiImage * bgTopImg = NULL;
static GuiImage * bgBottomImg = NULL; static GuiImage * bgBottomImg = NULL;
static GuiSound * bgMusic = NULL; static GuiSound * bgMusic = NULL;
static GuiSound * enterSound = NULL;
static GuiSound * exitSound = NULL;
static GuiWindow * mainWindow = NULL; static GuiWindow * mainWindow = NULL;
static GuiText * settingText = NULL; static GuiText * settingText = NULL;
static int lastMenu = MENU_NONE; static int lastMenu = MENU_NONE;
@ -117,6 +119,7 @@ WindowPrompt(const char *title, const char *msg, const char *btn1Label, const ch
promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE);
promptWindow.SetPosition(0, -10); promptWindow.SetPosition(0, -10);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiTrigger trigA; GuiTrigger trigA;
@ -156,6 +159,7 @@ WindowPrompt(const char *title, const char *msg, const char *btn1Label, const ch
btn1.SetImage(&btn1Img); btn1.SetImage(&btn1Img);
btn1.SetImageOver(&btn1ImgOver); btn1.SetImageOver(&btn1ImgOver);
btn1.SetSoundOver(&btnSoundOver); btn1.SetSoundOver(&btnSoundOver);
btn1.SetSoundClick(&btnSoundClick);
btn1.SetTrigger(&trigA); btn1.SetTrigger(&trigA);
btn1.SetState(STATE_SELECTED); btn1.SetState(STATE_SELECTED);
btn1.SetEffectGrow(); btn1.SetEffectGrow();
@ -170,6 +174,7 @@ WindowPrompt(const char *title, const char *msg, const char *btn1Label, const ch
btn2.SetImage(&btn2Img); btn2.SetImage(&btn2Img);
btn2.SetImageOver(&btn2ImgOver); btn2.SetImageOver(&btn2ImgOver);
btn2.SetSoundOver(&btnSoundOver); btn2.SetSoundOver(&btnSoundOver);
btn2.SetSoundClick(&btnSoundClick);
btn2.SetTrigger(&trigA); btn2.SetTrigger(&trigA);
btn2.SetEffectGrow(); btn2.SetEffectGrow();
@ -235,12 +240,6 @@ EmulatorUpdate (void *arg)
* *
* Primary thread to allow GUI to respond to state changes, and draws GUI * Primary thread to allow GUI to respond to state changes, and draws GUI
***************************************************************************/ ***************************************************************************/
/*static u32 arena1mem = 0;
static u32 arena2mem = 0;
static char mem[150] = { 0 };
static GuiText * memTxt = NULL;*/
static void * static void *
UpdateGUI (void *arg) UpdateGUI (void *arg)
{ {
@ -252,13 +251,6 @@ UpdateGUI (void *arg)
} }
else else
{ {
/*arena1mem = (u32)SYS_GetArena1Hi() - (u32)SYS_GetArena1Lo();
#ifdef HW_RVL
arena2mem = (u32)SYS_GetArena2Hi() - (u32)SYS_GetArena2Lo();
#endif
sprintf(mem, "A1: %u / A2: %u", arena1mem, arena2mem);
if(memTxt) memTxt->SetText(mem);*/
mainWindow->Draw(); mainWindow->Draw();
#ifdef HW_RVL #ifdef HW_RVL
@ -319,6 +311,7 @@ ProgressWindow(char *title, char *msg)
promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE);
promptWindow.SetPosition(0, -10); promptWindow.SetPosition(0, -10);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiTrigger trigA; GuiTrigger trigA;
@ -556,6 +549,7 @@ static void OnScreenKeyboard(char * var, u16 maxlen)
GuiKeyboard keyboard(var, maxlen); GuiKeyboard keyboard(var, maxlen);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiTrigger trigA; GuiTrigger trigA;
@ -576,6 +570,7 @@ static void OnScreenKeyboard(char * var, u16 maxlen)
okBtn.SetImage(&okBtnImg); okBtn.SetImage(&okBtnImg);
okBtn.SetImageOver(&okBtnImgOver); okBtn.SetImageOver(&okBtnImgOver);
okBtn.SetSoundOver(&btnSoundOver); okBtn.SetSoundOver(&btnSoundOver);
okBtn.SetSoundClick(&btnSoundClick);
okBtn.SetTrigger(&trigA); okBtn.SetTrigger(&trigA);
okBtn.SetEffectGrow(); okBtn.SetEffectGrow();
@ -589,6 +584,7 @@ static void OnScreenKeyboard(char * var, u16 maxlen)
cancelBtn.SetImage(&cancelBtnImg); cancelBtn.SetImage(&cancelBtnImg);
cancelBtn.SetImageOver(&cancelBtnImgOver); cancelBtn.SetImageOver(&cancelBtnImgOver);
cancelBtn.SetSoundOver(&btnSoundOver); cancelBtn.SetSoundOver(&btnSoundOver);
cancelBtn.SetSoundClick(&btnSoundClick);
cancelBtn.SetTrigger(&trigA); cancelBtn.SetTrigger(&trigA);
cancelBtn.SetEffectGrow(); cancelBtn.SetEffectGrow();
@ -637,6 +633,7 @@ SettingWindow(const char * title, GuiWindow * w)
GuiWindow promptWindow(448,288); GuiWindow promptWindow(448,288);
promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiTrigger trigA; GuiTrigger trigA;
@ -664,6 +661,7 @@ SettingWindow(const char * title, GuiWindow * w)
okBtn.SetImage(&okBtnImg); okBtn.SetImage(&okBtnImg);
okBtn.SetImageOver(&okBtnImgOver); okBtn.SetImageOver(&okBtnImgOver);
okBtn.SetSoundOver(&btnSoundOver); okBtn.SetSoundOver(&btnSoundOver);
okBtn.SetSoundClick(&btnSoundClick);
okBtn.SetTrigger(&trigA); okBtn.SetTrigger(&trigA);
okBtn.SetEffectGrow(); okBtn.SetEffectGrow();
@ -677,6 +675,7 @@ SettingWindow(const char * title, GuiWindow * w)
cancelBtn.SetImage(&cancelBtnImg); cancelBtn.SetImage(&cancelBtnImg);
cancelBtn.SetImageOver(&cancelBtnImgOver); cancelBtn.SetImageOver(&cancelBtnImgOver);
cancelBtn.SetSoundOver(&btnSoundOver); cancelBtn.SetSoundOver(&btnSoundOver);
cancelBtn.SetSoundClick(&btnSoundClick);
cancelBtn.SetTrigger(&trigA); cancelBtn.SetTrigger(&trigA);
cancelBtn.SetEffectGrow(); cancelBtn.SetEffectGrow();
@ -878,6 +877,7 @@ static int MenuGameSelection()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData iconHome(icon_home_png); GuiImageData iconHome(icon_home_png);
GuiImageData iconSettings(icon_settings_png); GuiImageData iconSettings(icon_settings_png);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
@ -904,6 +904,7 @@ static int MenuGameSelection()
settingsBtn.SetImage(&settingsBtnImg); settingsBtn.SetImage(&settingsBtnImg);
settingsBtn.SetImageOver(&settingsBtnImgOver); settingsBtn.SetImageOver(&settingsBtnImgOver);
settingsBtn.SetSoundOver(&btnSoundOver); settingsBtn.SetSoundOver(&btnSoundOver);
settingsBtn.SetSoundClick(&btnSoundClick);
settingsBtn.SetTrigger(&trigA); settingsBtn.SetTrigger(&trigA);
settingsBtn.SetEffectGrow(); settingsBtn.SetEffectGrow();
@ -921,6 +922,7 @@ static int MenuGameSelection()
exitBtn.SetImage(&exitBtnImg); exitBtn.SetImage(&exitBtnImg);
exitBtn.SetImageOver(&exitBtnImgOver); exitBtn.SetImageOver(&exitBtnImgOver);
exitBtn.SetSoundOver(&btnSoundOver); exitBtn.SetSoundOver(&btnSoundOver);
exitBtn.SetSoundClick(&btnSoundClick);
exitBtn.SetTrigger(&trigA); exitBtn.SetTrigger(&trigA);
exitBtn.SetTrigger(&trigHome); exitBtn.SetTrigger(&trigHome);
exitBtn.SetEffectGrow(); exitBtn.SetEffectGrow();
@ -1105,6 +1107,7 @@ static int MenuGame()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnCloseOutline(button_small_png); GuiImageData btnCloseOutline(button_small_png);
@ -1142,6 +1145,7 @@ static int MenuGame()
saveBtn.SetImageOver(&saveBtnImgOver); saveBtn.SetImageOver(&saveBtnImgOver);
saveBtn.SetIcon(&saveBtnIcon); saveBtn.SetIcon(&saveBtnIcon);
saveBtn.SetSoundOver(&btnSoundOver); saveBtn.SetSoundOver(&btnSoundOver);
saveBtn.SetSoundClick(&btnSoundClick);
saveBtn.SetTrigger(&trigA); saveBtn.SetTrigger(&trigA);
saveBtn.SetEffectGrow(); saveBtn.SetEffectGrow();
@ -1157,6 +1161,7 @@ static int MenuGame()
loadBtn.SetImageOver(&loadBtnImgOver); loadBtn.SetImageOver(&loadBtnImgOver);
loadBtn.SetIcon(&loadBtnIcon); loadBtn.SetIcon(&loadBtnIcon);
loadBtn.SetSoundOver(&btnSoundOver); loadBtn.SetSoundOver(&btnSoundOver);
loadBtn.SetSoundClick(&btnSoundClick);
loadBtn.SetTrigger(&trigA); loadBtn.SetTrigger(&trigA);
loadBtn.SetEffectGrow(); loadBtn.SetEffectGrow();
@ -1172,6 +1177,7 @@ static int MenuGame()
resetBtn.SetImageOver(&resetBtnImgOver); resetBtn.SetImageOver(&resetBtnImgOver);
resetBtn.SetIcon(&resetBtnIcon); resetBtn.SetIcon(&resetBtnIcon);
resetBtn.SetSoundOver(&btnSoundOver); resetBtn.SetSoundOver(&btnSoundOver);
resetBtn.SetSoundClick(&btnSoundClick);
resetBtn.SetTrigger(&trigA); resetBtn.SetTrigger(&trigA);
resetBtn.SetEffectGrow(); resetBtn.SetEffectGrow();
@ -1187,6 +1193,7 @@ static int MenuGame()
controllerBtn.SetImageOver(&controllerBtnImgOver); controllerBtn.SetImageOver(&controllerBtnImgOver);
controllerBtn.SetIcon(&controllerBtnIcon); controllerBtn.SetIcon(&controllerBtnIcon);
controllerBtn.SetSoundOver(&btnSoundOver); controllerBtn.SetSoundOver(&btnSoundOver);
controllerBtn.SetSoundClick(&btnSoundClick);
controllerBtn.SetTrigger(&trigA); controllerBtn.SetTrigger(&trigA);
controllerBtn.SetEffectGrow(); controllerBtn.SetEffectGrow();
@ -1202,6 +1209,7 @@ static int MenuGame()
cheatsBtn.SetImageOver(&cheatsBtnImgOver); cheatsBtn.SetImageOver(&cheatsBtnImgOver);
cheatsBtn.SetIcon(&cheatsBtnIcon); cheatsBtn.SetIcon(&cheatsBtnIcon);
cheatsBtn.SetSoundOver(&btnSoundOver); cheatsBtn.SetSoundOver(&btnSoundOver);
cheatsBtn.SetSoundClick(&btnSoundClick);
cheatsBtn.SetTrigger(&trigA); cheatsBtn.SetTrigger(&trigA);
cheatsBtn.SetEffectGrow();*/ cheatsBtn.SetEffectGrow();*/
@ -1215,6 +1223,7 @@ static int MenuGame()
mainmenuBtn.SetImage(&mainmenuBtnImg); mainmenuBtn.SetImage(&mainmenuBtnImg);
mainmenuBtn.SetImageOver(&mainmenuBtnImgOver); mainmenuBtn.SetImageOver(&mainmenuBtnImgOver);
mainmenuBtn.SetSoundOver(&btnSoundOver); mainmenuBtn.SetSoundOver(&btnSoundOver);
mainmenuBtn.SetSoundClick(&btnSoundClick);
mainmenuBtn.SetTrigger(&trigA); mainmenuBtn.SetTrigger(&trigA);
mainmenuBtn.SetEffectGrow(); mainmenuBtn.SetEffectGrow();
@ -1228,6 +1237,7 @@ static int MenuGame()
closeBtn.SetImage(&closeBtnImg); closeBtn.SetImage(&closeBtnImg);
closeBtn.SetImageOver(&closeBtnImgOver); closeBtn.SetImageOver(&closeBtnImgOver);
closeBtn.SetSoundOver(&btnSoundOver); closeBtn.SetSoundOver(&btnSoundOver);
closeBtn.SetSoundClick(&btnSoundClick);
closeBtn.SetTrigger(&trigA); closeBtn.SetTrigger(&trigA);
closeBtn.SetTrigger(&trigHome); closeBtn.SetTrigger(&trigHome);
closeBtn.SetEffectGrow(); closeBtn.SetEffectGrow();
@ -1297,6 +1307,7 @@ static int MenuGame()
if(lastMenu == MENU_NONE) if(lastMenu == MENU_NONE)
{ {
enterSound->Play();
bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35); bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35);
closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35); closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35);
titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35); titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_IN, 35);
@ -1398,6 +1409,7 @@ static int MenuGame()
{ {
menu = MENU_EXIT; menu = MENU_EXIT;
exitSound->Play();
bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
@ -1411,13 +1423,13 @@ static int MenuGame()
batteryBtn[3]->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35); batteryBtn[3]->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35);
#endif #endif
saveBtn.SetEffect(EFFECT_FADE, -15); saveBtn.SetEffect(EFFECT_FADE, -20);
loadBtn.SetEffect(EFFECT_FADE, -15); loadBtn.SetEffect(EFFECT_FADE, -20);
resetBtn.SetEffect(EFFECT_FADE, -15); resetBtn.SetEffect(EFFECT_FADE, -20);
controllerBtn.SetEffect(EFFECT_FADE, -15); controllerBtn.SetEffect(EFFECT_FADE, -20);
//cheatsBtn.SetEffect(EFFECT_FADE, -15); //cheatsBtn.SetEffect(EFFECT_FADE, -20);
usleep(150000); // wait for effects to finish usleep(200000); // wait for effects to finish
} }
} }
@ -1472,6 +1484,7 @@ static int MenuGameSaves(int action)
titleTxt.SetText("Save Game"); titleTxt.SetText("Save Game");
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnCloseOutline(button_small_png); GuiImageData btnCloseOutline(button_small_png);
@ -1496,6 +1509,7 @@ static int MenuGameSaves(int action)
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -1509,6 +1523,7 @@ static int MenuGameSaves(int action)
closeBtn.SetImage(&closeBtnImg); closeBtn.SetImage(&closeBtnImg);
closeBtn.SetImageOver(&closeBtnImgOver); closeBtn.SetImageOver(&closeBtnImgOver);
closeBtn.SetSoundOver(&btnSoundOver); closeBtn.SetSoundOver(&btnSoundOver);
closeBtn.SetSoundClick(&btnSoundClick);
closeBtn.SetTrigger(&trigA); closeBtn.SetTrigger(&trigA);
closeBtn.SetTrigger(&trigHome); closeBtn.SetTrigger(&trigHome);
closeBtn.SetEffectGrow(); closeBtn.SetEffectGrow();
@ -1691,6 +1706,7 @@ static int MenuGameSaves(int action)
{ {
menu = MENU_EXIT; menu = MENU_EXIT;
exitSound->Play();
bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
@ -1698,9 +1714,9 @@ static int MenuGameSaves(int action)
bgBottomImg->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35); bgBottomImg->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35);
btnLogo->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35); btnLogo->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35);
w.SetEffect(EFFECT_FADE, -15); w.SetEffect(EFFECT_FADE, -20);
usleep(150000); // wait for effects to finish usleep(200000); // wait for effects to finish
} }
} }
@ -1740,6 +1756,7 @@ static int MenuGameCheats()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnCloseOutline(button_small_png); GuiImageData btnCloseOutline(button_small_png);
@ -1764,6 +1781,7 @@ static int MenuGameCheats()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -1777,6 +1795,7 @@ static int MenuGameCheats()
closeBtn.SetImage(&closeBtnImg); closeBtn.SetImage(&closeBtnImg);
closeBtn.SetImageOver(&closeBtnImgOver); closeBtn.SetImageOver(&closeBtnImgOver);
closeBtn.SetSoundOver(&btnSoundOver); closeBtn.SetSoundOver(&btnSoundOver);
closeBtn.SetSoundClick(&btnSoundClick);
closeBtn.SetTrigger(&trigA); closeBtn.SetTrigger(&trigA);
closeBtn.SetTrigger(&trigHome); closeBtn.SetTrigger(&trigHome);
closeBtn.SetEffectGrow(); closeBtn.SetEffectGrow();
@ -1816,6 +1835,7 @@ static int MenuGameCheats()
{ {
menu = MENU_EXIT; menu = MENU_EXIT;
exitSound->Play();
bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); bgTopImg->SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); closeBtn.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35); titleTxt.SetEffect(EFFECT_SLIDE_TOP | EFFECT_SLIDE_OUT, 35);
@ -1823,9 +1843,9 @@ static int MenuGameCheats()
bgBottomImg->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35); bgBottomImg->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35);
btnLogo->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35); btnLogo->SetEffect(EFFECT_SLIDE_BOTTOM | EFFECT_SLIDE_OUT, 35);
w.SetEffect(EFFECT_FADE, -15); w.SetEffect(EFFECT_FADE, -20);
usleep(150000); // wait for effects to finish usleep(200000); // wait for effects to finish
} }
} }
HaltGui(); HaltGui();
@ -1847,6 +1867,7 @@ static int MenuSettings()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnLargeOutline(button_large_png); GuiImageData btnLargeOutline(button_large_png);
@ -1876,6 +1897,7 @@ static int MenuSettings()
mappingBtn.SetImageOver(&mappingBtnImgOver); mappingBtn.SetImageOver(&mappingBtnImgOver);
mappingBtn.SetIcon(&mappingBtnIcon); mappingBtn.SetIcon(&mappingBtnIcon);
mappingBtn.SetSoundOver(&btnSoundOver); mappingBtn.SetSoundOver(&btnSoundOver);
mappingBtn.SetSoundClick(&btnSoundClick);
mappingBtn.SetTrigger(&trigA); mappingBtn.SetTrigger(&trigA);
mappingBtn.SetEffectGrow(); mappingBtn.SetEffectGrow();
@ -1892,6 +1914,7 @@ static int MenuSettings()
videoBtn.SetImageOver(&videoBtnImgOver); videoBtn.SetImageOver(&videoBtnImgOver);
videoBtn.SetIcon(&videoBtnIcon); videoBtn.SetIcon(&videoBtnIcon);
videoBtn.SetSoundOver(&btnSoundOver); videoBtn.SetSoundOver(&btnSoundOver);
videoBtn.SetSoundClick(&btnSoundClick);
videoBtn.SetTrigger(&trigA); videoBtn.SetTrigger(&trigA);
videoBtn.SetEffectGrow(); videoBtn.SetEffectGrow();
@ -1913,6 +1936,7 @@ static int MenuSettings()
savingBtn.SetImageOver(&savingBtnImgOver); savingBtn.SetImageOver(&savingBtnImgOver);
savingBtn.SetIcon(&fileBtnIcon); savingBtn.SetIcon(&fileBtnIcon);
savingBtn.SetSoundOver(&btnSoundOver); savingBtn.SetSoundOver(&btnSoundOver);
savingBtn.SetSoundClick(&btnSoundClick);
savingBtn.SetTrigger(&trigA); savingBtn.SetTrigger(&trigA);
savingBtn.SetEffectGrow(); savingBtn.SetEffectGrow();
@ -1929,6 +1953,7 @@ static int MenuSettings()
menuBtn.SetImageOver(&menuBtnImgOver); menuBtn.SetImageOver(&menuBtnImgOver);
menuBtn.SetIcon(&menuBtnIcon); menuBtn.SetIcon(&menuBtnIcon);
menuBtn.SetSoundOver(&btnSoundOver); menuBtn.SetSoundOver(&btnSoundOver);
menuBtn.SetSoundClick(&btnSoundClick);
menuBtn.SetTrigger(&trigA); menuBtn.SetTrigger(&trigA);
menuBtn.SetEffectGrow(); menuBtn.SetEffectGrow();
@ -1945,6 +1970,7 @@ static int MenuSettings()
networkBtn.SetImageOver(&networkBtnImgOver); networkBtn.SetImageOver(&networkBtnImgOver);
networkBtn.SetIcon(&networkBtnIcon); networkBtn.SetIcon(&networkBtnIcon);
networkBtn.SetSoundOver(&btnSoundOver); networkBtn.SetSoundOver(&btnSoundOver);
networkBtn.SetSoundClick(&btnSoundClick);
networkBtn.SetTrigger(&trigA); networkBtn.SetTrigger(&trigA);
networkBtn.SetEffectGrow(); networkBtn.SetEffectGrow();
@ -1958,6 +1984,7 @@ static int MenuSettings()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -1971,6 +1998,7 @@ static int MenuSettings()
resetBtn.SetImage(&resetBtnImg); resetBtn.SetImage(&resetBtnImg);
resetBtn.SetImageOver(&resetBtnImgOver); resetBtn.SetImageOver(&resetBtnImgOver);
resetBtn.SetSoundOver(&btnSoundOver); resetBtn.SetSoundOver(&btnSoundOver);
resetBtn.SetSoundClick(&btnSoundClick);
resetBtn.SetTrigger(&trigA); resetBtn.SetTrigger(&trigA);
resetBtn.SetEffectGrow(); resetBtn.SetEffectGrow();
@ -2056,6 +2084,7 @@ static int MenuSettingsMappings()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnLargeOutline(button_large_png); GuiImageData btnLargeOutline(button_large_png);
@ -2082,6 +2111,7 @@ static int MenuSettingsMappings()
nesBtn.SetImageOver(&nesBtnImgOver); nesBtn.SetImageOver(&nesBtnImgOver);
nesBtn.SetIcon(&nesBtnIcon); nesBtn.SetIcon(&nesBtnIcon);
nesBtn.SetSoundOver(&btnSoundOver); nesBtn.SetSoundOver(&btnSoundOver);
nesBtn.SetSoundClick(&btnSoundClick);
nesBtn.SetTrigger(&trigA); nesBtn.SetTrigger(&trigA);
nesBtn.SetEffectGrow(); nesBtn.SetEffectGrow();
@ -2098,6 +2128,7 @@ static int MenuSettingsMappings()
zapperBtn.SetImageOver(&zapperBtnImgOver); zapperBtn.SetImageOver(&zapperBtnImgOver);
zapperBtn.SetIcon(&zapperBtnIcon); zapperBtn.SetIcon(&zapperBtnIcon);
zapperBtn.SetSoundOver(&btnSoundOver); zapperBtn.SetSoundOver(&btnSoundOver);
zapperBtn.SetSoundClick(&btnSoundClick);
zapperBtn.SetTrigger(&trigA); zapperBtn.SetTrigger(&trigA);
zapperBtn.SetEffectGrow(); zapperBtn.SetEffectGrow();
@ -2111,6 +2142,7 @@ static int MenuSettingsMappings()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -2167,6 +2199,7 @@ static int MenuSettingsMappingsController()
subtitleTxt.SetPosition(50,60); subtitleTxt.SetPosition(50,60);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiImageData btnLargeOutline(button_large_png); GuiImageData btnLargeOutline(button_large_png);
@ -2195,6 +2228,7 @@ static int MenuSettingsMappingsController()
gamecubeBtn.SetImageOver(&gamecubeBtnImgOver); gamecubeBtn.SetImageOver(&gamecubeBtnImgOver);
gamecubeBtn.SetIcon(&gamecubeBtnIcon); gamecubeBtn.SetIcon(&gamecubeBtnIcon);
gamecubeBtn.SetSoundOver(&btnSoundOver); gamecubeBtn.SetSoundOver(&btnSoundOver);
gamecubeBtn.SetSoundClick(&btnSoundClick);
gamecubeBtn.SetTrigger(&trigA); gamecubeBtn.SetTrigger(&trigA);
gamecubeBtn.SetEffectGrow(); gamecubeBtn.SetEffectGrow();
@ -2210,6 +2244,7 @@ static int MenuSettingsMappingsController()
wiimoteBtn.SetImageOver(&wiimoteBtnImgOver); wiimoteBtn.SetImageOver(&wiimoteBtnImgOver);
wiimoteBtn.SetIcon(&wiimoteBtnIcon); wiimoteBtn.SetIcon(&wiimoteBtnIcon);
wiimoteBtn.SetSoundOver(&btnSoundOver); wiimoteBtn.SetSoundOver(&btnSoundOver);
wiimoteBtn.SetSoundClick(&btnSoundClick);
wiimoteBtn.SetTrigger(&trigA); wiimoteBtn.SetTrigger(&trigA);
wiimoteBtn.SetEffectGrow(); wiimoteBtn.SetEffectGrow();
@ -2226,6 +2261,7 @@ static int MenuSettingsMappingsController()
classicBtn.SetImageOver(&classicBtnImgOver); classicBtn.SetImageOver(&classicBtnImgOver);
classicBtn.SetIcon(&classicBtnIcon); classicBtn.SetIcon(&classicBtnIcon);
classicBtn.SetSoundOver(&btnSoundOver); classicBtn.SetSoundOver(&btnSoundOver);
classicBtn.SetSoundClick(&btnSoundClick);
classicBtn.SetTrigger(&trigA); classicBtn.SetTrigger(&trigA);
classicBtn.SetEffectGrow(); classicBtn.SetEffectGrow();
@ -2247,6 +2283,7 @@ static int MenuSettingsMappingsController()
nunchukBtn.SetImageOver(&nunchukBtnImgOver); nunchukBtn.SetImageOver(&nunchukBtnImgOver);
nunchukBtn.SetIcon(&nunchukBtnIcon); nunchukBtn.SetIcon(&nunchukBtnIcon);
nunchukBtn.SetSoundOver(&btnSoundOver); nunchukBtn.SetSoundOver(&btnSoundOver);
nunchukBtn.SetSoundClick(&btnSoundClick);
nunchukBtn.SetTrigger(&trigA); nunchukBtn.SetTrigger(&trigA);
nunchukBtn.SetEffectGrow(); nunchukBtn.SetEffectGrow();
@ -2260,6 +2297,7 @@ static int MenuSettingsMappingsController()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -2328,6 +2366,7 @@ ButtonMappingWindow()
promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE); promptWindow.SetAlignment(ALIGN_CENTRE, ALIGN_MIDDLE);
promptWindow.SetPosition(0, -10); promptWindow.SetPosition(0, -10);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
GuiTrigger trigA; GuiTrigger trigA;
@ -2462,6 +2501,7 @@ static int MenuSettingsMappingsMap()
subtitleTxt.SetPosition(50,60); subtitleTxt.SetPosition(50,60);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
@ -2481,6 +2521,7 @@ static int MenuSettingsMappingsMap()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -2792,6 +2833,7 @@ static int MenuSettingsVideo()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
@ -2811,6 +2853,7 @@ static int MenuSettingsVideo()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -2937,6 +2980,7 @@ static int MenuSettingsFile()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
@ -2956,6 +3000,7 @@ static int MenuSettingsFile()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -3117,6 +3162,7 @@ static int MenuSettingsMenu()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
@ -3136,6 +3182,7 @@ static int MenuSettingsMenu()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -3249,6 +3296,7 @@ static int MenuSettingsNetwork()
titleTxt.SetPosition(50,50); titleTxt.SetPosition(50,50);
GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM); GuiSound btnSoundOver(button_over_pcm, button_over_pcm_size, SOUND_PCM);
GuiSound btnSoundClick(button_click_pcm, button_click_pcm_size, SOUND_PCM);
GuiImageData btnOutline(button_png); GuiImageData btnOutline(button_png);
GuiImageData btnOutlineOver(button_over_png); GuiImageData btnOutlineOver(button_over_png);
@ -3268,6 +3316,7 @@ static int MenuSettingsNetwork()
backBtn.SetImage(&backBtnImg); backBtn.SetImage(&backBtnImg);
backBtn.SetImageOver(&backBtnImgOver); backBtn.SetImageOver(&backBtnImgOver);
backBtn.SetSoundOver(&btnSoundOver); backBtn.SetSoundOver(&btnSoundOver);
backBtn.SetSoundClick(&btnSoundClick);
backBtn.SetTrigger(&trigA); backBtn.SetTrigger(&trigA);
backBtn.SetEffectGrow(); backBtn.SetEffectGrow();
@ -3389,12 +3438,6 @@ MainMenu (int menu)
mainWindow->Append(bgBottomImg); mainWindow->Append(bgBottomImg);
mainWindow->Append(btnLogo); mainWindow->Append(btnLogo);
/*// memory usage - for debugging
memTxt = new GuiText(NULL, 18, (GXColor){255, 255, 255, 255});
memTxt->SetAlignment(ALIGN_LEFT, ALIGN_TOP);
memTxt->SetPosition(20, 20);
mainWindow->Append(memTxt);*/
if(currentMenu == MENU_GAMESELECTION) if(currentMenu == MENU_GAMESELECTION)
ResumeGui(); ResumeGui();
@ -3405,6 +3448,11 @@ MainMenu (int menu)
#ifndef NO_SOUND #ifndef NO_SOUND
bgMusic = new GuiSound(bg_music_ogg, bg_music_ogg_size, SOUND_OGG); bgMusic = new GuiSound(bg_music_ogg, bg_music_ogg_size, SOUND_OGG);
bgMusic->SetVolume(GCSettings.MusicVolume); bgMusic->SetVolume(GCSettings.MusicVolume);
bgMusic->SetLoop(true);
enterSound = new GuiSound(enter_ogg, enter_ogg_size, SOUND_OGG);
enterSound->SetVolume(GCSettings.SFXVolume);
exitSound = new GuiSound(exit_ogg, exit_ogg_size, SOUND_OGG);
exitSound->SetVolume(GCSettings.SFXVolume);
if(currentMenu == MENU_GAMESELECTION) bgMusic->Play(); // startup music if(currentMenu == MENU_GAMESELECTION) bgMusic->Play(); // startup music
#endif #endif
@ -3462,15 +3510,20 @@ MainMenu (int menu)
ShutoffRumble(); ShutoffRumble();
#endif #endif
#ifndef NO_SOUND
if(exitSound->IsPlaying())
usleep(150000); // give sound more time to play
#endif
CancelAction(); CancelAction();
HaltGui(); HaltGui();
#ifndef NO_SOUND #ifndef NO_SOUND
bgMusic->Stop();
delete bgMusic; delete bgMusic;
delete enterSound;
delete exitSound;
#endif #endif
//delete memTxt;
delete btnLogo; delete btnLogo;
delete bgImg; delete bgImg;
delete bgTopImg; delete bgTopImg;

Binary file not shown.

BIN
source/ngc/sounds/enter.ogg Normal file

Binary file not shown.

BIN
source/ngc/sounds/exit.ogg Normal file

Binary file not shown.