Repository URL to install this package:
Version:
7.26.0-0.2 ▾
|
/* $NoKeywords: $ */
/*
//
// Copyright (c) 1993-2012 Robert McNeel & Associates. All rights reserved.
// OpenNURBS, Rhinoceros, and Rhino3D are registered trademarks of Robert
// McNeel & Associates.
//
// THIS SOFTWARE IS PROVIDED "AS IS" WITHOUT EXPRESS OR IMPLIED WARRANTY.
// ALL IMPLIED WARRANTIES OF FITNESS FOR ANY PARTICULAR PURPOSE AND OF
// MERCHANTABILITY ARE HEREBY DISCLAIMED.
//
// For complete openNURBS copyright information see <http://www.opennurbs.org>.
//
////////////////////////////////////////////////////////////////
*/
#ifndef OPENNURBS_ANNOTATION2_H_INC
#define OPENNURBS_ANNOTATION2_H_INC
#if defined(ON_OS_WINDOWS_GDI)
#define ON_RECT RECT
#else
typedef struct tagON_RECT
{
int left;
int top;
int right;
int bottom;
} ON_RECT;
#endif
class ON_CLASS ON_Annotation2Text : public ON_wString
{
public:
ON_Annotation2Text();
~ON_Annotation2Text();
// 24 Sep 2010 Dale Lear
// None of these were implmented and they don't make any sense.
// ON_Annotation2Text is derived from ON_wString, not ON_Object.
// I'm commenting out these functions and it doesn't break the
// SDK because linking would fail for anybody trying to use
// these functions.
//////void SetDefaults();
////// // override virtual ON_Object::Dump function
//////void Dump( ON_TextLog& text_log ) const;
//////// override virtual ON_Object::Dump function
//////unsigned int SizeOf() const;
//////// override virtual ON_Object::Write function
//////ON_BOOL32 Write(ON_BinaryArchive& binary_archive) const;
//////// override virtual ON_Object::Read function
//////ON_BOOL32 Read(ON_BinaryArchive& binary_archive);
//////// override virtual ON_UserData::GetDescription function
//////ON_BOOL32 GetDescription( ON_wString& description );
//////// override virtual ON_UserData::Archive function
//////ON_BOOL32 Archive() const;
ON_Annotation2Text& operator=(const char*);
ON_Annotation2Text& operator=(const wchar_t*);
void SetText( const char* s );
void SetText( const wchar_t* s );
// m_rect is a Windows gdi RECT that bounds text
// ("x" increases to the right and "y" increases downwards).
// If all fields are 0, then m_rect is not set.
// If left < right and top < bottom, then the rect bounds
// the text when it is drawn with its font's
// lfHeight=ON_Font::normal_font_height and (0,0) left baseline
// point of the leftmost character on the first line
// of text. If (x,y) is a point on the drawn text, then
// left <= x < right and top <= y < bottom.
ON_RECT m_rect;
};
// Extension to ON_TextEntity added 12/10/2009 for Text background drawing
class ON_CLASS ON_TextExtra : public ON_UserData
{
ON_OBJECT_DECLARE(ON_TextExtra);
public:
ON_TextExtra();
~ON_TextExtra();
static
ON_TextExtra* TextExtension(class ON_TextEntity2* pDim, bool bCreate);
static const
ON_TextExtra* TextExtension(const class ON_TextEntity2* pDim, bool bCreate);
void SetDefaults();
// override virtual ON_Object::Dump function
void Dump( ON_TextLog& text_log ) const;
// override virtual ON_Object::Dump function
unsigned int SizeOf() const;
// override virtual ON_Object::Write function
ON_BOOL32 Write(ON_BinaryArchive& binary_archive) const;
// override virtual ON_Object::Read function
ON_BOOL32 Read(ON_BinaryArchive& binary_archive);
// override virtual ON_UserData::GetDescription function
ON_BOOL32 GetDescription( ON_wString& description );
// override virtual ON_UserData::Archive function
ON_BOOL32 Archive() const;
ON_UUID ParentUUID() const;
void SetParentUUID( ON_UUID parent_uuid);
bool DrawTextMask() const;
void SetDrawTextMask(bool bDraw);
int MaskColorSource() const;
void SetMaskColorSource(int source);
ON_Color MaskColor() const; // Only works right if MaskColorSource returns 2.
// Does not return viewport background color
void SetMaskColor(ON_Color color);
double MaskOffsetFactor() const;
void SetMaskOffsetFactor(double offset);
ON_UUID m_parent_uuid; // uuid of the text using this extension
bool m_bDrawMask; // do or don't draw a mask
int m_color_source; // 0: Use background color from viewport
// 1: Use specific color from m_mask_color
ON_Color m_mask_color; // Color to use for mask if m_color_source is 2
double m_border_offset; // Offset for the border around text to the rectangle used to draw the mask
// This number * HeightOfI for the text is the offset on each side of the
// tight rectangle around the text characters to the mask rectangle.
};
class ON_CLASS ON_DimensionExtra : public ON_UserData
{
ON_OBJECT_DECLARE(ON_DimensionExtra);
public:
ON_DimensionExtra();
~ON_DimensionExtra();
static
ON_DimensionExtra* DimensionExtension(class ON_LinearDimension2* pDim, bool bCreate);
static const
ON_DimensionExtra* DimensionExtension(const class ON_LinearDimension2* pDim, bool bCreate);
static
ON_DimensionExtra* DimensionExtension(class ON_RadialDimension2* pDim, bool bCreate);
static const
ON_DimensionExtra* DimensionExtension(const class ON_RadialDimension2* pDim, bool bCreate);
static
ON_DimensionExtra* DimensionExtension(class ON_OrdinateDimension2* pDim, bool bCreate);
static const
ON_DimensionExtra* DimensionExtension(const class ON_OrdinateDimension2* pDim, bool bCreate);
void SetDefaults();
// override virtual ON_Object::Dump function
void Dump( ON_TextLog& text_log ) const;
// override virtual ON_Object::Dump function
unsigned int SizeOf() const;
// override virtual ON_Object::Write function
ON_BOOL32 Write(ON_BinaryArchive& binary_archive) const;
// override virtual ON_Object::Read function
ON_BOOL32 Read(ON_BinaryArchive& binary_archive);
// override virtual ON_UserData::GetDescription function
ON_BOOL32 GetDescription( ON_wString& description );
// override virtual ON_UserData::Archive function
ON_BOOL32 Archive() const;
ON_UUID ParentUUID() const;
void SetParentUUID( ON_UUID parent_uuid);
// 0: default position
// 1: force inside
// -1: force outside
int ArrowPosition() const;
void SetArrowPosition( int position);
// For a dimension in page space that measures between points in model space
// of a detail view, this is the ratio of the page distance / model distance.
// When the dimension text is displayed, the distance measured in model space
// is multiplied by this number to get the value to display.
double DistanceScale() const;
void SetDistanceScale(double s);
// Basepont in modelspace coordinates for ordinate dimensions
void SetModelSpaceBasePoint(ON_3dPoint basepoint);
ON_3dPoint ModelSpaceBasePoint() const;
//const wchar_t* ToleranceUpperString() const;
//ON_wString& ToleranceUpperString();
//void SetToleranceUpperString( const wchar_t* upper_string);
//void SetToleranceUpperString( ON_wString& upper_string);
//const wchar_t* ToleranceLowerString() const;
//ON_wString& ToleranceLowerString();
//void SetToleranceLowerString( const wchar_t* lower_string);
//void SetToleranceLowerString( ON_wString& lower_string);
//const wchar_t* AlternateString() const;
//ON_wString& AlternateString();
//void SetAlternateString( const wchar_t* alt_string);
//void SetAlternateString( ON_wString& alt_string);
//const wchar_t* AlternateToleranceUpperString() const;
//ON_wString& AlternateToleranceUpperString();
//void SetAlternateToleranceUpperString( const wchar_t* upper_string);
//void SetAlternateToleranceUpperString( ON_wString& upper_string);
//const wchar_t* AlternateToleranceLowerString() const;
//ON_wString& AlternateToleranceLowerString();
//void SetAlternateToleranceLowerString( const wchar_t* lower_string);
//void SetAlternateToleranceLowerString( ON_wString& lower_string);
ON_UUID m_partent_uuid; // the dimension using this extension
int m_arrow_position;
// This is either NULL or an array of GDI rects for the substrings
// that make up the dimension string.
// If the dimension text is all on the same line, there is just one
// rectangle needed to bound the text and that is the same as the
// m_rect on the ON_Annotation2Text.
// If the dimension has tolerances or for some other reason has more
// than one line of text, m_text_rects is an array of 7 rects, one
// each for the substrings that might be needed to display the dimension.
// If some of the rects aren't used, they are empty at 0,0
// The strings that correspond to these rectangles are generated from
// info in the dimstyle
ON_RECT* m_text_rects;
double m_distance_scale;
ON_3dPoint m_modelspace_basepoint;
};
/*
class ON_Annotation2
Description:
Used to serialize definitions of annotation objects (dimensions, text, leaders, etc.).
Virtual base class for annotation objects
Replaces ON_Annotation
*/
class ON_CLASS ON_Annotation2 : public ON_Geometry
{
ON_OBJECT_DECLARE(ON_Annotation2);
// UNICODE symbol code to use for degrees, radius, diameter and plus/minus in dimensions
enum SYMBOLS
{
degreesym = 176,
radiussym = L'R',
diametersym = 216,
plusminussym = 177
};
public:
ON_Annotation2();
~ON_Annotation2();
// C++ automatically provides the correct copy constructor and operator= .
//ON_Annotation2(const ON_Annotation2&);
//ON_Annotation2& operator=(const ON_Annotation2&);
// convert from old style annotation
ON_Annotation2(const ON_Annotation&);
ON_Annotation2& operator=(const ON_Annotation&);
// Description:
// Sets initial defaults
void Create();
void Destroy();
void EmergencyDestroy();
/////////////////////////////////////////////////////////////////
//
// ON_Object overrides
//
ON_BOOL32 IsValid( ON_TextLog* text_log = NULL ) const;
/*
Description: Writes the object to a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Write(
ON_BinaryArchive&
) const;
/*
Description: Reads the object from a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Read(
ON_BinaryArchive&
);
/*
Returns: The Object Type of this object
*/
ON::object_type ObjectType() const;
/////////////////////////////////////////////////////////////////
//
// ON_Geometry overrides
//
/*
Returns the geometric dimension of the object ( usually 3)
*/
int Dimension() const;
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
// virtual ON_Geometry override
bool EvaluatePoint( const class ON_ObjRef& objref, ON_3dPoint& P ) const;
/////////////////////////////////////////////////////////////////
//
// ON_Annotation2 interface
//
// Definitions of text justification
// Not implemented on all annotation objects
enum eTextJustification
{
tjUndefined = 0,
tjLeft = 1<<0,
tjCenter = 1<<1,
tjRight = 1<<2,
tjBottom = 1<<16,
tjMiddle = 1<<17,
tjTop = 1<<18,
tjBottomLeft = tjBottom | tjLeft,
tjBottomCenter = tjBottom | tjCenter,
tjBottomRight = tjBottom | tjRight,
tjMiddleLeft = tjMiddle | tjLeft,
tjMiddleCenter = tjMiddle | tjCenter,
tjMiddleRight = tjMiddle | tjRight,
tjTopLeft = tjTop | tjLeft,
tjTopCenter = tjTop | tjCenter,
tjTopRight = tjTop | tjRight
};
/*
Description:
Query if the annotation object is a text object
Parameters:
none
Returns:
@untitled table
true It is text
false Its not text
*/
bool IsText() const;
/*
Description:
Query if the annotation object is a leader
Parameters:
none
Returns:
@untitled table
true It is a leader
false Its not a leader
*/
bool IsLeader() const;
/*
Description:
Query if the annotation object is a dimension
Parameters:
none
Returns:
@untitled table
true It is a dimension
false Its not a dimension
*/
bool IsDimension() const;
/*
Description:
Set or get the index in the appropriate table for either the font or
dimstyle of this object
Parameters:
[in] int the new index (Set)
Returns:
int - The index (Get)
Remarks:
If the object is a text object the index is of object's font in the Font Table
If the object is anything else, the index is of the object's dimstyle in the DimStyle Table
Derived objects can use FontIndex() and StyleIndex() to set/get these same values.
*/
int Index() const;
void SetIndex( int);
/*
Returns:
Dimension type
Linear dim: distance between arrow tips
Radial dim: radius or diameter depending on m_type value
Angular dim: angle in degrees
Leader: ON_UNSET_VALUE
Text: ON_UNSET_VALUE
*/
virtual
double NumericValue() const;
/*
Description:
Set or Get the height of the text in this annotation
Parameters:
[in] double new text height to set
Returns:
double Height of the text
Remarks:
Height is in model units
*/
void SetHeight( double);
double Height() const;
/*
Description:
Sets or gets the object type member to a specific annotation type:
dtDimLinear, dtDimAligned, dtDimAngular, etc.
Parameters:
[in] ON::eAnnotationType type - dtDimLinear, dtDimAligned, dtDimAngular, etc.
Returns:
ON::eAnnotationType of the object
*/
void SetType( ON::eAnnotationType);
ON::eAnnotationType Type() const;
/*
Description:
Set or get the plane for the object's ECS
Parameters:
[in] ON_Plane& plane in WCS
Returns:
const ON_Plane& - the object's ECS plane in WCS coords
*/
void SetPlane( const ON_Plane&);
const ON_Plane& Plane() const;
/*
Description:
Returns the number of definition points this object has
Parameters:
none
Returns:
@untitled table
int the object's point count
*/
int PointCount() const;
void SetPointCount( int count);
/*
Description:
Set or get the object's whole points array at once
Parameters:
[in] ON_2dPointArray& pts
Returns:
const ON_2dPointArray& - ref to the object's point array
*/
void SetPoints( const ON_2dPointArray&);
const ON_2dPointArray& Points() const;
/*
Description:
Set individual definition points for the annotation
Parameters:
@untitled table
[in] int index index of the point to set in ECS 2d coordinates
[in] const ON_2dPoint& pt the new point value
Returns:
ON_2dPoint the point coordinates in ECS
*/
void SetPoint( int, const ON_2dPoint&);
ON_2dPoint Point( int) const;
/*
Description:
Set or get the string value of the user text, with no substitution for "<>"
Parameters:
[in] const wchar_t* string the new value for UserText
Returns:
const ON_wString& The object's UserText
Remarks:
UserText is the string that gets printed when the dimension is drawn.
If it contains the token "<>", that token is replaced with the measured
value for the dimension, formatted according to the DimStyle settings.
"<>" is the default for linear dimensions.
Other dimensions include "<>" in their default string
*/
// OBSOLETE - call SetTextValue( text_value );
ON_DEPRECATED void SetUserText( const wchar_t* text_value );
// OBSOLETE - call TextValue( text_value );
ON_DEPRECATED const ON_wString& UserText() const;
/*
Description:
Gets the value of the annotation text.
Returns:
Value of the annotation text.
See Also:
ON_Annotation2Text::SetTextValue()
ON_Annotation2Text::SetTextFormula()
ON_Annotation2Text::TextFormula()
Remarks:
This gets the literal value of the text, there is no
substitution for any "<>" substrings. When a dimension
is drawn, any occurance of "<>" will be replaced
with the measured value for the dimension and formatted
according to the DimStyle settings.
Annotation text values can be constant or the result
of evaluating text formula containing %<...>%
expressions. The ...TextValue() functions set
and get the text's value. The ...TextFormula()
functions get and set the text's formula.
*/
const wchar_t* TextValue() const;
/*
Description:
Sets the value of the annotation text. No changes
are made to the text_value string.
Parameters:
text_value - [in]
Returns:
Value of the annotation text.
See Also:
ON_Annotation2Text::SetTextFormula()
ON_Annotation2Text::TextValue()
ON_Annotation2Text::TextFormula()
Remarks:
Annotation text values can be constant or the result
of evaluating text formula containing %<...>%
expressions. The ...TextValue() functions set
and get the text's value. The ...TextFormula()
functions get and set the text's formula.
*/
void SetTextValue( const wchar_t* text_value );
/*
Description:
Gets the formula for the annotation text.
Parameters:
text_value - [in]
Returns:
Value of the annotation text.
See Also:
ON_Annotation2Text::SetTextValue()
ON_Annotation2Text::TextValue()
ON_Annotation2Text::TextFormula()
Remarks:
Annotation text values can be constant or the result
of evaluating text formula containing %<...>%
expressions. The ...TextValue() functions set
and get the text's value. The ...TextFormula()
functions get and set the text's formula.
*/
const wchar_t* TextFormula() const;
/*
Description:
Sets the formula for the annotation text.
Parameters:
text_value - [in]
Returns:
Value of the annotation text.
See Also:
ON_Annotation2Text::SetTextValue()
ON_Annotation2Text::Value()
ON_Annotation2Text::Formula()
Remarks:
Annotation text values can be constant or the result
of evaluating text formula containing %<...>%
expressions. The ...TextValue() functions set
and get the text's value. The ...TextFormula()
functions get and set the text's formula.
*/
void SetTextFormula( const wchar_t* s );
/*
Description:
Set or get a flag indication that the dimension text has been moved
from the default location.
Parameters:
bUserPositionedText - [in]
true to indicate that the text has been placed by the user.
false to indicate that it hasn't
Returns:
@untitled table
true The text has been moved
false The text is in the default location
Remarks:
If the text is in the default location, it should be repositioned
automatically when the dimension is adjusted.
If it has been moved, it should not be automatically positioned.
*/
void SetUserPositionedText( int bUserPositionedText );
bool UserPositionedText() const;
/*
Description:
Set or get the text display mode for the annotation
Parameters:
[in] ON::eTextDisplayMode mode - new mode to set
Returns:
ON::eTextDisplayMode - current mode
Remarks:
This is the way the text is oriented with respect to the dimension line or screen:
Above line, In LIne, Horizontal
*/
void SetTextDisplayMode( ON::eTextDisplayMode);
ON::eTextDisplayMode TextDisplayMode() const;
/*
Description:
Gets a transform matrix to change from the object's 2d ECS to 3d WCS
Parameters:
[out] xform set to produce the ECS to WCS transform
Returns:
@untitled table
true Success
false Failure
*/
ON_BOOL32 GetECStoWCSXform( ON_Xform&) const;
/*
Description:
Gets a transform matrix to change from to 3d WCS to the object's 2d ECS
Parameters:
[out] xform - set to produce the WCS to ECS transform
Returns:
@untitled table
true Success
false Failure
*/
ON_BOOL32 GetWCStoECSXform( ON_Xform& xform) const;
/*
Description:
Set the object's point array to a specified length
Parameters:
[in] length - the new size of the array
Returns:
void
*/
void ReservePoints( int);
/*
Description:
static function to provide the default UserText string for the object
Returns:
const wchar_t* - the default string to use
*/
static const wchar_t* DefaultText();
/*
Description:
Convert back to the version of ON_Annotation used in Rhino 2
Parameters:
target [out] the old-style object
Returns:
@untitled table
true Success
False Failure
See Also: ON_AngularDimension::ConvertBack()
*/
virtual
void ConvertBack( ON_Annotation& target);
/*
Description:
Set or Get the text justification
Parameters:
justification [in] See enum eJustification for meanings
Returns:
The justification for the text in this object
Comments:
This is not implemented on all annotation objects.
The default SetJustification() does nothing
The default Justification() always returns 0
*/
virtual
void SetJustification( unsigned int justification);
virtual
unsigned int Justification();
/*
Description:
Get the transformation that maps the annotation's
text to world coordinates.
Added Oct 30, 07 LW
Parameters:
gdi_text_rect - [in]
Windows gdi rect of text when it is drawn with
LOGFONT lfHeight = ON_Font::normal_font_height.
gdi_height_of_I - [in]
Value returned by ON_Font::HeightOfI().
dimstyle_textheight - [in]
Height of text in world units. If the annotation is
an ON_TextEntity2, this is the m_textheight value.
If the annotation is not an ON_TextEntity2, pass in
the value returned by the dimension style's
ON_DimStyle::TextHeight()
dimstyle_textgap - [in]
The value of the annotation's dimension style's
ON_DimStyle::TextGap().
dimstyle_textalignment - [in]
ON::TextDisplayMode(ON_DimStyle::TextAlignment()).
dimscale - [in]
Global dimension scaling value. If you are using the
Rhino SDK, this value is returned by
CRhinoDoc::Properties().AnnotationSettings().DimScale().
If you are using the OpenNURBS IO toolkit, this value
is on ON_3dmSettings::m_AnnotationSettings.m_dimscale.
cameraX - [in]
zero or the view's unit camera right vector
cameraY - [in]
zero or the view's unit camera up vector
model_xform - [in] transforms the text's parent entity
to world coordinates in case its instance geometry
NULL == Identity
text_xform - [out]
Returns:
True if text_xform is set.
*/
bool GetTextXform(
ON_RECT gdi_text_rect,
int gdi_height_of_I,
double dimstyle_textheight,
double dimstyle_textgap,
ON::eTextDisplayMode dimstyle_textalignment,
double dimscale,
ON_3dVector cameraX,
ON_3dVector cameraY,
const ON_Xform* model_xform,
ON_Xform& text_xform // output
) const;
/*
Description:
This function has been replaced with a version that
takes a model transform to transform block instance
geometry to world coordinates Oct 30, 07 LW
Get the transformation that maps the annotation's
text to world coordinates.
Parameters:
gdi_text_rect - [in]
Windows gdi rect of text when it is drawn with
LOGFONT lfHeight = ON_Font::normal_font_height.
gdi_height_of_I - [in]
Value returned by ON_Font::HeightOfI().
dimstyle_textheight - [in]
Height of text in world units. If the annotation is
an ON_TextEntity2, this is the m_textheight value.
If the annotation is not an ON_TextEntity2, pass in
the value returned by the dimension style's
ON_DimStyle::TextHeight()
dimstyle_textgap - [in]
The value of the annotation's dimension style's
ON_DimStyle::TextGap().
dimstyle_textalignment - [in]
ON::TextDisplayMode(ON_DimStyle::TextAlignment()).
dimscale - [in]
Global dimension scaling value. If you are using the
Rhino SDK, this value is returned by
CRhinoDoc::Properties().AnnotationSettings().DimScale().
If you are using the OpenNURBS IO toolkit, this value
is on ON_3dmSettings::m_AnnotationSettings.m_dimscale.
cameraX - [in]
zero or the view's unit camera right vector
cameraY - [in]
zero or the view's unit camera up vector
xform - [out]
Returns:
True if xform is set.
*/
bool GetTextXform(
ON_RECT gdi_text_rect,
int gdi_height_of_I,
double dimstyle_textheight,
double dimstyle_textgap,
ON::eTextDisplayMode dimstyle_textalignment,
double dimscale,
ON_3dVector cameraX,
ON_3dVector cameraY,
ON_Xform& xform
) const;
/*
Description:
Get the transformation that maps the annotation's
text to world coordinates.
Oct 30, 07 LW
Parameters:
gdi_text_rect - [in]
Windows gdi rect of text when it is drawn with
LOGFONT lfHeight = ON_Font::normal_font_height.
font - [in]
dimstyle - [in]
dimscale - [in]
Global dimension scaling value. If you are using the
Rhino SDK, this value is returned by
CRhinoDoc::Properties().AnnotationSettings().DimScale().
If you are using the OpenNURBS IO toolkit, this value
is on ON_3dmSettings::m_AnnotationSettings.m_dimscale.
vp - [in]
model_xform - [in] transforms the text's parent entity
to world coordinates in case its instance geometry
NULL == Identity
text_xform - [out]
Returns:
True if text_xform is set.
*/
//bool GetTextXform(
// const ON_RECT gdi_text_rect,
// const ON_Font& font,
// const ON_DimStyle& dimstyle,
// double dimscale,
// const ON_Viewport* vp,
// const ON_Xform* model_xform,
// ON_Xform& text_xform // output
// ) const;
bool GetTextXform(
const ON_RECT gdi_text_rect,
const ON_Font& font,
const ON_DimStyle* dimstyle,
double dimscale,
const ON_Viewport* vp,
const ON_Xform* model_xform,
ON_Xform& text_xform // output
) const;
/*
Description:
This function has been replaced with a version that
takes a model transform because the viewport doesn't
contain block instance transform info Oct 30, 07 LW
Get the transformation that maps the annotation's
text to world coordinates.
Parameters:
gdi_text_rect - [in]
Windows gdi rect of text when it is drawn with
LOGFONT lfHeight = ON_Font::normal_font_height.
font - [in]
dimstyle - [in]
dimscale - [in]
Global dimension scaling value. If you are using the
Rhino SDK, this value is returned by
CRhinoDoc::Properties().AnnotationSettings().DimScale().
If you are using the OpenNURBS IO toolkit, this value
is on ON_3dmSettings::m_AnnotationSettings.m_dimscale.
vp - [in]
xform - [out]
Returns:
True if xform is set.
*/
bool GetTextXform(
ON_RECT gdi_text_rect,
const ON_Font& font,
const ON_DimStyle& dimstyle,
double dimscale,
const ON_Viewport* vp,
ON_Xform& xform
) const;
/*
Description:
Get the annotation plane coordinates (ECS) of the point
that is used to position the text. The relative position
of the text to this points depends on the type of
annotation, the dimstyle's text alignment flag, and the
view projection.
This point is not the same as the base point of the text.
Parameters:
text_point - [out];
Returns:
True if text_point is set.
*/
bool GetTextPoint( ON_2dPoint& text_2d_point ) const;
// enum for tyoe of annotation DimLinear, DimRadius, etc.
ON::eAnnotationType m_type;
// m_textdisplaymode controls the orientation
// of the text.
// If m_textdisplaymode = dtHorizontal, then
// the text is always horizontal and in the
// view plane. Otherwise it lies in m_plane.
ON::eTextDisplayMode m_textdisplaymode;
// m_plane is the plane containing the annotation.
// All parts of the annotation that are not
// text lie in this plane. If
// m_textdisplaymode != dtHorizontal, then
// the text lies in the plane too.
// (ECS reference plane in WCS coordinates.)
ON_Plane m_plane;
// Definition points for the dimension.
// These are 2d coordinates in m_plane.
// The location of these points depends on the
// type of annotation class. There is a comment
// at the start of the definions for
// ON_LinearDimension2, ON_RadialDimension2,
// ON_AngularDimension2, ON_TextEntity2, and
// ON_Leader2 that explains how the points are used.
ON_2dPointArray m_points;
// With the addition of tolerances and therefore multi-line
// text, the ON_wString in m_usertext will hold multiple
// strings with NULLs between them.
// The strings will be in this order:
// Result of expanding "<>", or user override
// Alternate dimension
// Tolerance upper
// Tolerance lower
// Alt tolerance upper
// Alt tolerance lower
// Prefix
// Suffix
// Alt prefix
// Alt suffix
//
ON_Annotation2Text m_usertext;
// true: User has positioned text
// false: use default location
bool m_userpositionedtext;
// Added 13 Aug, 2010 - Lowell
// This determines whether the object will be scaled according to detail
// scale factor or by 1.0 in paperspace rather than by
// dimscale or text scale.
// For the first try this will only be used on text and its
// here on the base class because it would fit and in case
// its needed later on dimensions.
bool m_annotative_scale;
private:
bool m_reserved_b1;
bool m_reserved_b2;
public:
// For dimensions, this is the ON_DimStyle index
// For text, its the ON_Font index
int m_index;
// Text height in model units
// This is used by text, but not by dimensions
// Dimensions get their height from dimension styles
double m_textheight;
// Left, Center, Right / Bottom, Middle, Top text justification
// See eTextJustification above
unsigned int m_justification;
};
// Subclass of ON_Annotation2 to provide linear dimensions
class ON_CLASS ON_LinearDimension2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_LinearDimension2);
public:
/*
The annotation's dimstyle controls the position of TEXT,
the size of the arrowheads, and the amount the ends of
linear dimension's extension lines extend beyond the
dimension lines.
In the picture below, [n] means ON_Annotation2::m_points[n].
[2]
|
| |
[1]-------------------------------------------[3]
| |
| TEXT
| [4]
[0]
The "x" and "y" coordinates of [0] must be (0.0, 0.0).
The "x" coordinate of [1] = "x" of [0]
The "y" coordinate of [1] can be any value.
The "x" and "y" coordinates of [2] can be any value.
The "x" coordinate of [3] = "x" coordinate of [2].
The "y" coordinate of [3] = "y" coordinate of [1].
*/
enum POINT_INDEX
{
// Do not change these enum values. They are saved in files as the
// ON_COMPONENT_INDEX.m_index value.
//
// Indices of linear dimension definition points in
// the m_points[] array
ext0_pt_index = 0, // end of first extension line
arrow0_pt_index = 1, // arrowhead tip on first extension line
ext1_pt_index = 2, // end of second extension line
arrow1_pt_index = 3, // arrowhead tip on second extension line
userpositionedtext_pt_index = 4,
dim_pt_count = 5, // number of m_points[] in an angular dim
// Points calculated from values in m_points[]
text_pivot_pt = 10000, // center of dimension text
dim_mid_pt = 10001 // midpoint of dimension line
};
ON_LinearDimension2();
~ON_LinearDimension2();
// C++ automatically provides the correct copy constructor and operator= .
//ON_LinearDimension2( const ON_LinearDimension2& );
//ON_LinearDimension2& operator=(const ON_LinearDimension2&);
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
/*
Description:
Checks the linear dimension and repairs any point locations or flags
that are not set correctly.
Returns:
0: linear dimension is damaged beyond repair
1: linear dimension was perfect and nothing needed to be repaired.
2: linear dimension had flaws that were repaired.
*/
int Repair();
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_2dPoint Dim2dPoint(
int point_index
) const;
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_3dPoint Dim3dPoint(
int point_index
) const;
// overrides virual ON_Object::IsValid
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Object::Write
ON_BOOL32 Write(ON_BinaryArchive&) const;
// overrides virual ON_Object::Read
ON_BOOL32 Read(ON_BinaryArchive&);
// overrides virual ON_Geometry::GetBBox
ON_BOOL32 GetBBox(
double*,
double*,
ON_BOOL32 = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Overrides virtual ON_Annotation2::NumericValue();
Returns:
distance between arrow tips
*/
double NumericValue() const;
/*
Description:
Get or set the DimStyle index in the dimstyle table for the dimension
Parameters:
[in] int the new index (Set)
Returns:
int - The current index (Get)
*/
int StyleIndex() const;
void SetStyleIndex( int);
/*
Description:
static function to provide the default UserText string for the object
Returns:
const wchar_t* - the default string to use
*/
static const wchar_t* DefaultText();
// 6-23-03 lw Added v2 file writing of annotation
void GetV2Form( ON_LinearDimension& dim);
bool CreateFromV2(
const ON_Annotation& v2_ann,
const ON_3dmAnnotationSettings& settings,
int dimstyle_index
);
/*
Description:
Get the annotation plane x coordinates of the dimension
line. The y coordinate of the dimension line is m_ponts[1].y.
Parameters:
gdi_text_rect - [in]
Windows rect (left < right, top < bottom) that bounds text.
The baseline of the text should be at y=0 in the rect coordinates.
gdi_height_of_I - [in]
Height of an I in the text in the same.
gdi_to_world - [in]
transform returned by ON_Annotation2::GetTextXform().
dimstyle - [in]
dimscale - [in]
vp - [in]
x - [out] plane x coordinates of the dimension line.
The y coordinate = m_points[arrow0_pt_index].y
bInside - [out] true if arrowheads go inside extension lines,
false if they go outside
Returns:
0: the input or class is not valid
1: A single line from x[0] to x[1] with arrow heads at both ends.
Arrowtips at x[4] & x[5]
2: Two lines from x[0] to x[1] and from x[1] to x[2]. The
Arrowtips at x[4] & x[5]
*/
int GetDimensionLineSegments(
ON_RECT gdi_text_rect,
int gdi_height_of_I,
ON_Xform gdi_to_world,
const ON_DimStyle& dimstyle,
double dimscale,
const ON_Viewport* vp,
double a[6],
bool& bInside
) const;
// Added for V5. 4/24/07 LW
// Get the userdata extension for this dimension
ON_DimensionExtra* DimensionExtension();
const ON_DimensionExtra* DimensionExtension() const;
};
//////////
// class ON_RadialDimension2
class ON_CLASS ON_RadialDimension2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_RadialDimension2);
public:
/*
The annotation's dimstyle controls the position of TEXT,
and the size of the arrowheads.
In the picture below, [n] means ON_Annotation2::m_points[n].
Radial dimensions do not permit user positioned text
knee
[3]--------[2] TEXT
/ (tail)
/
/
[1] (arrow head here)
+ [0] = (usually at (0,0) = center of circle)
*/
enum POINT_INDEX
{
// Do not change these enum values. They are saved in files as the
// ON_COMPONENT_INDEX.m_index value.
//
// Indices of radial dimension definition points in
// the m_points[] array
center_pt_index = 0, // location of + (usually at center of circle)
arrow_pt_index = 1, // arrow tip
tail_pt_index = 2, // end of radial dimension
knee_pt_index = 3, // number of m_points[] in a radial dim
dim_pt_count = 4, // number of m_points[] in a radial dim
// Points calculated from values in m_points[]
text_pivot_pt = 10000 // start/end of dimension text at tail
};
ON_RadialDimension2();
~ON_RadialDimension2();
// C++ automatically provides the correct copy constructor and operator= .
//ON_RadialDimension2(const ON_RadialDimension2&);
//ON_RadialDimension2& operator=(const ON_RadialDimension2&);
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_2dPoint Dim2dPoint(
int point_index
) const;
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_3dPoint Dim3dPoint(
int point_index
) const;
// overrides virual ON_Object::IsValid
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Object::Write
ON_BOOL32 Write(ON_BinaryArchive&) const;
// overrides virual ON_Object::Read
ON_BOOL32 Read(ON_BinaryArchive&);
// overrides virual ON_Geometry::GetBBox
ON_BOOL32 GetBBox(
double*,
double*,
ON_BOOL32 = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Set the plane and definition points from WCS 3d input
Parameters:
center - [in] center of circle
arrowtip - [in] 3d point on the circle at the dimension arrow tip
xaxis - [in] x axis of the dimension's plane
normal - [in] normal to the dimension's plane
offset_distance - [in] distance from arrow tip to knee point
Returns:
@untitled table
true Success
false Failure
*/
bool CreateFromPoints(
ON_3dPoint center,
ON_3dPoint arrowtip,
ON_3dVector xaxis,
ON_3dVector normal,
double offset_distance
);
/*
Description:
Overrides virtual ON_Annotation2::NumericValue();
Returns:
If m_type is ON::dtDimDiameter, then the diameter
is returned, othewise the radius is returned.
*/
double NumericValue() const;
/*
Description:
Get or set the DimStyle index in the dimstyle table for the dimension
Parameters:
[in] int the new index (Set)
Returns:
int - The current index (Get)
*/
int StyleIndex() const;
void SetStyleIndex( int);
/*
Description:
static function to provide the default UserText string for the object
Returns:
const wchar_t* - the default string to use
*/
static const wchar_t* DefaultDiameterText();
static const wchar_t* DefaultRadiusText();
// 6-23-03 lw Added v2 file writing of annotation
void GetV2Form( ON_RadialDimension& dim);
bool CreateFromV2(
const ON_Annotation& v2_ann,
const ON_3dmAnnotationSettings& settings,
int dimstyle_index
);
bool GetArrowHeadDirection( ON_2dVector& arrowhead_dir ) const;
bool GetArrowHeadTip( ON_2dPoint& arrowhead_tip ) const;
};
//////////
// class ON_AngularDimension2
class ON_CLASS ON_AngularDimension2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_AngularDimension2);
public:
/*
The annotation's dimstyle controls the position of TEXT,
the size of the arrowheads, and the amount the ends of
linear dimension's extension lines extend beyond the
dimension lines.
In the picture below, [n] means ON_Annotation2::m_points[n].
[0] = if m_userpositionedtext=true, this is the center of text.
If m_userpositionedtext=false, this point is not used and
the center of the text is at the arc's midpoint.
Always counter clockwise arc in m_plane with center = (0,0)
[1] = a point somewhere on the line from the center through the start point.
The distance from center to [1] can be any value.
[2] = a point somewhere on the line from the center through the end point.
The distance from center to [2] can be any value.
[3] = a point on the interior of the arc. The distance
from (0,0) to [3] is the radius of the arc.
/
[2]
/
/ [0]TEXT
/
/ [3]
-----(0,0)----------[1]---
/
/
/
*/
enum POINT_INDEX
{
// Do not change these enum values. They are saved in files as the
// ON_COMPONENT_INDEX.m_index value.
//
// Indices of angular dimension definition points in
// the m_points[] array
userpositionedtext_pt_index = 0, //
start_pt_index = 1, // point on the start ray (not necessarily on arc)
end_pt_index = 2, // point on the end ray (not necessarily on arc)
arc_pt_index = 3, // point on the interior of dimension arc
dim_pt_count = 4, // number of m_points[] in an angular dim
// Points calculated from values in m_points[]
text_pivot_pt = 10000, // center of dimension text
arcstart_pt = 10001,
arcend_pt = 10002,
arcmid_pt = 10003,
arccenter_pt = 10004, // center of circle arc lies on
extension0_pt = 10005, // point where first extension line starts
extension1_pt = 10006 // point where second extension line starts
};
ON_AngularDimension2();
~ON_AngularDimension2();
// C++ copy constructor and operator= work fine.
//ON_AngularDimension2(const ON_AngularDimension2&);
//ON_AngularDimension2& operator=(const ON_AngularDimension2&);
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_2dPoint Dim2dPoint(
int point_index
) const;
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_3dPoint Dim3dPoint(
int point_index
) const;
// overrides virual ON_Object::IsValid
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Geometry::GetBBox
ON_BOOL32 GetBBox(
double*,
double*,
ON_BOOL32 = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Read from or write to a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Write( ON_BinaryArchive& file ) const;
ON_BOOL32 Read( ON_BinaryArchive& file );
/*
Description:
Set the plane and definition points from 3d points
in world coordinates.
Parameters:
apex - [in] 3d apex of the dimension
(center of arc)
p0 - [in] 3d point on first line
p1 - [in] 3d point on second line
arcpt - [in] 3d point on dimension arc
(determines radius of arc)
Normal - [in] normal of the plane on which to make the dimension
(must be perpendicular to p0-apex and p1-apex)
Returns:
@untitled table
true Success
false Failure
*/
bool CreateFromPoints(
const ON_3dPoint& apex,
const ON_3dPoint& p0,
const ON_3dPoint& p1,
ON_3dPoint& arcpt,
ON_3dVector& Normal
);
/*
Description:
Set the plane and definition points from a 3d arc.
Parameters:
arc - [in]
Returns:
@untitled table
true Success
false Failure
*/
bool CreateFromArc(
const ON_Arc& arc
);
bool CreateFromV2(
const ON_Annotation& v2_ann,
const ON_3dmAnnotationSettings& settings,
int dimstyle_index
);
bool GetArc( ON_Arc& arc ) const;
bool GetExtensionLines(ON_Line extensions[2]) const;
// Set or get the measured angle in radians
void SetAngle( double angle);
double Angle() const;
void SetRadius( double radius);
double Radius() const;
/*
Description:
Overrides virtual ON_Annotation2::NumericValue();
Returns:
Angle in degrees
*/
double NumericValue() const;
/*
Description:
Get or set the DimStyle index in the dimstyle table for the dimension
Parameters:
[in] int the new index (Set)
Returns:
int - The current index (Get)
*/
int StyleIndex() const;
void SetStyleIndex( int);
/*
Description:
static function to provide the default UserText string for the object
Returns:
const wchar_t* - the default string to use
*/
static const wchar_t* DefaultText();
/*
Description:
Convert back to the version of ON_Annotation used in Rhino 2
Parameters:
target [out] the old-style object
Returns:
@untitled table
true Success
False Failure
See Also: ON_AnnotationObject::ConvertBack()
*/
using ON_Annotation2::ConvertBack;
void ConvertBack( ON_AngularDimension2& target);
// 6-23-03 lw Added v2 file writing of annotation
void GetV2Form( ON_AngularDimension& dim);
double m_angle; // angle being dimensioned
double m_radius; // radius for dimension arc
/*
Description:
Get the annotation plane angles of the dimension arc.
Parameters:
gdi_text_rect - [in] Windows rect (left < right, top < bottom)
that bounds text.
gdi_height_of_I - [in]
Height of an I in the text.
gdi_to_world - [in]
transform returned by ON_Annotation2::GetTextXform().
dimstyle - [in]
dimscale - [in]
vp - [in]
a - [out]
angles at the ends of the arc segment(s) and the arrow tips
bInside - [out] true if arrowheads go inside, false if they go outside
Returns:
number of arc segments to draw
0: the input or class is not valid
1: A single arc from a[0] to a[1] with arrow heads at a[4] & a[5].
2: Two arcs from a[0] to a[1] & from a[2] to a[3].
Arrowheads are at a[4] & a[5].
*/
int GetDimensionArcSegments(
ON_RECT gdi_text_rect,
int gdi_height_of_I,
ON_Xform gdi_to_world,
const ON_DimStyle& dimstyle,
double dimscale,
const ON_Viewport* vp,
double a[6],
bool& bInside
) const;
/*
Description:
Get distance from dimension apex to extension line offset points
Parameters:
index - [in] which distance to get
Returns:
Distance to offset point [index]
*/
double DimpointOffset(
int index) const;
/*
Description:
Set distance from dimension apex to extension line offset points
Parameters:
index - [in] which distance to set
offset - [in] Value to set
*/
void SetDimpointOffset(
int index,
double offset);
};
/*
class ON_LinearDimension2
Description:
Override od ON_Annotation2 to provide linear dimensions
*/
class ON_CLASS ON_OrdinateDimension2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_OrdinateDimension2);
public:
/*
In the picture below, [n] means ON_Annotation2::m_points[n].
Measures in X direction
[1]
|
|
|
|
|
[0]
+
[plane origin] [plane origin]
+
or - Measures in Y direction *---[1]
/
/
[0]--------------------[1] [0]---------------*
* = calculated, not stored
+
[plane origin]
The reference point of for the dimension is at the entity plane origin
The "x" and "y" coordinates of [1] can be any value.
The "x" and "y" coordinates of [2] can be any value.
If Direction is "x", the dimension measures along the "x" axis
If Direction is "y", the dimension measures along the "y" axis
If Direction is "x" and [1][x] <> [0][x], an offset segment is drawn
If Direction is "y" and [1][y] <> [0][y], an offset segment is drawn
The dimension lines are always drawn in the X or Y directions of the entity plane
The distance represented by the dimension is measured from the
plane origin to point [0], parallel to the appropriate axis.
The points of the offset segment are calculated rather than stored
*/
enum POINT_INDEX
{
// Do not change these enum values. They are saved in files as the
// ON_COMPONENT_INDEX.m_index value.
//
// Indices of linear dimension definition points in
// the m_points[] array
definition_pt_index = 0, // First end of the dimension line
leader_end_pt_index = 1, // Other end of the leader (near the text)
dim_pt_count = 2, // Number of m_points[] in an ordinate dim
// Points calculated from values in m_points[]
text_pivot_pt = 10000, // Center of dimension text
offset_pt_0 = 10001, // First offset point (nearest text)
offset_pt_1 = 10002 // Second offset point
};
enum DIRECTION
{
x = 0, // measures horizontally
y = 1 // measures vertically
};
ON_OrdinateDimension2();
~ON_OrdinateDimension2();
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
default_offset [in] - kink offset to use if m_kink_offset_0
or m_kink_offset_1 are ON_UNSET_VALUE
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_2dPoint Dim2dPoint(
int point_index,
double default_offset = 1.0
) const;
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
default_offset [in] - kink offset to use if m_kink_offset_0
or m_kink_offset_1 are ON_UNSET_VALUE
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_3dPoint Dim3dPoint(
int point_index,
double default_offset = 1.0
) const;
// overrides virual ON_Object::IsValid
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Geometry::GetBBox
ON_BOOL32 GetBBox(
double* boxmin,
double* boxmax,
ON_BOOL32 bGrowBox = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Read from or write to a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Write( ON_BinaryArchive& file ) const;
ON_BOOL32 Read( ON_BinaryArchive& file );
/*
Description:
Overrides virtual ON_Annotation2::NumericValue();
Returns:
If Direction is 'X', x coordinate of point[1]
If Direction is 'Y', y coordinate of point[1]
*/
double NumericValue() const;
/*
Description:
Get or set the DimStyle index in the dimstyle table for the dimension
Parameters:
[in] int the new index (Set)
Returns:
int - The current index (Get)
*/
int StyleIndex() const;
void SetStyleIndex( int);
/*
Description:
Gets the direction ( X or Y) that the ordinate dimension measures
based on the relative location of the defining point and leader endpoint
Returns:
0: measures parallel to the entity plane x axis
1: measures parallel to the entity plane y axis
Remarks:
This does not consider the dimension's explicit Direction setting
*/
int ImpliedDirection() const;
/*
Description:
Gets or sets the direction ( X or Y) that the ordinate dimension measures
Returns:
-1: direction determined by dim point and leader point
0: measures parallel to the entity plane x axis
1: measures parallel to the entity plane y axis
*/
int Direction() const;
void SetDirection( int direction);
/*
Description:
Get the height of the text in this dimension
by asking the dimension's dimstyle
Returns:
double Height of the text
Remarks:
Height is in model units
double Height() const;
*/
/*
Description:
static function to provide the default UserText string for the object
Returns:
const wchar_t* - the default string to use
*/
static const wchar_t* DefaultText();
/*
Description:
Returns or sets the offset distance parallel to the dimension
line direction of from the text end of the dimension line to
the offset point
If the offset point hasn't been explicitly defined, returns
ON_UNSET_VALUE and a default should be used to find the point.
Parameters:
index [in] - which offset distance to return
(0 is closer to the text)
offset [in] - the offset distance to set
*/
double KinkOffset( int index) const;
void SetKinkOffset( int index, double offset);
int m_direction; // -1 == undetermined
// 0 == x direction
// 1 == y direction
// kink offsets added 2-4-06 - LW
double m_kink_offset_0; // from leader_end_point to first break point
double m_kink_offset_1; // from first break point to second break point
/*
Description:
Calculates the 2d point locations of the dimension line kinks
Parameters:
p0, p1 [in] - End points of the dimension line
direction [in] - orientation of the dimension
default_offset [in] - Use this if offsets are ON_UNSET_VALUE
k0, k1 [out] - The kink points
Remarks:
The offsets must be set to the right values before calling this, or
If they are ON_UNSET_VALUE, they will be set to the defaults
*/
void CalcKinkPoints( ON_2dPoint p0, ON_2dPoint p1,
int direction, double default_offset,
ON_2dPoint& k0, ON_2dPoint& k1) const;
};
//////////
// class ON_TextEntity2
class ON_CLASS ON_TextEntity2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_TextEntity2);
public:
ON_TextEntity2();
~ON_TextEntity2();
// overrides virual ON_Object::IsValid
// Text entities with strings that contain no "printable" characters
// are considered to be NOT valid.
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Object::Write
ON_BOOL32 Write(ON_BinaryArchive&) const;
// overrides virual ON_Object::Read
ON_BOOL32 Read(ON_BinaryArchive&);
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
// overrides virual ON_Geometry::GetBBox
// This just adds the text base point to the box
// There is no calculation of the size of the text or its bounds
ON_BOOL32 GetBBox(
double*,
double*,
ON_BOOL32 = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
// This just adds the text base point to the box
// There is no calculation of the size of the text or its bounds
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Get or set the Font index in the Font Table for the text
Parameters:
[in] int the new index (Set)
Returns:
int - The current index (Get)
*/
int FontIndex() const;
void SetFontIndex( int);
// 6-23-03 lw Added v2 file writing of annotation
void GetV2Form( ON_TextEntity& text);
void SetJustification( unsigned int justification);
unsigned int Justification();
// Determines whether or not to draw a Text Mask
bool DrawTextMask() const;
void SetDrawTextMask(bool bDraw);
// Determines where to get the color to draw a Text Mask
// 0: Use background color of the viewport. Initially, gradient backgrounds will not be supported
// 1: Use the ON_Color returned by MaskColor()
int MaskColorSource() const;
void SetMaskColorSource(int source);
ON_Color MaskColor() const; // Only works right if MaskColorSource returns 1.
// Does not return viewport background color
void SetMaskColor(ON_Color color);
// Offset for the border around text to the rectangle used to draw the mask
// This number * CRhinoAnnotation::TextHeight() for the text is the offset
// on each side of the tight rectangle around the text characters to the mask rectangle.
double MaskOffsetFactor() const;
void SetMaskOffsetFactor(double offset);
// Scale annotation according to detail scale factor in paperspace
// or by 1.0 in paperspace and not in a detail
// Otherwise, dimscale or text scale is used
bool AnnotativeScaling() const;
void SetAnnotativeScaling(bool b);
};
//////////
// class ON_Leader2
class ON_CLASS ON_Leader2 : public ON_Annotation2
{
ON_OBJECT_DECLARE(ON_Leader2);
public:
/*
The annotation's dimstyle controls the position of TEXT,
the size of the arrowheads, and the amount the ends of
linear dimension's extension lines extend beyond the
dimension lines.
Leaders:
Polyline with N=m_points.Count() points (N >= 2).
[N-2] ----- [N-1] TEXT
/ (tail)
/
/
[1]------[2]
/
/
/
[0] (arrow)
Leaders ignore the m_userpositionedtext setting. If the
default leader text handling is not adequate, then use
a leader with no text and an ON_TextEntity2.
*/
enum POINT_INDEX
{
// Do not change these enum values. They are saved in files as the
// ON_COMPONENT_INDEX.m_index value.
//
// Indices of leader definition points in
// the m_points[] array
arrow_pt_index = 0, // arrow tip
// Points calculated from values in m_points[]
text_pivot_pt = 10000, // start/end of dimension text at tail
tail_pt = 10001
};
// Constructors
ON_Leader2();
~ON_Leader2();
// C++ automatically provides the correct copy constructor and operator= .
//ON_Leader2(const ON_Leader2&);
//ON_Leader2& operator=(const ON_Leader2&);
// overrides virtual ON_Geometry::Transform()
ON_BOOL32 Transform( const ON_Xform& xform );
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_2dPoint Dim2dPoint(
int point_index
) const;
/*
Description:
Get the m_plane coordinates of the dimension point.
Parameters:
point_index - [in] One of the POINT_INDEX enum values
Returns:
2d point or ON_UNSET_POINT if point_index or m_points[]
array is not valid.
*/
ON_3dPoint Dim3dPoint(
int point_index
) const;
// overrides virual ON_Object::IsValid
ON_BOOL32 IsValid( ON_TextLog* text_log = 0 ) const;
// overrides virual ON_Object::Write
ON_BOOL32 Write(ON_BinaryArchive&) const;
// overrides virual ON_Object::Read
ON_BOOL32 Read(ON_BinaryArchive&);
// overrides virual ON_Geometry::GetBBox
ON_BOOL32 GetBBox(
double*,
double*,
ON_BOOL32 = false
) const;
// overrides virual ON_Geometry::GetTightBoundingBox
bool GetTightBoundingBox(
ON_BoundingBox& tight_bbox,
int bGrowBox = false,
const ON_Xform* xform = 0
) const;
/*
Description:
Add or delete points to the leader
Parameters:
index [in] the point to delete
point [in] The point to add
Returns:
@untitled table
true Success
False Failure
*/
void AddPoint( const ON_2dPoint& point);
bool RemovePoint( int index = -1);
/*
Description:
Converts an ON_Leader2 to the v2 form ON_Leader
Parameters:
leader [out] - the result of the conversion
*/
void GetV2Form( ON_Leader& leader);
bool CreateFromV2(
const ON_Annotation& v2_ann,
const ON_3dmAnnotationSettings& settings,
int dimstyle_index
);
// April 22, 2010 Lowell - Added to support right justified text on left pointing leader tails rr64292
bool GetTextDirection( ON_2dVector& text_dir ) const;
bool GetArrowHeadDirection( ON_2dVector& arrowhead_dir ) const;
bool GetArrowHeadTip( ON_2dPoint& arrowhead_tip ) const;
};
/*
A simple dot with text that doesn't rotate witn the world axes
*/
class ON_CLASS ON_TextDot : public ON_Geometry
{
ON_OBJECT_DECLARE(ON_TextDot);
public:
ON_TextDot();
~ON_TextDot();
// C++ automatically provides the correct copy constructor and operator= .
//ON_TextDot( const ON_TextDot& src);
//ON_TextDot& operator=( const ON_TextDot& src);
void EmergencyDestroy();
//---------------------------
// ON_Object overrides
/*
Description:
Tests an object to see if its data members are correctly
initialized.
Paramters:
text_log - [in] if the object is not valid and text_log
is not NULL, then a brief english description of the
reason the object is not valid is appended to the log.
The information appended to text_log is suitable for
low-level debugging purposes by programmers and is
not intended to be useful as a high level user
interface tool.
Returns:
@untitled table
true object is valid
false object is invalid, uninitialized, etc.
Remarks:
Overrides virtual ON_Object::IsValid
*/
ON_BOOL32 IsValid( ON_TextLog* text_log = NULL ) const;
/*
Description: Write data values to a text file for debugging
*/
void Dump( ON_TextLog& log) const;
/*
Description: Writes the object to a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Write( ON_BinaryArchive& ar) const;
/*
Description: Reads the object from a file
Returns:
@untitled Table
true Success
false Failure
*/
ON_BOOL32 Read( ON_BinaryArchive& ar);
/*
Returns: The Object Type of this object
*/
ON::object_type ObjectType() const;
//---------------------------
// ON_Geometry overrides
/*
Returns the geometric dimension of the object ( usually 3)
*/
int Dimension() const;
/*
Description:
Get a bounding 3d WCS box of the object
Parameters:
[in/out] double* boxmin - pointer to dim doubles for min box corner
[in/out] double* boxmax - pointer to dim doubles for max box corner
[in] ON_BOOL32 growbox - true to grow the existing box,
false ( the default) to reset the box
Returns:
true = Success
false = Failure
Remarks:
Since the bounding box of this entity changes size at different
zoom levels, the bounding box is a point at the definition point
*/
ON_BOOL32 GetBBox( double* box_min, double* box_max, ON_BOOL32 grow_box = false) const;
/*
Description:
Transform the object by a 4x4 xform matrix
Parameters:
[in] xform - An ON_Xform with the transformation information
Returns:
true = Success
false = Failure
Remarks:
The object has been transformed when the function returns
*/
ON_BOOL32 Transform( const ON_Xform& xform);
// virtual ON_Geometry::IsDeformable() override
bool IsDeformable() const;
// virtual ON_Geometry::MakeDeformable() override
bool MakeDeformable();
const ON_3dPoint& Point() const;
void SetPoint( const ON_3dPoint& point);
int Height() const;
void SetHeight( int);
const wchar_t* TextString() const;
void SetTextString( const wchar_t* string);
const wchar_t* FontFace() const;
void SetFontFace( const wchar_t* face);
/*
Description:
Get or Set whether the dot is drawn "On Top" of other geometry
Parameters:
[in] bTop bool - It is or isn't on top
Returns:
@untitled table
true - on top
false - not on top
*/
void SetAlwaysOnTop(bool bTop);
bool AlwaysOnTop() const;
/*
Description:
Get or Set whether the dot is drawn with a transparent background
Parameters:
[in] bTransparent bool - It is or isn't transparent
Returns:
@untitled table
true - transparent
false - not transparent
*/
void SetTransparent(bool bTransparent);
bool Transparent() const;
/*
Description:
Get or Set whether the dot is drawn with Bold text
Parameters:
[in] bBold bool - It is or isn't Bold
Returns:
@untitled table
true - Bold
false - not Bold
*/
void SetBold(bool bBold);
bool Bold() const;
/*
Description:
Get or Set whether the dot is drawn with Italic text
Parameters:
[in] bItalic bool - It is or isn't Italic
Returns:
@untitled table
true - Italic
false - not Italic
*/
void SetItalic(bool bItalic);
bool Italic() const;
ON_3dPoint m_point;
int m_height; // in points
ON_wString m_text;
ON_wString m_fontface;
int m_display; // some future display flags -
};
#endif