Medical Imaging Interaction Toolkit  2018.04.99-3ec0dd08
Medical Imaging Interaction Toolkit
mitkPlanarRectangle.h
Go to the documentation of this file.
1 /*============================================================================
2 
3 The Medical Imaging Interaction Toolkit (MITK)
4 
5 Copyright (c) German Cancer Research Center (DKFZ)
6 All rights reserved.
7 
8 Use of this source code is governed by a 3-clause BSD license that can be
9 found in the LICENSE file.
10 
11 ============================================================================*/
12 
13 #ifndef _MITK_PLANAR_RECTANGLE_H_
14 #define _MITK_PLANAR_RECTANGLE_H_
15 
16 #include "mitkPlanarPolygon.h"
18 
19 namespace mitk
20 {
21  class PlaneGeometry;
22 
28  {
29  public:
31 
32  itkFactorylessNewMacro(Self);
33 
34  itkCloneMacro(Self);
35 
41  // virtual void Initialize();
42  void PlaceFigure(const Point2D &point) override;
43 
45  unsigned int GetMinimumNumberOfControlPoints() const override { return 4; }
47  unsigned int GetMaximumNumberOfControlPoints() const override { return 4; }
48  bool SetControlPoint(unsigned int index, const Point2D &point, bool createIfDoesNotExist = false) override;
49 
50  protected:
52 
54 
56  void GeneratePolyLine() override;
57 
59  void GenerateHelperPolyLine(double mmPerDisplayUnit, unsigned int displayHeight) override;
60 
62  void EvaluateFeaturesInternal() override;
63 
64  void PrintSelf(std::ostream &os, itk::Indent indent) const override;
65 
66  const unsigned int FEATURE_ID_CIRCUMFERENCE;
67  const unsigned int FEATURE_ID_AREA;
68 
69  bool Equals(const mitk::PlanarFigure &other) const override;
70 
71  private:
72  };
73 
74 } // namespace mitk
75 
76 #endif //_MITK_PLANAR_POLYGON_H_
Base of all data objects.
Definition: mitkBaseData.h:42
const unsigned int FEATURE_ID_CIRCUMFERENCE
Implementation of PlanarFigure representing a polygon with two or more control points.
unsigned int GetMaximumNumberOfControlPoints() const override
Polygon maximum number of control points is principally not limited.
DataCollection - Class to facilitate loading/accessing structured data.
#define mitkClassMacro(className, SuperClassName)
Definition: mitkCommon.h:40
#define mitkCloneMacro(classname)
Definition: mitkCommon.h:158
#define MITKPLANARFIGURE_EXPORT
const unsigned int FEATURE_ID_AREA
Base-class for geometric planar (2D) figures, such as lines, circles, rectangles, polygons...
unsigned int GetMinimumNumberOfControlPoints() const override
Polygon has 2 control points per definition.