20#ifndef _OPENMBV_RIGIDSPINEEXTRUSION_H_
21#define _OPENMBV_RIGIDSPINEEXTRUSION_H_
23#include <openmbvcppinterface/rigidbody.h>
24#include <openmbvcppinterface/polygonpoint.h>
41 void setContour(
const std::shared_ptr<std::vector<std::shared_ptr<PolygonPoint> > > &contour_) {
contour = contour_; }
43 std::shared_ptr<std::vector<std::shared_ptr<PolygonPoint> > > getContour() {
return contour; }
45 void setCounterClockWise(
bool f) { ccw = f; }
46 bool getCounterClockWise() {
return ccw; }
49 Spine(
float x_,
float y_,
float z_,
float a,
float b,
float g) : x(x_), y(y_), z(z_), alpha(a), beta(b), gamma(g) {}
51 float alpha, beta, gamma;
53 void setSpine(
const std::vector<Spine>& spine_) { spine = spine_; };
54 std::vector<Spine> getSpine() {
return spine; }
60 xercesc::DOMElement*
writeXMLFile(xercesc::DOMNode *parent)
override;
62 RigidSpineExtrusion();
63 ~RigidSpineExtrusion()
override;
65 std::vector<Spine> spine;
68 std::shared_ptr<std::vector<std::shared_ptr<PolygonPoint> > >
contour;
Definition: objectfactory.h:38
Abstract base class for all rigid bodies.
Definition: rigidbody.h:68
Class for all rigid bodies extruded along a curve.
Definition: rigidspineextrusion.h:36
xercesc::DOMElement * writeXMLFile(xercesc::DOMNode *parent) override
Definition: rigidspineextrusion.cc:35
std::shared_ptr< std::vector< std::shared_ptr< PolygonPoint > > > contour
Definition: rigidspineextrusion.h:68
void setContour(const std::shared_ptr< std::vector< std::shared_ptr< PolygonPoint > > > &contour_)
Definition: rigidspineextrusion.h:41
void initializeUsingXML(xercesc::DOMElement *element) override
Definition: rigidspineextrusion.cc:51
Definition: rigidspineextrusion.h:48