PartFeatureReference.cpp

Go to the documentation of this file.
00001 /***************************************************************************
00002  *   Copyright (c) Jürgen Riegel          (juergen.riegel@web.de) 2002     *
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 
00026 #ifndef _PreComp_
00027 # include <gp_Trsf.hxx>
00028 # include <gp_Ax1.hxx>
00029 #endif
00030 
00031 
00032 //#include <strstream>
00033 //#include <Base/Console.h>
00034 //#include <Base/Writer.h>
00035 //#include <Base/Reader.h>
00036 //#include <Base/Exception.h>
00037 //#include <Base/FileInfo.h>
00038 //#include <Base/Stream.h>
00039 #include <Base/Placement.h>
00040 #include <Base/Rotation.h>
00041 
00042 #include "PartFeatureReference.h"
00043 
00044 using namespace Part;
00045 
00046 
00047 PROPERTY_SOURCE(Part::FeatureReference, App::GeoFeature)
00048 
00049 
00050 FeatureReference::FeatureReference(void) 
00051 {
00052     ADD_PROPERTY(Reference, (0));
00053 }
00054 
00055 FeatureReference::~FeatureReference()
00056 {
00057 }
00058 
00059 short FeatureReference::mustExecute(void) const
00060 {
00061     return GeoFeature::mustExecute();
00062 }
00063 
00064 App::DocumentObjectExecReturn *FeatureReference::execute(void)
00065 {
00066     return App::DocumentObject::StdReturn;
00067 }
00068 
00069 TopLoc_Location FeatureReference::getLocation() const
00070 {
00071     Base::Placement pl = this->Placement.getValue();
00072     Base::Rotation rot(pl.getRotation());
00073     Base::Vector3d axis;
00074     double angle;
00075     rot.getValue(axis, angle);
00076     gp_Trsf trf;
00077     trf.SetRotation(gp_Ax1(gp_Pnt(), gp_Dir(axis.x, axis.y, axis.z)), angle);
00078     trf.SetTranslationPart(gp_Vec(pl.getPosition().x,pl.getPosition().y,pl.getPosition().z));
00079     return TopLoc_Location(trf);
00080 }
00081 
00082 // ---------------------------------------------------------
00083 
00084 

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