Qt之二维绘图:设置动画效果

本文通过一个Qt实例演示了如何使用QGraphicsItemAnimation类实现图形项的动画效果,包括设置背景、添加文字与图片,并通过时间线控制动画播放。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <QGraphicsLineItem>
#include <QGraphicsTextItem>
#include <QGraphicsPixmapItem>
#include <QGraphicsItemAnimation>  //动画
#include <QTimeLine>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    QGraphicsLineItem *lineItem;
    QGraphicsTextItem *textItem;  //因为要设置属性,所以把它单独提出来
    QGraphicsPixmapItem *pixmapItem;
     _view = new QGraphicsView(this);
     _view->setBackgroundBrush(QBrush(Qt::gray));  //设置_view的背景色
     _view->setScene(_scene = new QGraphicsScene);
     _scene->addItem(lineItem = new QGraphicsLineItem(QLineF(0, 0, 100, 100)));
     _scene->addItem(textItem = new QGraphicsTextItem("hello world"));
     textItem->setPos(QPointF(100, 100));
     textItem->setFont(QFont("aaa", 50, 100, true));  //设置字体
     
     
     
     _scene->addItem(pixmapItem = new QGraphicsPixmapItem(QPixmap("../test1.bmp")));
     pixmapItem->setScale(0.2);
     pixmapItem->setFlag(QGraphicsItem::ItemIsMovable);

     QGraphicsItemAnimation *animation = new QGraphicsItemAnimation;
     animation->setItem(pixmapItem);

     QTimeLine *timeLine = new QTimeLine(3000);  //3ms动一次
     timeLine->setLoopCount(100);   //设置循环次数
     
     animation->setTimeLine(timeLine);  //怎么动
     animation->setTranslationAt(1, 200, 200);  //step, dx, dy

     timeLine->start();   //开始循环
}

void Widget::resizeEvent(QResizeEvent *)
{
    _view->setGeometry(QRect(QPoint(0, 0), size())); //设置_view的大小为widget的大小
}

 

转载于:https://my.oschina.net/u/3919756/blog/1944033

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值