我试图通过使用发现的here源代码复制示例linked at the bottom of that page.来使用QtCharts绘制极坐标图,我已经将C ++代码转换为PySide2兼容代码,并且似乎大部分工作(即显示出图并绘制了序列),但是由于某些原因,角轴标记不正确。运行代码时,尽管我按如下方式添加了角轴,但角轴的标签与径向轴的标签重叠:
self.chart.addAxis(self.angularAxis, QtCharts.QtCharts.QPolarChart.PolarOrientationAngular
根据文档,这是我应该对角轴执行的操作,但似乎不起作用。最终看起来像这样:
下面是生成此代码的代码。
import sys
from PySide2 import QtCore, QtWidgets, QtGui, QtCharts
class Main(QtWidgets.QMainWindow):
def __init__(self, parent=None):
super(Main, self).__init__(parent)
self.angularMin = 0
self.angularMax = 360
self.radialMin = -100
self.radialMax = 100
self.chart = QtCharts.QtCharts.QPolarChart()
self.chart.setTitle("Example Chart")
self.angularAxis = QtCharts.QtCharts.QValueAxis()
self.angularAxis.setTickCount(9)
self.angularAxis.setLabelFormat("%.1f")
self.angularAxis.setShadesVisible(True)
self.angularAxis.setShadesBrush(QtGui.QBrush(QtGui.QColor(249, 249, 255)))
self.chart.addAxis(self.angularAxis, QtCharts.QtCharts.QPolarChart.PolarOrientationAngular)
self.radialAxis = QtCharts.QtCharts.QValueAxis()
self.radialAxis.setTickCount(9)
self.radialAxis.setLabelFormat("%d")
self.chart.addAxis(self.radialAxis, QtCharts.QtCharts.QPolarChart.PolarOrientationRadial)
self.radialAxis.setRange(self.radialMin, self.radialMax);
self.angularAxis.setRange(self.angularMin, self.angularMax);
self.chartView = QtCharts.QtCharts.QChartView(self.chart)
self.chartView.setRenderHint(QtGui.QPainter.Antialiasing);
self.setCentralWidget(self.chartView)
app = QtWidgets.QApplication(sys.argv)
main = Main()
main.show()
sys.exit(app.exec_())