Class hierarchy   Compound list   Header files   Member list  

Arc.h

This is the verbatim text of the Arc.h include file.
/**************************************************************************\
 * 
 *  FILE: Arc.h
 *
 *  This source file is part of DIME.
 *  Copyright (C) 1998-1999 by Systems In Motion.  All rights reserved.
 *
 *  This library is free software; you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License, version 2, as
 *  published by the Free Software Foundation.  DO NOT MISTAKE THIS LICENSE
 *  FOR THE GNU LGPL LICENSE.
 *
 *  This library is distributed in the hope that it will be useful, but
 *  WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  General Public License (the accompanying file named COPYING) for more
 *  details.
 *
 *  You should have received a copy of the GNU General Public License along
 *  with this program; if not, write to the Free Software Foundation, Inc.,
 *  59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 *
 **************************************************************************
 *
 *  If you need DIME for commercial purposes, you can contact Systems In
 *  Motion about acquiring a commercial license.
 *
 *  Systems In Motion                                   http://www.sim.no/
 *  Prof. Brochs gate 6                                       sales@sim.no
 *  N-7030 Trondheim                                   Voice: +47 73540378
 *  NORWAY                                               Fax: +47 73943861
 *
\**************************************************************************/

#ifndef DIME_ARC_H
#define DIME_ARC_H
  
#include <dime/Basic.h>
#include <dime/entities/ExtrusionEntity.h>
#include <dime/util/Linear.h>

class dimeArc : public dimeExtrusionEntity
{
public:
  dimeArc();

  void setCenter(const dimeVec3f &c);
  void getCenter(dimeVec3f &c) const;
  void setRadius(const dxfdouble r);
  dxfdouble getRadius() const;
  void setStartAngle(const dxfdouble a);
  dxfdouble getStartAngle() const;
  void setEndAngle(const dxfdouble a);
  dxfdouble getEndAngle() const;
  void setThickness(const dxfdouble t); 
  dxfdouble getThickness() const;
  void setExtrusionDir(const dimeVec3f &e);
  void getExtrusionDir(dimeVec3f &e) const;
  
  virtual bool getRecord(const int groupcode,
			 dimeParam &param,
			 const int index = 0) const;
  virtual const char *getEntityName() const;

  virtual dimeEntity *copy(dimeModel * const model) const;
  
  virtual void print() const;
  virtual bool write(dimeOutput * const out);
  virtual int typeId() const;
  virtual int countRecords() const;
  
  virtual GeometryType extractGeometry(dimeArray <dimeVec3f> &verts,
				       dimeArray <int> &indices,
				       dimeVec3f &extrusionDir,
				       float &thickness);
  
protected:
  virtual bool handleRecord(const int groupcode, 
			    const dimeParam &param,
                            dimeMemHandler * const memhandler);
    
private:
  dimeVec3f center;
  dxfdouble radius;
  dxfdouble startAngle;
  dxfdouble endAngle;

}; // class dimeArc

//
// inline methods
//

inline void 
dimeArc::setCenter(const dimeVec3f &c)
{
  this->center = c;
}

inline void 
dimeArc::getCenter(dimeVec3f &c) const
{
  c = this->center;
}

inline void 
dimeArc::setRadius(const dxfdouble r)
{
  this->radius = r;
}

inline dxfdouble 
dimeArc::getRadius() const
{
  return this->radius;
}

inline void 
dimeArc::setStartAngle(const dxfdouble a)
{
  this->startAngle = a;
}

inline dxfdouble 
dimeArc::getStartAngle() const
{
  return this->startAngle;
}

inline void 
dimeArc::setEndAngle(const dxfdouble a)
{
  this->endAngle = a;
}

inline dxfdouble 
dimeArc::getEndAngle() const
{
  return this->endAngle;
}

inline void 
dimeArc::setThickness(const dxfdouble t)
{
  this->thickness = t;
}

inline dxfdouble 
dimeArc::getThickness() const
{
  return this->thickness;
}

inline void 
dimeArc::setExtrusionDir(const dimeVec3f &e)
{
  this->extrusionDir = e;
}

inline void 
dimeArc::getExtrusionDir(dimeVec3f &e) const
{
  e = this->extrusionDir;
}

#endif // ! DIME_ARC_H

/******************************************************************** EOF */

Copyright © 1998-1999, Systems In Motion <sales@sim.no>. All rights reserved.
System documentation was generated using doxygen.