QHeaderView - fix setOffsetToSectionPosition a bit
It might be silly to have sections with size 0 without using hideSection. Nevertheless we should still use the principle of least surprise. It does not make sense that hiding a row 'far' away should affect the semantics of setOffsetToSectionPosition on lower indexes. Change-Id: Iaf847eba2ea4d28fc7bcfe3a27d62f432f6f61e0 Reviewed-by: Stephen Kelly <stephen.kelly@kdab.com>
This commit is contained in:
parent
5a2efb490b
commit
12c2a3d852
@ -3390,11 +3390,11 @@ int QHeaderViewPrivate::viewSectionSizeHint(int logical) const
|
|||||||
|
|
||||||
int QHeaderViewPrivate::adjustedVisualIndex(int visualIndex) const
|
int QHeaderViewPrivate::adjustedVisualIndex(int visualIndex) const
|
||||||
{
|
{
|
||||||
if (hiddenSectionSize.count() > 0) {
|
if (!sectionHidden.isEmpty()) {
|
||||||
int adjustedVisualIndex = visualIndex;
|
int adjustedVisualIndex = visualIndex;
|
||||||
int currentVisualIndex = 0;
|
int currentVisualIndex = 0;
|
||||||
for (int i = 0; i < sectionSpans.count(); ++i) {
|
for (int i = 0; i < sectionSpans.count(); ++i) {
|
||||||
if (sectionSpans.at(i).size == 0)
|
if (sectionHidden.testBit(i))
|
||||||
++adjustedVisualIndex;
|
++adjustedVisualIndex;
|
||||||
else
|
else
|
||||||
++currentVisualIndex;
|
++currentVisualIndex;
|
||||||
|
@ -205,6 +205,7 @@ private slots:
|
|||||||
void QTBUG12268_hiddenMovedSectionSorting();
|
void QTBUG12268_hiddenMovedSectionSorting();
|
||||||
void QTBUG14242_hideSectionAutoSize();
|
void QTBUG14242_hideSectionAutoSize();
|
||||||
void ensureNoIndexAtLength();
|
void ensureNoIndexAtLength();
|
||||||
|
void offsetConsistent();
|
||||||
|
|
||||||
void initialSortOrderRole();
|
void initialSortOrderRole();
|
||||||
|
|
||||||
@ -2168,6 +2169,33 @@ void tst_QHeaderView::ensureNoIndexAtLength()
|
|||||||
QVERIFY(hv->visualIndexAt(hv->length()) == -1);
|
QVERIFY(hv->visualIndexAt(hv->length()) == -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void tst_QHeaderView::offsetConsistent()
|
||||||
|
{
|
||||||
|
// Ensure that a hidden section 'far away'
|
||||||
|
// does not affect setOffsetToSectionPosition ..
|
||||||
|
const int sectionToHide = 513;
|
||||||
|
QTableView qtv;
|
||||||
|
QStandardItemModel amodel(1000, 4);
|
||||||
|
qtv.setModel(&amodel);
|
||||||
|
QHeaderView *hv = qtv.verticalHeader();
|
||||||
|
for (int u = 0; u < 100; u += 2)
|
||||||
|
hv->resizeSection(u, 0);
|
||||||
|
hv->setOffsetToSectionPosition(150);
|
||||||
|
int offset1 = hv->offset();
|
||||||
|
hv->hideSection(sectionToHide);
|
||||||
|
hv->setOffsetToSectionPosition(150);
|
||||||
|
int offset2 = hv->offset();
|
||||||
|
QVERIFY(offset1 == offset2);
|
||||||
|
// Ensure that hidden indexes (still) is considered.
|
||||||
|
hv->resizeSection(sectionToHide, hv->sectionSize(200) * 2);
|
||||||
|
hv->setOffsetToSectionPosition(800);
|
||||||
|
offset1 = hv->offset();
|
||||||
|
hv->showSection(sectionToHide);
|
||||||
|
hv->setOffsetToSectionPosition(800);
|
||||||
|
offset2 = hv->offset();
|
||||||
|
QVERIFY(offset2 > offset1);
|
||||||
|
}
|
||||||
|
|
||||||
void tst_QHeaderView::initialSortOrderRole()
|
void tst_QHeaderView::initialSortOrderRole()
|
||||||
{
|
{
|
||||||
QTableView view; // ### Shadowing member view (of type QHeaderView)
|
QTableView view; // ### Shadowing member view (of type QHeaderView)
|
||||||
|
Loading…
Reference in New Issue
Block a user