第7章Qt5图形视图框架要点.pptVIP

  • 35
  • 0
  • 约1.82万字
  • 约 58页
  • 2016-12-27 发布于湖北
  • 举报
7.2.3 图元创建 (4)将程序中所用图片保存到该工程的D:\Qt\CH7\CH703\build-GraphicsItem- Desktop_Qt_5_4_0_MinGW_32bit-Debug文件夹下,此时运行效果如图7.8所示。 7.2.3 图元创建 以上完成了主窗体的显示工作,下面介绍如何实现圆的闪烁功能。 (1)在“GraphicsItem”项目名上单击鼠标右键,在弹出的快捷菜单中选择“添加新文件...”菜单项,在弹出的对话框中选择“C++ Class”选项。单击“Choose...”按钮,弹出对话框,在“Base class”后面的下拉列表框中选择基类名“QObject”,在“Class name”后面的文本框中输入类的名称“FlashItem”。 FlashItem类继承自QGraphicsItem类和QObject类,闪烁效果是通过利用定时器的timerEvent()函数定时重画圆的颜色来实现的。 (2)单击“下一步”按钮,单击“完成”按钮,添加文件“flashitem.h”和文件“flashitem.cpp”。 7.2.3 图元创建 (3)“flashitem.h”文件的具体代码如下: #include QGraphicsItem #include QPainter class FlashItem : public QObject,public QGraphicsItem { Q_OBJECT public: explicit FlashItem(QObject *parent = 0); QRectF boundingRect() const; void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget); void timerEvent(QTimerEvent *); private: bool flash; QTimer *timer; signals: public slots: }; 7.2.3 图元创建 (4)“flashitem.cpp”文件的具体代码如下: #include flashitem.h FlashItem::FlashItem(QObject *parent) : QObject(parent) { flash=true; //为颜色切换标识赋初值 setFlag(ItemIsMovable); //(a) startTimer(1000); //启动一个定时器,以1000毫秒为时间间隔 } 7.2.3 图元创建 定义图元边界的函数boundingRect(),完成以图元坐标系为基础,增加两个像素点的冗余工作。具体实现代码如下: QRectF FlashItem::boundingRect() const { qreal adjust = 2; return QRectF(-10-adjust,-10-adjust,43+adjust,43+adjust); } 7.2.3 图元创建 为自定义图元重绘的函数paint()具体实现代码如下: void FlashItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { painter-setPen(Qt::NoPen); //闪烁图元的阴影区不绘制边线 painter-setBrush(Qt::darkGray);//闪烁图元的阴影区的阴影画刷颜色为深灰 painter-drawEllipse(-7,-7,40,40); //绘制阴影区 painter-setPen(QPen(Qt::black,0)); //闪烁区的椭圆边线颜色为黑色、线宽为0 painter-setBrush(flash?(Qt::red):(Qt::yellow)); //(a) painter-drawEllipse(-10,-10,40,40); //(b) } 7.2.3 图元创建 定时器响应函数timerEvent()完成颜色切换标识的反置,并在每次反置后调用update()函数重绘图元以实现闪烁的效果。具体实现代码如下: void FlashItem::timerEvent(QTimerEvent *) { flash=!flash; update(); } 7.2.3 图元创建 (5)在“mainwindow

文档评论(0)

1亿VIP精品文档

相关文档