PieSeries QML Type
Presents data in pie graphs. More...
Import Statement: | import QtGraphs |
In C++: | QPieSeries |
Inherits: |
- List of all members, including inherited members
- PieSeries is part of Qt Graphs QML Types for 2D.
Properties
- count : int
- endAngle : real
- holeSize : real
- horizontalPosition : real
- pieSize : real
- startAngle : real
- sum : real
- verticalPosition : real
Signals
- added(list<PieSlice> slices)
- clicked(PieSlice slice)
- countChanged()
- doubleClicked(PieSlice slice)
- endAngleChanged()
- holeSizeChanged()
- horizontalPositionChanged()
- pieSizeChanged()
- pressed(PieSlice slice)
- released(PieSlice slice)
- removed(list<PieSlice> slices)
- startAngleChanged()
- sumChanged()
- verticalPositionChanged()
Methods
- PieSlice append(string label, real value)
- PieSlice at(int index)
- clear()
- PieSlice find(string label)
- bool remove(PieSlice slice)
- bool remove(int index)
- void removeMultiple(int index, int count)
- bool replace(list<PieSlice> slices)
- bool replace(PieSlice oldSlice, PieSlice newSlice)
- bool replace(int index, PieSlice slice)
- bool take(PieSlice slice)
Detailed Description
A pie series consists of slices that are defined using the PieSlice type. The slices can have any values as the PieSeries type calculates the percentage of a slice compared with the sum of all slices in the series to determine the actual size of the slice in the graph.
Pie size and position on the graph are controlled by using relative values that range from 0.0 to 1.0. These relate to the actual graph rectangle.
By default, the pie is defined as a full pie. A partial pie can be created by setting a starting angle and angle span for the series. A full pie is 360 degrees, where 0 is at 12 o'clock.
The following QML example shows how to create a simple pie graph.
import QtQuick import QtGraphs Item { id: mainView width: 1280 height: 720 GraphsView { anchors.fill: parent theme: GraphsTheme { colorScheme: GraphsTheme.ColorScheme.Dark theme: GraphsTheme.Theme.QtGreen } PieSeries { id: pieSeries PieSlice { value: 1 } PieSlice { value: 2 } } } }
See also PieSlice and GraphsView.
Property Documentation
count : int |
The number of slices in the series.
endAngle : real |
The ending angle of the pie.
A full pie is 360 degrees, where 0 degrees is at 12 o'clock.
The default value is 360.
holeSize : real |
The donut hole size.
When setting the pieSize property, this property is adjusted if necessary, to ensure that the hole size is not greater than the pie size.
The default value is 0.0.
horizontalPosition : real |
The horizontal position of the pie.
The value is relative to the graph rectangle, so that:
- 0.0 is the absolute left.
- 1.0 is the absolute right.
The default value is 0.5 (center).
See also verticalPosition.
pieSize : real |
The pie size.
The value is relative to the graph rectangle, so that:
- 0.0 is the minimum pieSize (pie not drawn).
- 1.0 is the maximum pieSize that can fit the graph.
When setting this property, the holeSize property is adjusted if necessary, to ensure that the hole size is not greater than the pie size.
The default value is 0.7.
startAngle : real |
The starting angle of the pie.
A full pie is 360 degrees, where 0 degrees is at 12 o'clock.
The default value is 0.
sum : real |
The sum of all slices.
The series keeps track of the sum of all the slices it holds.
verticalPosition : real |
The vertical position of the pie.
The value is relative to the graph rectangle, so that:
- 0.0 is the absolute top.
- 1.0 is the absolute bottom.
The default value is 0.5 (center).
See also horizontalPosition.
Signal Documentation
This signal is emitted when the slices specified by slices are added to the series.
Note: The corresponding handler is onAdded
.
clicked(PieSlice slice) |
This signal is emitted when the slice is clicked or tapped.
Note: The corresponding handler is onClicked
.
countChanged() |
This signal is emitted when the slice count changes.
Note: The corresponding handler is onCountChanged
.
See also count.
doubleClicked(PieSlice slice) |
This signal is emitted when the slice is double-clicked or double-tapped. This signal always occurs after clicked.
Note: The corresponding handler is onDoubleClicked
.
endAngleChanged() |
This signal is emitted when the pie end angle changes.
Note: The corresponding handler is onEndAngleChanged
.
See also endAngle.
holeSizeChanged() |
This signal is emitted when the donut hole size changes.
Note: The corresponding handler is onHoleSizeChanged
.
See also holeSize.
horizontalPositionChanged() |
This signal is emitted when the horizontal position changes.
Note: The corresponding handler is onHorizontalPositionChanged
.
See also horizontalPosition.
pieSizeChanged() |
This signal is emitted when the pie size changes.
Note: The corresponding handler is onPieSizeChanged
.
See also pieSize.
pressed(PieSlice slice) |
This signal is emitted when the user clicks or taps the slice and holds down the mouse button or gesture.
Note: The corresponding handler is onPressed
.
released(PieSlice slice) |
This signal is emitted when the user releases a previously pressed mouse button or gesture on the slice.
Note: The corresponding handler is onReleased
.
This signal is emitted when the slices specified by slices are removed from the series.
Note: The corresponding handler is onRemoved
.
startAngleChanged() |
This signal is emitted when the pie start angle changes.
Note: The corresponding handler is onStartAngleChanged
.
See also startAngle.
sumChanged() |
This signal is emitted when the sum of all slices changes.
Note: The corresponding handler is onSumChanged
.
See also sum.
verticalPositionChanged() |
This signal is emitted when the vertical position changes.
Note: The corresponding handler is onVerticalPositionChanged
.
See also verticalPosition.
Method Documentation
Adds a new slice with the label label and the value value to the pie.
Returns the slice at the position specified by index. Returns null if the index is not valid.
clear() |
Removes all slices from the pie.
Returns the first slice that has the label label. Returns null if the label is not found.
Removes the slice specified by slice from the pie. Returns true
if the removal was successful, false
otherwise.
Removes the slice specified by index from the pie. Returns true
if the removal was successful, false
otherwise.
Removes a range of slices as specified by the index and count. The call traverses over all slices even if removal of one fails.
Completely replaces all current slices with slices. The size does not need to match. Returns false if any of the PieSlice in slices is invalid.
Replaces the slice specified by oldSlice with newSlice. Returns true
if the removal was successful, false
otherwise. oldSlice is destroyed if this is successful.
Replaces the slice specified by slice from the pie at index. Returns true
if the replace was successful, false
otherwise.
Takes a single slice, specified by slice, from the series. Does not delete the slice object. Returns true
if successful.
© 2025 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.