mirror of
https://github.com/dborth/vbagx.git
synced 2025-01-26 01:11:13 +01:00
draggable scrollbar
This commit is contained in:
parent
9b50532ca1
commit
6b4cbf3fc7
@ -71,6 +71,7 @@ enum
|
|||||||
STATE_DEFAULT,
|
STATE_DEFAULT,
|
||||||
STATE_SELECTED,
|
STATE_SELECTED,
|
||||||
STATE_CLICKED,
|
STATE_CLICKED,
|
||||||
|
STATE_HELD,
|
||||||
STATE_DISABLED
|
STATE_DISABLED
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -153,6 +154,30 @@ class GuiElement
|
|||||||
//!Considers vertical alignment, y offset, height, and parent element's GetTop() / GetHeight() values
|
//!Considers vertical alignment, y offset, height, and parent element's GetTop() / GetHeight() values
|
||||||
//!\return top coordinate
|
//!\return top coordinate
|
||||||
int GetTop();
|
int GetTop();
|
||||||
|
//!Sets the minimum y offset of the element
|
||||||
|
//!\param y Y offset
|
||||||
|
void SetMinY(int y);
|
||||||
|
//!Gets the minimum y offset of the element
|
||||||
|
//!\return Minimum Y offset
|
||||||
|
int GetMinY();
|
||||||
|
//!Sets the maximum y offset of the element
|
||||||
|
//!\param y Y offset
|
||||||
|
void SetMaxY(int y);
|
||||||
|
//!Gets the maximum y offset of the element
|
||||||
|
//!\return Maximum Y offset
|
||||||
|
int GetMaxY();
|
||||||
|
//!Sets the minimum x offset of the element
|
||||||
|
//!\param x X offset
|
||||||
|
void SetMinX(int x);
|
||||||
|
//!Gets the minimum x offset of the element
|
||||||
|
//!\return Minimum X offset
|
||||||
|
int GetMinX();
|
||||||
|
//!Sets the maximum x offset of the element
|
||||||
|
//!\param x X offset
|
||||||
|
void SetMaxX(int x);
|
||||||
|
//!Gets the maximum x offset of the element
|
||||||
|
//!\return Maximum X offset
|
||||||
|
int GetMaxX();
|
||||||
//!Gets the current width of the element. Does not currently consider the scale
|
//!Gets the current width of the element. Does not currently consider the scale
|
||||||
//!\return width
|
//!\return width
|
||||||
int GetWidth();
|
int GetWidth();
|
||||||
@ -172,12 +197,18 @@ class GuiElement
|
|||||||
//!Checks whether or not the element is clickable
|
//!Checks whether or not the element is clickable
|
||||||
//!\return true if clickable, false otherwise
|
//!\return true if clickable, false otherwise
|
||||||
bool IsClickable();
|
bool IsClickable();
|
||||||
|
//!Checks whether or not the element is draggable
|
||||||
|
//!\return true if draggable, false otherwise
|
||||||
|
bool IsDraggable();
|
||||||
//!Sets whether or not the element is selectable
|
//!Sets whether or not the element is selectable
|
||||||
//!\param s Selectable
|
//!\param s Selectable
|
||||||
void SetSelectable(bool s);
|
void SetSelectable(bool s);
|
||||||
//!Sets whether or not the element is clickable
|
//!Sets whether or not the element is clickable
|
||||||
//!\param c Clickable
|
//!\param c Clickable
|
||||||
void SetClickable(bool c);
|
void SetClickable(bool c);
|
||||||
|
//!Sets whether or not the element is draggable
|
||||||
|
//!\param c Draggable
|
||||||
|
void SetDraggable(bool d);
|
||||||
//!Gets the element's current state
|
//!Gets the element's current state
|
||||||
//!\return state
|
//!\return state
|
||||||
int GetState();
|
int GetState();
|
||||||
@ -270,6 +301,10 @@ class GuiElement
|
|||||||
int height; //!< Element height
|
int height; //!< Element height
|
||||||
int xoffset; //!< Element X offset
|
int xoffset; //!< Element X offset
|
||||||
int yoffset; //!< Element Y offset
|
int yoffset; //!< Element Y offset
|
||||||
|
int ymin; //!< Element's min Y offset allowed
|
||||||
|
int ymax; //!< Element's max Y offset allowed
|
||||||
|
int xmin; //!< Element's min X offset allowed
|
||||||
|
int xmax; //!< Element's max X offset allowed
|
||||||
int xoffsetDyn; //!< Element X offset, dynamic (added to xoffset value for animation effects)
|
int xoffsetDyn; //!< Element X offset, dynamic (added to xoffset value for animation effects)
|
||||||
int yoffsetDyn; //!< Element Y offset, dynamic (added to yoffset value for animation effects)
|
int yoffsetDyn; //!< Element Y offset, dynamic (added to yoffset value for animation effects)
|
||||||
int alpha; //!< Element alpha value (0-255)
|
int alpha; //!< Element alpha value (0-255)
|
||||||
@ -286,8 +321,10 @@ class GuiElement
|
|||||||
int alignmentHor; //!< Horizontal element alignment, respective to parent element (LEFT, RIGHT, CENTRE)
|
int alignmentHor; //!< Horizontal element alignment, respective to parent element (LEFT, RIGHT, CENTRE)
|
||||||
int alignmentVert; //!< Horizontal element alignment, respective to parent element (TOP, BOTTOM, MIDDLE)
|
int alignmentVert; //!< Horizontal element alignment, respective to parent element (TOP, BOTTOM, MIDDLE)
|
||||||
int state; //!< Element state (DEFAULT, SELECTED, CLICKED, DISABLED)
|
int state; //!< Element state (DEFAULT, SELECTED, CLICKED, DISABLED)
|
||||||
|
int stateChan; //!< Which controller channel is responsible for the last change in state
|
||||||
bool selectable; //!< Whether or not this element selectable (can change to SELECTED state)
|
bool selectable; //!< Whether or not this element selectable (can change to SELECTED state)
|
||||||
bool clickable; //!< Whether or not this element is clickable (can change to CLICKED state)
|
bool clickable; //!< Whether or not this element is clickable (can change to CLICKED state)
|
||||||
|
bool draggable; //!< Whether or not this element is draggable (can change to HELD state)
|
||||||
GuiTrigger * trigger[2]; //!< GuiTriggers (input actions) that this element responds to
|
GuiTrigger * trigger[2]; //!< GuiTriggers (input actions) that this element responds to
|
||||||
GuiElement * parentElement; //!< Parent element
|
GuiElement * parentElement; //!< Parent element
|
||||||
UpdateCallback updateCB; //!< Callback function to call when this element is updated
|
UpdateCallback updateCB; //!< Callback function to call when this element is updated
|
||||||
@ -615,6 +652,7 @@ class GuiFileBrowser : public GuiElement
|
|||||||
GuiSound * btnSoundOver;
|
GuiSound * btnSoundOver;
|
||||||
GuiSound * btnSoundClick;
|
GuiSound * btnSoundClick;
|
||||||
GuiTrigger * trigA;
|
GuiTrigger * trigA;
|
||||||
|
GuiTrigger * trigHeldA;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _optionlist {
|
typedef struct _optionlist {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_button.cpp
|
* gui_button.cpp
|
||||||
*
|
*
|
||||||
@ -115,19 +115,19 @@ void GuiButton::Draw()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
// draw image
|
// draw image
|
||||||
if(state == STATE_SELECTED && imageOver)
|
if((state == STATE_SELECTED || state == STATE_HELD) && imageOver)
|
||||||
imageOver->Draw();
|
imageOver->Draw();
|
||||||
else if(image)
|
else if(image)
|
||||||
image->Draw();
|
image->Draw();
|
||||||
// draw icon
|
// draw icon
|
||||||
if(state == STATE_SELECTED && iconOver)
|
if((state == STATE_SELECTED || state == STATE_HELD) && iconOver)
|
||||||
iconOver->Draw();
|
iconOver->Draw();
|
||||||
else if(icon)
|
else if(icon)
|
||||||
icon->Draw();
|
icon->Draw();
|
||||||
// draw text
|
// draw text
|
||||||
for(int i=0; i<3; i++)
|
for(int i=0; i<3; i++)
|
||||||
{
|
{
|
||||||
if(state == STATE_SELECTED && labelOver[i])
|
if((state == STATE_SELECTED || state == STATE_HELD) && labelOver[i])
|
||||||
labelOver[i]->Draw();
|
labelOver[i]->Draw();
|
||||||
else if(label[i])
|
else if(label[i])
|
||||||
label[i]->Draw();
|
label[i]->Draw();
|
||||||
@ -226,6 +226,45 @@ void GuiButton::Update(GuiTrigger * t)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(this->IsDraggable())
|
||||||
|
{
|
||||||
|
bool held = false;
|
||||||
|
|
||||||
|
for(int i=0; i<2; i++)
|
||||||
|
{
|
||||||
|
if(trigger[i] && (trigger[i]->chan == -1 || trigger[i]->chan == t->chan))
|
||||||
|
{
|
||||||
|
// higher 16 bits only (wiimote)
|
||||||
|
s32 wm_btns = t->wpad.btns_h << 16;
|
||||||
|
s32 wm_btns_trig = trigger[i]->wpad.btns_h << 16;
|
||||||
|
|
||||||
|
// lower 16 bits only (classic controller)
|
||||||
|
s32 cc_btns = t->wpad.btns_h >> 16;
|
||||||
|
s32 cc_btns_trig = trigger[i]->wpad.btns_h >> 16;
|
||||||
|
|
||||||
|
if(
|
||||||
|
(t->wpad.btns_h > 0 &&
|
||||||
|
wm_btns == wm_btns_trig ||
|
||||||
|
(cc_btns == cc_btns_trig && t->wpad.exp.type == EXP_CLASSIC)) ||
|
||||||
|
(t->pad.btns_h == trigger[i]->pad.btns_h && t->pad.btns_h > 0))
|
||||||
|
{
|
||||||
|
if(trigger[i]->type == TRIGGER_HELD)
|
||||||
|
held = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!held && state == STATE_HELD && stateChan == t->chan)
|
||||||
|
{
|
||||||
|
state = STATE_DEFAULT;
|
||||||
|
}
|
||||||
|
else if(held && state == STATE_SELECTED)
|
||||||
|
{
|
||||||
|
state = STATE_HELD;
|
||||||
|
stateChan = t->chan; // record which controller is holding the button
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(updateCB)
|
if(updateCB)
|
||||||
updateCB(this);
|
updateCB(this);
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_element.cpp
|
* gui_element.cpp
|
||||||
*
|
*
|
||||||
@ -17,17 +17,23 @@ GuiElement::GuiElement()
|
|||||||
{
|
{
|
||||||
xoffset = 0;
|
xoffset = 0;
|
||||||
yoffset = 0;
|
yoffset = 0;
|
||||||
|
xmin = 0;
|
||||||
|
xmax = 0;
|
||||||
|
ymin = 0;
|
||||||
|
ymax = 0;
|
||||||
width = 0;
|
width = 0;
|
||||||
height = 0;
|
height = 0;
|
||||||
alpha = 255;
|
alpha = 255;
|
||||||
scale = 1;
|
scale = 1;
|
||||||
state = STATE_DEFAULT;
|
state = STATE_DEFAULT;
|
||||||
|
stateChan = -1;
|
||||||
trigger[0] = NULL;
|
trigger[0] = NULL;
|
||||||
trigger[1] = NULL;
|
trigger[1] = NULL;
|
||||||
parentElement = NULL;
|
parentElement = NULL;
|
||||||
rumble = true;
|
rumble = true;
|
||||||
selectable = false;
|
selectable = false;
|
||||||
clickable = false;
|
clickable = false;
|
||||||
|
draggable = false;
|
||||||
visible = true;
|
visible = true;
|
||||||
focus = -1; // cannot be focused
|
focus = -1; // cannot be focused
|
||||||
updateCB = NULL;
|
updateCB = NULL;
|
||||||
@ -128,6 +134,46 @@ int GuiElement::GetTop()
|
|||||||
return y + yoffset;
|
return y + yoffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GuiElement::SetMinX(int x)
|
||||||
|
{
|
||||||
|
xmin = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
int GuiElement::GetMinX()
|
||||||
|
{
|
||||||
|
return xmin;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GuiElement::SetMaxX(int x)
|
||||||
|
{
|
||||||
|
xmax = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
int GuiElement::GetMaxX()
|
||||||
|
{
|
||||||
|
return xmax;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GuiElement::SetMinY(int y)
|
||||||
|
{
|
||||||
|
ymin = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
int GuiElement::GetMinY()
|
||||||
|
{
|
||||||
|
return ymin;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GuiElement::SetMaxY(int y)
|
||||||
|
{
|
||||||
|
ymax = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
int GuiElement::GetMaxY()
|
||||||
|
{
|
||||||
|
return ymax;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the width of the GuiElement.
|
* Get the width of the GuiElement.
|
||||||
* @see SetWidth()
|
* @see SetWidth()
|
||||||
@ -243,6 +289,11 @@ void GuiElement::SetSelectable(bool s)
|
|||||||
selectable = s;
|
selectable = s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GuiElement::SetDraggable(bool d)
|
||||||
|
{
|
||||||
|
draggable = d;
|
||||||
|
}
|
||||||
|
|
||||||
bool GuiElement::IsSelectable()
|
bool GuiElement::IsSelectable()
|
||||||
{
|
{
|
||||||
if(state == STATE_DISABLED || state == STATE_CLICKED)
|
if(state == STATE_DISABLED || state == STATE_CLICKED)
|
||||||
@ -253,12 +304,22 @@ bool GuiElement::IsSelectable()
|
|||||||
|
|
||||||
bool GuiElement::IsClickable()
|
bool GuiElement::IsClickable()
|
||||||
{
|
{
|
||||||
if(state == STATE_DISABLED || state == STATE_CLICKED)
|
if(state == STATE_DISABLED ||
|
||||||
|
state == STATE_CLICKED ||
|
||||||
|
state == STATE_HELD)
|
||||||
return false;
|
return false;
|
||||||
else
|
else
|
||||||
return clickable;
|
return clickable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GuiElement::IsDraggable()
|
||||||
|
{
|
||||||
|
if(state == STATE_DISABLED)
|
||||||
|
return false;
|
||||||
|
else
|
||||||
|
return draggable;
|
||||||
|
}
|
||||||
|
|
||||||
void GuiElement::SetFocus(int f)
|
void GuiElement::SetFocus(int f)
|
||||||
{
|
{
|
||||||
focus = f;
|
focus = f;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_filebrowser.cpp
|
* gui_filebrowser.cpp
|
||||||
*
|
*
|
||||||
@ -29,6 +29,12 @@ 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);
|
||||||
|
|
||||||
|
trigHeldA = new GuiTrigger;
|
||||||
|
if(GCSettings.WiimoteOrientation)
|
||||||
|
trigHeldA->SetHeldTrigger(-1, WPAD_BUTTON_2 | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
|
||||||
|
else
|
||||||
|
trigHeldA->SetHeldTrigger(-1, WPAD_BUTTON_A | WPAD_CLASSIC_BUTTON_A, PAD_BUTTON_A);
|
||||||
|
|
||||||
btnSoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
|
btnSoundOver = new GuiSound(button_over_pcm, button_over_pcm_size, SOUND_PCM);
|
||||||
btnSoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
|
btnSoundClick = new GuiSound(button_click_pcm, button_click_pcm_size, SOUND_PCM);
|
||||||
|
|
||||||
@ -84,7 +90,12 @@ GuiFileBrowser::GuiFileBrowser(int w, int h)
|
|||||||
scrollbarBoxBtn->SetImage(scrollbarBoxImg);
|
scrollbarBoxBtn->SetImage(scrollbarBoxImg);
|
||||||
scrollbarBoxBtn->SetImageOver(scrollbarBoxOverImg);
|
scrollbarBoxBtn->SetImageOver(scrollbarBoxOverImg);
|
||||||
scrollbarBoxBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP);
|
scrollbarBoxBtn->SetAlignment(ALIGN_RIGHT, ALIGN_TOP);
|
||||||
|
scrollbarBoxBtn->SetMinY(0);
|
||||||
|
scrollbarBoxBtn->SetMaxY(304);
|
||||||
scrollbarBoxBtn->SetSelectable(false);
|
scrollbarBoxBtn->SetSelectable(false);
|
||||||
|
scrollbarBoxBtn->SetClickable(false);
|
||||||
|
scrollbarBoxBtn->SetDraggable(true);
|
||||||
|
scrollbarBoxBtn->SetTrigger(trigHeldA);
|
||||||
|
|
||||||
for(int i=0; i<PAGESIZE; i++)
|
for(int i=0; i<PAGESIZE; i++)
|
||||||
{
|
{
|
||||||
@ -202,14 +213,45 @@ void GuiFileBrowser::Update(GuiTrigger * t)
|
|||||||
if(state == STATE_DISABLED || !t)
|
if(state == STATE_DISABLED || !t)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
int position;
|
||||||
|
|
||||||
// update the location of the scroll box based on the position in the file list
|
// update the location of the scroll box based on the position in the file list
|
||||||
int position = 136*(browser.pageIndex + selectedItem) / browser.numEntries;
|
position = 136*(browser.pageIndex + selectedItem) / browser.numEntries;
|
||||||
scrollbarBoxBtn->SetPosition(0,position+36);
|
scrollbarBoxBtn->SetPosition(0,position+36);
|
||||||
|
|
||||||
arrowUpBtn->Update(t);
|
arrowUpBtn->Update(t);
|
||||||
arrowDownBtn->Update(t);
|
arrowDownBtn->Update(t);
|
||||||
scrollbarBoxBtn->Update(t);
|
scrollbarBoxBtn->Update(t);
|
||||||
|
|
||||||
|
if(scrollbarBoxBtn->GetState() == STATE_HELD)
|
||||||
|
{
|
||||||
|
// move the file listing to respond to wiimote cursor movement
|
||||||
|
if(t->wpad.ir.valid)
|
||||||
|
{
|
||||||
|
scrollbarBoxBtn->SetPosition(0,0);
|
||||||
|
position = t->wpad.ir.y - 60 - scrollbarBoxBtn->GetTop();
|
||||||
|
|
||||||
|
if(position > scrollbarBoxBtn->GetMinY() &&
|
||||||
|
position < scrollbarBoxBtn->GetMaxY())
|
||||||
|
{
|
||||||
|
scrollbarBoxBtn->SetPosition(0, position);
|
||||||
|
browser.pageIndex = (position * browser.numEntries)/136.0 - selectedItem;
|
||||||
|
|
||||||
|
if(browser.pageIndex <= 0)
|
||||||
|
{
|
||||||
|
browser.pageIndex = 0;
|
||||||
|
selectedItem = 0;
|
||||||
|
}
|
||||||
|
else if(browser.pageIndex+PAGESIZE >= browser.numEntries)
|
||||||
|
{
|
||||||
|
browser.pageIndex = browser.numEntries-PAGESIZE;
|
||||||
|
selectedItem = PAGESIZE-1;
|
||||||
|
}
|
||||||
|
listChanged = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// pad/joystick navigation
|
// pad/joystick navigation
|
||||||
if(!focus)
|
if(!focus)
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_image.cpp
|
* gui_image.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_imagedata.cpp
|
* gui_imagedata.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_keyboard.cpp
|
* gui_keyboard.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_optionbrowser.cpp
|
* gui_optionbrowser.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_savebrowser.cpp
|
* gui_savebrowser.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_sound.cpp
|
* gui_sound.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_text.cpp
|
* gui_text.cpp
|
||||||
*
|
*
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_trigger.cpp
|
* gui_trigger.cpp
|
||||||
*
|
*
|
||||||
@ -42,6 +42,19 @@ void GuiTrigger::SetSimpleTrigger(s32 ch, u32 wiibtns, u16 gcbtns)
|
|||||||
pad.btns_d = gcbtns;
|
pad.btns_d = gcbtns;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets a held trigger. Requires:
|
||||||
|
* - Element is selected
|
||||||
|
* - Trigger button is pressed and held
|
||||||
|
*/
|
||||||
|
void GuiTrigger::SetHeldTrigger(s32 ch, u32 wiibtns, u16 gcbtns)
|
||||||
|
{
|
||||||
|
type = TRIGGER_HELD;
|
||||||
|
chan = ch;
|
||||||
|
wpad.btns_h = wiibtns;
|
||||||
|
pad.btns_h = gcbtns;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets a button trigger. Requires:
|
* Sets a button trigger. Requires:
|
||||||
* - Trigger button is pressed
|
* - Trigger button is pressed
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Snes9x 1.51 Nintendo Wii/Gamecube Port
|
* libwiigui
|
||||||
*
|
*
|
||||||
* Tantric February 2009
|
* Tantric 2009
|
||||||
*
|
*
|
||||||
* gui_window.cpp
|
* gui_window.cpp
|
||||||
*
|
*
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
TRIGGER_SIMPLE,
|
TRIGGER_SIMPLE,
|
||||||
|
TRIGGER_HELD,
|
||||||
TRIGGER_BUTTON_ONLY,
|
TRIGGER_BUTTON_ONLY,
|
||||||
TRIGGER_BUTTON_ONLY_IN_FOCUS
|
TRIGGER_BUTTON_ONLY_IN_FOCUS
|
||||||
};
|
};
|
||||||
@ -56,6 +57,7 @@ class GuiTrigger
|
|||||||
GuiTrigger();
|
GuiTrigger();
|
||||||
~GuiTrigger();
|
~GuiTrigger();
|
||||||
void SetSimpleTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
void SetSimpleTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
||||||
|
void SetHeldTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
||||||
void SetButtonOnlyTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
void SetButtonOnlyTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
||||||
void SetButtonOnlyInFocusTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
void SetButtonOnlyInFocusTrigger(s32 ch, u32 wiibtns, u16 gcbtns);
|
||||||
s8 WPAD_Stick(u8 right, int axis);
|
s8 WPAD_Stick(u8 right, int axis);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user