1 /****************************************************************************
2 **
3 ** Copyright (C) 2016 The Qt Company Ltd.
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the Qt Charts module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:GPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** GNU General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU
19 ** General Public License version 3 or (at your option) any later version
20 ** approved by the KDE Free Qt Foundation. The licenses are as published by
21 ** the Free Software Foundation and appearing in the file LICENSE.GPL3
22 ** included in the packaging of this file. Please review the following
23 ** information to ensure the GNU General Public License requirements will
24 ** be met: https://www.gnu.org/licenses/gpl-3.0.html.
25 **
26 ** $QT_END_LICENSE$
27 **
28 ****************************************************************************/
29 
30 #include "xyseriesiodevice.h"
31 
32 #include <QtCharts/QXYSeries>
33 
XYSeriesIODevice(QXYSeries * series,QObject * parent)34 XYSeriesIODevice::XYSeriesIODevice(QXYSeries *series, QObject *parent) :
35     QIODevice(parent),
36     m_series(series)
37 {
38 }
39 
readData(char * data,qint64 maxSize)40 qint64 XYSeriesIODevice::readData(char *data, qint64 maxSize)
41 {
42     Q_UNUSED(data)
43     Q_UNUSED(maxSize)
44     return -1;
45 }
46 
writeData(const char * data,qint64 maxSize)47 qint64 XYSeriesIODevice::writeData(const char *data, qint64 maxSize)
48 {
49     static const int resolution = 4;
50 
51     if (m_buffer.isEmpty()) {
52         m_buffer.reserve(sampleCount);
53         for (int i = 0; i < sampleCount; ++i)
54             m_buffer.append(QPointF(i, 0));
55     }
56 
57     int start = 0;
58     const int availableSamples = int(maxSize) / resolution;
59     if (availableSamples < sampleCount) {
60         start = sampleCount - availableSamples;
61         for (int s = 0; s < start; ++s)
62             m_buffer[s].setY(m_buffer.at(s + availableSamples).y());
63     }
64 
65     for (int s = start; s < sampleCount; ++s, data += resolution)
66         m_buffer[s].setY(qreal(uchar(*data) -128) / qreal(128));
67 
68     m_series->replace(m_buffer);
69     return (sampleCount - start) * resolution;
70 }
71