Qt QML 中为 ComBox设置鸿蒙字体(HarmonyOS Sans)——适配 Qt 5.6.x 与 Qt 5.12+

本教程假设您已经在 C++ 中正确加载了鸿蒙字体(族族名为 "HarmonyOS Sans SC"),并已将其添加到资源文件。我们将重点介绍不同 Qt 版本下如何在 QML 的 ComboBox 中应用该字体,Qt 5.12+ 版本全程不使用旧版 ComboBoxStyle,仅通过官方推荐的 contentItem + delegate 实现全局字体统一


1. Qt 5.6.x 方案:仅自定义当前选中项字体

在 Qt 5.6.x 中,ComboBoxStyle 仅支持 label 属性,用于控制当前选中项的显示。下拉列表项无法通过样式自定义,将保持系统默认字体。

qml

复制代码
import QtQuick 2.6
import QtQuick.Window 2.2
import QtQuick.Controls 1.4
import QtQuick.Controls.Styles 1.4

Window {
    visible: true
    width: 400
    height: 300

    ComboBox {
        id: combo
        anchors.centerIn: parent
        width: 200
        height: 30
        model: ["选项一", "选项二", "选项三"]

        style: ComboBoxStyle {
            label: Text {
                text: combo.currentText
                font.family: "HarmonyOS Sans SC"   // 仅当前选中项应用鸿蒙字体
                font.pixelSize: 13
                color: "black"
                verticalAlignment: Text.AlignVCenter
            }
        }
    }
}

效果:仅 ComboBox 顶部显示的当前选中项为鸿蒙字体,下拉列表项为系统默认字体。


2. Qt 5.12+ 方案:全局统一鸿蒙字体(选中项 + 下拉列表项)

Qt 5.12+ 使用 Qt Quick Controls 2 ,通过 contentItem 定制当前选中项、delegate 定制下拉列表项,无需旧版样式,代码简洁、兼容性强,可实现整个 ComboBox 完全使用鸿蒙字体。

优化后可用代码(无冗余、可直接运行)

qml

复制代码
import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.12

Window {
    visible: true
    width: 400
    height: 300

    ComboBox {
        id: combo
        anchors.centerIn: parent
        width: 200
        height: 30
        model: ["选项一", "选项二", "选项三"]

        // --------------------------
        // 1. 下拉列表项样式(鸿蒙字体)
        // --------------------------
        delegate: ItemDelegate {
            width: parent.width
            height: 25
            // 全局应用鸿蒙字体
            font.family: "HarmonyOS Sans SC"
            font.pixelSize: 13
            highlighted: parent.highlighted

            contentItem: Text {
                text: modelData
                font: parent.font
                // 高亮文字蓝色,默认黑色
                color: parent.highlighted ? "blue" : "black"
                verticalAlignment: Text.AlignVCenter
            }
        }

        // --------------------------
        // 2. 当前选中项样式(鸿蒙字体)
        // --------------------------
        contentItem: Text {
            text: combo.currentText
            font.family: "HarmonyOS Sans SC"  // 选中项鸿蒙字体
            font.pixelSize: 14
            color: "black"
            verticalAlignment: Text.AlignVCenter
            leftPadding: 6
        }
    }
}

功能说明

  1. contentItem :控制 ComboBox 顶部显示的当前选中项,强制应用鸿蒙字体;
  2. delegate :控制 下拉弹出列表中的每一项,统一使用鸿蒙字体;
  3. 支持高亮样式自定义(文字颜色 / 字体粗细均可调整);
  4. 代码干净无冗余,适配 Qt 5.12 ~ Qt 5.15 所有稳定版本。

效果 :ComboBox 当前选中项 + 全部下拉列表项 均完美显示鸿蒙字体,样式统一。


3. 版本兼容性说明

表格

Qt 版本 支持属性 使用说明
5.6.x label (旧版样式) 仅能自定义当前选中项
5.7 ~ 5.12+ contentItem + delegate 可全局自定义字体,推荐使用

4. 注意事项

  1. 使用前必须在 C++ 代码中正确加载字体文件 ,并确认字体族名严格为 HarmonyOS Sans SC
  2. Qt Quick Controls 1(5.6)与 Qt Quick Controls 2(5.12+)不能混用,需对应版本使用;
  3. 下拉列表的高度、边距、颜色均可在代码中直接调整,不影响字体生效。

5. 总结

无需修改 C++ 加载逻辑,仅需根据 Qt 版本选择对应 QML 代码:

  • Qt 5.6:用 label 实现选中项字体;
  • Qt 5.12+:用 contentItem + delegate 实现全组件鸿蒙字体统一,效果最完善。
相关推荐
2501_945423541 小时前
C++编译期多态实现
开发语言·c++·算法
2401_879693871 小时前
设计模式在C++中的实现
开发语言·c++·算法
☆5661 小时前
C++中的代理模式高级应用
开发语言·c++·算法
2301_818419011 小时前
编译器命令选项优化
开发语言·c++·算法
m0_518019481 小时前
C++图形编程(OpenGL)
开发语言·c++·算法
2301_816651221 小时前
自定义异常类设计
开发语言·c++·算法
weixin_421922691 小时前
C++与自动驾驶系统
开发语言·c++·算法
屯子来了2 小时前
window11 qt5.14.1 msvc2017 编译OpenDDS-3.33.0
c++·qt5·opendds·msvc2017
小郭学习之路2 小时前
Qt vs tools的一个编译问题
开发语言·qt