Création de diagrammes à barres empilées
Remarque : cet exemple fait partie de l'exemple de la galerie Charts with Widgets.
Le diagramme à barres empilées affiche les données sous forme de barres empilées les unes sur les autres. L'empilement se fait par catégorie. L'exemple montre comment créer un diagramme à barres empilées simple. Le diagramme à barres empilées montre les données des ensembles 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 empilées est identique à celle d'un diagramme à barres classique, à ceci près que pour un diagramme à barres empilées, nous utilisons l'API QStackedBarSeries 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 le graphique à barres 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 ensembles de barres. La série est propriétaire des ensembles de barres. La série regroupe les données des ensembles en catégories. Les premières valeurs de chaque ensemble sont regroupées dans la première catégorie, les deuxièmes valeurs dans la deuxième catégorie, etc.
auto series = new QStackedBarSeries; 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, puis nous activons les animations de la série en appelant setAnimationOptions(QChart::SeriesAnimations).
auto chart = new QChart; chart->addSeries(series); chart->setTitle("Simple 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 aligné en bas, agissant comme l'axe des x. Le graphique s'approprie l'axe. Le graphique s'approprie l'axe. Pour l'axe des ordonnées, nous utilisons un axe des valeurs, aligné sur le côté gauche.
QStringList categories {"Jan", "Feb", "Mar", "Apr", "May", "Jun"}; auto axisX = new QBarCategoryAxis; axisX->append(categories); chart->addAxis(axisX, Qt::AlignBottom); series->attachAxis(axisX); auto axisY = new QValueAxis; chart->addAxis(axisY, Qt::AlignLeft); series->attachAxis(axisY);
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);
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.