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

Другие вопросы по тегам