列表项的动画/重绘Qt QListView

Jay*_*Jay 3 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();
Run Code Online (Sandbox Code Playgroud)

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

void myDelegate::update()
{
   const QModelIndex index;
   emit QStyledItemDelegate::sizeHintChanged( index );
}
Run Code Online (Sandbox Code Playgroud)

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

Abh*_*ith 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));
Run Code Online (Sandbox Code Playgroud)

  • 啊,显然不是。您可以在itemdelegate中添加一个`repaintRequest()`信号,并将其连接到QListview中的repaint()插槽。这将反过来调用列表的代表进行重绘。 (2认同)