FeatureGeometrySet.cpp

Go to the documentation of this file.
00001 /***************************************************************************
00002  *   Copyright (c) Jürgen Riegel          (juergen.riegel@web.de) 2010     *
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 #include "PreCompiled.h"
00025 #ifndef _PreComp_
00026 #endif
00027 
00028 #include "Geometry.h"
00029 
00030 #include "FeatureGeometrySet.h"
00031 
00032 
00033 using namespace Part;
00034 
00035 
00036 PROPERTY_SOURCE(Part::FeatureGeometrySet, Part::Feature)
00037 
00038 
00039 FeatureGeometrySet::FeatureGeometrySet()
00040 {
00041     ADD_PROPERTY(GeometrySet,(0));
00042 }
00043 
00044 
00045 App::DocumentObjectExecReturn *FeatureGeometrySet::execute(void)
00046 {
00047     TopoShape result;
00048 
00049     const std::vector<Geometry*> &Geoms = GeometrySet.getValues();
00050 
00051     bool first = true;
00052     for(std::vector<Geometry*>::const_iterator it=Geoms.begin();it!=Geoms.end();++it){
00053         TopoDS_Shape sh = (*it)->toShape();
00054         if (first) {
00055             first = false;
00056             result._Shape = sh;
00057         }
00058         else {
00059             result._Shape = result.fuse(sh);
00060         }
00061     }
00062     
00063     Shape.setValue(result);
00064 
00065     return App::DocumentObject::StdReturn;
00066 }

Generated on Wed Nov 23 19:00:11 2011 for FreeCAD by  doxygen 1.6.1