Qt: QPolarChart с категориальной угловой осью
Я хотел бы заменить градусы угловой оси в QPolarChart текстом, как показано на прилагаемом рисунке (например, вместо 90.0 -> "Cat 1"). Я попробовал QCategoryAxis, но в этом случае категории появились между осью (например, между 90 и 180 градусами).
Теперь я использую следующий код для создания полярной диаграммы:
QPolarChart *chart = new QPolarChart();
QValueAxis *angularAxis = new QValueAxis();
angularAxis->setRange(0, 360);
QLineSeries *series1 = new QLineSeries();
series1->append(0, 60);
series1->append(90, -60);
series1->append(180, 50);
series1->append(270, 62);
series1->append(360, 60);
QLineSeries *series2 = new QLineSeries();
series2->append(0, 0);
series2->append(90, 0);
series2->append(180, 0);
series2->append(270, 0);
series2->append(360, 0);
chart->addSeries(series1);
chart->addSeries(series2);
chart->addAxis(angularAxis, QPolarChart::PolarOrientationAngular);
ValueAxis *radialAxis = new QValueAxis();
radialAxis->setTickCount(9);
radialAxis->setLabelFormat("%d");
chart->addAxis(radialAxis, QPolarChart::PolarOrientationRadial);
series1->attachAxis(radialAxis);
series1->attachAxis(angularAxis);
series2->attachAxis(radialAxis);
series2->attachAxis(angularAxis);
radialAxis->setRange(-100, 100);
QChartView *chartView = new QChartView();
chartView->setChart(chart);
chartView->setRenderHint(QPainter::Antialiasing);
ui->mainPlot->addWidget(chartView);
1 ответ
Решение
Решение заключается в использовании QCategoryAxis
но с labelsPosition
в QCategoryAxis::AxisLabelsPositionOnValue
,
#include <QApplication>
#include <QtCharts>
using namespace QtCharts;
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QPolarChart *chart = new QPolarChart();
QCategoryAxis *angularAxis = new QCategoryAxis;
angularAxis->setLabelsPosition(QCategoryAxis::AxisLabelsPositionOnValue);
angularAxis->setRange(0, 360);
angularAxis->append("Cat 1", 90);
QLineSeries *series1 = new QLineSeries();
*series1 << QPointF(0, 60) << QPointF(90, -60) << QPointF(180, 50) << QPointF(270, 62) << QPointF(360, 60);
QLineSeries *series2 = new QLineSeries();
*series2 << QPointF(0, 0)<< QPointF(90, 0) << QPointF(180, 0) << QPointF(270, 0) << QPointF(360, 0);
chart->addSeries(series1);
chart->addSeries(series2);
chart->addAxis(angularAxis, QPolarChart::PolarOrientationAngular);
QValueAxis *radialAxis = new QValueAxis();
radialAxis->setTickCount(9);
radialAxis->setLabelFormat("%d");
chart->addAxis(radialAxis, QPolarChart::PolarOrientationRadial);
series1->attachAxis(radialAxis);
series1->attachAxis(angularAxis);
series2->attachAxis(radialAxis);
series2->attachAxis(angularAxis);
radialAxis->setRange(-100, 100);
QChartView *chartView = new QChartView();
chartView->setChart(chart);
chartView->setRenderHint(QPainter::Antialiasing);
chartView->show();
return a.exec();
}