QT案例解析(1): Animated Tiles Example
演示效果
步骤概述
- 继承QGraphicsPixmapItem 实现显示图片
- 继承QGraphicsWidget 实现按钮
- 继承QGraphicsView 实现视图
- 实现功能
图像不同状态的动画切换。
涉及知识点
图形视图框架 (QGraphicsScene(场景)),QGraphicsView(视图)),QGraphicsItem(图形项))
动画框架 (QAbstractAnimation(基类))
状态机框架 (QStateMachine(状态机) QState(状态))
信号与槽 (Signals & Slots)
2D绘图 (paint)
代码解析
一、继承QGraphicsPixmapItem
实现图片显示。
只是修改缓存模式。
class Pixmap : public QObject, public QGraphicsPixmapItem
{
Q_OBJECT
Q_PROPERTY(QPointF pos READ pos WRITE setPos)
public:
Pixmap(const QPixmap &pix)
: QObject(), QGraphicsPixmapItem(pix)
{
//开启缓存模式(高质量显示)
setCacheMode(DeviceCoordinateCache);
}
};
二、继承QGraphicsWidget
实现按钮功能。
重写 paint 实现 悬停和点击 的效果 相当于设置样式
class Button : public QGraphicsWidget
{
Q_OBJECT
public:
Button(const QPixmap &pixmap, QGraphicsItem *parent = 0)
: QGraphicsWidget(parent), _pix(pixmap)
{
//使能悬停功能
setAcceptHoverEvents(true);
//开启缓存模式(高质量显示)
setCacheMode(DeviceCoordinateCache);
}
//设置按钮理想大小(默认大小)
QRectF boundingRect() const Q_DECL_OVERRIDE
{
return QRectF(-65, -65, 130, 130);
}
//返回按钮区域
QPainterPath shape() const Q_DECL_OVERRIDE
{
QPainterPath path;
//注意这里是椭圆了
path.addEllipse(boundingRect());
return path;
}
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *) Q_DECL_OVERRIDE
{
//判断下陷状态 (pressed)
bool down = option->state & QStyle::State_Sunken;
QRectF r = boundingRect();
//线性渐变
QLinearGradient grad(r.topLeft(), r.bottomRight());
grad.setColorAt(down ? 1 : 0, option->state & QStyle::State_MouseOver ? Qt::white : Qt::lightGray);
grad.setColorAt(down ? 0 : 1, Qt::darkGray);
painter->setPen(Qt::darkGray);
painter->setBrush(grad);
//画外圈
painter->drawEllipse(r);
grad.setColorAt(down ? 1 : 0, Qt::darkGray);
grad.setColorAt(down ? 0 : 1, Qt