mirror of
https://github.com/wiiu-env/wudd.git
synced 2024-11-13 05:35:08 +01:00
05aea5756b
- Display name/type of the partition - Block home menu when launching via HBL - Use libmocha instead of libiosuhax, which should result in a small performance boost - Improve logging - Improve memory management - Add option to abort dumps - Slightly improve .wux handling
79 lines
2.7 KiB
C++
79 lines
2.7 KiB
C++
#pragma once
|
|
|
|
#include "common/common.h"
|
|
#include "input/Input.h"
|
|
#include "utils/ScreenUtils.h"
|
|
#include "utils/WiiUScreen.h"
|
|
#include <stdint.h>
|
|
|
|
class ApplicationState {
|
|
public:
|
|
enum eSubState {
|
|
SUBSTATE_RUNNING,
|
|
SUBSTATE_RETURN,
|
|
};
|
|
|
|
virtual ~ApplicationState() = default;
|
|
|
|
virtual void render() = 0;
|
|
|
|
virtual eSubState update(Input *input) = 0;
|
|
|
|
virtual void proccessMenuNavigationY(Input *input, int32_t maxOptionValue) {
|
|
if (input->data.buttons_d & Input::BUTTON_UP) {
|
|
this->selectedOptionY--;
|
|
} else if (input->data.buttons_d & Input::BUTTON_DOWN) {
|
|
this->selectedOptionY++;
|
|
}
|
|
if (this->selectedOptionY < 0) {
|
|
this->selectedOptionY = maxOptionValue - 1;
|
|
} else if (this->selectedOptionY >= maxOptionValue) {
|
|
this->selectedOptionY = 0;
|
|
}
|
|
}
|
|
|
|
virtual void proccessMenuNavigationX(Input *input, int32_t maxOptionValue) {
|
|
if (input->data.buttons_d & Input::BUTTON_LEFT) {
|
|
this->selectedOptionX--;
|
|
} else if (input->data.buttons_d & Input::BUTTON_RIGHT) {
|
|
this->selectedOptionX++;
|
|
}
|
|
|
|
if (this->selectedOptionX < 0) {
|
|
this->selectedOptionX = maxOptionValue - 1;
|
|
} else if (this->selectedOptionX >= maxOptionValue) {
|
|
this->selectedOptionX = 0;
|
|
}
|
|
}
|
|
|
|
virtual bool buttonPressed(Input *input, Input::eButtons button) {
|
|
return input->data.buttons_d & button;
|
|
}
|
|
|
|
virtual bool entrySelected(Input *input) {
|
|
return input->data.buttons_d & Input::BUTTON_A;
|
|
}
|
|
|
|
virtual void printHeader() {
|
|
WiiUScreen::drawLine("WUDD - Wii U Disc Dumper");
|
|
WiiUScreen::drawLine("==================");
|
|
WiiUScreen::drawLine("");
|
|
}
|
|
|
|
virtual void printFooter() {
|
|
if (gRunFromHBL && !gBlockHomeButton) {
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_TV, 0, 25, "Press HOME to exit to HBL");
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_DRC, 0, 15, "Press HOME to exit to HBL");
|
|
} else if (gRunFromHBL && gBlockHomeButtonCooldown > 0) {
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_TV, 0, 25, "You can not exit while dumping.");
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_DRC, 0, 15, "You can not exit while dumping.");
|
|
gBlockHomeButtonCooldown--;
|
|
}
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_TV, 0, 27, "Created by Maschell, inspired by wudump from FIX94");
|
|
ScreenUtils::printTextOnScreen(CONSOLE_SCREEN_DRC, 0, 17, "Created by Maschell, inspired by wudump from FIX94");
|
|
}
|
|
|
|
|
|
int selectedOptionY = 0;
|
|
int selectedOptionX = 0;
|
|
}; |