#include <hps.h>

Inheritance diagram for HPS::EllipseKey:
HPS::GeometryKey HPS::Key HPS::Object

Public Member Functions

void Consume (EllipseKit &in_kit)
 
 EllipseKey ()
 
 EllipseKey (Key const &in_that)
 
 EllipseKey (EllipseKey const &in_that)
 
 EllipseKey (EllipseKey &&in_that)
 
HPS::Type ObjectType () const
 
EllipseKeyoperator= (EllipseKey const &other)
 
EllipseKeyoperator= (EllipseKey &&in_that)
 
void Set (EllipseKit const &in_kit)
 
EllipseKeySetCenter (Point const &in_center)
 
EllipseKeySetMajor (Point const &in_major)
 
EllipseKeySetMinor (Point const &in_minor)
 
void Show (EllipseKit &out_kit) const
 
bool ShowCenter (Point &out_center) const
 
bool ShowMajor (Point &out_major) const
 
bool ShowMinor (Point &out_minor) const
 
- Public Member Functions inherited from HPS::GeometryKey
 GeometryKey ()
 
 GeometryKey (Key const &in_that)
 
 GeometryKey (GeometryKey const &in_that)
 
 GeometryKey (GeometryKey &&in_that)
 
GeometryKeyoperator= (GeometryKey const &in_that)
 
GeometryKeyoperator= (GeometryKey &&in_that)
 
GeometryKeySetPriority (int in_priority)
 
GeometryKeySetUserData (intptr_t in_index, size_t in_bytes, byte const in_data[])
 
GeometryKeySetUserData (intptr_t in_index, ByteArray const &in_data)
 
GeometryKeySetUserData (IntPtrTArray const &in_indices, ByteArrayArray const &in_data)
 
bool ShowBounding (BoundingKit &out_kit) const
 
bool ShowPriority (int &out_priority) const
 
size_t ShowReferrers (SegmentKeyArray &out_segments) const
 
size_t ShowReferrers (ReferenceKeyArray &out_references) const
 
bool ShowUserData (intptr_t in_index, ByteArray &out_data) const
 
bool ShowUserData (IntPtrTArray &out_indices, ByteArrayArray &out_data) const
 
size_t ShowUserDataCount () const
 
bool ShowUserDataIndices (IntPtrTArray &out_indices) const
 
GeometryKeyUnsetAllUserData ()
 
GeometryKeyUnsetPriority ()
 
GeometryKeyUnsetUserData (intptr_t in_index)
 
GeometryKeyUnsetUserData (size_t in_count, intptr_t const in_indices[])
 
GeometryKeyUnsetUserData (IntPtrTArray const &in_indices)
 
- Public Member Functions inherited from HPS::Key
virtual void Assign (Key const &in_that)
 
Key CopyTo (SegmentKey const &in_destination) const
 
void Delete ()
 
bool Equals (Key const &in_that) const
 
size_t GetHash () const
 
bool HasOwner () const
 
 Key ()
 
 Key (Key const &in_that)
 
 Key (Control const &in_control)
 
 Key (Key &&in_that)
 
void MoveTo (SegmentKey const &in_new_owner)
 
bool operator!= (Key const &in_that) const
 
Keyoperator= (Key &&in_that)
 
Keyoperator= (Key const &in_that)
 
bool operator== (Key const &in_that) const
 
SegmentKey Owner () const
 
SegmentKey Up () const
 
virtual ~Key ()
 
- Public Member Functions inherited from HPS::Object
virtual bool Empty () const
 
intptr_t GetClassID () const
 
intptr_t GetInstanceID () const
 
bool HasType (HPS::Type in_mask) const
 
Object (Object const &that)
 
 Object (Object &&in_that)
 
Objectoperator= (Object const &other_object)
 
Objectoperator= (Object &&in_that)
 
virtual void Reset ()
 
virtual HPS::Type Type () const
 

Static Public Attributes

static const HPS::Type staticType = HPS::Type::EllipseKey
 
- Static Public Attributes inherited from HPS::GeometryKey
static const HPS::Type staticType = HPS::Type::GeometryKey
 
- Static Public Attributes inherited from HPS::Key
static const HPS::Type staticType = HPS::Type::Key
 
- Static Public Attributes inherited from HPS::Object
static const HPS::Type staticType = HPS::Type::None
 

Additional Inherited Members

- Static Public Member Functions inherited from HPS::Object
template<typename T >
static intptr_t ClassID ()
 

Detailed Description

The EllipseKey class is a smart pointer to a database object. It is a handle to an ellipse inserted via SegmentKey::InsertEllipse.

Constructor & Destructor Documentation

