00001 /*************************************************************************** 00002 * Copyright (c) Jürgen Riegel (juergen.riegel@web.de) 2008 * 00003 * * 00004 * This file is part of the FreeCAD CAx development system. * 00005 * * 00006 * This library is free software; you can redistribute it and/or * 00007 * modify it under the terms of the GNU Library General Public * 00008 * License as published by the Free Software Foundation; either * 00009 * version 2 of the License, or (at your option) any later version. * 00010 * * 00011 * This library is distributed in the hope that it will be useful, * 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00014 * GNU Library General Public License for more details. * 00015 * * 00016 * You should have received a copy of the GNU Library General Public * 00017 * License along with this library; see the file COPYING.LIB. If not, * 00018 * write to the Free Software Foundation, Inc., 59 Temple Place, * 00019 * Suite 330, Boston, MA 02111-1307, USA * 00020 * * 00021 ***************************************************************************/ 00022 00023 00024 #ifndef Fem_PropertyFemMesh_H 00025 #define Fem_PropertyFemMesh_H 00026 00027 #include "FemMesh.h" 00028 #include <App/PropertyGeo.h> 00029 #include <Base/BoundBox.h> 00030 00031 namespace Fem 00032 { 00033 00034 00038 class AppFemExport PropertyFemMesh : public App::PropertyComplexGeoData 00039 { 00040 TYPESYSTEM_HEADER(); 00041 00042 public: 00043 PropertyFemMesh(); 00044 ~PropertyFemMesh(); 00045 00048 void setValuePtr(FemMesh* mesh); 00050 void setValue(const FemMesh&); 00052 const FemMesh &getValue(void) const; 00053 const Data::ComplexGeoData* getComplexData() const; 00055 00056 00060 Base::BoundBox3d getBoundingBox() const; 00061 void transformGeometry(const Base::Matrix4D &rclMat); 00062 void getFaces(std::vector<Base::Vector3d> &Points, 00063 std::vector<Data::ComplexGeoData::Facet> &Topo, 00064 float Accuracy, uint16_t flags=0) const; 00066 00069 PyObject* getPyObject(void); 00070 void setPyObject(PyObject *value); 00072 00075 void Save (Base::Writer &writer) const; 00076 void Restore(Base::XMLReader &reader); 00077 void SaveDocFile (Base::Writer &writer) const; 00078 void RestoreDocFile(Base::Reader &reader); 00079 00080 App::Property *Copy(void) const; 00081 void Paste(const App::Property &from); 00082 unsigned int getMemSize (void) const; 00084 00085 private: 00086 Base::Reference<FemMesh> _FemMesh; 00087 }; 00088 00089 00090 } //namespace Fem 00091 00092 00093 #endif // PROPERTYTOPOSHAPE_H