File: SvmAbstractBackend.h

package info (click to toggle)
calligra 1%3A3.2.1%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 260,432 kB
  • sloc: cpp: 650,911; xml: 27,662; python: 6,044; perl: 2,724; yacc: 1,817; ansic: 1,325; sh: 1,277; lex: 1,107; ruby: 1,010; javascript: 495; makefile: 24
file content (112 lines) | stat: -rw-r--r-- 3,002 bytes parent folder | download | duplicates (2)
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
  Copyright 2009 Inge Wallin <inge@lysator.liu.se>

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either 
  version 2.1 of the License, or (at your option) any later version.
  
  This library is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public 
  License along with this library.  If not, see <http://www.gnu.org/licenses/>.
*/

#ifndef SVMABSTRACTBACKEND_H
#define SVMABSTRACTBACKEND_H

#include "kovectorimage_export.h"

#include "SvmEnums.h"
#include "SvmStructs.h"
#include "SvmGraphicsContext.h"


class QPoint;
class QRect;
class QPolygon;
class QString;


/**
   \file

   Primary definitions for SVM output backend
*/

/**
   Namespace for StarView Metafile (SVM) classes
*/
namespace Libsvm
{

/**
    Abstract output strategy for SVM Parser
*/
class KOVECTORIMAGE_EXPORT SvmAbstractBackend
{
public:
    SvmAbstractBackend() {};
    virtual ~SvmAbstractBackend() {};

    /**
       Initialisation routine

       \param header the SVM Header record
    */
    virtual void init(const SvmHeader &header) = 0;

    /**
       Cleanup routine

       This function is called when the parsing is done.  Any
       initializations that are done in init() can be undone here if
       necessary.
    */
    virtual void cleanup() = 0;

    /**
       Close-out routine
    */
    virtual void eof() = 0;

    virtual void rect(SvmGraphicsContext &context, const QRect &rect) = 0;

    /**
       Handler META_POLYLINE_ACTION

       This action type specifies how to output a multi-segment line
       (unfilled polyline).

       \param context the graphics context to be used when drawing the polyline
       \param polyline the sequence of points that describe the line

       \note the line is not meant to be closed nor filled, i.e. do
       not connect the last point to the first point.
    */
    virtual void polyLine(SvmGraphicsContext &context, const QPolygon &polyline) = 0;

    /**
       This action type specifies how to output a multi-segment line
       (unfilled polygon).

       \param context the graphics context to be used when drawing the polygon
       \param polygon the sequence of points that describe the polygon
    */
    virtual void polygon(SvmGraphicsContext &context, const QPolygon &polygon) = 0;

    virtual void polyPolygon(SvmGraphicsContext &context, const QList<QPolygon> &polyPolygon) = 0;

    virtual void textArray(SvmGraphicsContext &context,
                           const QPoint &point, const QString &string,
                           quint16 startIndex, quint16 len,
                           quint32 dxArrayLen, qint32 *dxArray) = 0;
};


}

#endif