mayhem-firmware/firmware/application/ui_tabview.cpp
furrtek 89a3afcd74 Started writing TabView
Loopable NumberField
2017-07-30 09:39:01 +01:00

172 lines
3.6 KiB
C++

/*
* Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc.
* Copyright (C) 2017 Furrtek
*
* This file is part of PortaPack.
*
* 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 2, 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; see the file COPYING. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street,
* Boston, MA 02110-1301, USA.
*/
#include "ui_tabview.hpp"
#include "portapack.hpp"
using namespace portapack;
namespace ui {
Tab::Tab() {
set_focusable(true);
};
void Tab::set(
uint16_t index,
Dim width,
std::string text,
Color text_color
) {
set_parent_rect({ index * width, 0, width, 24 });
text_ = text.substr(0, (width - 8) / 8);
text_color_ = text_color;
index_ = index;
}
void Tab::paint(Painter& painter) {
const auto rect = screen_rect();
const Color color = highlighted() ? Color::black() : Color::light_grey();
painter.fill_rectangle({ rect.left(), rect.top(), rect.width() - 8, rect.height() }, color);
if (!highlighted())
painter.draw_hline({ rect.left(), rect.top() }, rect.width() - 9, Color::white());
painter.draw_bitmap(
{ rect.right() - 8, rect.top() },
bitmap_tab_edge,
color,
Color::dark_grey()
);
auto text_point = rect.center() - Point(4, 0) - Point(text_.size() * 8 / 2, 16 / 2);
painter.draw_string(
text_point,
{ ui::font::fixed_8x16, color, text_color_ },
text_
);
if (has_focus())
painter.draw_hline(text_point + Point(0, 16), text_.size() * 8, Color::white());
}
bool Tab::on_key(const KeyEvent key) {
if( key == KeyEvent::Select ) {
static_cast<TabView*>(parent())->set_selected(index_);
return true;
}
return false;
}
bool Tab::on_touch(const TouchEvent event) {
switch(event.type) {
case TouchEvent::Type::Start:
focus();
set_dirty();
return true;
case TouchEvent::Type::End:
static_cast<TabView*>(parent())->set_selected(index_);
return true;
default:
return false;
}
}
void TabView::set_selected(uint16_t index) {
Tab * tab;
if (index >= n_tabs)
return;
//if (index == current_tab)
// return;
// Hide all widgets
for (const auto widget : parent()->children()) {
widget->hidden(true);
}
// Except this one :)
hidden(false);
tab = &tabs[current_tab];
tab->set_highlighted(false);
tab->set_focusable(true);
tab->set_dirty();
// Show new tab's widgets
for (auto widget : widget_lists[index]) {
widget->hidden(false);
}
tab = &tabs[index];
current_tab = index;
tab->set_highlighted(true);
tab->set_focusable(false);
tab->set_dirty();
parent()->set_dirty();
}
void TabView::focus() {
tabs[current_tab].focus();
}
void TabView::on_show() {
set_selected(current_tab);
}
TabView::TabView(std::initializer_list<TabDef> tab_definitions) {
size_t i = 0;
n_tabs = tab_definitions.size();
if (n_tabs > 5)
n_tabs = 5;
size_t tab_width = 240 / n_tabs;
set_parent_rect({ 0, 0, 30 * 8, 3 * 8 });
for (auto &tab_definition : tab_definitions) {
tabs[i].set(i, tab_width, tab_definition.text, tab_definition.color);
for (auto widget : tab_definition.widget_list) {
widget_lists[i].emplace_back(widget);
}
add_child(&tabs[i]);
i++;
if (i == 5) break;
}
}
TabView::~TabView() {
}
} /* namespace ui */