Création de diagrammes à barres empilées horizontalement
Remarque : cet exemple fait partie de l'exemple de la galerie Charts with Widgets.
Le diagramme à barres empilées présente les données sous forme de barres empilées les unes sur les autres. L'empilement se fait par catégorie. La création d'un diagramme à barres horizontales empilées est identique à celle d'un diagramme à barres normal, à ceci près que pour un diagramme à barres horizontales empilées, nous utilisons l'interface QHorizontalStackedBarSeries au lieu de QBarSeries.

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 visualisées par barchart 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 séries 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 QHorizontalStackedBarSeries; series->append(set0); series->append(set1); series->append(set2); series->append(set3); series->append(set4);
Nous créons ici l'objet graphique et lui ajoutons la série. Nous définissons le titre du graphique avec setTitle, puis nous activons les animations de la série en appelant setAnimationOptions(QChart::SeriesAnimations).
auto chart = new QChart; chart->addSeries(series); chart->setTitle("Simple Horizontal Stacked Bar Chart"); chart->setAnimationOptions(QChart::SeriesAnimations);
Pour afficher les catégories sur un axe, nous devons d'abord créer un site QBarCategoryAxis. Ici, nous créons un axe de catégorie avec une liste de catégories et nous l'ajoutons au graphique sur le côté gauche, en tant qu'axe des ordonnées. Le graphique s'approprie l'axe. Pour l'axe des x, 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);
Nous voulons également afficher la légende. Pour ce faire, nous récupérons le pointeur de légende du graphique et le rendons 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.
createDefaultChartView(chart);
© 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.