sprk_parasolid.h
1 // Copyright (c) 1998-2014 by Tech Soft 3D, Inc.
2 //
3 // The information contained herein is confidential and proprietary to Tech Soft 3D, Inc.,
4 // and considered a trade secret as defined under civil and criminal statutes.
5 // Tech Soft 3D, Inc. shall pursue its civil and criminal remedies in the event of
6 // unauthorized use or misappropriation of its trade secrets. Use of this information
7 // by anyone other than authorized employees of Tech Soft 3D, Inc. is granted only under
8 // a written non-disclosure agreement, expressly prescribing the scope and manner of such use.
9 
10 #ifndef SPRK_PARASOLID_H
11 #define SPRK_PARASOLID_H
12 
13 #include "sprk.h"
14 
15 #ifdef _MSC_VER
16 #ifndef STATIC_APP
17 # ifdef SPROCKETS
18 # define PARASOLID_API __declspec (dllexport)
19 # else
20 # define PARASOLID_API __declspec (dllimport)
21 # endif
22 #endif
23 #else
24 # include <stddef.h>
25 # if defined(LINUX_SYSTEM) && defined(SPROCKETS)
26 # ifndef STATIC_APP
27 # define PARASOLID_API __attribute__ ((visibility ("default")))
28 # endif
29 # endif
30 #endif
31 
32 #ifndef PARASOLID_API
33 # define PARASOLID_API
34 #endif
35 
36 namespace HPS
37 {
39  class PARASOLID_API Parasolid
40  {
41  public:
42  typedef int ParasolidEntity;
43  class Viewport;
44 
45  typedef HPS::IntArray EntityArray;
46  typedef std::vector<double, HPS::Allocator<double>> DoubleArray;
47  typedef std::vector<Viewport, HPS::Allocator<Viewport>> ViewportArray;
48 
51  enum class TessellationLevel
52  {
53  ExtraLow,
54  Low,
55  Medium,
56  High,
57  ExtraHigh,
58  Custom,
59  };
60 
63  enum class Format
64  {
65  Text,
66  Binary,
67  NeutralBinary,
68  };
69 
72  enum class MismatchBehavior
73  {
74  Ignore,
75  Fail,
76  };
77 
81  {
82  Split,
83  Keep,
84  Fail,
85  };
86 
87  class PARASOLID_API Viewport
88  {
89  public:
90  Viewport();
91  Viewport(DoubleArray in_box, DPoint in_location, DVector in_z_direction, DVector in_x_direction);
92  void ShowViewport(DoubleArray & out_box, DPoint & out_location, DVector & out_z_direction, DVector & out_x_direction) const;
93 
94  bool operator==(Viewport const & in_viewport) const;
95  bool operator!=(Viewport const & in_viewport) const;
96  bool Equals(Viewport const & in_viewport) const;
97 
98  private:
99  DoubleArray box; //min xyz, max xyz
100  DPoint location;
101  DVector axis; //local z-direction
102  DVector reference_direction; //local x-direction. must be orthogonal to axis.
103  };
104 
108  enum class Ignore
109  {
110  Absolute,
111  FeatureToModelRatio,
112  FeatureToBodyRatio,
113  };
114 
115  class Facet
116  {
117  public:
121  enum class Shape
122  {
123  Any,
124  Cut,
125  Convex,
126  };
127 
131  enum class Match
132  {
133  Geometrical,
134  Topological,
135  Trimmed,
136  };
137 
141  enum class Density
142  {
143  ViewIndependent,
144  Silhouette,
145  Parallel,
146  SilhouetteAndParallel,
147  };
148 
152  enum class Degeneracy
153  {
154  MultipleVertices,
155  SingleVertex,
156  Average,
157  };
158 
163  {
164  Off,
165  OffNoAttributes,
166  OffRefreshAttributes,
167  On,
168  };
169 
170  class PARASOLID_API Tolerance
171  {
172  public:
173  Tolerance();
174  Tolerance(double curve_chord_tolerance, double curve_chord_maximum_length, double curve_chord_max_angle,
175  double surface_tolerance, double surface_max_angle);
176 
177  void ShowTolerance(double & out_curve_chord_tolerance, double & out_curve_chord_maximum_length, double & out_curve_chord_max_angle,
178  double & out_surface_tolerance, double & out_surface_max_angle) const;
179 
180  bool operator==(Tolerance const & in_tolerance) const;
181  bool operator!=(Tolerance const & in_tolerance) const;
182  bool Equals(Tolerance const & in_tolerance) const;
183 
184  private:
185  double curve_chord_tolerance;
186  double curve_chord_maximum_length;
187  double curve_chord_max_angle;
188  double surface_tolerance;
189  double surface_max_angle;
190  };
191  };
192 
193  class Line
194  {
195  public:
196  class Hatching
197  {
198  public:
199  enum class Planar
200  {
201  NoHatching,
202  ByAttribute,
203  ByVectorNoLocking,
204  ByVector,
205  };
206 
207  enum class Radial
208  {
209  NoHatching,
210  ByAttribute,
211  ByVectorNoLocking,
212  ByVector,
213  };
214 
215  enum class Parametric
216  {
217  NoHatching,
218  ByAttribute,
219  ByVectorNoLocking,
220  ByVector,
221  };
222  };
223 
224  enum class UnfixedBlends
225  {
226  Draw,
227  DoNotDraw,
228  ByAttribute,
229  };
230 
231  enum class Visibility
232  {
233  DoNotEvaluate,
234  NoHidden,
235  MarkHiddenAsInvisible,
236  Draft,
237  Custom,
238  };
239 
240  enum class Smooth
241  {
242  Indicate,
243  DoNotIndicate,
244  Draft,
245  };
246 
247  enum class Region
248  {
249  Output,
250  DoNotOutput,
251  ByAttribute,
252  };
253 
254  enum class Hierarchical
255  {
256  On,
257  Off,
258  NoGeometry,
259  Parameterized,
260  };
261 
262  enum class BCurveRendering
263  {
264  Polyline,
265  Bezier,
266  NURBS,
267  };
268 
270  {
271  DoNotAllow,
272  Allow,
273  AllowAndIntersectAll,
274  AllowAndIntersectPairs,
275  };
276  };
277 
278  typedef std::vector<Facet::Tolerance, HPS::Allocator<Facet::Tolerance>> ToleranceArray;
279  class FacetTessellationKit;
280  class LineTessellationKit;
281 
285  class PARASOLID_API Component : public HPS::Component
286  {
287  public:
289  Component();
290 
294  Component(HPS::Component const & in_that);
295 
298  Component(Parasolid::Component const & in_that);
299 
302  Component(Parasolid::Component && in_that);
303 
304  virtual ~Component();
305 
306  HPS::Type ObjectType() const { return HPS::Type::ParasolidComponent; }
307 
308 #ifndef _MSC_VER
309  Component & operator=(Component const & in_that) = default;
310 #endif
311 
315  Component & operator=(Parasolid::Component && in_that);
316 
317 
320  ParasolidEntity GetParasolidEntity() const;
321 
327  void Tessellate(Parasolid::FacetTessellationKit const & in_facet_options, Parasolid::LineTessellationKit const & in_line_options);
328  };
329 
330  typedef std::vector<Component, HPS::Allocator<Component>> ComponentArray;
331 
334  class PARASOLID_API CADModel : public HPS::CADModel
335  {
336  public:
338  CADModel();
339 
344  CADModel(Component const & in_that);
345 
350  CADModel(HPS::CADModel const & in_that);
351 
354  CADModel(Parasolid::CADModel const & in_that);
355 
358  CADModel(Parasolid::CADModel && in_that);
359 
360  virtual ~CADModel();
361 
362  HPS::Type ObjectType() const { return HPS::Type::ParasolidCADModel; }
363 
364 #ifndef _MSC_VER
365  CADModel & operator=(Parasolid::CADModel const & in_that) = default;
366 #endif
367 
371  CADModel & operator=(Parasolid::CADModel && in_that);
372 
376  Component GetComponentFromEntity(ParasolidEntity in_entity);
377 
385  Component AddEntity(ParasolidEntity in_entity_to_add, FacetTessellationKit const & in_facet_tessellation, LineTessellationKit const & in_line_tessellation, Component const & in_owner = Component());
386  };
387 
389  class PARASOLID_API Factory : public Sprocket
390  {
391  public:
395  static Component CreateComponent(HPS::Component const & in_owner, HPS::Component::ComponentType in_type, ParasolidEntity in_entity = 0);
396 
399  static CADModel CreateCADModel(Model const & in_model = HPS::Factory::CreateModel());
400 
401  private:
403  Factory();
404  };
405 
407  class PARASOLID_API ImportNotifier : public IONotifier
408  {
409  public:
411  ImportNotifier();
412 
415  ImportNotifier(ImportNotifier const & in_that);
416 
421  ImportNotifier(IONotifier const & in_that);
422 
426  ImportNotifier(ImportNotifier && in_that);
427 
431  ImportNotifier & operator=(ImportNotifier && in_that);
432 
433  virtual ~ImportNotifier();
434 
435  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportNotifier; };
436 
440  ImportNotifier & operator=(ImportNotifier const & in_that);
441 
444  void Assign(ImportNotifier const & in_that);
445 
448  Parasolid::CADModel GetCADModel() const;
449 
452  Time GetImportTime() const;
453 
456  Time GetParseTime() const;
457  };
458 
459  class ImportOptionsKit;
460  class ExportOptionsKit;
461 
463  class PARASOLID_API File
464  {
465  public:
466 
471  static ImportNotifier Import(char const * in_file_name, ImportOptionsKit const & in_options);
472 
478  static ImportNotifier Import(EntityArray const & in_parts, FacetTessellationKit const & in_facet_options, LineTessellationKit const & in_line_options);
479 
484  static void Export(CADModel const & in_cad_model, char const * in_file_name, ExportOptionsKit const & in_options);
485 
486  private:
488  File();
489  };
490 
492  class PARASOLID_API ImportOptionsKit : public HPS::Sprocket
493  {
494  public:
497 
500  ImportOptionsKit(ImportOptionsKit const & in_kit);
501 
506 
510  ImportOptionsKit & operator=(ImportOptionsKit && in_that);
511 
512  virtual ~ImportOptionsKit();
513 
514  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportOptionsKit; }
515 
519  static ImportOptionsKit GetDefault();
520 
523  void Set(ImportOptionsKit const & in_kit);
524 
527  void Show(ImportOptionsKit & out_kit) const;
528 
532  ImportOptionsKit & operator=(ImportOptionsKit const & in_kit);
533 
536  bool Empty() const;
537 
541  bool Equals(ImportOptionsKit const & in_kit) const;
542 
546  bool operator==(ImportOptionsKit const & in_kit) const;
547 
551  bool operator!=(ImportOptionsKit const & in_kit) const;
552 
559  ImportOptionsKit & SetFormat(Parasolid::Format in_format);
560 
567  ImportOptionsKit & SetUserFields(bool in_import_user_fields);
568 
575  ImportOptionsKit & SetAttributeMismatchBehavior(Parasolid::MismatchBehavior in_behavior);
576 
583  ImportOptionsKit & SetCompoundBodyBehavior(Parasolid::CompoundBodyBehavior in_behavior);
584 
589  ImportOptionsKit & SetFacetTessellation(Parasolid::FacetTessellationKit const & in_facet_tessellation_kit);
590 
595  ImportOptionsKit & SetLineTessellation(Parasolid::LineTessellationKit const & in_line_tessellation_kit);
596 
597 
600  ImportOptionsKit & UnsetFormat();
601 
604  ImportOptionsKit & UnsetUserFields();
605 
608  ImportOptionsKit & UnsetAttributeMismatchBehavior();
609 
612  ImportOptionsKit & UnsetCompoundBodyBehavior();
613 
616  ImportOptionsKit & UnsetFacetTessellation();
617 
620  ImportOptionsKit & UnsetLineTessellation();
621 
624  ImportOptionsKit & UnsetEverything();
625 
626 
630  bool ShowFormat(Parasolid::Format & out_format) const;
631 
635  bool ShowUserFields(bool & out_user_fields) const;
636 
640  bool ShowAttributeMismatchBehavior(Parasolid::MismatchBehavior & out_behavior) const;
641 
645  bool ShowCompoundBodyBehavior(Parasolid::CompoundBodyBehavior & out_behavior) const;
646 
650  bool ShowFacetTessellation(Parasolid::FacetTessellationKit & out_facet_tessellation) const;
651 
655  bool ShowLineTessellation(Parasolid::LineTessellationKit & out_line_tessellation) const;
656 
657  };
658 
661  class PARASOLID_API FacetTessellationKit : public HPS::Sprocket
662  {
663  public:
666 
670 
675 
679  FacetTessellationKit & operator=(FacetTessellationKit && in_that);
680 
681  virtual ~FacetTessellationKit();
682 
683  HPS::Type ObjectType() const { return HPS::Type::ParasolidFacetTessellationKit; }
684 
688  static FacetTessellationKit GetDefault();
689 
692  void Set(FacetTessellationKit const & in_kit);
693 
696  void Show(FacetTessellationKit & out_kit) const;
697 
701  FacetTessellationKit & operator=(FacetTessellationKit const & in_kit);
702 
705  bool Empty() const;
706 
710  bool Equals(FacetTessellationKit const & in_kit) const;
711 
715  bool operator==(FacetTessellationKit const & in_kit) const;
716 
720  bool operator!=(FacetTessellationKit const & in_kit) const;
721 
722 
728  FacetTessellationKit & SetTessellationLevel(HPS::Parasolid::TessellationLevel in_tessellation_level, double in_chord = -1, double in_angle = -1);
729 
734  FacetTessellationKit & SetShapeGeneration(Facet::Shape in_shape);
735 
740  FacetTessellationKit & SetVertexMatching(Facet::Match in_vertex_matching);
741 
748  FacetTessellationKit & SetDensity(Facet::Density in_density, double in_density_tolerance = 0, double in_density_max_angle = 0, DVectorArray const & in_view_directions = DVectorArray());
749 
754  FacetTessellationKit & SetIgnoredLoops(IntArray & in_ignored_loops);
755 
761  FacetTessellationKit & SetFacetSize(double in_minimum_width, double in_maximum_width, int in_maximum_sides);
762 
768  FacetTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
769 
774  FacetTessellationKit & SetSurfacePlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
775 
780  FacetTessellationKit & SetFacetPlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
781 
785  FacetTessellationKit & SetDegeneracyBehavior(Facet::Degeneracy in_degeneracy_behavior);
786 
792  FacetTessellationKit & SetLocalTolerances(ToleranceArray const & in_tolerance_array, IntArray const & in_topology_array, IntArray const & in_tolerance_for_tolopoly);
793 
800  FacetTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0, bool in_treat_faces_individually = false);
801 
805  FacetTessellationKit & SetWireEdges(bool in_wire_edges);
806 
811  FacetTessellationKit & SetIncrementalFaceting(Facet::IncrementalFaceting in_faceting, bool refine_tessellation = false);
812 
816  FacetTessellationKit & SetInflection(bool in_refine);
817 
821  FacetTessellationKit & SetImprovedFacetQuality(bool in_improved_quality);
822 
826  FacetTessellationKit & SetFlattenVertices(bool in_flatten_vertices);
827 
831  FacetTessellationKit & SetOffsetFaces(bool in_offset_faces);
832 
836  FacetTessellationKit & SetNormals(bool in_normals);
837 
841  FacetTessellationKit & SetParameters(bool in_parameters);
842 
846  FacetTessellationKit & SetEdges(bool in_edges);
847 
853  FacetTessellationKit & SetStrips(bool in_strips, int in_max_facets_per_strip, bool in_split_strips);
854 
857  FacetTessellationKit & UnsetTessellationLevel();
858 
861  FacetTessellationKit & UnsetShapeGeneration();
862 
865  FacetTessellationKit & UnsetVertexMatching();
866 
869  FacetTessellationKit & UnsetDensity();
870 
873  FacetTessellationKit & UnsetIgnoredLoops();
874 
877  FacetTessellationKit & UnsetFacetSize();
878 
881  FacetTessellationKit & UnsetChordTolerance();
882 
885  FacetTessellationKit & UnsetSurfacePlaneTolerance();
886 
889  FacetTessellationKit & UnsetFacetPlaneTolerance();
890 
893  FacetTessellationKit & UnsetDegeneracyBehavior();
894 
897  FacetTessellationKit & UnsetLocalTolerances();
898 
901  FacetTessellationKit & UnsetIgnoreCriteria();
902 
905  FacetTessellationKit & UnsetWireEdges();
906 
909  FacetTessellationKit & UnsetIncrementalFaceting();
910 
913  FacetTessellationKit & UnsetInflection();
914 
917  FacetTessellationKit & UnsetImprovedFacetQuality();
918 
921  FacetTessellationKit & UnsetFlattenVertices();
922 
925  FacetTessellationKit & UnsetOffsetFaces();
926 
929  FacetTessellationKit & UnsetNormals();
930 
933  FacetTessellationKit & UnsetParameters();
934 
937  FacetTessellationKit & UnsetEdges();
938 
941  FacetTessellationKit & UnsetStrips();
942 
945  FacetTessellationKit & UnsetEverything();
946 
947 
953  bool ShowTessellationLevel(TessellationLevel & out_tessellation_level, double & out_chord, double & out_angle) const;
954 
958  bool ShowShapeGeneration(Facet::Shape & out_shape) const;
959 
963  bool ShowVertexMatching(Facet::Match & out_vertex_matching) const;
964 
971  bool ShowDensity(Facet::Density & out_density, double & out_density_tolerance, double & out_density_max_angle, DVectorArray & out_view_directions) const;
972 
976  bool ShowIgnoredLoops(IntArray & out_ignored_loops) const;
977 
983  bool ShowFacetSize(double & out_minimum_width, double & out_maximum_width, int & out_maximum_sides) const;
984 
990  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
991 
996  bool ShowSurfacePlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
997 
1002  bool ShowFacetPlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1003 
1007  bool ShowDegeneracyBehavior(Facet::Degeneracy & out_degeneracy_behavior) const;
1008 
1014  bool ShowLocalTolerances(ToleranceArray & out_tolerance_array, IntArray & out_topology_array, IntArray & out_tolerance_for_tolopoly) const;
1015 
1022  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value, bool & out_treat_faces_individually) const;
1023 
1027  bool ShowWireEdges(bool & out_wire_edges) const;
1028 
1033  bool ShowIncrementalFaceting(Facet::IncrementalFaceting & out_faceting, bool & out_refine_tessellation) const;
1034 
1038  bool ShowInflection(bool & out_refine) const;
1039 
1043  bool ShowImprovedFacetQuality(bool & out_improved_quality) const;
1044 
1048  bool ShowFlattenVertices(bool & out_flatten_vertices) const;
1049 
1053  bool ShowOffsetFaces(bool & out_offset_faces) const;
1054 
1058  bool ShowNormals(bool & out_normals) const;
1059 
1063  bool ShowParameters(bool & out_parameters) const;
1064 
1068  bool ShowEdges(bool & out_edges) const;
1069 
1075  bool ShowStrips(bool & out_strips, int & out_max_facets_per_strip, bool & out_split_strips) const;
1076 
1077  };
1078 
1080  class PARASOLID_API LineTessellationKit : public HPS::Sprocket
1081  {
1082  public:
1085 
1088  LineTessellationKit(LineTessellationKit const & in_kit);
1089 
1094 
1098  LineTessellationKit & operator=(LineTessellationKit && in_that);
1099 
1100  virtual ~LineTessellationKit();
1101 
1102  HPS::Type ObjectType() const { return HPS::Type::ParasolidLineTessellationKit; }
1103 
1107  static LineTessellationKit GetDefault();
1108 
1111  void Set(LineTessellationKit const & in_kit);
1112 
1115  void Show(LineTessellationKit & out_kit) const;
1116 
1120  LineTessellationKit & operator=(LineTessellationKit const & in_kit);
1121 
1124  bool Empty() const;
1125 
1129  bool Equals(LineTessellationKit const & in_kit) const;
1130 
1134  bool operator==(LineTessellationKit const & in_kit) const;
1135 
1139  bool operator!=(LineTessellationKit const & in_kit) const;
1140 
1141 
1142 
1147  LineTessellationKit & SetEdges(bool in_draw_edges, bool in_internal_edges);
1148 
1154  LineTessellationKit & SetSilhouetteEdges(bool in_draw_silhouette_edges, bool in_draw_circles_as_arcs);
1155 
1162  LineTessellationKit & SetPlanarHatching(Line::Hatching::Planar in_planar_haching, double in_planar_spacing = 0, DPoint in_point_through = DPoint(0, 0, 0), DVector in_direction = DVector(0, 0, 0));
1163 
1173  LineTessellationKit & SetRadialHatching(Line::Hatching::Radial in_radial_hatching, double in_around = 0, double in_around_start = 0, double in_along = 0, double in_along_start = 0, double in_about = 0, double in_about_start = 0);
1174 
1182  LineTessellationKit & SetParametricHatching(Line::Hatching::Parametric in_parametric_hatching, double in_u = 0, double in_u_start = 0, double in_v = 0, double in_v_start = 0);
1183 
1188  LineTessellationKit & SetUnfixedBlends(Line::UnfixedBlends in_unfixed_blends, double in_spacing = 0);
1189 
1197  LineTessellationKit & SetVisibilityEvaluation(Line::Visibility in_visibility, bool in_draw_invisible = false, bool in_drafting = false, bool in_self_hidden = false, IntArray in_suppressed_indices = IntArray());
1198 
1203  LineTessellationKit & SetSmoothEdges(Line::Smooth in_smooth, double in_tolerance = 0);
1204 
1208  LineTessellationKit & SetRegionalData(Line::Region in_region);
1209 
1213  LineTessellationKit & SetHierarchicalOutput(Line::Hierarchical in_hierarchical_output);
1214 
1218  LineTessellationKit & SetBCurveRenderingMethod(Line::BCurveRendering in_bcurve_rendering_method);
1219 
1226  LineTessellationKit & SetViewports(bool in_use_viewports, bool in_is_3d = true, bool viewport_clipping = false, ViewportArray in_viewports = ViewportArray());
1227 
1233  LineTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
1234 
1240  LineTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0);
1241 
1246  LineTessellationKit & SetMemoryLimit(bool in_use_memory_limit, size_t in_limit = 0);
1247 
1253  LineTessellationKit & SetTransparentBodies(bool in_allow_transparency, bool in_transparent_hide, IntArray in_transparent_bodies = IntArray());
1254 
1258  LineTessellationKit & SetMissingGeometryFailure(bool in_fail_on_missing_geometry);
1259 
1265  LineTessellationKit & SetOverlappingBehavior(Line::OverlappingBehavior in_overlapping_behavior, IntArray in_indices_one = IntArray(), IntArray in_indices_two = IntArray());
1266 
1267 
1268 
1271  LineTessellationKit & UnsetEdges();
1272 
1275  LineTessellationKit & UnsetSilhouetteEdges();
1276 
1279  LineTessellationKit & UnsetPlanarHatching();
1280 
1283  LineTessellationKit & UnsetRadialHatching();
1284 
1287  LineTessellationKit & UnsetParametericHatching();
1288 
1291  LineTessellationKit & UnsetUnfixedBlends();
1292 
1295  LineTessellationKit & UnsetVisibilityEvaluation();
1296 
1299  LineTessellationKit & UnsetSmoothEdges();
1300 
1303  LineTessellationKit & UnsetRegionalData();
1304 
1307  LineTessellationKit & UnsetHierarchicalOutput();
1308 
1311  LineTessellationKit & UnsetBCurveRenderingMethod();
1312 
1315  LineTessellationKit & UnsetViewports();
1316 
1319  LineTessellationKit & UnsetChordTolerance();
1320 
1323  LineTessellationKit & UnsetIgnoreCriteria();
1324 
1327  LineTessellationKit & UnsetMemoryLimit();
1328 
1331  LineTessellationKit & UnsetTransparentBodies();
1332 
1335  LineTessellationKit & UnsetMissingGeometryFailure();
1336 
1339  LineTessellationKit & UnsetOverlappingBehavior();
1340 
1343  LineTessellationKit & UnsetEverything();
1344 
1345 
1346 
1347 
1352  bool ShowEdges(bool & out_draw_edges, bool & out_internal_edges) const;
1353 
1359  bool ShowSilhouetteEdges(bool & out_draw_silhouette_edges, bool & out_draw_circles_as_arcs) const;
1360 
1367  bool ShowPlanarHatching(Line::Hatching::Planar & out_planar_haching, double & out_planar_spacing, DPoint & out_point_through, DVector & out_direction) const;
1368 
1378  bool ShowRadialHatching(Line::Hatching::Radial & out_radial_hatching, double & out_around, double & out_around_start, double & out_along, double & out_along_start, double & out_about, double & out_about_start) const;
1379 
1387  bool ShowParametericHatching(Line::Hatching::Parametric & out_parametric_hatching, double & out_u, double & out_u_start, double & out_v, double & out_v_start) const;
1388 
1393  bool ShowUnfixedBlends(Line::UnfixedBlends & out_unfixed_blends, double & out_spacing) const;
1394 
1402  bool ShowVisibilityEvaluation(Line::Visibility & out_visibility, bool & out_draw_invisible, bool & out_drafting, bool & out_self_hidden, IntArray & out_suppressed_indices) const;
1403 
1408  bool ShowSmoothEdges(Line::Smooth & out_smooth, double & out_tolerance) const;
1409 
1413  bool ShowRegionalData(Line::Region & out_region) const;
1414 
1418  bool ShowHierarchicalOutput(Line::Hierarchical & out_hierarchical_output) const;
1419 
1423  bool ShowBCurveRenderingMethod(Line::BCurveRendering & out_bcurve_rendering_method) const;
1424 
1431  bool ShowViewports(bool & out_use_viewports, bool & out_is_3d, bool & out_viewport_clipping, ViewportArray & out_viewports) const;
1432 
1438  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1439 
1445  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value) const;
1446 
1451  bool ShowMemoryLimit(bool & out_use_memory_limit, size_t & out_limit) const;
1452 
1458  bool ShowTransparentBodies(bool & out_allow_transparency, bool & out_transparent_hide, IntArray & out_force_transparent) const;
1459 
1463  bool ShowMissingGeometryFailure(bool & out_fail_on_missing_geometry) const;
1464 
1470  bool ShowOverlappingBehavior(Line::OverlappingBehavior & out_overlapping_behavior, IntArray & out_indices_one, IntArray & out_indices_two) const;
1471  };
1472 
1473 
1475  class PARASOLID_API ExportOptionsKit : public HPS::Sprocket
1476  {
1477  public:
1479  ExportOptionsKit();
1480 
1483  ExportOptionsKit(ExportOptionsKit const & in_kit);
1484 
1488  ExportOptionsKit(ExportOptionsKit && in_that);
1489 
1493  ExportOptionsKit & operator=(ExportOptionsKit && in_that);
1494 
1495  virtual ~ExportOptionsKit();
1496 
1497  HPS::Type ObjectType() const { return HPS::Type::ParasolidExportOptionsKit; }
1498 
1502  static ExportOptionsKit GetDefault();
1503 
1506  void Set(ExportOptionsKit const & in_kit);
1507 
1510  void Show(ExportOptionsKit & out_kit) const;
1511 
1515  ExportOptionsKit & operator=(ExportOptionsKit const & in_kit);
1516 
1519  bool Empty() const;
1520 
1524  bool Equals(ExportOptionsKit const & in_kit) const;
1525 
1529  bool operator==(ExportOptionsKit const & in_kit) const;
1530 
1534  bool operator!=(ExportOptionsKit const & in_kit) const;
1535 
1542  ExportOptionsKit & SetFormat(Parasolid::Format in_format);
1543 
1548  ExportOptionsKit & SetUserFields(bool in_export_user_fields);
1549 
1550 
1553  ExportOptionsKit & UnsetFormat();
1554 
1557  ExportOptionsKit & UnsetUserFields();
1558 
1561  ExportOptionsKit & UnsetEverything();
1562 
1563 
1567  bool ShowFormat(Parasolid::Format & out_format) const;
1568 
1572  bool ShowUserFields(bool & out_user_fields) const;
1573  };
1574  };
1575 }
1576 
1577 #endif //SPRK_PARASOLID_H
MismatchBehavior
Definition: sprk_parasolid.h:72
Definition: sprk_parasolid.h:87
Definition: sprk_parasolid.h:115
Smooth
Definition: sprk_parasolid.h:240
Parametric
Definition: sprk_parasolid.h:215
Definition: sprk.h:69
Radial
Definition: sprk_parasolid.h:207
Definition: sprk_parasolid.h:170
Definition: sprk_parasolid.h:1475
Degeneracy
Definition: sprk_parasolid.h:152
TessellationLevel
Definition: sprk_parasolid.h:51
Format
Definition: sprk_parasolid.h:63
Definition: sprk_parasolid.h:389
Definition: sprk_parasolid.h:463
Definition: hps.h:1516
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:362
Hierarchical
Definition: sprk_parasolid.h:254
Definition: sprk_parasolid.h:196
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:683
BCurveRendering
Definition: sprk_parasolid.h:262
UnfixedBlends
Definition: sprk_parasolid.h:224
Density
Definition: sprk_parasolid.h:141
Definition: sprk_parasolid.h:193
Match
Definition: sprk_parasolid.h:131
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:1102
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:306
Definition: sprk_parasolid.h:1080
Definition: sprk.h:1512
Definition: hps.h:42090
Planar
Definition: sprk_parasolid.h:199
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:435
Definition: sprk.h:430
Definition: sprk_parasolid.h:39
CompoundBodyBehavior
Definition: sprk_parasolid.h:80
Definition: sprk_parasolid.h:334
ComponentType
Definition: sprk.h:1517
Definition: sprk_parasolid.h:285
Shape
Definition: sprk_parasolid.h:121
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:1497
OverlappingBehavior
Definition: sprk_parasolid.h:269
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:514
IncrementalFaceting
Definition: sprk_parasolid.h:162
Ignore
Definition: sprk_parasolid.h:108
Definition: sprk_parasolid.h:661
Definition: sprk.h:2260
Visibility
Definition: sprk_parasolid.h:231
static Model CreateModel(char const *in_name="")
Definition: sprk_parasolid.h:407
Region
Definition: sprk_parasolid.h:247
Definition: sprk_parasolid.h:492