DoubleSpinBox - Material 双精度数值调节框¶
DoubleSpinBox 是 Material Design 3 双精度数值调节框控件的完整实现,支持浮点数输入、增减按钮、描边样式、焦点指示器和状态层效果。
类参考¶
头文件:ui/widget/material/widget/doublespinbox/doublespinbox.h
基本用法¶
#include "widget/material/widget/doublespinbox/doublespinbox.h"
using namespace cf::ui::widget::material;
// 创建双精度数值调节框
auto* spin = new DoubleSpinBox(this);
spin->setRange(0.0, 100.0);
spin->setValue(50.0);
spin->setSingleStep(0.1);
spin->setDecimals(2);
// 设置前缀和后缀
spin->setPrefix("$ ");
spin->setSuffix(" mm");
// 连接信号(与 QDoubleSpinBox 兼容)
connect(spin, QOverload<double>::of(&QDoubleSpinBox::valueChanged),
this, &MyClass::onValueChanged);
与 SpinBox 的区别¶
| 特性 | SpinBox | DoubleSpinBox |
|---|---|---|
| 基类 | QSpinBox |
QDoubleSpinBox |
| 数值类型 | int |
double |
| 小数位数 | 不适用 | setDecimals(int) |
| 步长精度 | 整数步长 | 浮点步长 |
其余视觉和行为完全一致。
增减按钮¶
与 SpinBox 相同,提供增减按钮:
交互状态¶
| 状态 | 视觉效果 |
|---|---|
| Normal | 描边边框 + 文本 + 增减图标 |
| Hovered (整体) | 状态层叠加 |
| Hovered (按钮) | 按钮区域状态层 |
| Pressed (按钮) | 水波纹 + 状态层 |
| Focused | 描边高亮 + 焦点环 |
| Disabled | 38% 透明度 |
绘制流程¶
DoubleSpinBox 的 paintEvent 实现 7 步 Material Design 绘制流程:
- 绘制背景(
drawBackground) - 绘制状态层(
drawStateLayer) - 绘制水波纹(
drawRipple) - 绘制描边(
drawOutline) - 绘制文本(
drawText) - 绘制增减按钮(
drawButtons) - 绘制焦点指示器(
drawFocusIndicator)
内部 LineEdit 约束¶
重写了 resizeEvent 以约束内部 LineEdit:
颜色系统¶
| 元素 | 颜色角色 |
|---|---|
| 容器背景 | Surface |
| 文本 | OnSurface |
| 描边 | Outline |
| 焦点描边 | Primary |
| 按钮图标 | OnSurfaceVariant |
| 状态层 | 根据状态计算 |
主要方法¶
| 方法 | 说明 |
|---|---|
| 继承自 QDoubleSpinBox | setValue(), setRange(), setSingleStep(), setDecimals(), setPrefix(), setSuffix() 等 |
sizeHint() / minimumSizeHint() |
获取推荐/最小尺寸 |