File: IVtk_pre.cpp

package info (click to toggle)
python-ocp 7.9.3.1%2B~cs7.9.3.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 61,552 kB
  • sloc: cpp: 341,803; ansic: 3,829; python: 803; pascal: 37; makefile: 12
file content (220 lines) | stat: -rw-r--r-- 11,112 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
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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220

// pybind 11 related includes
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>

namespace py = pybind11;


// Standard Handle
#include <Standard_Handle.hxx>

// user-defined inclusion per module before includes

// includes to resolve forward declarations
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>
#include <Adaptor2d_Curve2d.hxx>
#include <Adaptor3d_Curve.hxx>
#include <Adaptor3d_Surface.hxx>

// module includes
#include <IVtk_Interface.hxx>
#include <IVtk_IShape.hxx>
#include <IVtk_IShapeData.hxx>
#include <IVtk_IShapeMesher.hxx>
#include <IVtk_IView.hxx>
#include <IVtk_Types.hxx>

// template related includes

#include "NCollection_tmpl.hxx"

#include "NCollection_tmpl.hxx"

#include "NCollection_tmpl.hxx"

#include "NCollection_tmpl.hxx"

#include "NCollection_tmpl.hxx"

#include "NCollection_tmpl.hxx"


// user-defined pre
#include "OCP_specific.inc"

// user-defined inclusion per module

// Module definiiton
void register_IVtk_enums(py::module &main_module) {


py::module m = main_module.def_submodule("IVtk", R"#()#");

// add namespaces as submodules

// user-defined inclusion per module in the body

// enums
    py::enum_<IVtk_SelectionMode>(m, "IVtk_SelectionMode",R"#(Enumeration that describes all supported selection modes for 3D shapes. SM_None means that the shape should become non-selectable. SM_Shape makes the shape selectable as a whole. Other modes activate selection of sub-shapes of corresponding types.)#")
        .value("SM_None",IVtk_SelectionMode::SM_None)
        .value("SM_Shape",IVtk_SelectionMode::SM_Shape)
        .value("SM_Vertex",IVtk_SelectionMode::SM_Vertex)
        .value("SM_Edge",IVtk_SelectionMode::SM_Edge)
        .value("SM_Wire",IVtk_SelectionMode::SM_Wire)
        .value("SM_Face",IVtk_SelectionMode::SM_Face)
        .value("SM_Shell",IVtk_SelectionMode::SM_Shell)
        .value("SM_Solid",IVtk_SelectionMode::SM_Solid)
        .value("SM_CompSolid",IVtk_SelectionMode::SM_CompSolid)
        .value("SM_Compound",IVtk_SelectionMode::SM_Compound).export_values();
    py::enum_<IVtk_MeshType>(m, "IVtk_MeshType",R"#(Enumeration that describes all supported types of mesh parts for 3D shapes.)#")
        .value("MT_Undefined",IVtk_MeshType::MT_Undefined)
        .value("MT_IsoLine",IVtk_MeshType::MT_IsoLine)
        .value("MT_FreeVertex",IVtk_MeshType::MT_FreeVertex)
        .value("MT_SharedVertex",IVtk_MeshType::MT_SharedVertex)
        .value("MT_FreeEdge",IVtk_MeshType::MT_FreeEdge)
        .value("MT_BoundaryEdge",IVtk_MeshType::MT_BoundaryEdge)
        .value("MT_SharedEdge",IVtk_MeshType::MT_SharedEdge)
        .value("MT_WireFrameFace",IVtk_MeshType::MT_WireFrameFace)
        .value("MT_ShadedFace",IVtk_MeshType::MT_ShadedFace)
        .value("MT_SeamEdge",IVtk_MeshType::MT_SeamEdge).export_values();
    py::enum_<IVtk_DisplayMode>(m, "IVtk_DisplayMode",R"#(Enumeration that describes all supported display modes for 3D shapes.)#")
        .value("DM_Wireframe",IVtk_DisplayMode::DM_Wireframe)
        .value("DM_Shading",IVtk_DisplayMode::DM_Shading).export_values();

//Python trampoline classes
    class Py_IVtk_IShape : public IVtk_IShape{
    public:
        using IVtk_IShape::IVtk_IShape;


        // public pure virtual
        IVtk_ShapeIdList GetSubIds( const IVtk_IdType theId) const  override { using return_type = IVtk_ShapeIdList;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShape,GetSubIds,theId) };


        // protected pure virtual


        // private pure virtual

    };
    class Py_IVtk_IShapeData : public IVtk_IShapeData{
    public:
        using IVtk_IShapeData::IVtk_IShapeData;


        // public pure virtual
        IVtk_PointId InsertPoint( const gp_Pnt & thePnt, const NCollection_Vec3<float> & theNorm) override { using return_type = IVtk_PointId;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeData,InsertPoint,thePnt,theNorm) };
        void InsertVertex( const IVtk_IdType theShapeID, const IVtk_PointId thePointId, const IVtk_MeshType theMeshType) override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeData,InsertVertex,theShapeID,thePointId,theMeshType) };
        void InsertLine( const IVtk_IdType theShapeID, const IVtk_PointId thePointId1, const IVtk_PointId thePointId2, const IVtk_MeshType theMeshType) override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeData,InsertLine,theShapeID,thePointId1,thePointId2,theMeshType) };
        void InsertLine( const IVtk_IdType theShapeID, const IVtk_PointIdList * thePointIds, const IVtk_MeshType theMeshType) override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeData,InsertLine,theShapeID,thePointIds,theMeshType) };
        void InsertTriangle( const IVtk_IdType theShapeID, const IVtk_PointId thePointId1, const IVtk_PointId thePointId2, const IVtk_PointId thePointId3, const IVtk_MeshType theMeshType) override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeData,InsertTriangle,theShapeID,thePointId1,thePointId2,thePointId3,theMeshType) };


        // protected pure virtual


        // private pure virtual

    };
    class Py_IVtk_IShapeMesher : public IVtk_IShapeMesher{
    public:
        using IVtk_IShapeMesher::IVtk_IShapeMesher;


        // public pure virtual


        // protected pure virtual
        void internalBuild() override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IShapeMesher,internalBuild,) };


        // private pure virtual

    };
    class Py_IVtk_IView : public IVtk_IView{
    public:
        using IVtk_IView::IVtk_IView;


        // public pure virtual
        bool IsPerspective() const  override { using return_type = bool;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,IsPerspective,) };
        double GetDistance() const  override { using return_type = double;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetDistance,) };
        void GetEyePosition(double & theX,double & theY,double & theZ) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetEyePosition,theX,theY,theZ) };
        void GetPosition(double & theX,double & theY,double & theZ) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetPosition,theX,theY,theZ) };
        void GetViewUp(double & theDx,double & theDy,double & theDz) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetViewUp,theDx,theDy,theDz) };
        void GetDirectionOfProjection(double & theDx,double & theDy,double & theDz) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetDirectionOfProjection,theDx,theDy,theDz) };
        void GetScale(double & theX,double & theY,double & theZ) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetScale,theX,theY,theZ) };
        double GetParallelScale() const  override { using return_type = double;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetParallelScale,) };
        double GetViewAngle() const  override { using return_type = double;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetViewAngle,) };
        void GetClippingRange(double & theZNear,double & theZFar) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetClippingRange,theZNear,theZFar) };
        double GetAspectRatio() const  override { using return_type = double;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetAspectRatio,) };
        void GetViewCenter(double & theX,double & theY) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetViewCenter,theX,theY) };
        void GetWindowSize(int & theX,int & theY) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetWindowSize,theX,theY) };
        bool DisplayToWorld( const gp_XY & theDisplayPnt,gp_XYZ & theWorldPnt) const  override { using return_type = bool;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,DisplayToWorld,theDisplayPnt,theWorldPnt) };
        void GetCamera(Graphic3d_Mat4d & theProj,Graphic3d_Mat4d & theOrient,Standard_Boolean & theIsOrtho) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetCamera,theProj,theOrient,theIsOrtho) };
        void GetViewport(Standard_Real & theX,Standard_Real & theY,Standard_Real & theWidth,Standard_Real & theHeight) const  override { using return_type = void;
    PYBIND11_OVERLOAD_PURE(return_type,IVtk_IView,GetViewport,theX,theY,theWidth,theHeight) };


        // protected pure virtual


        // private pure virtual

    };

