##// END OF EJS Templates
Fix debug-and-release build...
Fix debug-and-release build Charts is part of the Qt release and there is no need to do magic hacks to install the qmldir file. This was supposed to help running examples separately, but we assume that the lib is shipped with Qt proper. The problem was that the qmldir file would be simultaneously copied into the same location twice which will fail on Windows. Change-Id: I4d765c18367f7985c7dbfadbc7ddae78ce24f398 Reviewed-by: Miikka Heikkinen <miikka.heikkinen@theqtcompany.com> Reviewed-by: Jędrzej Nowacki <jedrzej.nowacki@theqtcompany.com> Reviewed-by: Titta Heikkala <titta.heikkala@theqtcompany.com>

File last commit:

r2845:ae12522d475c
r2853:a801e78fb8d1
Show More
declarativepieseries.cpp
155 lines | 4.5 KiB | text/x-c | CppLexer
/ src / chartsqml2 / declarativepieseries.cpp
/******************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd.
** Contact: http://www.qt.io/licensing/
**
** This file is part of the Qt Charts module.
**
** $QT_BEGIN_LICENSE:COMM$
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see http://www.qt.io/terms-conditions. For further
** information use the contact form at http://www.qt.io/contact-us.
**
** $QT_END_LICENSE$
**
******************************************************************************/
#include "declarativepieseries.h"
#include <QtCharts/QPieSlice>
#include <QtCharts/QVPieModelMapper>
#include <QtCharts/QHPieModelMapper>
QT_CHARTS_BEGIN_NAMESPACE
DeclarativePieSlice::DeclarativePieSlice(QObject *parent)
: QPieSlice(parent)
{
connect(this, SIGNAL(brushChanged()), this, SLOT(handleBrushChanged()));
}
QString DeclarativePieSlice::brushFilename() const
{
return m_brushFilename;
}
void DeclarativePieSlice::setBrushFilename(const QString &brushFilename)
{
QImage brushImage(brushFilename);
if (QPieSlice::brush().textureImage() != brushImage) {
QBrush brush = QPieSlice::brush();
brush.setTextureImage(brushImage);
QPieSlice::setBrush(brush);
m_brushFilename = brushFilename;
m_brushImage = brushImage;
emit brushFilenameChanged(brushFilename);
}
}
void DeclarativePieSlice::handleBrushChanged()
{
// If the texture image of the brush has changed along the brush
// the brush file name needs to be cleared.
if (!m_brushFilename.isEmpty() && QPieSlice::brush().textureImage() != m_brushImage) {
m_brushFilename.clear();
emit brushFilenameChanged(QString(""));
}
}
// Declarative pie series =========================================================================
DeclarativePieSeries::DeclarativePieSeries(QQuickItem *parent) :
QPieSeries(parent)
{
connect(this, SIGNAL(added(QList<QPieSlice*>)), this, SLOT(handleAdded(QList<QPieSlice*>)));
connect(this, SIGNAL(removed(QList<QPieSlice*>)), this, SLOT(handleRemoved(QList<QPieSlice*>)));
}
void DeclarativePieSeries::classBegin()
{
}
void DeclarativePieSeries::componentComplete()
{
foreach (QObject *child, children()) {
if (qobject_cast<QPieSlice *>(child)) {
QPieSeries::append(qobject_cast<QPieSlice *>(child));
} else if (qobject_cast<QVPieModelMapper *>(child)) {
QVPieModelMapper *mapper = qobject_cast<QVPieModelMapper *>(child);
mapper->setSeries(this);
} else if (qobject_cast<QHPieModelMapper *>(child)) {
QHPieModelMapper *mapper = qobject_cast<QHPieModelMapper *>(child);
mapper->setSeries(this);
}
}
}
QQmlListProperty<QObject> DeclarativePieSeries::seriesChildren()
{
return QQmlListProperty<QObject>(this, 0, &DeclarativePieSeries::appendSeriesChildren ,0,0,0);
}
void DeclarativePieSeries::appendSeriesChildren(QQmlListProperty<QObject> * list, QObject *element)
{
// Empty implementation; the children are parsed in componentComplete instead
Q_UNUSED(list);
Q_UNUSED(element);
}
QPieSlice *DeclarativePieSeries::at(int index)
{
QList<QPieSlice *> sliceList = slices();
if (index >= 0 && index < sliceList.count())
return sliceList[index];
return 0;
}
QPieSlice *DeclarativePieSeries::find(QString label)
{
foreach (QPieSlice *slice, slices()) {
if (slice->label() == label)
return slice;
}
return 0;
}
DeclarativePieSlice *DeclarativePieSeries::append(QString label, qreal value)
{
DeclarativePieSlice *slice = new DeclarativePieSlice(this);
slice->setLabel(label);
slice->setValue(value);
if (QPieSeries::append(slice))
return slice;
delete slice;
return 0;
}
bool DeclarativePieSeries::remove(QPieSlice *slice)
{
return QPieSeries::remove(slice);
}
void DeclarativePieSeries::clear()
{
QPieSeries::clear();
}
void DeclarativePieSeries::handleAdded(QList<QPieSlice *> slices)
{
foreach (QPieSlice *slice, slices)
emit sliceAdded(slice);
}
void DeclarativePieSeries::handleRemoved(QList<QPieSlice *> slices)
{
foreach (QPieSlice *slice, slices)
emit sliceRemoved(slice);
}
#include "moc_declarativepieseries.cpp"
QT_CHARTS_END_NAMESPACE