在 QtCharts.QDateTimeAxis 上设置动态刻度

Posted

技术标签:

【中文标题】在 QtCharts.QDateTimeAxis 上设置动态刻度【英文标题】:set dynamic ticks on QtCharts.QDateTimeAxis 【发布时间】:2021-04-28 09:42:24 【问题描述】:

我正在使用 Qt5(通过 pyside2)绘制“金钱/时间”图表应用程序。

我可以绘制数据,现在我正在尝试设置轴。 我已经用支持动态刻度的QValueAxis 设置了 y 轴,所以我可以说“每 10000 欧元画一个刻度”

axis_y = QtCharts.QValueAxis()
axis_y.setTickType(QtCharts.QValueAxis.TicksDynamic)
axis_y.setTickAnchor(0.)
axis_y.setTickInterval(10000.)
axis_y.setMinorTickCount(9)
self.addAxis(axis_y, Qt.AlignLeft)

我无法使用 x 轴获得相同的结果。我正在使用QDateTimeAxis,但在我看来它缺乏动态设置刻度的任何方法。

我想要实现的是:“在每年的 1 月、每年的 1 日绘制一个主要刻度,在每个月初绘制一个次要刻度”。

【问题讨论】:

【参考方案1】:

这确实不是正确的方法[0],但作为一种快速且“可实现”的解决方法,您可以将 QDateTimeAxis 替换为 QCategoryAxis 并填充各种“类别” " 作为(例如)数据可用的年份(+- 之前和之后的某年)。

axis_x = QtCharts.QCategoryAxis()
axis_x.setLabelsPosition(QtCharts.QCategoryAxis.AxisLabelsPositionOnValue)
for dt in years(data):
    axis_x.append(f'dt', ts(dt))
self.addAxis(axis_x, Qt.AlignBottom)
series.attachAxis(axis_x)

其中years 产生数据的年份(作为date 对象)和ts 提取EPOCH 时间戳

[0] 据我了解,唯一“真正”的解决方案是放弃QtCharts 并依靠Qwt 来绘制图表

【讨论】:

以上是关于在 QtCharts.QDateTimeAxis 上设置动态刻度的主要内容,如果未能解决你的问题,请参考以下文章

分配的变量引用在哪里,在堆栈中还是在堆中?

NOIP 2015 & SDOI 2016 Round1 & CTSC 2016 & SDOI2016 Round2游记

秋的潇洒在啥?在啥在啥?

上传的数据在云端的怎么查看,保存在啥位置?

在 React 应用程序中在哪里转换数据 - 在 Express 中还是在前端使用 React?

存储在 plist 中的数据在模拟器中有效,但在设备中无效