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);

PolarPlot

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();
}

введите описание изображения здесь

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]