// pre-register typdefs+classes (topologically sorted)
    preregister_template_NCollection_Map<IVtk_IdType>(m,"IVtk_IdTypeMap");
    py::class_<IVtk_Interface ,opencascade::handle<IVtk_Interface>  , Standard_Transient >(m,"IVtk_Interface",R"#(Base interface for visualisation component.Base interface for visualisation component.Base interface for visualisation component.)#");
    preregister_template_NCollection_List<gp_XY>(m,"IVtk_Pnt2dList");
    preregister_template_NCollection_List<IVtk_SelectionMode>(m,"IVtk_SelectionModeList");
    preregister_template_NCollection_List<IVtk_IdType>(m,"IVtk_ShapeIdList");
    preregister_template_NCollection_List<IVtk_IShape::Handle>(m,"IVtk_ShapePtrList");
    py::class_<IVtk_IShape ,opencascade::handle<IVtk_IShape> ,Py_IVtk_IShape , IVtk_Interface >(m,"IVtk_IShape",R"#(Interface for working with a shape and its sub-shapes ids.Interface for working with a shape and its sub-shapes ids.Interface for working with a shape and its sub-shapes ids.)#");
    py::class_<IVtk_IShapeData ,opencascade::handle<IVtk_IShapeData> ,Py_IVtk_IShapeData , IVtk_Interface >(m,"IVtk_IShapeData",R"#(Interface for working with triangulated data.Interface for working with triangulated data.)#");
    py::class_<IVtk_IShapeMesher ,opencascade::handle<IVtk_IShapeMesher> ,Py_IVtk_IShapeMesher , IVtk_Interface >(m,"IVtk_IShapeMesher",R"#(Interface for triangulator of 3D shapes.Interface for triangulator of 3D shapes.Interface for triangulator of 3D shapes.)#");
    py::class_<IVtk_IView ,opencascade::handle<IVtk_IView> ,Py_IVtk_IView , IVtk_Interface >(m,"IVtk_IView",R"#(Interface for obtaining view transformation parameters.Interface for obtaining view transformation parameters.Interface for obtaining view transformation parameters.)#");
    preregister_template_NCollection_DataMap<IVtk_IdType, IVtk_ShapeIdList>(m,"IVtk_SubShapeMap");

};

// user-defined post-inclusion per module

// user-defined post