csg - python

This commit is contained in:
Joachim Schoeberl 2014-12-09 12:01:39 +00:00
parent 2350e8b9d5
commit 8c4b7151a7
2 changed files with 57 additions and 24 deletions

View File

@ -143,44 +143,56 @@ void ExportCSG()
ModuleScope module("csg"); ModuleScope module("csg");
bp::class_<Point<2>> ("Point2d", bp::init<double,double>()) bp::class_<Point<2>> ("Point2d", bp::init<double,double>())
.def ("__str__", &ToString<Point<2>>)
.def(bp::self-bp::self)
.def(bp::self+Vec<2>()) .def(bp::self+Vec<2>())
.def(bp::self-Vec<2>())
; ;
bp::class_<Point<3>> ("Point3d", bp::init<double,double,double>()) bp::class_<Point<3>> ("Point3d", bp::init<double,double,double>())
.def ("__str__", &ToString<Point<3>>)
.def(bp::self-bp::self) .def(bp::self-bp::self)
.def(bp::self+Vec<3>()) .def(bp::self+Vec<3>())
.def(bp::self-Vec<3>()) .def(bp::self-Vec<3>())
; ;
bp::def ("Pnt", FunctionPointer( [] (double x, double y, double z) { return Point<3>(x,y,z); } ) ); bp::def ("Pnt", FunctionPointer
bp::def ("Pnt", FunctionPointer( [] (double x, double y) { return Point<2>(x,y); } ) ); ([](double x, double y, double z) { return Point<3>(x,y,z); }));
bp::def ("Pnt", FunctionPointer
([](double x, double y) { return Point<2>(x,y); }));
bp::class_<Vec<2>> ("Vec2d", bp::init<double,double>()) bp::class_<Vec<2>> ("Vec2d", bp::init<double,double>())
.def ("__str__", &ToString<Vec<3>>)
.def(bp::self+bp::self) .def(bp::self+bp::self)
// .def(bp::self*double()) .def(bp::self-bp::self)
.def(-bp::self)
.def(double()*bp::self) .def(double()*bp::self)
.def("Norm", &Vec<2>::Length) .def("Norm", &Vec<2>::Length)
; ;
bp::class_<Vec<3>> ("Vec3d", bp::init<double,double,double>()) bp::class_<Vec<3>> ("Vec3d", bp::init<double,double,double>())
.def ("__str__", &ToString<Vec<3>>)
.def(bp::self+bp::self) .def(bp::self+bp::self)
// .def(bp::self*double()) .def(bp::self-bp::self)
.def(-bp::self)
.def(double()*bp::self) .def(double()*bp::self)
.def("Norm", &Vec<3>::Length) .def("Norm", &Vec<3>::Length)
; ;
bp::def ("Vec", FunctionPointer( [] (double x, double y, double z) { return Vec<3>(x,y,z); } ) ); bp::def ("Vec", FunctionPointer
bp::def ("Vec", FunctionPointer( [] (double x, double y) { return Vec<2>(x,y); } ) ); ([] (double x, double y, double z) { return Vec<3>(x,y,z); }));
bp::def ("Vec", FunctionPointer
([] (double x, double y) { return Vec<2>(x,y); }));
bp::class_<SPSolid, shared_ptr<SPSolid>, boost::noncopyable> ("Solid", bp::no_init) bp::class_<SPSolid, shared_ptr<SPSolid>, boost::noncopyable> ("Solid", bp::no_init)
.def ("__str__", &ToString<SPSolid>) .def ("__str__", &ToString<SPSolid>)
.def ("__add__", FunctionPointer( [] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other ) { return make_shared<SPSolid> (SPSolid::UNION, self, other); } ) ) .def ("__add__", FunctionPointer( [] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other) { return make_shared<SPSolid> (SPSolid::UNION, self, other); }))
.def ("__mul__", FunctionPointer( [] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other ) { return make_shared<SPSolid> (SPSolid::SECTION, self, other); } ) ) .def ("__mul__", FunctionPointer( [] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other) { return make_shared<SPSolid> (SPSolid::SECTION, self, other); }))
.def ("__sub__", FunctionPointer( [] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other ) .def ("__sub__", FunctionPointer
{ return make_shared<SPSolid> (SPSolid::SECTION, self, make_shared<SPSolid> (SPSolid::SUB, other, nullptr)); } ) ) ([] ( shared_ptr<SPSolid> self, shared_ptr<SPSolid> other)
// .def ("__neg__", FunctionPointer( [] ( shared_ptr<SPSolid> self ) { return make_shared<SPSolid> (SPSolid::SUB, self); } ) ) COMPLEMENT? { return make_shared<SPSolid> (SPSolid::SECTION, self,
make_shared<SPSolid> (SPSolid::SUB, other, nullptr)); }))
.def ("bc", FunctionPointer([](shared_ptr<SPSolid> & self, int nr) -> shared_ptr<SPSolid> .def ("bc", FunctionPointer([](shared_ptr<SPSolid> & self, int nr) -> shared_ptr<SPSolid>
{ self->SetBC(nr); return self; })) { self->SetBC(nr); return self; }))
@ -189,14 +201,15 @@ void ExportCSG()
.def ("mat", FunctionPointer([](shared_ptr<SPSolid> & self, string mat) -> shared_ptr<SPSolid> .def ("mat", FunctionPointer([](shared_ptr<SPSolid> & self, string mat) -> shared_ptr<SPSolid>
{ self->SetMaterial(mat); return self; })) { self->SetMaterial(mat); return self; }))
.def ("mat", &SPSolid::GetMaterial) .def ("mat", &SPSolid::GetMaterial)
.def("col", FunctionPointer([](shared_ptr<SPSolid> & self, bp::list rgb) -> shared_ptr<SPSolid> .def("col", FunctionPointer([](shared_ptr<SPSolid> & self, bp::list rgb) -> shared_ptr<SPSolid>
{ {
bp::extract<double> red(rgb[0]); bp::extract<double> red(rgb[0]);
bp::extract<double> green(rgb[1]); bp::extract<double> green(rgb[1]);
bp::extract<double> blue(rgb[2]); bp::extract<double> blue(rgb[2]);
self->SetColor(red(),green(),blue()); self->SetColor(red(),green(),blue());
return self; })) return self;
.def("transp", FunctionPointer([](shared_ptr<SPSolid> & self)->shared_ptr < SPSolid > { self->SetTransparent(); return self; })) }))
.def("transp", FunctionPointer([](shared_ptr<SPSolid> & self)->shared_ptr < SPSolid > { self->SetTransparent(); return self; }))
; ;
bp::def ("Sphere", FunctionPointer([](Point<3> c, double r) bp::def ("Sphere", FunctionPointer([](Point<3> c, double r)
@ -281,8 +294,8 @@ void ExportCSG()
solid->GiveUpOwner(); solid->GiveUpOwner();
int tlonr = self.SetTopLevelObject (solid->GetSolid()); int tlonr = self.SetTopLevelObject (solid->GetSolid());
self.GetTopLevelObject(tlonr) -> SetMaterial(solid->GetMaterial()); self.GetTopLevelObject(tlonr) -> SetMaterial(solid->GetMaterial());
self.GetTopLevelObject(tlonr) -> SetRGB(solid->GetRed(),solid->GetGreen(),solid->GetBlue()); self.GetTopLevelObject(tlonr) -> SetRGB(solid->GetRed(),solid->GetGreen(),solid->GetBlue());
self.GetTopLevelObject(tlonr)->SetTransparent(solid->IsTransparent()); self.GetTopLevelObject(tlonr)->SetTransparent(solid->IsTransparent());
})) }))
.def("CloseSurfaces", FunctionPointer .def("CloseSurfaces", FunctionPointer
@ -321,6 +334,25 @@ void ExportCSG()
return dummy; return dummy;
})) }))
; ;
bp::def("Save", FunctionPointer
([](const Mesh & self, const string & filename, const CSGeometry & geom)
{
ostream * outfile;
if (filename.substr (filename.length()-3, 3) == ".gz")
outfile = new ogzstream (filename.c_str());
else
outfile = new ofstream (filename.c_str());
self.Save (*outfile);
*outfile << endl << endl << "endmesh" << endl << endl;
geom.SaveToMeshFile (*outfile);
delete outfile;
}))
;
bp::def("ZRefinement", FunctionPointer bp::def("ZRefinement", FunctionPointer
([](Mesh & mesh, CSGeometry & geom) ([](Mesh & mesh, CSGeometry & geom)
{ {

View File

@ -15,3 +15,4 @@ exportNeutral.Export (m1, "shaft.mesh")
Save (m1, "mesh.vol", geo)