Merge pull request #1 from GaryOderNichts/wiiu-env-master

fix state to support all channels
This commit is contained in:
Maschell 2020-04-24 17:46:57 +02:00 committed by GitHub
commit 45bad52a0c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 30 additions and 30 deletions

View File

@ -241,30 +241,30 @@ public:
//!\param s State (STATE_DEFAULT, STATE_SELECTED, STATE_CLICKED, STATE_DISABLED) //!\param s State (STATE_DEFAULT, STATE_SELECTED, STATE_CLICKED, STATE_DISABLED)
//!\param c Controller channel (0-3, -1 = none) //!\param c Controller channel (0-3, -1 = none)
virtual void setState(int32_t s, int32_t c = -1) { virtual void setState(int32_t s, int32_t c = -1) {
if(c >= 0 && c < 4) { if(c >= 0 && c < 5) {
state[c] |= s; state[c] |= s;
} else { } else {
for(int32_t i = 0; i < 4; i++) for(int32_t i = 0; i < 5; i++)
state[i] |= s; state[i] |= s;
} }
stateChan = c; stateChan = c;
stateChanged(this, s, c); stateChanged(this, s, c);
} }
virtual void clearState(int32_t s, int32_t c = -1) { virtual void clearState(int32_t s, int32_t c = -1) {
if(c >= 0 && c < 4) { if(c >= 0 && c < 5) {
state[c] &= ~s; state[c] &= ~s;
} else { } else {
for(int32_t i = 0; i < 4; i++) for(int32_t i = 0; i < 5; i++)
state[i] &= ~s; state[i] &= ~s;
} }
stateChan = c; stateChan = c;
stateChanged(this, s, c); stateChanged(this, s, c);
} }
virtual bool isStateSet(int32_t s, int32_t c = -1) const { virtual bool isStateSet(int32_t s, int32_t c = -1) const {
if(c >= 0 && c < 4) { if(c >= 0 && c < 5) {
return (state[c] & s) != 0; return (state[c] & s) != 0;
} else { } else {
for(int32_t i = 0; i < 4; i++) for(int32_t i = 0; i < 5; i++)
if((state[i] & s) != 0) if((state[i] & s) != 0)
return true; return true;
@ -283,7 +283,7 @@ public:
}; };
//!Resets the element's state to STATE_DEFAULT //!Resets the element's state to STATE_DEFAULT
virtual void resetState() { virtual void resetState() {
for(int32_t i = 0; i < 4; i++) for(int32_t i = 0; i < 5; i++)
state[i] = STATE_DEFAULT; state[i] = STATE_DEFAULT;
stateChan = -1; stateChan = -1;
} }
@ -519,7 +519,7 @@ protected:
float scaleY; //!< Element scale (1 = 100%) float scaleY; //!< Element scale (1 = 100%)
float scaleZ; //!< Element scale (1 = 100%) float scaleZ; //!< Element scale (1 = 100%)
int32_t alignment; //!< Horizontal element alignment, respective to parent element int32_t alignment; //!< Horizontal element alignment, respective to parent element
int32_t state[4]; //!< Element state (DEFAULT, SELECTED, CLICKED, DISABLED) int32_t state[5]; //!< Element state (DEFAULT, SELECTED, CLICKED, DISABLED)
int32_t stateChan; //!< Which controller channel is responsible for the last change in state int32_t stateChan; //!< Which controller channel is responsible for the last change in state
GuiElement * parentElement; //!< Parent element GuiElement * parentElement; //!< Parent element

View File

@ -159,15 +159,15 @@ void GuiButton::draw(CVideo *v) {
} }
void GuiButton::update(GuiController * c) { void GuiButton::update(GuiController * c) {
if(!c || isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chan)) if(!c || isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chanIdx))
return; return;
else if(parentElement && (parentElement->isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chan))) else if(parentElement && (parentElement->isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chanIdx)))
return; return;
if(selectable) { if(selectable) {
if(c->data.validPointer && this->isInside(c->data.x, c->data.y)) { if(c->data.validPointer && this->isInside(c->data.x, c->data.y)) {
if(!isStateSet(STATE_OVER, c->chan)) { if(!isStateSet(STATE_OVER, c->chanIdx)) {
setState(STATE_OVER, c->chan); setState(STATE_OVER, c->chanIdx);
//if(this->isRumbleActive()) //if(this->isRumbleActive())
// this->rumble(t->chan); // this->rumble(t->chan);
@ -184,8 +184,8 @@ void GuiButton::update(GuiController * c) {
pointedOn(this, c); pointedOn(this, c);
} }
} else if(isStateSet(STATE_OVER, c->chan)) { } else if(isStateSet(STATE_OVER, c->chanIdx)) {
this->clearState(STATE_OVER, c->chan); this->clearState(STATE_OVER, c->chanIdx);
pointedOff(this, c); pointedOff(this, c);
if(effectTarget == effectTargetOver && effectAmount == effectAmountOver) { if(effectTarget == effectTargetOver && effectAmount == effectAmountOver) {
@ -207,25 +207,25 @@ void GuiButton::update(GuiController * c) {
int32_t isClicked = trigger[i]->clicked(c); int32_t isClicked = trigger[i]->clicked(c);
if( !clickedTrigger && (isClicked != GuiTrigger::CLICKED_NONE) if( !clickedTrigger && (isClicked != GuiTrigger::CLICKED_NONE)
&& (trigger[i]->isClickEverywhere() || (isStateSet(STATE_SELECTED | STATE_OVER, c->chan) && trigger[i]->isSelectionClickEverywhere()) || this->isInside(c->data.x, c->data.y))) { && (trigger[i]->isClickEverywhere() || (isStateSet(STATE_SELECTED | STATE_OVER, c->chanIdx) && trigger[i]->isSelectionClickEverywhere()) || this->isInside(c->data.x, c->data.y))) {
if(soundClick) if(soundClick)
soundClick->Play(); soundClick->Play();
clickedTrigger = trigger[i]; clickedTrigger = trigger[i];
if(!isStateSet(STATE_CLICKED, c->chan)) { if(!isStateSet(STATE_CLICKED, c->chanIdx)) {
if(isClicked == GuiTrigger::CLICKED_TOUCH) { if(isClicked == GuiTrigger::CLICKED_TOUCH) {
setState(STATE_CLICKED_TOUCH, c->chan); setState(STATE_CLICKED_TOUCH, c->chanIdx);
} else { } else {
setState(STATE_CLICKED, c->chan); setState(STATE_CLICKED, c->chanIdx);
} }
} }
clicked(this, c, trigger[i]); clicked(this, c, trigger[i]);
} else if((isStateSet(STATE_CLICKED, c->chan) || isStateSet(STATE_CLICKED_TOUCH, c->chan)) && (clickedTrigger == trigger[i]) && !isStateSet(STATE_HELD, c->chan) && !trigger[i]->held(c) && ((isClicked == GuiTrigger::CLICKED_NONE) || trigger[i]->released(c))) { } else if((isStateSet(STATE_CLICKED, c->chanIdx) || isStateSet(STATE_CLICKED_TOUCH, c->chanIdx)) && (clickedTrigger == trigger[i]) && !isStateSet(STATE_HELD, c->chanIdx) && !trigger[i]->held(c) && ((isClicked == GuiTrigger::CLICKED_NONE) || trigger[i]->released(c))) {
if((isStateSet(STATE_CLICKED_TOUCH, c->chan) && this->isInside(c->data.x, c->data.y)) || (isStateSet(STATE_CLICKED, c->chan))) { if((isStateSet(STATE_CLICKED_TOUCH, c->chanIdx) && this->isInside(c->data.x, c->data.y)) || (isStateSet(STATE_CLICKED, c->chanIdx))) {
clickedTrigger = NULL; clickedTrigger = NULL;
clearState(STATE_CLICKED, c->chan); clearState(STATE_CLICKED, c->chanIdx);
released(this, c, trigger[i]); released(this, c, trigger[i]);
} }
} }
@ -235,21 +235,21 @@ void GuiButton::update(GuiController * c) {
bool isHeld = trigger[i]->held(c); bool isHeld = trigger[i]->held(c);
if( (!heldTrigger || heldTrigger == trigger[i]) && isHeld if( (!heldTrigger || heldTrigger == trigger[i]) && isHeld
&& (trigger[i]->isHoldEverywhere() || (isStateSet(STATE_SELECTED | STATE_OVER, c->chan) && trigger[i]->isSelectionClickEverywhere()) || this->isInside(c->data.x, c->data.y))) { && (trigger[i]->isHoldEverywhere() || (isStateSet(STATE_SELECTED | STATE_OVER, c->chanIdx) && trigger[i]->isSelectionClickEverywhere()) || this->isInside(c->data.x, c->data.y))) {
heldTrigger = trigger[i]; heldTrigger = trigger[i];
if(!isStateSet(STATE_HELD, c->chan)) if(!isStateSet(STATE_HELD, c->chanIdx))
setState(STATE_HELD, c->chan); setState(STATE_HELD, c->chanIdx);
held(this, c, trigger[i]); held(this, c, trigger[i]);
} else if(isStateSet(STATE_HELD, c->chan) && (heldTrigger == trigger[i]) && (!isHeld || trigger[i]->released(c))) { } else if(isStateSet(STATE_HELD, c->chanIdx) && (heldTrigger == trigger[i]) && (!isHeld || trigger[i]->released(c))) {
//! click is removed at this point and converted to held //! click is removed at this point and converted to held
if(clickedTrigger == trigger[i]) { if(clickedTrigger == trigger[i]) {
clickedTrigger = NULL; clickedTrigger = NULL;
clearState(STATE_CLICKED, c->chan); clearState(STATE_CLICKED, c->chanIdx);
} }
heldTrigger = NULL; heldTrigger = NULL;
clearState(STATE_HELD, c->chan); clearState(STATE_HELD, c->chanIdx);
released(this, c, trigger[i]); released(this, c, trigger[i]);
} }
} }

View File

@ -54,9 +54,9 @@ void GuiDragListener::setTrigger(GuiTrigger * t, int32_t idx) {
} }
void GuiDragListener::update(GuiController * c) { void GuiDragListener::update(GuiController * c) {
if(!c || isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chan)) if(!c || isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chanIdx))
return; return;
else if(parentElement && (parentElement->isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chan))) else if(parentElement && (parentElement->isStateSet(STATE_DISABLED|STATE_HIDDEN|STATE_DISABLE_INPUT, c->chanIdx)))
return; return;
for(int32_t i = 0; i < iMaxGuiTriggers; i++) { for(int32_t i = 0; i < iMaxGuiTriggers; i++) {

View File

@ -33,7 +33,7 @@ GuiElement::GuiElement() {
scaleX = 1.0f; scaleX = 1.0f;
scaleY = 1.0f; scaleY = 1.0f;
scaleZ = 1.0f; scaleZ = 1.0f;
for(int32_t i = 0; i < 4; i++) for(int32_t i = 0; i < 5; i++)
state[i] = STATE_DEFAULT; state[i] = STATE_DEFAULT;
stateChan = -1; stateChan = -1;
parentElement = NULL; parentElement = NULL;