QProxyStyle的用法

 

通过重载函数可以修改特定元素的样式

int pixelMetric(QStyle::PixelMetric metric, const QStyleOption *option, const QWidget *widget) const;
void drawControl(ControlElement oCtrElement, const QStyleOption * poStyleOptionption, QPainter * poPainter, const QWidget * poWidget = 0) const;
void drawPrimitive ( PrimitiveElement element, const QStyleOption * option, QPainter * painter, const QWidget * widget = 0 ) const;

2、pixelMetric

返回给定像素度量的值。

例如:修改单元格边距。

int MyTableStyle::pixelMetric(QStyle::PixelMetric metric, const QStyleOption *option, const QWidget *widget) const
{
    switch (metric) {
    case PM_FocusFrameHMargin:
        return m_margin;//返回边距
    default:
        break;
    }
    return QProxyStyle::pixelMetric(metric, option, widget);
}

2、drawControl

由给定的画家绘制指定样式的元素

例如:当表头有排序图标时,修改对应列的文字位置。

void MyTableStyle::drawControl(ControlElement ctrElement, const QStyleOption * styleOptionption, QPainter * painter, const QWidget * widget) const
{
    if (ctrElement == CE_HeaderLabel) {
        QStyleOptionHeader *poStyleOptionHeader = (QStyleOptionHeader *) styleOptionption;
        QStyleOptionHeader::SortIndicator sortOption = poStyleOptionHeader->sortIndicator;
        if (sortOption != QStyleOptionHeader::None)
        {
            QRect oRect = poStyleOptionHeader->rect;
            // Text
            int iTextWidth = poStyleOptionHeader->fontMetrics.width(poStyleOptionHeader->text);
            int iTextHeight = poStyleOptionHeader->fontMetrics.height();
            Qt::Alignment align = poStyleOptionHeader->textAlignment;
            int left;
            if (align & Qt::AlignLeft)
            {
                left = oRect.left();
            }
            else
            {
                left = oRect.left() + oRect.width() - iTextWidth - 10;
            }
            QString text = poStyleOptionHeader->text;
            QRect oTextRect = QRect(left, oRect.top() + (oRect.height() - iTextHeight)/2,
                                    iTextWidth*1.2, iTextHeight);
            painter->setPen(QPen(poStyleOptionHeader->palette.text().color()));
            painter->drawText(oTextRect, poStyleOptionHeader->text); // Draw text

            return;
        }
    }
    QProxyStyle::drawControl(ctrElement, styleOptionption, painter, widget);
}

3、drawPrimitive

使用选项指定的样式选项,使用提供的画家绘制给定的基本元素。

例如:修改拖拽时的样式

void MyTableStyle::drawPrimitive (PrimitiveElement element, const QStyleOption * option, QPainter * painter, const QWidget * widget) const{
    QStyleOption opt(*option);
    if (element == QStyle::PE_IndicatorItemViewItemDrop && !option->rect.isNull()){
        opt.rect.setLeft(0);
        opt.rect.setRight(m_dropStyleWidth);//显示宽度
        QPen pen = painter->pen();
        pen.setColor("#277BFF");
        painter->setPen(pen);
    }
    QProxyStyle::drawPrimitive(element, &opt, painter, widget);
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果想要重写QMdiSubWindow的样式,可以通过继承QProxyStyle来实现。下面是一个简单的例子: 1. 创建一个新的类,继承自QProxyStyle: ``` class MyProxyStyle : public QProxyStyle { public: MyProxyStyle(QStyle *style = nullptr) : QProxyStyle(style) { } // 重写drawControl方法,可以在这里更改QMdiSubWindow的样式 void drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget = nullptr) const override { if (element == CE_MdiSubWindowTitleBar) { // 更改标题栏的背景色和文字颜色 QStyleOptionTitleBar titleBarOption = *qstyleoption_cast<const QStyleOptionTitleBar *>(option); painter->fillRect(titleBarOption.rect, QColor(200, 200, 200)); painter->setPen(QColor(0, 0, 0)); painter->drawText(titleBarOption.rect, Qt::AlignCenter, titleBarOption.text); return; } QProxyStyle::drawControl(element, option, painter, widget); } }; ``` 2. 在创建QMdiArea之前,将自定义的QProxyStyle设置为应用程序的全局样式: ``` QApplication::setStyle(new MyProxyStyle); ``` 3. 创建QMdiArea和QMdiSubWindow,然后显示: ``` QMdiArea *mdiArea = new QMdiArea(this); QMdiSubWindow *subWindow = new QMdiSubWindow(mdiArea); subWindow->setWindowTitle("My Document"); subWindow->setWidget(new QWidget(subWindow)); mdiArea->addSubWindow(subWindow); mdiArea->show(); subWindow->show(); ``` 这样,就可以自定义QMdiSubWindow的样式了。注意,这里只是演示了如何重写QMdiSubWindow的标题栏样式,如果需要更改其他部分的样式,可以在drawControl方法中根据不同的ControlElement进行判断和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值