portapack-mayhem/firmware/common/ui.hpp

307 lines
4.7 KiB
C++
Raw Normal View History

2015-07-08 11:39:24 -04:00
/*
* Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc.
*
* 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.
*/
#ifndef __UI_H__
#define __UI_H__
#include <cstdint>
namespace ui {
using Coord = int16_t;
using Dim = int16_t;
struct Color {
uint16_t v;
constexpr Color(
) : v { 0 }
{
}
/*
explicit constexpr Color(
const uint32_t value
) : v { static_cast<uint16_t>(value) }
{
}
*/
constexpr Color(
uint8_t r,
uint8_t g,
uint8_t b
) : v {
static_cast<uint16_t>(
((r & 0xf8) << 8)
| ((g & 0xfc) << 3)
| ((b & 0xf8) >> 3)
)}
{
}
static constexpr Color black() {
return { 0, 0, 0 };
}
static constexpr Color red() {
return { 255, 0, 0 };
}
static constexpr Color orange() {
return { 255, 127, 0 };
}
2015-07-08 11:39:24 -04:00
static constexpr Color yellow() {
return { 255, 255, 0 };
}
static constexpr Color green() {
return { 0, 255, 0 };
}
static constexpr Color blue() {
return { 0, 0, 255 };
}
static constexpr Color cyan() {
return { 0, 128, 255 };
}
2015-07-08 11:39:24 -04:00
static constexpr Color white() {
return { 255, 255, 255 };
}
static constexpr Color grey() {
return { 127, 127, 127 };
}
static constexpr Color purple() {
return { 204, 0, 102 };
}
2015-07-08 11:39:24 -04:00
};
#if 0
enum class CardinalDirection : uint8_t {
West,
South,
North,
East,
};
#endif
struct Point {
Coord x;
Coord y;
constexpr Point(
) : x { 0 },
y { 0 }
{
}
constexpr Point(
2016-01-31 03:34:24 -05:00
int x,
int y
) : x { static_cast<Coord>(x) },
y { static_cast<Coord>(y) }
2015-07-08 11:39:24 -04:00
{
}
Point operator-() const {
2016-01-31 03:34:24 -05:00
return { -x, -y };
2015-07-08 11:39:24 -04:00
}
Point operator+(const Point& p) const {
2016-01-31 03:34:24 -05:00
return { x + p.x, y + p.y };
2015-07-08 11:39:24 -04:00
}
Point operator-(const Point& p) const {
2016-01-31 03:34:24 -05:00
return { x - p.x, y - p.y };
2015-07-08 11:39:24 -04:00
}
Point& operator+=(const Point& p) {
x += p.x;
y += p.y;
return *this;
}
#if 0
uint32_t magnitude_squared() const {
return (x * x) + (y * y);
}
CardinalDirection cardinal_direction() const {
/* TODO: Doesn't handle 0,0 */
const auto rotated = sloppy_rotate_by_45_degrees();
if( rotated.x > 0 ) {
if( rotated.y > 0 ) {
return CardinalDirection::East;
} else {
// y<=0
return CardinalDirection::North;
}
} else {
// x<=0
if( rotated.y > 0 ) {
return CardinalDirection::South;
} else {
return CardinalDirection::West;
}
}
}
private:
Point sloppy_rotate_by_45_degrees() const {
/* Clockwise rotate (in screen coordinates), with a gain in
* magnitude of sqrt(2).
*/
2016-01-31 03:34:24 -05:00
return { x - y, x + y };
2015-07-08 11:39:24 -04:00
}
#endif
};
struct Size {
Dim w;
Dim h;
constexpr Size(
) : w { 0 },
h { 0 }
{
}
constexpr Size(
2016-01-31 03:34:24 -05:00
int w,
int h
) : w { static_cast<Dim>(w) },
h { static_cast<Dim>(h) }
2015-07-08 11:39:24 -04:00
{
}
bool is_empty() const {
return (w < 1) || (h < 1);
}
};
struct Rect {
Point pos;
Size size;
constexpr Rect(
) : pos { },
size { }
{
}
constexpr Rect(
2016-01-31 03:34:24 -05:00
int x, int y,
int w, int h
2015-07-08 11:39:24 -04:00
) : pos { x, y },
size { w, h }
{
}
constexpr Rect(
Point pos,
Size size
) : pos(pos),
size(size)
{
}
2016-01-31 03:34:24 -05:00
int top() const {
2015-07-08 11:39:24 -04:00
return pos.y;
}
2016-01-31 03:34:24 -05:00
int bottom() const {
2015-07-08 11:39:24 -04:00
return pos.y + size.h;
}
2016-01-31 03:34:24 -05:00
int left() const {
2015-07-08 11:39:24 -04:00
return pos.x;
}
2016-01-31 03:34:24 -05:00
int right() const {
2015-07-08 11:39:24 -04:00
return pos.x + size.w;
}
2016-01-31 03:34:24 -05:00
int width() const {
2015-07-08 11:39:24 -04:00
return size.w;
}
2016-01-31 03:34:24 -05:00
int height() const {
2015-07-08 11:39:24 -04:00
return size.h;
}
Point center() const {
2016-01-31 03:34:24 -05:00
return { pos.x + size.w / 2, pos.y + size.h / 2 };
2015-07-08 11:39:24 -04:00
}
bool is_empty() const {
return size.is_empty();
}
bool contains(const Point p) const;
Rect intersect(const Rect& o) const;
Rect operator+(const Point& p) const {
return { pos + p, size };
}
Rect& operator+=(const Rect& p);
operator bool() const {
return !size.is_empty();
}
};
2016-02-03 16:23:23 -05:00
struct Bitmap {
const Size size;
const uint8_t* const data;
};
2015-07-08 11:39:24 -04:00
enum class KeyEvent {
/* Ordinals map to bit positions reported by CPLD */
Right = 0,
Left = 1,
Down = 2,
Up = 3,
Select = 4,
};
using EncoderEvent = int32_t;
struct TouchEvent {
enum class Type : uint32_t {
Start = 0,
Move = 1,
End = 2,
};
Point point;
Type type;
2015-08-22 23:08:38 -04:00
Point rawpoint;
2015-07-08 11:39:24 -04:00
};
} /* namespace ui */
#endif/*__UI_H__*/