File: KoChartModel.h

package info (click to toggle)
calligra 1%3A25.04.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 309,164 kB
  • sloc: cpp: 667,890; xml: 126,105; perl: 2,724; python: 2,497; yacc: 1,817; ansic: 1,326; sh: 1,223; lex: 1,107; javascript: 495; makefile: 24
file content (73 lines) | stat: -rw-r--r-- 1,858 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* This file is part of the KDE project

   SPDX-FileCopyrightText: 2008 Johannes Simon <johannes.simon@gmail.com>

   SPDX-License-Identifier: LGPL-2.0-only
*/

#ifndef KO_CHART_MODEL
#define KO_CHART_MODEL

#include <QHash>
#include <QVector>
#include <QtPlugin>

class QRect;

namespace KoChart
{

/**
 * Item data role used to retrieve the string representing the data area
 * of a row or a column.
 *
 * Example:
 * The area string of the 3rd row would be retrieved with this line of code:
 * QString area = model->headerData( 2, Qt::Vertical, SECTION_AREA_ROLE );
 * ("$Table2.$D9:$D13", for instance)
 */
const int SECTION_AREA_ROLE = 32;

/**
 * Item data role used to retrieve the string representing the data cell
 * of a header. The header data usually is a name for the dataset.
 *
 * Example:
 * The area string of the name of the data series that has its y-values
 * in the 5th column could be retrieved with this line of code:
 * QString cell = model->headerData( 4, Qt::Horizontal, HEADER_AREA_ROLE );
 * ("$Table1.$C8", for instance)
 */
const int HEADER_AREA_ROLE = 33;

/**
 * The ChartModel class implements a model that can be filled and
 * passed on to KChart to provide the data used within the chart.
 */
class ChartModel
{
public:
    virtual ~ChartModel() = default;

    /**
     * \return the cell region in ranges ordered by sheet name
     */
    virtual QHash<QString, QVector<QRect>> cellRegion() const = 0;

    /**
     * Sets the cell region.
     * \return \c true on success
     */
    virtual bool setCellRegion(const QString &regionName) = 0;

    /**
     * \return \c true if the cell region is valid
     */
    virtual bool isCellRegionValid(const QString &regionName) const = 0;
};

} // Namespace KoChart

Q_DECLARE_INTERFACE(KoChart::ChartModel, "org.calligra.KoChart.ChartModel:1.0")

#endif // KO_CHART_MODEL