Création de graphiques à barres horizontales

Remarque : cet exemple fait partie de la galerie Charts with Widgets.

QHorizontalBarChart affiche les données des ensembles sous forme de barres séparées, regroupées en catégories. QHorizontalBarChart fonctionne comme QBarChart, sauf que les barres sont dessinées horizontalement sur le graphique.

Capture d'écran montrant un exemple de diagramme à barres horizontal

Les ensembles de barres sont utilisés de la même manière dans tous les diagrammes à barres. Pour illustrer la différence entre les différents diagrammes à barres, nous utilisons les mêmes données dans tous les exemples. Les données que le diagramme à barres visualise sont définies par les instances QBarSet. Ici, nous créons les ensembles et y ajoutons des données. Les données sont ajoutées ici à l'aide de l'opérateur <<. Il est également possible d'utiliser la méthode append.

auto set0 = new QBarSet("Jane");
auto set1 = new QBarSet("John");
auto set2 = new QBarSet("Axel");
auto set3 = new QBarSet("Mary");
auto set4 = new QBarSet("Samantha");

*set0 << 1 << 2 << 3 << 4 << 5 << 6;
*set1 << 5 << 0 << 0 << 4 << 0 << 7;
*set2 << 3 << 5 << 8 << 13 << 8 << 5;
*set3 << 5 << 6 << 7 << 3 << 4 << 5;
*set4 << 9 << 7 << 5 << 3 << 1 << 2;

Nous créons la série et y ajoutons les jeux de barres. La série est propriétaire des séries de barres. La série regroupe les données des ensembles en catégories. Les premières valeurs de chaque série sont regroupées dans la première catégorie ; les deuxièmes valeurs dans la deuxième catégorie, et ainsi de suite.

auto series = new QHorizontalBarSeries;
series->append(set0);
series->append(set1);
series->append(set2);
series->append(set3);
series->append(set4);

Nous créons ici l'objet graphique et y ajoutons la série. Nous définissons le titre du graphique avec setTitle et activons les animations de la série en appelant setAnimationOptions(QChart::SeriesAnimations).

auto chart = new QChart;
chart->addSeries(series);
chart->setTitle("Simple Horizontal Bar Chart");
chart->setAnimationOptions(QChart::SeriesAnimations);

Pour afficher les catégories sur l'axe, nous devons créer un site QBarCategoryAxis à cet effet. Ici, nous créons un axe de catégorie avec une liste de catégories et nous le configurons pour qu'il soit aligné sur le côté gauche, agissant comme l'axe des ordonnées, et nous l'attachons à la série. Le graphique s'approprie l'axe. Pour l'axe des abscisses, nous utilisons un axe des valeurs, aligné en bas.

QStringList categories {"Jan", "Feb", "Mar", "Apr", "May", "Jun"};
auto axisY = new QBarCategoryAxis;
axisY->append(categories);
chart->addAxis(axisY, Qt::AlignLeft);
series->attachAxis(axisY);
auto axisX = new QValueAxis;
chart->addAxis(axisX, Qt::AlignBottom);
series->attachAxis(axisX);
axisX->applyNiceNumbers();

Nous voulons également afficher la légende. Pour ce faire, nous obtenons le pointeur de légende du graphique et le définissons comme visible. Nous plaçons également la légende au bas du graphique en réglant son alignement sur Qt::AlignBottom.

chart->legend()->setVisible(true);
chart->legend()->setAlignment(Qt::AlignBottom);

Enfin, nous ajoutons le graphique à une vue. Nous activons également l'anticrénelage pour le chartView.

createDefaultChartView(chart);

Le graphique est prêt à être affiché.

© 2026 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.