QGIS API Documentation  2.11.0-Master
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
util.h
Go to the documentation of this file.
1 /*
2  * libpal - Automated Placement of Labels Library
3  *
4  * Copyright (C) 2008 Maxence Laurent, MIS-TIC, HEIG-VD
5  * University of Applied Sciences, Western Switzerland
6  * http://www.hes-so.ch
7  *
8  * Contact:
9  * maxence.laurent <at> heig-vd <dot> ch
10  * or
11  * eric.taillard <at> heig-vd <dot> ch
12  *
13  * This file is part of libpal.
14  *
15  * libpal is free software: you can redistribute it and/or modify
16  * it under the terms of the GNU General Public License as published by
17  * the Free Software Foundation, either version 3 of the License, or
18  * (at your option) any later version.
19  *
20  * libpal is distributed in the hope that it will be useful,
21  * but WITHOUT ANY WARRANTY; without even the implied warranty of
22  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23  * GNU General Public License for more details.
24  *
25  * You should have received a copy of the GNU General Public License
26  * along with libpal. If not, see <http://www.gnu.org/licenses/>.
27  *
28  */
29 
30 #ifndef _UTIL_H
31 #define _UTIL_H
32 
33 #include "pal.h"
34 #include "rtree.hpp"
35 #include "pointset.h"
36 #include "qgsgeometry.h"
37 
38 namespace pal
39 {
40 
41  class LabelPosition;
42  class Layer;
43  class FeaturePart;
44 
45  QLinkedList<const GEOSGeometry*> * unmulti( const GEOSGeometry* the_geom );
46 
50  class Feats
51  {
52  public:
54  : feature( 0 )
55  , shape( 0 )
56  {}
57 
60  double priority;
62  };
63 
64 
66  {
67  int feat;
68  int old_label;
69  int new_label;
70  } ElemTrans;
71 
72  struct Point
73  {
74  double x, y;
75  };
76 
77 #define EPSILON 1e-9
78 
85  void sort( void** items, int N, bool ( *greater )( void *l, void *r ) );
86 
87 } // namespace
88 
89 #endif
FeaturePart * feature
Definition: util.h:58
struct pal::_elementary_transformation ElemTrans
Feats()
Definition: util.h:53
PointSet * shape
Definition: util.h:59
QLinkedList< const GEOSGeometry * > * unmulti(const GEOSGeometry *the_geom)
Definition: util.cpp:113
double x
Definition: util.h:74
For usage in problem solving algorithm.
Definition: util.h:50
double priority
Definition: util.h:60
Main class to handle feature.
Definition: feature.h:203
double y
Definition: util.h:74
void sort(void **items, int N, bool(*greater)(void *l, void *r))
Sort an array of pointers.
Definition: util.cpp:61
QList< LabelPosition * > lPos
Definition: util.h:61