◆ EllipseKey() [1/4]

HPS::EllipseKey::EllipseKey ( )

The default constructor creates an uninitialized EllipseKey object. The Type() function will return Type::None.

◆ EllipseKey() [2/4]

HPS::EllipseKey::EllipseKey ( Key const &  in_that)
explicit

This constructor creates an EllipseKey object that shares the underlying smart-pointer of the source Key. The copy will only be successful if the source key is really an upcast of an Ellipse key. Otherwise the copy will fail and the resulting EllipseKey will be invalid.

Parameters
in_keyThe source Key to copy.

◆ EllipseKey() [3/4]

HPS::EllipseKey::EllipseKey ( EllipseKey const &  in_that)

The copy constructor creates an EllipseKey object that shares the underlying smart-pointer of the source EllipseKey.

Parameters
in_thatThe source EllipseKey to copy.

◆ EllipseKey() [4/4]

HPS::EllipseKey::EllipseKey ( EllipseKey &&  in_that)

The move constructor creates an EllipseKey by transferring the underlying impl of the rvalue reference to this EllipseKey thereby avoiding a copy and allocation.

Parameters
in_thatAn rvalue reference to an EllipseKey to take the impl from.

Member Function Documentation

◆ Consume()

void HPS::EllipseKey::Consume ( EllipseKit in_kit)

Completely replaces all settings on this EllipseKit with those set on the specified kit and resets the kit.

Parameters
in_kitThe kit from which to get the settings to replace on this EllipseKit.

◆ ObjectType()

HPS::Type HPS::EllipseKey::ObjectType ( ) const
inlinevirtual

This function returns the type the object, as declared (if the object is derived, this does not give the true type of the derived object).

Returns
The declared type of the object in question, which may differ from the true, underlying type.

Reimplemented from HPS::GeometryKey.

◆ operator=() [1/2]

EllipseKey& HPS::EllipseKey::operator= ( EllipseKey const &  other)

Associate this EllipseKey with the same underlying impl as the source EllipseKey.

Parameters
in_thatThe source EllipseKey for the assignment.
Returns
A reference to this EllipseKey.

◆ operator=() [2/2]

EllipseKey& HPS::EllipseKey::operator= ( EllipseKey &&  in_that)

The move assignment operator transfers the underlying impl of the rvalue reference to this EllipseKey thereby avoiding a copy.

Parameters
in_thatAn rvalue reference to an EllipseKey to take the impl from.
Returns
A reference to this EllipseKey.

◆ Set()

void HPS::EllipseKey::Set ( EllipseKit const &  in_kit)

Replace those settings on this EllipseKey with those set on the specified kit.

Parameters
in_kitThe kit from which to get the settings to replace on this EllipseKey.

◆ SetCenter()

EllipseKey& HPS::EllipseKey::SetCenter ( Point const &  in_center)

Sets the center point for the ellipse.

Parameters
in_centerThe center point for the ellipse.
Returns
A reference to this EllipseKey.

◆ SetMajor()

EllipseKey& HPS::EllipseKey::SetMajor ( Point const &  in_major)

Sets the intersection point of the major axis and the ellipse.

Parameters
in_majorThe intersection point of the major axis and the ellipse.
Returns
A reference to this EllipseKey.

◆ SetMinor()

EllipseKey& HPS::EllipseKey::SetMinor ( Point const &  in_minor)

Sets the intersection point of the minor axis and the ellipse.

Parameters
in_minorThe intersection point of the minor axis and the ellipse.
Returns
A reference to this EllipseKey.

◆ Show()

void HPS::EllipseKey::Show ( EllipseKit out_kit) const

Copy the contents of this EllipseKey into the specified kit.

Parameters
out_kitThe kit to populate with the contents of this EllipseKey.

◆ ShowCenter()

bool HPS::EllipseKey::ShowCenter ( Point out_center) const

Shows the center point for the ellipse.

Parameters
out_centerThe center point for the ellipse.
Returns
true if a center was set, false otherwise.

◆ ShowMajor()

bool HPS::EllipseKey::ShowMajor ( Point out_major) const

Shows the intersection point of the major axis and the ellipse.

Parameters
out_majorThe intersection point of the major axis and the ellipse.
Returns
true if an intersection point with the major axis was set, false otherwise.

◆ ShowMinor()

bool HPS::EllipseKey::ShowMinor ( Point out_minor) const

Shows the intersection point of the minor axis and the ellipse.

Parameters
out_minorThe intersection point of the minor axis and the ellipse.
Returns
true if an intersection point with the minor axis was set, false otherwise.

The documentation for this class was generated from the following file: