QTableView: Make sure to repaint all needed cells during resizing
Don't try to update the scrollarea geometry while resizing a row or column since this may lead in flickering and artifacts, esp when the scroll mode is scrollPerItems. Instead do the calculation only when the resize is finished. Fixes: QTBUG-72870 Fixes: QTBUG-82595 Change-Id: Id6903c00485b3be6ed54bd5f9bcafdda6da21598 Reviewed-by: Friedemann Kleint <Friedemann.Kleint@qt.io> Reviewed-by: Samuel Gaist <samuel.gaist@idiap.ch> Reviewed-by: Shawn Rutledge <shawn.rutledge@qt.io>
This commit is contained in:
parent
d55dad94f9
commit
1e03015d55
@ -2939,14 +2939,17 @@ void QTableView::timerEvent(QTimerEvent *event)
|
|||||||
Q_D(QTableView);
|
Q_D(QTableView);
|
||||||
|
|
||||||
if (event->timerId() == d->columnResizeTimerID) {
|
if (event->timerId() == d->columnResizeTimerID) {
|
||||||
updateGeometries();
|
const int oldScrollMax = horizontalScrollBar()->maximum();
|
||||||
killTimer(d->columnResizeTimerID);
|
if (horizontalHeader()->d_func()->state != QHeaderViewPrivate::ResizeSection) {
|
||||||
d->columnResizeTimerID = 0;
|
updateGeometries();
|
||||||
|
killTimer(d->columnResizeTimerID);
|
||||||
|
d->columnResizeTimerID = 0;
|
||||||
|
}
|
||||||
|
|
||||||
QRect rect;
|
QRect rect;
|
||||||
int viewportHeight = d->viewport->height();
|
int viewportHeight = d->viewport->height();
|
||||||
int viewportWidth = d->viewport->width();
|
int viewportWidth = d->viewport->width();
|
||||||
if (d->hasSpans()) {
|
if (d->hasSpans() || horizontalScrollBar()->value() == oldScrollMax) {
|
||||||
rect = QRect(0, 0, viewportWidth, viewportHeight);
|
rect = QRect(0, 0, viewportWidth, viewportHeight);
|
||||||
} else {
|
} else {
|
||||||
for (int i = d->columnsToUpdate.size()-1; i >= 0; --i) {
|
for (int i = d->columnsToUpdate.size()-1; i >= 0; --i) {
|
||||||
@ -2964,14 +2967,17 @@ void QTableView::timerEvent(QTimerEvent *event)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (event->timerId() == d->rowResizeTimerID) {
|
if (event->timerId() == d->rowResizeTimerID) {
|
||||||
updateGeometries();
|
const int oldScrollMax = verticalScrollBar()->maximum();
|
||||||
killTimer(d->rowResizeTimerID);
|
if (verticalHeader()->d_func()->state != QHeaderViewPrivate::ResizeSection) {
|
||||||
d->rowResizeTimerID = 0;
|
updateGeometries();
|
||||||
|
killTimer(d->rowResizeTimerID);
|
||||||
|
d->rowResizeTimerID = 0;
|
||||||
|
}
|
||||||
|
|
||||||
int viewportHeight = d->viewport->height();
|
int viewportHeight = d->viewport->height();
|
||||||
int viewportWidth = d->viewport->width();
|
int viewportWidth = d->viewport->width();
|
||||||
int top;
|
int top;
|
||||||
if (d->hasSpans()) {
|
if (d->hasSpans() || verticalScrollBar()->value() == oldScrollMax) {
|
||||||
top = 0;
|
top = 0;
|
||||||
} else {
|
} else {
|
||||||
top = viewportHeight;
|
top = viewportHeight;
|
||||||
|
Loading…
Reference in New Issue
Block a user