Creación de gráficos de barras apiladas
Nota: Esto es parte del ejemplo de la Galería de Gráficos con Widgets.
El gráfico de barras apiladas muestra los datos en conjuntos como barras apiladas unas sobre otras. El apilamiento se realiza por categoría. El ejemplo muestra cómo crear un simple gráfico de barras apiladas. El gráfico de barras apiladas muestra los datos de los conjuntos como barras apiladas unas sobre otras. El apilamiento se realiza por categoría. Crear un gráfico de barras apiladas es igual que crear un gráfico de barras normal, excepto que para un gráfico de barras apiladas, utilizamos la API QStackedBarSeries en lugar de QBarSeries.

Los conjuntos de barras se utilizan del mismo modo en todos los gráficos de barras. Para ilustrar la diferencia entre los distintos gráficos de barras, utilizamos los mismos datos en todos los ejemplos. Los datos que visualiza el gráfico de barras se definen en las instancias de QBarSet. Aquí creamos los conjuntos y les añadimos los datos. Los datos se añaden aquí con el operador <<. Alternativamente se puede utilizar el método 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;
Creamos la serie y le añadimos los conjuntos de barras. La serie toma posesión de los conjuntos de barras. La serie agrupa los datos de conjuntos a categorías. Los primeros valores de cada conjunto se agrupan en la primera categoría, los segundos valores en la segunda categoría, etc.
auto series = new QStackedBarSeries; series->append(set0); series->append(set1); series->append(set2); series->append(set3); series->append(set4);
Aquí creamos el objeto gráfico y le añadimos la serie. Establecemos el título del gráfico con setTitle, y luego activamos las animaciones de las series llamando a setAnimationOptions(QChart::SeriesAnimations).
auto chart = new QChart; chart->addSeries(series); chart->setTitle("Simple Stacked Bar Chart"); chart->setAnimationOptions(QChart::SeriesAnimations);
Para que las categorías se muestren en un eje, necesitamos crear primero un QBarCategoryAxis. Aquí creamos un eje de categorías con una lista de categorías y lo añadimos al gráfico alineado en la parte inferior, actuando como eje x. El gráfico se apropia del eje. El gráfico toma posesión del eje. Para el eje y utilizamos un eje de valores, alineado a la izquierda.
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);
También queremos mostrar la leyenda. Para ello, obtenemos el puntero de la leyenda del gráfico y lo situamos en visible. También colocamos la leyenda en la parte inferior del gráfico estableciendo su alineación en Qt::AlignBottom.
chart->legend()->setVisible(true); chart->legend()->setAlignment(Qt::AlignBottom);
Por último, añadimos el gráfico a una vista.
createDefaultChartView(chart);
El gráfico está listo para ser mostrado.
© 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.