File: qgsorientedbox3d.sip.in

package info (click to toggle)
qgis 3.40.11%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,183,800 kB
  • sloc: cpp: 1,595,841; python: 372,637; xml: 23,474; sh: 3,761; perl: 3,664; ansic: 2,257; sql: 2,137; yacc: 1,068; lex: 577; javascript: 540; lisp: 411; makefile: 154
file content (160 lines) | stat: -rw-r--r-- 4,500 bytes parent folder | download | duplicates (12)
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/core/geometry/qgsorientedbox3d.h                                 *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.py again   *
 ************************************************************************/






class QgsOrientedBox3D
{
%Docstring(signature="appended")
Represents a oriented (rotated) box in 3 dimensions.

.. warning::

   Non-stable API, exposed to Python for unit testing only.

.. versionadded:: 3.34
%End

%TypeHeaderCode
#include "qgsorientedbox3d.h"
%End
  public:

    QgsOrientedBox3D();
%Docstring
Constructor for a null oriented box.
%End

    QgsOrientedBox3D( const QList<double> &center, const QList< double > &halfAxes );
%Docstring
Constructor for a oriented box, with a specified center and half axes
matrix.
%End

    QgsOrientedBox3D( const QgsVector3D &center, const QList< QgsVector3D > &halfAxes );
%Docstring
Constructor for a oriented box, with a specified center and half axes
matrix.
%End

    static QgsOrientedBox3D fromBox3D( const QgsBox3D &box );
%Docstring
Constructs an oriented box from an axis-aligned bounding box.
%End

    bool operator==( const QgsOrientedBox3D &other ) const /HoldGIL/;

    bool operator!=( const QgsOrientedBox3D &other ) const /HoldGIL/;

    bool isNull() const /HoldGIL/;
%Docstring
Returns ``True`` if the box is a null box.
%End

    double centerX() const /HoldGIL/;
%Docstring
Returns the center x-coordinate.

.. seealso:: :py:func:`centerY`

.. seealso:: :py:func:`centerZ`
%End

    double centerY() const /HoldGIL/;
%Docstring
Returns the center y-coordinate.

.. seealso:: :py:func:`centerX`

.. seealso:: :py:func:`centerZ`
%End

    double centerZ() const /HoldGIL/;
%Docstring
Returns the center z-coordinate.

.. seealso:: :py:func:`centerX`

.. seealso:: :py:func:`centerY`
%End

    QgsVector3D center() const /HoldGIL/;
%Docstring
Returns the vector to the center of the box.
%End


    QList< double > halfAxesList() const /HoldGIL,PyName=halfAxes/;
%Docstring
Returns the half axes matrix;
%End

    QgsBox3D extent() const /HoldGIL/;
%Docstring
Returns the overall bounding box of the object.
%End

    QVector< QgsVector3D > corners() const /HoldGIL/;
%Docstring
Returns an array of all corners as 3D vectors.
%End

    QgsVector3D size() const /HoldGIL/;
%Docstring
Returns size of sides of the box.
%End

    QgsBox3D reprojectedExtent( const QgsCoordinateTransform &ct ) const throw( QgsCsException ) /HoldGIL/;
%Docstring
Reprojects corners of this box using the given coordinate ``transform``
and returns axis-aligned box containing reprojected corners.

:raises QgsCsException: 
%End

    QgsOrientedBox3D transformed( const QgsMatrix4x4 &transform ) const /HoldGIL/;
%Docstring
Returns box transformed by a 4x4 matrix.
%End

    bool intersects( const QgsOrientedBox3D &other ) const /HoldGIL/;
%Docstring
Returns ``True`` if the box intersects the ``other`` box.
%End

    SIP_PYOBJECT __repr__();
%MethodCode
    QString str = QStringLiteral( "<QgsOrientedBox3D([%1, %2, %3], [%4, %5, %6, %7, %8, %9, %10, %11, %12])>" )
                  .arg( sipCpp->centerX() )
                  .arg( sipCpp->centerY() )
                  .arg( sipCpp->centerZ() )
                  .arg( sipCpp->halfAxes()[0] )
                  .arg( sipCpp->halfAxes()[1] )
                  .arg( sipCpp->halfAxes()[2] )
                  .arg( sipCpp->halfAxes()[3] )
                  .arg( sipCpp->halfAxes()[4] )
                  .arg( sipCpp->halfAxes()[5] )
                  .arg( sipCpp->halfAxes()[6] )
                  .arg( sipCpp->halfAxes()[7] )
                  .arg( sipCpp->halfAxes()[8] );
    sipRes = PyUnicode_FromString( str.toUtf8().constData() );
%End

};


/************************************************************************
 * This file has been generated automatically from                      *
 *                                                                      *
 * src/core/geometry/qgsorientedbox3d.h                                 *
 *                                                                      *
 * Do not edit manually ! Edit header and run scripts/sipify.py again   *
 ************************************************************************/