为了账号安全,请及时绑定邮箱和手机立即绑定

重写QComboBox,实现自定义QFontComboBox,可以添加自定义字体,显示字体样式

标签:
C++

在开发的过程中,有个需求,是添加一个字体选择框,这个简单,我可以直接用了QFontComboBox解决,但是我的需求是字体不用系统字体,而是用我们自定义添加的字体库,后来我尝试用QComboBox解决,但是,这个鬼东西却不能单独改变单独item的字体样式,算了,直接自己写吧,话不多说,上代码:


class CFontComboBox : public QComboBox {
    Q_OBJECT
private:
    QListWidget * mFontList;
public:
    CFontComboBox(QWidget * parent = nullptr);
    void addFont(QString famil);
    void addFonts(QStringList famils);
protected:
    void wheelEvent(QWheelEvent ) override;
};

.cpp文件

CFontComboBox::CFontComboBox(QWidgetparent) :
    QComboBox(parent)
{
    mFontList = new QListWidget(this);
    setModel(mFontList->model());
    setView(mFontList);
    mFontList->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
    setStyleSheet("QComboBox{combobox-popup:0;}");
    setMaxVisibleItems(5);
}
void CFontComboBox::wheelEvent(QWheelEvent * event) {
}
void CFontComboBox::addFont(QString famil) {
    auto item = new QListWidgetItem(famil);
    QFont font;
    font.setFamily(famil);
    item->setFont(font);
    QIcon icon(":icons/T.png");
    item->setIcon(icon);
    mFontList->addItem(item);
}
void CFontComboBox::addFonts(QStringList famils) {
    for (auto famil : famils)
    {
        addFont(famil);
    }
}

大功告成,话不多说,上图:
选择字体.png

自定义的是没有前面是没有那个图标的,这是我让UI给我设计的,想要的可以拿去用,话不多说,上图:
图标.png

为了防止有人看不懂,我还是解释一下吧,看懂的直接跳过,
setView(),是把我们的View替换上去,然后我们在对我们的View进行操作,

setStyleSheet(“QComboBox{combobox-popup:0;}”);
setMaxVisibleItems(5);

这三句是为了设置滚动条和最大显示个数,不需要的可以不用设置
我这里重写了wheelEvent方法,是为了我不想不让用户通过鼠标去改变字体,不需要的可以不重写,
最后addFont和addFonts不用解释了吧,直接用这两个方法去添加字体都行了
如果感觉我的实例可以帮助到你,记得关注,以后会经常更新Qt技巧和方法
话不多说,下课

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消