Custom Chart Example▲
Running the Example▲
To run the example from Qt Creator, open the Welcome mode and select the example from Examples. For more information, visit Building and Running an Example.
Customizing Charts▲
We begin by creating a simple line series and a chart object.
QLineSeries *
series =
new
QLineSeries();
*
series &
lt;&
lt; QPointF(0
, 6
) &
lt;&
lt; QPointF(9
, 4
) &
lt;&
lt; QPointF(15
, 20
) &
lt;&
lt; QPointF(25
, 12
) &
lt;&
lt; QPointF(29
, 26
);
QChart *
chart =
new
QChart();
chart-&
gt;legend()-&
gt;hide();
chart-&
gt;addSeries(series);
First we customize the series and the chart's title and background.
// Customize series
QPen pen(QRgb(0xfdb157
));
pen.setWidth(5
);
series-&
gt;setPen(pen);
// Customize chart title
QFont font;
font.setPixelSize(18
);
chart-&
gt;setTitleFont(font);
chart-&
gt;setTitleBrush(QBrush(Qt::
white));
chart-&
gt;setTitle("Customchart example"
);
// Customize chart background
QLinearGradient backgroundGradient;
backgroundGradient.setStart(QPointF(0
, 0
));
backgroundGradient.setFinalStop(QPointF(0
, 1
));
backgroundGradient.setColorAt(0.0
, QRgb(0xd2d0d1
));
backgroundGradient.setColorAt(1.0
, QRgb(0x4c4547
));
backgroundGradient.setCoordinateMode(QGradient::
ObjectBoundingMode);
chart-&
gt;setBackgroundBrush(backgroundGradient);
// Customize plot area background
QLinearGradient plotAreaGradient;
plotAreaGradient.setStart(QPointF(0
, 1
));
plotAreaGradient.setFinalStop(QPointF(1
, 0
));
plotAreaGradient.setColorAt(0.0
, QRgb(0x555555
));
plotAreaGradient.setColorAt(1.0
, QRgb(0x55aa55
));
plotAreaGradient.setCoordinateMode(QGradient::
ObjectBoundingMode);
chart-&
gt;setPlotAreaBackgroundBrush(plotAreaGradient);
chart-&
gt;setPlotAreaBackgroundVisible(true
);
Then we customize the axes.
QCategoryAxis *
axisX =
new
QCategoryAxis();
QCategoryAxis *
axisY =
new
QCategoryAxis();
// Customize axis label font
QFont labelsFont;
labelsFont.setPixelSize(12
);
axisX-&
gt;setLabelsFont(labelsFont);
axisY-&
gt;setLabelsFont(labelsFont);
// Customize axis colors
QPen axisPen(QRgb(0xd18952
));
axisPen.setWidth(2
);
axisX-&
gt;setLinePen(axisPen);
axisY-&
gt;setLinePen(axisPen);
// Customize axis label colors
QBrush axisBrush(Qt::
white);
axisX-&
gt;setLabelsBrush(axisBrush);
axisY-&
gt;setLabelsBrush(axisBrush);
// Customize grid lines and shades
axisX-&
gt;setGridLineVisible(false
);
axisY-&
gt;setGridLineVisible(false
);
axisY-&
gt;setShadesPen(Qt::
NoPen);
axisY-&
gt;setShadesBrush(QBrush(QColor(0x99
, 0xcc
, 0xcc
, 0x55
)));
axisY-&
gt;setShadesVisible(true
);
Then the axis label values and ranges. Once the axes are ready, we set them to be used by the chart.
axisX-&
gt;append("low"
, 10
);
axisX-&
gt;append("optimal"
, 20
);
axisX-&
gt;append("high"
, 30
);
axisX-&
gt;setRange(0
, 30
);
axisY-&
gt;append("slow"
, 10
);
axisY-&
gt;append("med"
, 20
);
axisY-&
gt;append("fast"
, 30
);
axisY-&
gt;setRange(0
, 30
);
chart-&
gt;addAxis(axisX, Qt::
AlignBottom);
chart-&
gt;addAxis(axisY, Qt::
AlignLeft);
series-&
gt;attachAxis(axisX);
series-&
gt;attachAxis(axisY);
Finally, we create a view containing the chart.
QChartView *
chartView =
new
QChartView(chart);
chartView-&
gt;setRenderHint(QPainter::
Antialiasing);
Now we are ready to show the chart on a main window.
QMainWindow window;
window.setCentralWidget(chartView);
window.resize(400
, 300
);
window.show();