1
0
Fork 0
forked from len0rd/rockbox

Theme Editor: Implemented some touch area click events

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@27397 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Robert Bieber 2010-07-12 05:33:14 +00:00
parent c9f997cc91
commit bae1836337
3 changed files with 65 additions and 6 deletions

View file

@ -24,14 +24,18 @@
#include "devicestate.h" #include "devicestate.h"
#include <QPainter> #include <QPainter>
#include <QDebug>
#include <QGraphicsSceneMouseEvent>
RBTouchArea::RBTouchArea(int width, int height, QString action, RBTouchArea::RBTouchArea(int width, int height, QString action,
const RBRenderInfo& info) const RBRenderInfo& info)
: QGraphicsItem(info.screen()), : QGraphicsItem(info.screen()),
size(QRectF(0, 0, width, height)), action(action) size(QRectF(0, 0, width, height)), action(action),
device(info.device())
{ {
debug = info.device()->data("showtouch").toBool(); debug = info.device()->data("showtouch").toBool();
setZValue(5); setZValue(5);
setCursor(Qt::PointingHandCursor);
} }
RBTouchArea::~RBTouchArea() RBTouchArea::~RBTouchArea()
@ -56,3 +60,52 @@ void RBTouchArea::paint(QPainter *painter,
painter->drawRect(size); painter->drawRect(size);
} }
} }
void RBTouchArea::mousePressEvent(QGraphicsSceneMouseEvent *event)
{
if(action[0] == '&')
action = action.right(action.count() - 1);
action = action.toLower();
if(action == "play")
{
if(device->data("?mp").toInt() == 2)
device->setData("mp", "Play");
else
device->setData("mp", "Pause");
}
else if(action == "ffwd")
{
device->setData("mp", "Fast Forward");
}
else if(action == "rwd")
{
device->setData("mp", "Rewind");
}
else if(action == "repmode")
{
int index = device->data("?mm").toInt();
index = (index + 1) % 5;
device->setData("mm", index);
}
else if(action == "shuffle")
{
device->setData("ps", !device->data("ps").toBool());
}
else if(action == "volup")
{
device->setData("pv", device->data("pv").toInt() + 1);
}
else if(action == "voldown")
{
device->setData("pv", device->data("pv").toInt() - 1);
}
else
{
event->ignore();
return;
}
event->accept();
}

View file

@ -25,6 +25,7 @@
#include <QGraphicsItem> #include <QGraphicsItem>
#include "rbrenderinfo.h" #include "rbrenderinfo.h"
#include "devicestate.h"
class RBTouchArea : public QGraphicsItem class RBTouchArea : public QGraphicsItem
{ {
@ -37,11 +38,12 @@ public:
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,
QWidget *widget); QWidget *widget);
void mousePressEvent(QGraphicsSceneMouseEvent *event);
private: private:
QRectF size; QRectF size;
QString action; QString action;
RBScreen* screen; DeviceState* device;
bool debug; bool debug;
}; };

View file

@ -474,10 +474,14 @@ void DeviceState::setData(QString tag, QVariant data)
break; break;
case Combo: case Combo:
dynamic_cast<QComboBox*> if(data.type() == QVariant::String)
(found.second)-> dynamic_cast<QComboBox*>
setCurrentIndex(dynamic_cast<QComboBox*> (found.second)->
(found.second)->findText(data.toString())); setCurrentIndex(dynamic_cast<QComboBox*>
(found.second)->findText(data.toString()));
else
dynamic_cast<QComboBox*>(found.second)->
setCurrentIndex(data.toInt());
break; break;
case Check: case Check: