StackedColumnChartWidget class
A stacked column chart widget where multiple datasets are stacked vertically.
Each column is divided into segments representing different data series, with each segment stacked on top of the previous one. This is useful for comparing the composition of different categories while showing the total.
Features
- Multiple data series stacked vertically
- Customizable bar width and border radius
- Interactive bar tapping with visual border highlighting
- Gradient fills per segment
- Loading and error states
- Full theme support
Example
StackedColumnChartWidget(
dataSets: [
ChartDataSet(
label: 'Q1',
color: Colors.blue,
dataPoints: [
ChartDataPoint(x: 0, y: 10),
ChartDataPoint(x: 1, y: 20),
],
),
ChartDataSet(
label: 'Q2',
color: Colors.green,
dataPoints: [
ChartDataPoint(x: 0, y: 15),
ChartDataPoint(x: 1, y: 25),
],
),
],
theme: ChartTheme.light(),
title: 'Quarterly Sales',
onBarTap: (point, datasetIndex, barIndex, position) {
// Handle bar tap
},
)
- Inheritance
-
- Object
- DiagnosticableTree
- Widget
- StatefulWidget
- StackedColumnChartWidget
Constructors
-
StackedColumnChartWidget({Key? key, required List<
ChartDataSet> dataSets, ChartTheme? theme, double barWidth = 30.0, double borderRadius = 4.0, bool showGrid = true, bool showAxis = true, bool showLabel = true, String? title, String? subtitle, bool useGlassmorphism = false, bool useNeumorphism = false, BarCallback? onBarTap, bool isLoading = false, bool isError = false, String? errorMessage})
Properties
- barWidth → double
-
final
- borderRadius → double
-
final
-
dataSets
→ List<
ChartDataSet> -
final
- errorMessage → String?
-
final
- hashCode → int
-
The hash code for this object.
no setterinherited
- isError → bool
-
final
- isLoading → bool
-
final
- key → Key?
-
Controls how one widget replaces another widget in the tree.
finalinherited
- onBarTap → BarCallback?
-
final
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
- showAxis → bool
-
final
- showGrid → bool
-
final
- showLabel → bool
-
final
- subtitle → String?
-
final
- theme → ChartTheme?
-
final
- title → String?
-
final
- useGlassmorphism → bool
-
final
- useNeumorphism → bool
-
final
Methods
-
createElement(
) → StatefulElement -
Creates a StatefulElement to manage this widget's location in the tree.
inherited
-
createState(
) → State< StackedColumnChartWidget> -
Creates the mutable state for this widget at a given location in the tree.
override
-
debugDescribeChildren(
) → List< DiagnosticsNode> -
Returns a list of DiagnosticsNode objects describing this node's
children.
inherited
-
debugFillProperties(
DiagnosticPropertiesBuilder properties) → void -
Add additional properties associated with the node.
inherited
-
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
toDiagnosticsNode(
{String? name, DiagnosticsTreeStyle? style}) → DiagnosticsNode -
Returns a debug representation of the object that is used by debugging
tools and by DiagnosticsNode.toStringDeep.
inherited
-
toString(
{DiagnosticLevel minLevel = DiagnosticLevel.info}) → String -
A string representation of this object.
inherited
-
toStringDeep(
{String prefixLineOne = '', String? prefixOtherLines, DiagnosticLevel minLevel = DiagnosticLevel.debug, int wrapWidth = 65}) → String -
Returns a string representation of this node and its descendants.
inherited
-
toStringShallow(
{String joiner = ', ', DiagnosticLevel minLevel = DiagnosticLevel.debug}) → String -
Returns a one-line detailed description of the object.
inherited
-
toStringShort(
) → String -
A short, textual description of this widget.
inherited
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited