forked from mcneel/opennurbs
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathopennurbs_annotationbase.h
1177 lines (958 loc) · 40.6 KB
/
opennurbs_annotationbase.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
/* $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>.
//
////////////////////////////////////////////////////////////////
*/
#if !defined(OPENNURBS_ANNOTATIONBASE_INC_)
#define OPENNURBS_ANNOTATIONBASE_INC_
class ON_CLASS ON_Annotation : public ON_Geometry
{
ON_OBJECT_DECLARE(ON_Annotation);
protected:
ON_Annotation( ON::AnnotationType annotation_type );
ON_Annotation( const ON_Annotation& src);
~ON_Annotation();
ON_Annotation& operator=(const ON_Annotation& src);
public:
static ON_Annotation* CreateFromV2Annotation(
const class ON_OBSOLETE_V2_Annotation& V2_annotation,
const class ON_3dmAnnotationContext* annotation_context
);
public:
static ON_Annotation* CreateFromV5Annotation(
const class ON_OBSOLETE_V5_Annotation& V5_annotation,
const class ON_3dmAnnotationContext* annotation_context
);
protected:
void Internal_SetDimStyleFromV5Annotation(
const class ON_OBSOLETE_V5_Annotation& V5_annotation,
const class ON_3dmAnnotationContext* annotation_context
);
private:
ON_Annotation() = delete;
private:
void Internal_CopyFrom(const ON_Annotation& src);
void Internal_Destroy();
public:
/*
Returns:
An ON::AnnotationType value that indicates the
type of the annotation.
*/
ON::AnnotationType Type() const;
ON::object_type ObjectType() const override;
bool IsValid( class ON_TextLog* text_log = nullptr ) const override;
virtual bool GetAnnotationBoundingBox(
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
double dimscale,
double* boxmin,
double* boxmax,
bool bGrow = false
) const = 0;
/*
Parameters:
vp - [in]
nullptr or viewport where annotation object is displayed
dimstyle - [in]
&this->DimensionStyle(const ON_DimStyle& parent_dimstyle)
bApplyDimStyleDimScale - [in]
If true, dimsytyle->DimScale() is applied.
If vp is a page view, bApplyDimStyleDimScale is generally false.
If vp is a model view, bApplyDimStyleDimScale is generally
the value of a model property IsAnnotationScalingEnabled().
from
bSingleStrokeFont - [in]
True if text uses a single font that is a single stroke font and returned contours
should be left open.
text_contours - [out]
*/
bool GetTextGlyphContours(
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
bool bApplyDimStyleDimScale,
bool bSingleStrokeFont,
ON_ClassArray< ON_ClassArray< ON_SimpleArray< ON_Curve* > > >& text_contours
) const;
protected:
/*
Parameters:
vp - [in]
nullptr or viewport where annotation object is displayed
dimstyle - [in]
&this->DimensionStyle(const ON_DimStyle& parent_dimstyle)
*/
const ON_SHA1_Hash Internal_GetBBox_InputHash(
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
double dimscale,
const ON_2dPoint& text_point,
unsigned int point_count,
const ON_2dPoint* points
) const;
/*
Parameters:
vp - [in]
nullptr or viewport where annotation object is displayed
dimstyle - [in]
&this->DimensionStyle(const ON_DimStyle& parent_dimstyle)
*/
bool Internal_GetBBox_TextGlyphBox(
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
double dimscale,
ON_BoundingBox& text_glyph_box
) const;
/*
Returns:
True if a cached bounding box was found
and boxmin, boxmax are set.
*/
bool Internal_GetBBox_Begin(
const ON_SHA1_Hash& hash,
double* boxmin,
double* boxmax,
bool bGrow
) const;
/*
Returns:
True if a boxmin, boxmax is a valid bounding box
*/
bool Internal_GetBBox_End(
const ON_BoundingBox& bbox,
const ON_SHA1_Hash& hash,
double* boxmin,
double* boxmax,
bool bGrow
) const;
public:
virtual bool GetTextXform(
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
double dimscale,
ON_Xform& text_xform_out
) const = 0;
bool GetTextXform(
const ON_Xform* model_xform,
const ON_Viewport* vp,
const ON_DimStyle* dimstyle,
double dimscale,
ON_Xform& text_xform_out
) const;
void SetPlane(const ON_Plane& plane);
const ON_Plane& Plane() const;
void SetHorizontalDirection(ON_2dVector);
const ON_2dVector HorizontalDirection() const;
// Returns a 2d vector to use as annotation horizontal
// Use this function when you don't have a known horizontal direction
static ON_3dVector GetDefaultHorizontal(const ON_Plane& plane);
static void CalcTextFlip(
const ON_3dVector& text_xdir, const ON_3dVector& text_ydir, const ON_3dVector& text_zdir,
const ON_3dVector& view_xdir, const ON_3dVector& view_ydir, const ON_3dVector& view_zdir,
const ON_Xform* model_xform,
const double flip_tol,
bool& flip_x,
bool& flip_y);
/*
Returns:
Rich text that can contain rich text formatting instructions.
*/
const ON_wString RichText() const;
/*
Returns:
Text information with rich text formatting insturctions removed.
Fields are not evaluated.
*/
const ON_wString PlainText() const;
/*
Returns:
Text information with rich text formatting insturctions removed.
The result string from evaluating fields is included
Field results may be cached from previous evaluation
*/
const ON_wString PlainTextWithFields() const;
/*
Finds the positions and lengths of substrings in the string returned by PlainTextWithFields()
That string is the plain text (no rtf formatting) with field source unevaluated
Each 3dex in the array is
i: run index,
j: position in the string where text from run[i] starts,
k: length of text from run[i]
Returns the same string that PlainTextWithFields() returns
*/
const ON_wString PlainTextWithFields(ON_SimpleArray<ON_3dex>* runmap) const;
// Return the id of the main (parent) dimstyle used by this object.
// The style with this id should not be used directly if there is
// an override dimstyle present.
// Use this->DimensionStyle(parent_style) to get the effective
// dimstyle for this object.
ON_UUID DimensionStyleId() const;
// Sets the id of the main (parent) dimstyle used by this annotation object
// Any override dimstyle on this object will be deleted when this is called,
// resetting any style overrides.
void SetDimensionStyleId(ON_UUID dimstyle_id);
/*
Description:
Set the id of the main (parent) dimstyle used by this annotation object
and allow an expert user to control what happens to style override settings
in cases where id collisions occur and ids need to be changed.
Parameters:
bKeepOverrides - [in]
If you are not an expert oding something low level and complicated, then
call SetDimensionStyleId(dimstyle_id) or pass bKeepOverrides = false.
If bKeepOverrides is true and dimstyle_id is not nil and this object has
valid overrides, those overrides are retained. In all other cases, any
existing overrides are deleted.
*/
void SetDimensionStyleIdForExperts(
ON_UUID dimstyle_id,
bool bKeepOverrides
);
/*
parameters:
dim_style - [in]
If dim_style.ParentId() is nil, then this function
calls SetDimensionStyleId(dim_style.Id()) and returns.
If dim_style.ParentId() is not nil, then this functions
calls SetDimensionStyleId(dim_style.ParentId()) and uses a copy
of dim_style as the override dimstyle.
*/
void SetDimensionStyleId(
const class ON_DimStyle& dim_style
);
// Get the proper dimension style, including overrides, to use for this
// annotation object.
// If there is an override in place, that dimstyle will be returned
// If there is no override, the parent style passed in will be returned
// If the content of the parent style has changed since the override was made,
// the override style will be updated with the non-overriden values from
// the parent before returning.
// If your annotation object has an override style and you call either of
// these functions with a dimstyle other than the correct parent style
// for this annotation, the override style will be removed.
const ON_DimStyle& DimensionStyle(const ON_DimStyle& parent_dimstyle) const;
const ON_DimStyle& DimensionStyle(
const ON_DimStyle& parent_dimstyle,
bool bForceOverrideUpdate
) const;
// Apply a dimstyle with overrides set to this annotation object.
//
// Use ON_Annotation::IsOverrideDimStyleCandidate() to determine if a non-nullptr
// override_style is a valid to be used to set overrides.
//
// The override dimstyle memory will be managed and deleted by the annotation object and
// must have been allocated using new.
// On return, if this function returns true,
// The dimstyle id of the annotation object must be set before this function is called.
// Calling SetOverrideDimensionStyle(nullptr) will remove all overrides for this object.
// override_dimstyle will be null.
//
// Returns:
// true if the override style was successfully set
// false if this->m_dimstyle_id is ON_nil_uuid causing failure
bool SetOverrideDimensionStyle(ON_DimStyle*& override_style) const;
/*
Description:
Removes any override dimension style that is present.
*/
void ClearOverrideDimensionStyle();
/*
Description:
If this->IsOverrideDimStyleCandidate(override_style_candidate,bRequireSetOverrides)
is true, then a managed copy of override_style_candidate is set as an override.
Returns:
True if an override is set.
*/
bool SetOverrideDimensionStyle(
const ON_DimStyle* override_style_candidate,
bool bRequireSetOverrides
);
/*
Description:
A valid override dimstyle candidate has all of the following properties.
override_style_candidate != nullptr.
IsDeleted() = false;
Id() = ON_nil_uuid;
Name() is empty.
Index() = ON_ModelComponent::Unset.Index()
bRequireSetOverrides is false or HasOverrides() returns true.
Parameters:
override_style_candidate -[in]
style candidate to evaluate.
bRequireSetOverrides - [in]
If bRequireSetOverrides is true, then override_style_candidate->HasOverrides() must be true for a valid candidate.
If bRequireSetOverrides is flase, then override_style_candidate->HasOverrides() can have any value.
Returns:
True if override_style could be successfully used as the parameter
to SetOverrideDimensionStyle.
*/
bool IsOverrideDimStyleCandidate(
const ON_DimStyle* override_style_candidate,
bool bRequireSetOverrides
) const;
/*
Description:
Conceptually, calling this function applies ON_DimsStyle(scale) to the
dimstyle information used for this annotation.
When an annotation object is in **layout/page space**, this is
the only way top get properties like TextHeight() to scale properly.
When an annotation object is in **model space** and
**model space scaling is enabled**,
then calling this->SetDimScale(this->DimScale()*scale)
will work as well.
Parameters:
parent_dimstyle - [in]
scale - [in]
*/
void ScaleOverrideDimstyle(
const ON_DimStyle* parent_dimstyle,
double scale
);
protected:
static bool Internal_IsOverrideDimStyleCandidate(
const ON_DimStyle* override_style_candidate,
ON_UUID parent_id,
bool bRequireSetOverrides,
bool bIssueErrorsAndWarnings
);
public:
// Quickly check if this annotation object has style overrides applied.
bool HasDimensionStyleOverrides() const;
const ON_TextContent* Text() const;
ON_TextContent* Text();
void SetText(ON_TextContent*& text) const;
void ClearText() const;
// return angle in radians between text plane and object plane
virtual double TextRotationRadians() const;
virtual void SetTextRotationRadians(double rotation);
// return angle in degrees between text plane and object plane
virtual double TextRotationDegrees() const;
virtual void SetTextRotationDegrees(double rotation);
//virtual bool Explode(
// const ON_DimStyle* dimstyle,
// ON_SimpleArray<const ON_Geometry*> object_parts) const = 0;
/*
Returns:
The value of ON_DimStyle.TextPositionPropertiesHash() from the dimension style used
to calculate the runtime text position (location, glyphs, and size).
*/
ON_SHA1_Hash DimStyleTextPositionPropertiesHash() const;
/*
Returns:
True if this text position information used to create this text
is identical to the text position paramters on dimstyle.
*/
bool EqualTextPositionProperties(
const class ON_DimStyle* dimstyle
) const;
const wchar_t* RtfText() const;
bool ReplaceTextString(
const wchar_t* RtfString,
const ON_DimStyle* dimstyle
);
bool RunReplaceString(
const ON_DimStyle* dimstyle,
const wchar_t* str,
int start_run_idx,
int start_run_pos,
int end_run_idx,
int end_run_pos);
void GetAlignment(ON::TextHorizontalAlignment& horz, ON::TextVerticalAlignment& vert) const;
void SetAlignment(ON::TextHorizontalAlignment horz, ON::TextVerticalAlignment vert);
// FormattingRectangleWidth is a width set by text wrapping. It's in model units
double FormattingRectangleWidth() const;
void SetFormattingRectangleWidth(double width);
// Get corners of the whole text object
// corners requires space for 4 points
bool GetText3dCorners(ON_3dPoint corners[4]) const;
/*
Parameters:
ptr - [in]
pointer to test
Returns:
True if ptr is not nullptr and points to the override style mangaged by this
instance.
*/
bool IsOverrideStylePointer(
const ON_DimStyle* ptr
) const;
// These functions are being added to continue the V5 behavior of
// per-object text scaling. There is no user interface
// in V6 or V7 that shows this setting or that allows a user
// to change this setting.
// AllowTextScaling() = false means the effective dimstyle value
// of DimScale() (model space scale factor) is ignored (treated as if it were 1).
bool AllowTextScaling() const;
void SetAllowTextScaling(bool scale);
protected:
ON::AnnotationType m_annotation_type = ON::AnnotationType::Unset;
bool m_allow_text_scaling = true;
unsigned char m_reserved2 = 0;
unsigned char m_reserved3 = 0;
unsigned int m_reserved4 = 0;
ON_UUID m_dimstyle_id = ON_DimStyle::Default.Id();
ON_Plane m_plane = ON_Plane::World_xy; // plane origin used for alignment point
ON_2dVector m_horizontal_direction = ON_2dVector::XAxis; // direction used as horizontal to draw annotation, especially text
mutable ON_TextContent* m_text = nullptr; // Deleted by ~ON_Annotation()
private:
// Pointer to an override dimstyle when style properties are overridden for this annotation object
// If this pointer is null, use the style with id = m_dimstyle_id
// Copy and delete this dimstyle (not this pointer) with the object.
// This dimstyle should never be one held in a dimstyle table. It is owned by this object
mutable ON_DimStyle* m_override_dimstyle = nullptr;
mutable ON__UINT64 m_parent_dimstyle_content_version_number = 0;
void Internal_DeleteOverrideDimstyle() const;
mutable ON_BoundingBoxCache m_bbox_cache;
protected:
bool Internal_WriteAnnotation(
ON_BinaryArchive& archive
) const;
bool Internal_ReadAnnotation(
ON_BinaryArchive& archive
);
private:
ON_DimStyle* Internal_GetOverrideStyle(bool bCreateIfNull) const;
/*
Description:
Gets the appropriate ON_DimStyle to query for a property value.
Parameters:
parent_style - [in]
parent style pased to the ON_Annotation query function
field_id - [in]
field being queried - this is used to select between using the override style or the parent style.
*/
const ON_DimStyle& Internal_StyleForFieldQuery(
const ON_DimStyle* parent_style,
ON_DimStyle::field field_id
) const;
private:
static bool Internal_DimStyleDoubleChanged(
const double current_value,
double candidate_value
);
public:
void ClearFieldOverride(ON_DimStyle::field field);
bool FieldIsOverridden(ON_DimStyle::field field) const;
// These next several functions are to set overrides on individual annotation objects
// Extension line extension
double ExtensionLineExtension(const ON_DimStyle* parent_style) const;
void SetExtensionLineExtension(const ON_DimStyle* parent_style, double d);
// Extension line offset
double ExtensionLineOffset(const ON_DimStyle* parent_style) const;
void SetExtensionLineOffset(const ON_DimStyle* parent_style, double d);
// Arrow size
double ArrowSize(const ON_DimStyle* parent_style) const;
void SetArrowSize(const ON_DimStyle* parent_style, double d);
// Arrow size
double LeaderArrowSize(const ON_DimStyle* parent_style) const;
void SetLeaderArrowSize(const ON_DimStyle* parent_style, double d);
// Centermark size
double CenterMarkSize(const ON_DimStyle* parent_style) const;
void SetCenterMarkSize(const ON_DimStyle* parent_style, double d);
// Centermark style
ON_DimStyle::centermark_style CenterMarkStyle(const ON_DimStyle* parent_style) const;
void SetCenterMarkStyle(const ON_DimStyle* parent_style, ON_DimStyle::centermark_style style);
// The location of text relative to the dimension line in linear, angular, and ordinate dimensions.
ON_DimStyle::TextLocation DimTextLocation(const ON_DimStyle* parent_style) const;
void SetDimTextLocation(const ON_DimStyle* parent_style, ON_DimStyle::TextLocation dim_text_location);
// The location of text relative to the dimension line in radial dimensions.
ON_DimStyle::TextLocation DimRadialTextLocation(const ON_DimStyle* parent_style) const;
void SetDimRadialTextLocation(const ON_DimStyle* parent_style, ON_DimStyle::TextLocation dim_text_location);
// Angle units - Degrees, Degrees-Minutes-Seconds, Radians
ON_DimStyle::angle_format AngleFormat(const ON_DimStyle* parent_style) const;
void SetAngleFormat(const ON_DimStyle* parent_style, ON_DimStyle::angle_format format);
// Display resolution for distance measurements
int LengthResolution(const ON_DimStyle* parent_style) const;
void SetLengthResolution(const ON_DimStyle* parent_style, int r);
// Display resolution for angle measurements
int AngleResolution(const ON_DimStyle* parent_style) const;
void SetAngleResolution(const ON_DimStyle* parent_style, int r);
// Distance from dimension lines to text
double TextGap(const ON_DimStyle* parent_style) const;
void SetTextGap(const ON_DimStyle* parent_style, double gap);
// Height of dimension text
double TextHeight(const ON_DimStyle* parent_style) const;
void SetTextHeight(const ON_DimStyle* parent_style, double height);
// Scale factor for displayed distances
double LengthFactor(const ON_DimStyle* parent_style) const;
void SetLengthFactor(const ON_DimStyle* parent_style, double);
// Additional measurement display toggle
bool Alternate(const ON_DimStyle* parent_style) const;
void SetAlternate(const ON_DimStyle* parent_style, bool);
// Distance scale factor for alternate display
double AlternateLengthFactor(const ON_DimStyle* parent_style) const;
void SetAlternateLengthFactor(const ON_DimStyle* parent_style, double);
// Display resolution for alternate length measurements
int AlternateLengthResolution(const ON_DimStyle* parent_style) const;
void SetAlternateLengthResolution(const ON_DimStyle* parent_style, int);
// Dimension prefix text
const wchar_t* Prefix(const ON_DimStyle* parent_style) const;
void SetPrefix(const ON_DimStyle* parent_style, const wchar_t*);
// Dimension suffix text
const wchar_t* Suffix(const ON_DimStyle* parent_style) const;
void SetSuffix(const ON_DimStyle* parent_style, const wchar_t*);
// Dimension alternate prefix text
const wchar_t* AlternatePrefix(const ON_DimStyle* parent_style) const;
void SetAlternatePrefix(const ON_DimStyle* parent_style, const wchar_t*);
// Dimension alternate suffix text
const wchar_t* AlternateSuffix(const ON_DimStyle* parent_style) const;
void SetAlternateSuffix(const ON_DimStyle* parent_style, const wchar_t*);
// Suppress first dimension extension line
bool SuppressExtension1(const ON_DimStyle* parent_style) const;
void SetSuppressExtension1(const ON_DimStyle* parent_style, bool b);
// Suppress second dimension extension line
bool SuppressExtension2(const ON_DimStyle* parent_style) const;
void SetSuppressExtension2(const ON_DimStyle* parent_style, bool b);
// Extension of dimension line past extension lines
double DimExtension(const ON_DimStyle* parent_style) const;
void SetDimExtension(const ON_DimStyle* parent_style, const double e);
ON_DimStyle::tolerance_format ToleranceFormat(const ON_DimStyle* parent_style) const;
void SetToleranceFormat(const ON_DimStyle* parent_style, ON_DimStyle::tolerance_format format);
int ToleranceResolution(const ON_DimStyle* parent_style) const;
void SetToleranceResolution(const ON_DimStyle* parent_style, int resolution);
double ToleranceUpperValue(const ON_DimStyle* parent_style) const;
void SetToleranceUpperValue(const ON_DimStyle* parent_style, double upper_value);
double ToleranceLowerValue(const ON_DimStyle* parent_style) const;
void SetToleranceLowerValue(const ON_DimStyle* parent_style, double lower_value);
double ToleranceHeightScale(const ON_DimStyle* parent_style) const;
void SetToleranceHeightScale(const ON_DimStyle* parent_style, double scale);
double BaselineSpacing(const ON_DimStyle* parent_style) const;
void SetBaselineSpacing(const ON_DimStyle* parent_style, double spacing);
// Determines whether or not to draw a Text Mask
bool DrawTextMask(const ON_DimStyle* parent_style) const;
void SetDrawTextMask(const ON_DimStyle* parent_style, bool bDraw);
// Determines where to get the color to draw a Text Mask
ON_TextMask::MaskType MaskFillType(const ON_DimStyle* parent_style) const;
void SetMaskFillType(const ON_DimStyle* parent_style, ON_TextMask::MaskType source);
// Determines whether to draw a frame around a text mask
ON_TextMask::MaskFrame MaskFrameType(const ON_DimStyle* parent_style) const;
void SetMaskFrameType(const ON_DimStyle* parent_style, ON_TextMask::MaskFrame source);
ON_Color MaskColor(const ON_DimStyle* parent_style) const; // Only works right if MaskColorSource returns 1.
void SetMaskColor(const ON_DimStyle* parent_style, ON_Color color); // Does not return viewport background color
// Offset for the border around text to the rectangle used to draw the mask
// This number is the offset on each side of the tight rectangle around the
// text characters to the mask rectangle.
double MaskBorder(const ON_DimStyle* parent_style) const;
void SetMaskBorder(const ON_DimStyle* parent_style, double offset);
// The ON_TextMask class contains the property values for
// DrawTextMask()
// MaskColor()
// MaskFillType()
// MaskBorder()
// Use the
// DrawTextMask()
// MaskColor()
// MaskFillType()
// MaskBorder()
// functions to query individual text mask properties.
void SetTextMask(const ON_DimStyle* parent_style, const ON_TextMask& mask);
double FixedExtensionLength(const ON_DimStyle* parent_style) const;
void SetFixedExtensionLength(const ON_DimStyle* parent_style, double l);
bool FixedExtensionLengthOn(const ON_DimStyle* parent_style) const;
void SetFixedExtensionLengthOn(const ON_DimStyle* parent_style, bool on);
int AlternateToleranceResolution(const ON_DimStyle* parent_style) const;
void SetAlternateToleranceResolution(const ON_DimStyle* parent_style, int r);
bool SuppressArrow1(const ON_DimStyle* parent_style) const;
void SetSuppressArrow1(const ON_DimStyle* parent_style, bool s);
bool SuppressArrow2(const ON_DimStyle* parent_style) const;
void SetSuppressArrow2(const ON_DimStyle* parent_style, bool s);
int TextMoveLeader(const ON_DimStyle* parent_style) const;
void SetTextMoveLeader(const ON_DimStyle* parent_style, int m);
int ArcLengthSymbol(const ON_DimStyle* parent_style) const;
void SetArcLengthSymbol(const ON_DimStyle* parent_style, int m);
ON_DimStyle::stack_format StackFractionFormat(const ON_DimStyle* parent_style) const;
void SetStackFractionFormat(const ON_DimStyle* parent_style, ON_DimStyle::stack_format f);
double StackHeightScale(const ON_DimStyle* parent_style) const;
void SetStackHeightScale(const ON_DimStyle* parent_style, double f);
double RoundOff(const ON_DimStyle* parent_style) const;
void SetRoundOff(const ON_DimStyle* parent_style, double r);
double AlternateRoundOff(const ON_DimStyle* parent_style) const;
void SetAlternateRoundOff(const ON_DimStyle* parent_style, double r);
double AngleRoundOff(const ON_DimStyle* parent_style) const;
void SetAngleRoundOff(const ON_DimStyle* parent_style, double r);
ON_DimStyle::suppress_zero ZeroSuppress(const ON_DimStyle* parent_style) const;
void SetZeroSuppress(const ON_DimStyle* parent_style, ON_DimStyle::suppress_zero s);
ON_DimStyle::suppress_zero AlternateZeroSuppress(const ON_DimStyle* parent_style) const;
void SetAlternateZeroSuppress(const ON_DimStyle* parent_style, ON_DimStyle::suppress_zero s);
// OBSOLETE - The ZeroSuppress() or AlternateZeroSuppress() property
// is used to format tolerance display. ToleranceZeroSuppress() is ignored.
ON_DimStyle::suppress_zero ToleranceZeroSuppress(const ON_DimStyle* parent_style) const;
// OBSOLETE - The ZeroSuppress() or AlternateZeroSuppress() property
// is used to format tolerance display. ToleranceZeroSuppress() is ignored.
void SetToleranceZeroSuppress(const ON_DimStyle* parent_style, ON_DimStyle::suppress_zero s);
ON_DimStyle::suppress_zero AngleZeroSuppress(const ON_DimStyle* parent_style) const;
void SetAngleZeroSuppress(const ON_DimStyle* parent_style, ON_DimStyle::suppress_zero s);
bool AlternateBelow(const ON_DimStyle* parent_style) const;
void SetAlternateBelow(const ON_DimStyle* parent_style, bool below);
ON_Arrowhead::arrow_type ArrowType1(const ON_DimStyle* parent_style) const;
void SetArrowType1(const ON_DimStyle* parent_style, ON_Arrowhead::arrow_type);
ON_Arrowhead::arrow_type ArrowType2(const ON_DimStyle* parent_style) const;
void SetArrowType2(const ON_DimStyle* parent_style, ON_Arrowhead::arrow_type);
void SetArrowType1And2(const ON_DimStyle* parent_style, ON_Arrowhead::arrow_type);
ON_Arrowhead::arrow_type LeaderArrowType(const ON_DimStyle* parent_style) const;
void SetLeaderArrowType(const ON_DimStyle* parent_style, ON_Arrowhead::arrow_type);
ON_UUID ArrowBlockId1(const ON_DimStyle* parent_style) const;
void SetArrowBlockId1(const ON_DimStyle* parent_style, ON_UUID id);
ON_UUID ArrowBlockId2(const ON_DimStyle* parent_style) const;
void SetArrowBlockId2(const ON_DimStyle* parent_style, ON_UUID id);
ON_UUID LeaderArrowBlockId(const ON_DimStyle* parent_style) const;
void SetLeaderArrowBlockId(const ON_DimStyle* parent_style, ON_UUID id);
ON::TextVerticalAlignment TextVerticalAlignment(const ON_DimStyle* parent_style) const;
void SetTextVerticalAlignment(const ON_DimStyle* parent_style, ON::TextVerticalAlignment style);
ON::TextVerticalAlignment LeaderTextVerticalAlignment(const ON_DimStyle* parent_style) const;
void SetLeaderTextVerticalAlignment(const ON_DimStyle* parent_style, ON::TextVerticalAlignment style);
ON_DimStyle::ContentAngleStyle LeaderContentAngleStyle(const ON_DimStyle* parent_style) const;
void SetLeaderContentAngleStyle(const ON_DimStyle* parent_style, ON_DimStyle::ContentAngleStyle style);
ON_DimStyle::leader_curve_type LeaderCurveType(const ON_DimStyle* parent_style) const;
void SetLeaderCurveType(const ON_DimStyle* parent_style, ON_DimStyle::leader_curve_type type);
bool LeaderHasLanding(const ON_DimStyle* parent_style) const;
void SetLeaderHasLanding(const ON_DimStyle* parent_style, bool landing);
double LeaderLandingLength(const ON_DimStyle* parent_style) const;
void SetLeaderLandingLength(const ON_DimStyle* parent_style, double length);
double LeaderContentAngleRadians(const ON_DimStyle* parent_style) const;
void SetLeaderContentAngleRadians(const ON_DimStyle* parent_style, double angle_radians);
double LeaderContentAngleDegrees(const ON_DimStyle* parent_style) const;
void SetLeaderContentAngleDegrees(const ON_DimStyle* parent_style, double angle_degrees);
ON_DimStyle::ContentAngleStyle DimTextAngleStyle(const ON_DimStyle* parent_style) const;
void SetDimTextAngleStyle(const ON_DimStyle* parent_style, ON_DimStyle::ContentAngleStyle style);
ON_DimStyle::ContentAngleStyle DimRadialTextAngleStyle(const ON_DimStyle* parent_style) const;
void SetDimRadialTextAngleStyle(const ON_DimStyle* parent_style, ON_DimStyle::ContentAngleStyle style);
ON::TextHorizontalAlignment TextHorizontalAlignment(const ON_DimStyle* parent_style) const;
void SetTextHorizontalAlignment(const ON_DimStyle* parent_style, ON::TextHorizontalAlignment halign);
ON::TextHorizontalAlignment LeaderTextHorizontalAlignment(const ON_DimStyle* parent_style) const;
void SetLeaderTextHorizontalAlignment(const ON_DimStyle* parent_style, ON::TextHorizontalAlignment halign);
ON::TextOrientation TextOrientation(const ON_DimStyle* parent_style) const;
void SetTextOrientation(const ON_DimStyle* parent_style, ON::TextOrientation orientation);
ON::TextOrientation LeaderTextOrientation(const ON_DimStyle* parent_style) const;
void SetLeaderTextOrientation(const ON_DimStyle* parent_style, ON::TextOrientation orientation);
ON::TextOrientation DimTextOrientation(const ON_DimStyle* parent_style) const;
void SetDimTextOrientation(const ON_DimStyle* parent_style, ON::TextOrientation orientation);
ON::TextOrientation DimRadialTextOrientation(const ON_DimStyle* parent_style) const;
void SetDimRadialTextOrientation(const ON_DimStyle* parent_style, ON::TextOrientation orientation);
bool DrawForward(const ON_DimStyle* parent_style) const;
void SetDrawForward(const ON_DimStyle* parent_style, bool drawforward);
bool TextUnderlined(const ON_DimStyle* parent_style) const;
void SetTextUnderlined(const ON_DimStyle* parent_style, bool underlined);
bool SignedOrdinate(const ON_DimStyle* parent_style) const;
void SetSignedOrdinate(const ON_DimStyle* parent_style, bool allowsigned);
double DimScale(const ON_DimStyle* parent_style) const;
void SetDimScale(const ON_DimStyle* parent_style, double scale);
wchar_t DecimalSeparator(const ON_DimStyle* parent_style) const;
void SetDecimalSeparator(const ON_DimStyle* parent_style, wchar_t separator);
ON_DimStyle::LengthDisplay DimensionLengthDisplay(const ON_DimStyle* parent_style) const;
void SetDimensionLengthDisplay(const ON_DimStyle* parent_style, ON_DimStyle::LengthDisplay length_display);
ON_DimStyle::LengthDisplay AlternateDimensionLengthDisplay(const ON_DimStyle* parent_style) const;
void SetAlternateDimensionLengthDisplay(const ON_DimStyle* parent_style, ON_DimStyle::LengthDisplay length_display);
/// <summary>
/// Parameters:
/// model_sn - 0, a model serial number, or ON_UNSET_UINT_INDEX to
/// use the dimstyle's ModelSerialNumber() value.
/// Returns
/// Unit system for dimension length display.
/// If DimensionLengthDisplay() == ON_DimStyle::LengthDisplay::ModelUnits
/// and model_sn > 0, then the value of ON::LengthUnitSystemFromModelSerialNumber(model_sn)
/// is returned.
/// If DimensionLengthDisplay() == ON_DimStyle::LengthDisplay::ModelUnits
/// and model_sn == 0, then ON::LengthUnitSystem::None is returned.
///</summary>
ON::LengthUnitSystem DimensionLengthDisplayUnit(
const ON_DimStyle* parent_style,
unsigned int model_sn
) const;
/// <summary>
/// Parameters:
/// model_sn - 0, a model serial number, or ON_UNSET_UINT_INDEX to
/// use the dimstyle's ModelSerialNumber() value.
/// Returns
/// Unit system for dimension length display.
/// If DimensionLengthDisplay() == ON_DimStyle::LengthDisplay::ModelUnits
/// and model_sn > 0, then the value of ON::LengthUnitSystemFromModelSerialNumber(model_sn)
/// is returned.
/// If DimensionLengthDisplay() == ON_DimStyle::LengthDisplay::ModelUnits
/// and model_sn == 0, then ON::LengthUnitSystem::None is returned.
///</summary>
ON::LengthUnitSystem AlternateDimensionLengthDisplayUnit(
const ON_DimStyle* parent_style,
unsigned int model_sn
) const;
/*
Description:
Set the font used to render text.
Parameters:
font_characteristics - [in]
This parameter does not have to be a managed font.
Remarks:
If the parameter is a managed font (font_characteristics.IsManagedFont() is true),
then the identical value is returned by ON_DimStyle.Font().
If the parameter is not a managed font (font_characteristics.IsManagedFont() is false),
then the ON_Font::GetManagedFont(font_characteristics) will be returned by
ON_DimStyle.Font().
*/
void SetFont(const ON_DimStyle* parent_style, const class ON_Font& font_characteristics);
/*
Returns:
The managed font used to render text.
*/
const class ON_Font& Font(const ON_DimStyle* parent_style) const;
/*
Returns:
A copy of the font_characteristics information.
Remarks:
You probably want to use Font(). This function is only useful
in isolated situations and is typically used to study font
substitutions when a model moves between computers or platforms.
*/
const class ON_Font& FontCharacteristics(const ON_DimStyle* parent_style) const;
/*
Returns:
True if the font returned by Font() is a substitute
for the font passed to SetFont().
Remarks:
Font substitution can occur when a model is moved between
computers that have different fonts installed.
*/
const bool FontSubstituted(const ON_DimStyle* parent_style) const;
bool SetAnnotationBold(bool bold, const ON_DimStyle* dimstyle);
bool SetAnnotationItalic(bool italic, const ON_DimStyle* dimstyle);
bool SetAnnotationUnderline(bool underline, const ON_DimStyle* dimstyle);
bool SetAnnotationFacename(bool set_or_clear, const wchar_t* facename, const ON_DimStyle* parent_style);
bool SetAnnotationFont(const ON_Font* font, const ON_DimStyle* parent_style);
static bool SetAnnotationTextFormat(ON_wString& rtf_in, const wchar_t* fmt_str_on, const wchar_t* fmt_str_off, bool set_on);
static bool SetRtfFmt(ON_wString& rtf_in, const wchar_t* fmt_str);
static bool ClearRtfFmt(const wchar_t* fmt_str_on, const wchar_t* fmt_str_off, ON_wString& rtf_in);
static int FindRtfTable(ON_wString rtf_in, int startidx, const wchar_t* tablename);
static bool FirstCharTextProperties(const wchar_t* rtf_in, bool& bold, bool& italic, bool& underline, ON_wString& facename);
const ON_Font* FirstCharFont() const;
private:
bool IsAllFormat(bool (ON_Font::*func)() const) const;
public:
// true if all of the text is bold
bool IsAllBold() const;
// true if all of the text is italic
bool IsAllItalic() const;
// true if all of the text is underlined
bool IsAllUnderlined() const;
friend class ON_Dimension;
};
/*
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:
static const wchar_t* DefaultFontFace; // Arial
static const int DefaultHeightInPoints; // 14 points
static const int MinimumHeightInPoints; // 3 points
static const ON_TextDot Unset;
ON_TextDot();
~ON_TextDot();
ON_TextDot( const ON_TextDot& ) = default;
ON_TextDot& operator=( const ON_TextDot& ) = default;
ON_TextDot(
ON_3dPoint center_point,
const wchar_t* primary_text,
const wchar_t* secondary_text
);
static ON_TextDot* CreateFromV2AnnotationTextDot(
const class ON_OBSOLETE_V2_TextDot& V2_text_dot,
const class ON_3dmAnnotationContext* annotation_context,
ON_TextDot* destination
);
void EmergencyDestroy();
//---------------------------
// ON_Object overrides
bool IsValid( class ON_TextLog* text_log = nullptr ) const override;
/*
Description: Write data values to a text file for debugging
*/
void Dump( ON_TextLog& log) const override;
/*
Description: Writes the object to a file
Returns:
@untitled Table
true Success
false Failure
*/
bool Write( ON_BinaryArchive& ar) const override;
/*
Description: Reads the object from a file
Returns:
@untitled Table
true Success
false Failure
*/
bool Read( ON_BinaryArchive& ar) override;
/*
Returns: The Object Type of this object
*/
ON::object_type ObjectType() const override;
//---------------------------
// ON_Geometry overrides
/*
Returns the geometric dimension of the object ( usually 3)
*/
int Dimension() const override;