Qt: QHeaderView поместите индикатор сортировки справа от текста заголовка

Если я установлю: QHeaderView::down-arrow { subcontrol-position: center left}, стрелка вниз находится слева от столбца, и если я установил center right, он расположен справа от столбца, но я хочу разместить стрелку рядом с заголовком (с правой стороны).

введите описание изображения здесь

2 ответа

Решение

Я отсортировал путь, создав QProxyStyle для заголовка и переопределив drawControl. Я также назначил пустой значок, чтобы скрыть значок по умолчанию.

treeviewwidget.cpp при инициализации ():

treeviewHeaderProxy* m_oHeaderStyle = new treeviewHeaderProxy();
treeview->header()->setStyle(m_oHeaderStyle);
treeview->header()->setDefaultAlignment(Qt::AlignCenter);
treeview->header()->setStyleSheet("QHeaderView::down-arrow { image: url(:/shared/empty); }"
                                "QHeaderView::up-arrow { image: url(:/shared/empty); } ");

treeviewHeaderProxy.h:

class treeviewHeaderProxy : public QProxyStyle
{
public:
    explicit treeviewHeaderProxy();
    void drawControl(ControlElement oCtrElement, const QStyleOption * poStylrOptionption, QPainter * poPainter, const QWidget * poWidget = 0) const;

};

treeviewHeaderProxy.cpp:

void treeviewHeaderProxy::drawControl(ControlElement oCtrElement, const QStyleOption *poStyleOptionption, QPainter *poPainter, const QWidget *poWidget) const
{
    // Header label?
    if (oCtrElement == CE_HeaderLabel) {
        QStyleOptionHeader *poStyleOptionHeader = (QStyleOptionHeader *) poStyleOptionption;
        QStyleOptionHeader::SortIndicator sortOption = poStyleOptionHeader->sortIndicator;
        QRect oRect = poStyleOptionHeader->rect;

        // Text
        int iTextWidth = poStyleOptionHeader->fontMetrics.width(poStyleOptionHeader->text);
        int iTextHeight = poStyleOptionHeader->fontMetrics.height();
        QRect oTextRect = QRect(oRect.left() + oRect.width(), catRect.top() + (oRect.height() - iTextHeight)/2,
                                iTextWidth*1.2, iTextHeight);
        poPainter->setPen(SUPER_DARK_GREY);
        poPainter->drawText(oTextRect, poStyleOptionHeader->text); // Draw text

        // Sort Indicator
        QPixmap oSortPixmap;
        switch(sortOption){
        case QStyleOptionHeader::SortDown:
            oSortPixmap = QIcon(":/shared/drop_up_grey").pixmap(10,10);
            break;
        case QStyleOptionHeader::SortUp:
            oSortPixmap = QIcon(":/shared/drop_down_grey").pixmap(10,10);
            break;
        }

        if(!oSortPixmap.isNull()){
            QRect oSortRect = QRect(oTextRect.left() + oTextRect.width(), oRect.top() + (oRect.height() - oSortPixmap.height())/2,
                                    oSortPixmap.width(), oSortPixmap.height());
            poPainter->drawPixmap(oSortRect, oSortPixmap); // Draw sortIcon
        }
        return;
    }
    QProxyStyle::drawControl(oCtrElement, poStyleOptionption, poPainter, poWidget);
}

Вам нужно установить subcontrol-origin: margin | border | padding | content;

Посмотрите на ссылку на документацию ниже, чтобы понять блочную модель (которая объясняет прямоугольник полей, прямоугольник границы, прямоугольник заполнения и прямоугольник содержимого).

http://doc.qt.io/qt-5/stylesheet-customizing.html

Так что попробуйте добавить subcontrol-origin:padding к вашему коду, который может добавить рядом с вашим контентом.

Попробуйте что-то вроде ниже:

QHeaderView::down-arrow { subcontrol-origin:padding; subcontrol-position: center right;}
Другие вопросы по тегам