QCheckbox / QRadioButton换行Qt4.6.0

时间:2009-12-03 10:55:40

标签: qt4 checkbox radio-button qcheckbox

我正在尝试使用标准QCheckbox / QRadioButton与Qt建立多行复选框/单选按钮。

我找不到直接解决方案,因为QRadioButton{wrap:true;}没有效果。 唯一可能的是访问QRadioButton->label->setLineWrap(true)

  1. 我想从设计师那里做到这一点
  2. 无需重写小部件
  3. 除了将QRadioButton和QLabel放在一起之外,还有什么想法?

    Thx,Boris。

4 个答案:

答案 0 :(得分:11)

这确实非常烦人,如果没有重新实现就无法解决:如果我没有弄错的话,标签会使用Qt::PlainText。在我们的项目中,UI团队通过两种方法解决了这个问题。

使用QRadioButton按钮作为标题

Layout using the QRadioButton as a title

以这样的方式重写QRadioButton文本,它只有该选项的简短描述。将QLabel置于其下方并添加更长的描述。我们使用较小的字体和小缩进使其看起来整洁。例如,这在Mac OS X中经常使用。

从单选按钮中删除文字

Layout using buddy labels

重新布局UI,以便每个单选按钮放在QLabel的左侧。将整个文本添加到QLabel并将标签设置为单选按钮的伙伴。这是功能最少的方法,因为单击标签不会检查单选按钮。对齐也不是很好。

答案 1 :(得分:3)

我知道的唯一方法(但不是“可布局”)是将\ n符号放入字符串。

答案 2 :(得分:2)

我成功地为单选按钮添加了布局和标签作为子项,并将垂直大小策略更改为Preferred(而不是Fixed)。

不幸的是,这并没有自动使它对鼠标悬停和点击做出反应,就像本机标签一样,但是看一下黑客:我为单选按钮设置了setStyleSheet(“border:none”),它开始工作了。也许这是幕后发生的一些特征;我很想有一定的确定性。

指标可以使用“QRadioButton :: indicator {subcontrol-position:top left}”< - http://doc.trolltech.com/qq/qq20-qss.html

进行对齐

答案 3 :(得分:0)

我的解决方案:

#ifndef CHECKBOX_H
#define CHECKBOX_H

#include <QCheckBox>

#include <QHBoxLayout>
#include <QLabel>

class CheckBox : public QCheckBox
{
    Q_OBJECT
public:
   explicit CheckBox(QWidget *parent = 0);

   void setText(const QString & text);
   QSize sizeHint() const;
   bool hitButton(const QPoint &pos) const;

protected:
   void paintEvent(QPaintEvent *);

private:
   QHBoxLayout* _layout;
   QLabel*      _label;
};

#endif // CHECKBOX_H




#include "checkbox.h"

#include <QStylePainter>
#include <QStyleOption>

#define MARGIN 4 // hardcoded spacing acording to QCommonStyle implementation

CheckBox::CheckBox(QWidget *parent) : QCheckBox(parent)
{
    setSizePolicy(QSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred, QSizePolicy::CheckBox));

    QStyleOptionButton opt;
    initStyleOption(&opt);

    QRect label_rect = style()->subElementRect(QStyle::SE_CheckBoxContents, &opt, this);

    _label = new QLabel(this);
    _label->setWordWrap(true);
    _label->setMouseTracking(true);
    //_label->setMinimumHeight(label_rect.height());

    _layout = new QHBoxLayout(this);
    _layout->setContentsMargins(label_rect.left()+MARGIN, MARGIN/2, MARGIN/2, MARGIN/2);
    _layout->setSpacing(0);
    _layout->addWidget(_label);

    setLayout(_layout);
}

void CheckBox::setText(const QString & text)
{
    _label->setText(text);
    QCheckBox::setText(text);
}

void CheckBox::paintEvent(QPaintEvent *)
{
    QStylePainter p(this);
    QStyleOptionButton opt;
    initStyleOption(&opt);

    QStyleOptionButton subopt = opt;
    subopt.rect = style()->subElementRect(QStyle::SE_CheckBoxIndicator, &opt, this);
    subopt.rect.moveTop(opt.rect.top()+MARGIN/2); // align indicator to top

    style()->proxy()->drawPrimitive(QStyle::PE_IndicatorCheckBox, &subopt, &p, this);

    if (opt.state & QStyle::State_HasFocus)
    {
        QStyleOptionFocusRect fropt;
        fropt.QStyleOption::operator=(opt);
        fropt.rect = style()->subElementRect(QStyle::SE_CheckBoxFocusRect, &opt, this);
        style()->proxy()->drawPrimitive(QStyle::PE_FrameFocusRect, &fropt, &p, this);
    }
}

QSize CheckBox::sizeHint() const
{
    return QSize(); // will be calculated by layout
}

bool CheckBox::hitButton(const QPoint &pos) const
{
    QStyleOptionButton opt;
    initStyleOption(&opt);
    return opt.rect.contains(pos); // hit all button
}