列表项的动画/重绘Qt QListView

时间:2011-06-27 22:12:15

标签: c++ qt

我想要实现的目标

一个可视指示,用于引起对QListView中新添加项目的注意。我想到了背景颜色'悸动'一次(从颜色渐变到背景)。

设置

我有一个使用QListView显示QStandardItems的模型/视图。 Qt版本4.7

我尝试了什么:

我创建了一个派生自QStyledItemDelegate的新类。我有自己的绘制方法来渲染项目。那部分有效。我创建了一个QTimeLine对象并将其设置为创建事件以重绘项目。

我无法弄清楚如何触发QListView项目的重绘。

在项委托构造函数中:

   timeLine = new QTimeLine( 3000, this );
   timeLine->setFrameRange( 100, 0 );
   connect( timeLine, SIGNAL( frameChanged( int ) ), this, SLOT( update() ) );
   timeLine->start();

我尝试连接到sizehintChanged事件,但这不起作用

void myDelegate::update()
{
   const QModelIndex index;
   emit QStyledItemDelegate::sizeHintChanged( index );
}

有什么建议吗?可以用样式表来完成吗?

1 个答案:

答案 0 :(得分:5)

将动画包含在代码中的标准做法是使用状态机。 使用QtStylesheets无法实现Qt中的动画。使用QML或使用QStyledItemDelegate和状态机。

 /*CustomItemDelegate*/

    int state;
    enum states{
        animating,
        normal
     }

    void setstate(int state){
        this->state = state;
        /*Start animation depending on state ,by starting a QTimer and calling 
        repaint when the timer expires,also change animation variables like opacity ,         
        angle etc etc*/

    }

     void paint(QPainter *painter, const QStyleOptionViewItem &option,
            const QModelIndex &index) const{

          switch(state){
               case animating:
                     break;
               case normal;
                     break;
          }
      }
    ....

 /*CustomListView*/

    slots:
       void dataChanged ( const QModelIndex & topLeft, const QModelIndex & bottomRight ){
              ( (CustomItemDelegate)itemDelegate(topleft) )->setState(animating);
       } 
    ....


 /*Mainwindow*/
      connect(model,SIGNAL(datachanged(QModelIndex,QModelindex)),view,SLOTS(QModelindex,QModelindex));