Developer Documentation
PolyLineObject.hh
Go to the documentation of this file.
1 /*===========================================================================*\
2 * *
3 * OpenFlipper *
4  * Copyright (c) 2001-2015, RWTH-Aachen University *
5  * Department of Computer Graphics and Multimedia *
6  * All rights reserved. *
7  * www.openflipper.org *
8  * *
9  *---------------------------------------------------------------------------*
10  * This file is part of OpenFlipper. *
11  *---------------------------------------------------------------------------*
12  * *
13  * Redistribution and use in source and binary forms, with or without *
14  * modification, are permitted provided that the following conditions *
15  * are met: *
16  * *
17  * 1. Redistributions of source code must retain the above copyright notice, *
18  * this list of conditions and the following disclaimer. *
19  * *
20  * 2. Redistributions in binary form must reproduce the above copyright *
21  * notice, this list of conditions and the following disclaimer in the *
22  * documentation and/or other materials provided with the distribution. *
23  * *
24  * 3. Neither the name of the copyright holder nor the names of its *
25  * contributors may be used to endorse or promote products derived from *
26  * this software without specific prior written permission. *
27  * *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39 * *
40 \*===========================================================================*/
41 
42 /*===========================================================================*\
43 * *
44 * $Revision$ *
45 * $LastChangedBy$ *
46 * $Date$ *
47 * *
48 \*===========================================================================*/
49 
50 //=============================================================================
51 //
52 // Types
53 //
54 //=============================================================================
55 
62 #ifndef POLYLINEOBJECT_HH
63 #define POLYLINEOBJECT_HH
64 
65 
66 
67 //== INCLUDES =================================================================
68 
69 #include "PolyLineTypes.hh"
71 
72 #include <ObjectTypes/PolyLine/PolyLineNodeT.hh>
73 
75 
76 //== TYPEDEFS =================================================================
77 
78 //== CLASS DEFINITION =========================================================
79 
83 
84  friend class TypePolyLinePlugin;
85 
86  public:
87 
88  typedef PolyLine PolyLineType;
89 
92 
97  PolyLineObject(const PolyLineObject& _object);
98 
100  virtual ~PolyLineObject();
101 
103  virtual void cleanup();
104 
108  BaseObject* copy();
109 
110  protected:
111 
113  virtual void init(PolyLine* _line = 0);
114 
115  //===========================================================================
118  //===========================================================================
119  public:
120 
122  void setName( QString _name );
123 
124 
125  //===========================================================================
128  //===========================================================================
129 
130  public:
131 
133  PolyLine* line();
134 
135  private:
138 
141  //===========================================================================
148  //===========================================================================
149 
150  protected:
159  virtual void update(UpdateType _type = UPDATE_ALL );
160 
163  //===========================================================================
166  //===========================================================================
167 
168  public :
169 
172 
173  private :
174 
177 
180  //===========================================================================
183  //===========================================================================
184  public:
186  QString getObjectinfo();
187 
191  //===========================================================================
194  //===========================================================================
195  public:
197  bool picked( uint _node_idx );
198 
200  void enablePicking( bool _enable );
201 
203  bool pickingEnabled();
204 
205 
208  const ACG::Vec3d _hitPoint,
209  const ACG::Vec3d _start ,
210  const ACG::Vec3d _dir,
211  const unsigned int _targetIdx );
212 
215 };
216 
217 //=============================================================================
218 #endif // POLYLINEOBJECT_HH defined
219 //=============================================================================
PolyLine * line_
Pointer to the polyline.
virtual void cleanup()
#define DLLEXPORT
virtual bool picked(uint _node_idx)
detect if the node has been picked
Update type class.
Definition: UpdateType.hh:70
PickTarget
What target to use for picking.
Definition: BaseNode.hh:99
virtual bool pickingEnabled()
virtual void setName(QString _name)
path to the file from which the object is loaded ( defaults to "." )
virtual void update(UpdateType _type=UPDATE_ALL)
This function is called to update the object.
virtual BaseObject * copy()
Returns a full copy of the object.
Definition: BaseObject.cc:780
virtual void enablePicking(bool _enable)
virtual ACG::Vec3d refinePick(ACG::SceneGraph::PickTarget _pickTarget, const ACG::Vec3d _hitPoint, const ACG::Vec3d _start, const ACG::Vec3d _dir, const unsigned int _targetIdx)
Refine picking.
virtual QString getObjectinfo()
Get all Info for the Object as a string.
Definition: BaseObject.cc:255
const UpdateType UPDATE_ALL(UpdateTypeSet(1))
Identifier for all updates.
ACG::SceneGraph::PolyLineNodeT< PolyLine > * lineNode_
Scenegraph Mesh Node.