Checkpoint/common/ihidvertical.cpp
BernardoGiordano 13c0cfe9be Refactor code
2019-05-06 22:51:09 +02:00

190 lines
No EOL
5.8 KiB
C++

/*
* This file is part of Checkpoint
* Copyright (C) 2017-2019 Bernardo Giordano, FlagBrew
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Additional Terms 7.b and 7.c of GPLv3 apply to this file:
* * Requiring preservation of specified reasonable legal notices or
* author attributions in that material or in the Appropriate Legal
* Notices displayed by works containing it.
* * Prohibiting misrepresentation of the origin of that material,
* or requiring that modified versions of such material be marked in
* reasonable ways as different from the original version.
*/
#include "ihid.hpp"
void IHidVertical::update(size_t count)
{
mCurrentTime = tick();
size_t rows = mMaxVisibleEntries / mColumns;
mMaxPages = (count % mMaxVisibleEntries == 0) ? count / mMaxVisibleEntries : count / mMaxVisibleEntries + 1;
u64 kHeld = held();
u64 kDown = down();
if (kDown & _KEY_ZL()) {
page_back();
}
else if (kDown & _KEY_ZR()) {
page_forward();
}
else if (mColumns > 1) {
if (kDown & _KEY_LEFT()) {
if (mIndex % rows != mIndex) {
mIndex -= rows;
}
else {
page_back();
mIndex += rows;
}
}
else if (kDown & _KEY_RIGHT()) {
if (maxEntries(count) < rows) {
page_forward();
}
else if (mIndex + rows < mMaxVisibleEntries) {
mIndex += rows;
}
else {
page_forward();
mIndex -= rows;
}
}
else if (kDown & _KEY_UP()) {
if (mIndex % rows > 0) {
mIndex -= 1;
}
else {
mIndex = mIndex == rows ? mMaxVisibleEntries - 1 : ((mMaxVisibleEntries - 1) % rows);
}
}
else if (kDown & _KEY_DOWN()) {
if ((mIndex % rows) < rows - 1) {
if (mIndex + mPage * mMaxVisibleEntries == count - 1) {
mIndex = (mIndex / rows) * rows;
}
else {
mIndex += 1;
}
}
else {
mIndex = mIndex == rows - 1 ? 0 : rows;
}
}
else if (kHeld & _KEY_LEFT()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if (mIndex % rows != mIndex) {
mIndex -= rows;
}
else {
page_back();
mIndex += rows;
}
}
else if (kHeld & _KEY_RIGHT()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if (maxEntries(count) < rows) {
page_forward();
}
else if (mIndex + rows < mMaxVisibleEntries) {
mIndex += rows;
}
else {
page_forward();
mIndex -= rows;
}
}
else if (kHeld & _KEY_UP()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if (mIndex % rows > 0) {
mIndex -= 1;
}
else {
mIndex = mIndex == rows ? mMaxVisibleEntries - 1 : ((mMaxVisibleEntries - 1) % rows);
}
}
else if (kHeld & _KEY_DOWN()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if ((mIndex % rows) < rows - 1) {
if (mIndex + mPage * mMaxVisibleEntries == count - 1) {
mIndex = (mIndex / rows) * rows;
}
else {
mIndex += 1;
}
}
else {
mIndex = mIndex == rows - 1 ? 0 : rows;
}
}
}
else {
if (kDown & _KEY_UP()) {
if (mIndex > 0) {
mIndex--;
}
else if (mIndex == 0) {
page_back();
mIndex = maxEntries(count);
}
}
else if (kDown & _KEY_DOWN()) {
if (mIndex < maxEntries(count)) {
mIndex++;
}
else if (mIndex == maxEntries(count)) {
page_forward();
mIndex = 0;
}
}
else if (kHeld & _KEY_UP()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if (mIndex > 0) {
mIndex--;
}
else if (mIndex == 0) {
page_back();
mIndex = maxEntries(count);
}
}
else if (kHeld & _KEY_DOWN()) {
if (mCurrentTime <= mLastTime + mDelayTicks) {
return;
}
if (mIndex < maxEntries(count)) {
mIndex++;
}
else if (mIndex == maxEntries(count)) {
page_forward();
mIndex = 0;
}
}
}
if (mIndex > maxEntries(count)) {
mIndex = maxEntries(count);
}
mLastTime = mCurrentTime;
}