Overview

Sample Code

Programming Guide

API Reference

Support

sprk_parasolid.h
1 // Copyright (c) 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 SPRK_PARASOLID
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(SPRK_PARASOLID)
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:
396  static Component CreateComponent(HPS::Component const & in_owner, HPS::Component::ComponentType in_type, ParasolidEntity in_entity = 0);
397 
400  static CADModel CreateCADModel(Model const & in_model = HPS::Factory::CreateModel());
401 
402  private:
404  Factory();
405  };
406 
408  class PARASOLID_API ImportNotifier : public IONotifier
409  {
410  public:
412  ImportNotifier();
413 
416  ImportNotifier(ImportNotifier const & in_that);
417 
422  ImportNotifier(IONotifier const & in_that);
423 
427  ImportNotifier(ImportNotifier && in_that);
428 
432  ImportNotifier & operator=(ImportNotifier && in_that);
433 
434  virtual ~ImportNotifier();
435 
436  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportNotifier; };
437 
441  ImportNotifier & operator=(ImportNotifier const & in_that);
442 
445  void Assign(ImportNotifier const & in_that);
446 
449  Parasolid::CADModel GetCADModel() const;
450 
453  Time GetImportTime() const;
454 
457  Time GetParseTime() const;
458  };
459 
460  class ImportOptionsKit;
461  class ExportOptionsKit;
462 
464  class PARASOLID_API File
465  {
466  public:
467 
472  static ImportNotifier Import(char const * in_file_name, ImportOptionsKit const & in_options);
473 
479  static ImportNotifier Import(EntityArray const & in_parts, FacetTessellationKit const & in_facet_options, LineTessellationKit const & in_line_options);
480 
485  static void Export(CADModel const & in_cad_model, char const * in_file_name, ExportOptionsKit const & in_options);
486 
487  private:
489  File();
490  };
491 
493  class PARASOLID_API ImportOptionsKit : public HPS::Sprocket
494  {
495  public:
498 
501  ImportOptionsKit(ImportOptionsKit const & in_kit);
502 
507 
511  ImportOptionsKit & operator=(ImportOptionsKit && in_that);
512 
513  virtual ~ImportOptionsKit();
514 
515  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportOptionsKit; }
516 
520  static ImportOptionsKit GetDefault();
521 
524  void Set(ImportOptionsKit const & in_kit);
525 
528  void Show(ImportOptionsKit & out_kit) const;
529 
533  ImportOptionsKit & operator=(ImportOptionsKit const & in_kit);
534 
537  bool Empty() const;
538 
542  bool Equals(ImportOptionsKit const & in_kit) const;
543 
547  bool operator==(ImportOptionsKit const & in_kit) const;
548 
552  bool operator!=(ImportOptionsKit const & in_kit) const;
553 
560  ImportOptionsKit & SetFormat(Parasolid::Format in_format);
561 
568  ImportOptionsKit & SetUserFields(bool in_import_user_fields);
569 
576  ImportOptionsKit & SetAttributeMismatchBehavior(Parasolid::MismatchBehavior in_behavior);
577 
584  ImportOptionsKit & SetCompoundBodyBehavior(Parasolid::CompoundBodyBehavior in_behavior);
585 
590  ImportOptionsKit & SetFacetTessellation(Parasolid::FacetTessellationKit const & in_facet_tessellation_kit);
591 
596  ImportOptionsKit & SetLineTessellation(Parasolid::LineTessellationKit const & in_line_tessellation_kit);
597 
598 
601  ImportOptionsKit & UnsetFormat();
602 
605  ImportOptionsKit & UnsetUserFields();
606 
609  ImportOptionsKit & UnsetAttributeMismatchBehavior();
610 
613  ImportOptionsKit & UnsetCompoundBodyBehavior();
614 
617  ImportOptionsKit & UnsetFacetTessellation();
618 
621  ImportOptionsKit & UnsetLineTessellation();
622 
625  ImportOptionsKit & UnsetEverything();
626 
627 
631  bool ShowFormat(Parasolid::Format & out_format) const;
632 
636  bool ShowUserFields(bool & out_user_fields) const;
637 
641  bool ShowAttributeMismatchBehavior(Parasolid::MismatchBehavior & out_behavior) const;
642 
646  bool ShowCompoundBodyBehavior(Parasolid::CompoundBodyBehavior & out_behavior) const;
647 
651  bool ShowFacetTessellation(Parasolid::FacetTessellationKit & out_facet_tessellation) const;
652 
656  bool ShowLineTessellation(Parasolid::LineTessellationKit & out_line_tessellation) const;
657 
658  };
659 
662  class PARASOLID_API FacetTessellationKit : public HPS::Sprocket
663  {
664  public:
667 
671 
676 
680  FacetTessellationKit & operator=(FacetTessellationKit && in_that);
681 
682  virtual ~FacetTessellationKit();
683 
684  HPS::Type ObjectType() const { return HPS::Type::ParasolidFacetTessellationKit; }
685 
689  static FacetTessellationKit GetDefault();
690 
693  void Set(FacetTessellationKit const & in_kit);
694 
697  void Show(FacetTessellationKit & out_kit) const;
698 
702  FacetTessellationKit & operator=(FacetTessellationKit const & in_kit);
703 
706  bool Empty() const;
707 
711  bool Equals(FacetTessellationKit const & in_kit) const;
712 
716  bool operator==(FacetTessellationKit const & in_kit) const;
717 
721  bool operator!=(FacetTessellationKit const & in_kit) const;
722 
723 
729  FacetTessellationKit & SetTessellationLevel(HPS::Parasolid::TessellationLevel in_tessellation_level, double in_chord = -1, double in_angle = -1);
730 
735  FacetTessellationKit & SetShapeGeneration(Facet::Shape in_shape);
736 
741  FacetTessellationKit & SetVertexMatching(Facet::Match in_vertex_matching);
742 
749  FacetTessellationKit & SetDensity(Facet::Density in_density, double in_density_tolerance = 0, double in_density_max_angle = 0, DVectorArray const & in_view_directions = DVectorArray());
750 
755  FacetTessellationKit & SetIgnoredLoops(IntArray & in_ignored_loops);
756 
762  FacetTessellationKit & SetFacetSize(double in_minimum_width, double in_maximum_width, int in_maximum_sides);
763 
769  FacetTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
770 
775  FacetTessellationKit & SetSurfacePlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
776 
781  FacetTessellationKit & SetFacetPlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
782 
786  FacetTessellationKit & SetDegeneracyBehavior(Facet::Degeneracy in_degeneracy_behavior);
787 
793  FacetTessellationKit & SetLocalTolerances(ToleranceArray const & in_tolerance_array, IntArray const & in_topology_array, IntArray const & in_tolerance_for_tolopoly);
794 
801  FacetTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0, bool in_treat_faces_individually = false);
802 
806  FacetTessellationKit & SetWireEdges(bool in_wire_edges);
807 
812  FacetTessellationKit & SetIncrementalFaceting(Facet::IncrementalFaceting in_faceting, bool refine_tessellation = false);
813 
817  FacetTessellationKit & SetInflection(bool in_refine);
818 
822  FacetTessellationKit & SetImprovedFacetQuality(bool in_improved_quality);
823 
827  FacetTessellationKit & SetFlattenVertices(bool in_flatten_vertices);
828 
832  FacetTessellationKit & SetOffsetFaces(bool in_offset_faces);
833 
837  FacetTessellationKit & SetNormals(bool in_normals);
838 
842  FacetTessellationKit & SetParameters(bool in_parameters);
843 
847  FacetTessellationKit & SetEdges(bool in_edges);
848 
854  FacetTessellationKit & SetStrips(bool in_strips, int in_max_facets_per_strip, bool in_split_strips);
855 
858  FacetTessellationKit & UnsetTessellationLevel();
859 
862  FacetTessellationKit & UnsetShapeGeneration();
863 
866  FacetTessellationKit & UnsetVertexMatching();
867 
870  FacetTessellationKit & UnsetDensity();
871 
874  FacetTessellationKit & UnsetIgnoredLoops();
875 
878  FacetTessellationKit & UnsetFacetSize();
879 
882  FacetTessellationKit & UnsetChordTolerance();
883 
886  FacetTessellationKit & UnsetSurfacePlaneTolerance();
887 
890  FacetTessellationKit & UnsetFacetPlaneTolerance();
891 
894  FacetTessellationKit & UnsetDegeneracyBehavior();
895 
898  FacetTessellationKit & UnsetLocalTolerances();
899 
902  FacetTessellationKit & UnsetIgnoreCriteria();
903 
906  FacetTessellationKit & UnsetWireEdges();
907 
910  FacetTessellationKit & UnsetIncrementalFaceting();
911 
914  FacetTessellationKit & UnsetInflection();
915 
918  FacetTessellationKit & UnsetImprovedFacetQuality();
919 
922  FacetTessellationKit & UnsetFlattenVertices();
923 
926  FacetTessellationKit & UnsetOffsetFaces();
927 
930  FacetTessellationKit & UnsetNormals();
931 
934  FacetTessellationKit & UnsetParameters();
935 
938  FacetTessellationKit & UnsetEdges();
939 
942  FacetTessellationKit & UnsetStrips();
943 
946  FacetTessellationKit & UnsetEverything();
947 
948 
954  bool ShowTessellationLevel(TessellationLevel & out_tessellation_level, double & out_chord, double & out_angle) const;
955 
959  bool ShowShapeGeneration(Facet::Shape & out_shape) const;
960 
964  bool ShowVertexMatching(Facet::Match & out_vertex_matching) const;
965 
972  bool ShowDensity(Facet::Density & out_density, double & out_density_tolerance, double & out_density_max_angle, DVectorArray & out_view_directions) const;
973 
977  bool ShowIgnoredLoops(IntArray & out_ignored_loops) const;
978 
984  bool ShowFacetSize(double & out_minimum_width, double & out_maximum_width, int & out_maximum_sides) const;
985 
991  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
992 
997  bool ShowSurfacePlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
998 
1003  bool ShowFacetPlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1004 
1008  bool ShowDegeneracyBehavior(Facet::Degeneracy & out_degeneracy_behavior) const;
1009 
1015  bool ShowLocalTolerances(ToleranceArray & out_tolerance_array, IntArray & out_topology_array, IntArray & out_tolerance_for_tolopoly) const;
1016 
1023  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value, bool & out_treat_faces_individually) const;
1024 
1028  bool ShowWireEdges(bool & out_wire_edges) const;
1029 
1034  bool ShowIncrementalFaceting(Facet::IncrementalFaceting & out_faceting, bool & out_refine_tessellation) const;
1035 
1039  bool ShowInflection(bool & out_refine) const;
1040 
1044  bool ShowImprovedFacetQuality(bool & out_improved_quality) const;
1045 
1049  bool ShowFlattenVertices(bool & out_flatten_vertices) const;
1050 
1054  bool ShowOffsetFaces(bool & out_offset_faces) const;
1055 
1059  bool ShowNormals(bool & out_normals) const;
1060 
1064  bool ShowParameters(bool & out_parameters) const;
1065 
1069  bool ShowEdges(bool & out_edges) const;
1070 
1076  bool ShowStrips(bool & out_strips, int & out_max_facets_per_strip, bool & out_split_strips) const;
1077 
1078  };
1079 
1081  class PARASOLID_API LineTessellationKit : public HPS::Sprocket
1082  {
1083  public:
1086 
1089  LineTessellationKit(LineTessellationKit const & in_kit);
1090 
1095 
1099  LineTessellationKit & operator=(LineTessellationKit && in_that);
1100 
1101  virtual ~LineTessellationKit();
1102 
1103  HPS::Type ObjectType() const { return HPS::Type::ParasolidLineTessellationKit; }
1104 
1108  static LineTessellationKit GetDefault();
1109 
1112  void Set(LineTessellationKit const & in_kit);
1113 
1116  void Show(LineTessellationKit & out_kit) const;
1117 
1121  LineTessellationKit & operator=(LineTessellationKit const & in_kit);
1122 
1125  bool Empty() const;
1126 
1130  bool Equals(LineTessellationKit const & in_kit) const;
1131 
1135  bool operator==(LineTessellationKit const & in_kit) const;
1136 
1140  bool operator!=(LineTessellationKit const & in_kit) const;
1141 
1142 
1143 
1148  LineTessellationKit & SetEdges(bool in_draw_edges, bool in_internal_edges);
1149 
1155  LineTessellationKit & SetSilhouetteEdges(bool in_draw_silhouette_edges, bool in_draw_circles_as_arcs);
1156 
1163  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));
1164 
1174  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);
1175 
1183  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);
1184 
1189  LineTessellationKit & SetUnfixedBlends(Line::UnfixedBlends in_unfixed_blends, double in_spacing = 0);
1190 
1198  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());
1199 
1204  LineTessellationKit & SetSmoothEdges(Line::Smooth in_smooth, double in_tolerance = 0);
1205 
1209  LineTessellationKit & SetRegionalData(Line::Region in_region);
1210 
1214  LineTessellationKit & SetHierarchicalOutput(Line::Hierarchical in_hierarchical_output);
1215 
1219  LineTessellationKit & SetBCurveRenderingMethod(Line::BCurveRendering in_bcurve_rendering_method);
1220 
1227  LineTessellationKit & SetViewports(bool in_use_viewports, bool in_is_3d = true, bool viewport_clipping = false, ViewportArray in_viewports = ViewportArray());
1228 
1234  LineTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
1235 
1241  LineTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0);
1242 
1247  LineTessellationKit & SetMemoryLimit(bool in_use_memory_limit, size_t in_limit = 0);
1248 
1254  LineTessellationKit & SetTransparentBodies(bool in_allow_transparency, bool in_transparent_hide, IntArray in_transparent_bodies = IntArray());
1255 
1259  LineTessellationKit & SetMissingGeometryFailure(bool in_fail_on_missing_geometry);
1260 
1266  LineTessellationKit & SetOverlappingBehavior(Line::OverlappingBehavior in_overlapping_behavior, IntArray in_indices_one = IntArray(), IntArray in_indices_two = IntArray());
1267 
1268 
1269 
1272  LineTessellationKit & UnsetEdges();
1273 
1276  LineTessellationKit & UnsetSilhouetteEdges();
1277 
1280  LineTessellationKit & UnsetPlanarHatching();
1281 
1284  LineTessellationKit & UnsetRadialHatching();
1285 
1288  LineTessellationKit & UnsetParametericHatching();
1289 
1292  LineTessellationKit & UnsetUnfixedBlends();
1293 
1296  LineTessellationKit & UnsetVisibilityEvaluation();
1297 
1300  LineTessellationKit & UnsetSmoothEdges();
1301 
1304  LineTessellationKit & UnsetRegionalData();
1305 
1308  LineTessellationKit & UnsetHierarchicalOutput();
1309 
1312  LineTessellationKit & UnsetBCurveRenderingMethod();
1313 
1316  LineTessellationKit & UnsetViewports();
1317 
1320  LineTessellationKit & UnsetChordTolerance();
1321 
1324  LineTessellationKit & UnsetIgnoreCriteria();
1325 
1328  LineTessellationKit & UnsetMemoryLimit();
1329 
1332  LineTessellationKit & UnsetTransparentBodies();
1333 
1336  LineTessellationKit & UnsetMissingGeometryFailure();
1337 
1340  LineTessellationKit & UnsetOverlappingBehavior();
1341 
1344  LineTessellationKit & UnsetEverything();
1345 
1346 
1347 
1348 
1353  bool ShowEdges(bool & out_draw_edges, bool & out_internal_edges) const;
1354 
1360  bool ShowSilhouetteEdges(bool & out_draw_silhouette_edges, bool & out_draw_circles_as_arcs) const;
1361 
1368  bool ShowPlanarHatching(Line::Hatching::Planar & out_planar_haching, double & out_planar_spacing, DPoint & out_point_through, DVector & out_direction) const;
1369 
1379  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;
1380 
1388  bool ShowParametericHatching(Line::Hatching::Parametric & out_parametric_hatching, double & out_u, double & out_u_start, double & out_v, double & out_v_start) const;
1389 
1394  bool ShowUnfixedBlends(Line::UnfixedBlends & out_unfixed_blends, double & out_spacing) const;
1395 
1403  bool ShowVisibilityEvaluation(Line::Visibility & out_visibility, bool & out_draw_invisible, bool & out_drafting, bool & out_self_hidden, IntArray & out_suppressed_indices) const;
1404 
1409  bool ShowSmoothEdges(Line::Smooth & out_smooth, double & out_tolerance) const;
1410 
1414  bool ShowRegionalData(Line::Region & out_region) const;
1415 
1419  bool ShowHierarchicalOutput(Line::Hierarchical & out_hierarchical_output) const;
1420 
1424  bool ShowBCurveRenderingMethod(Line::BCurveRendering & out_bcurve_rendering_method) const;
1425 
1432  bool ShowViewports(bool & out_use_viewports, bool & out_is_3d, bool & out_viewport_clipping, ViewportArray & out_viewports) const;
1433 
1439  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1440 
1446  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value) const;
1447 
1452  bool ShowMemoryLimit(bool & out_use_memory_limit, size_t & out_limit) const;
1453 
1459  bool ShowTransparentBodies(bool & out_allow_transparency, bool & out_transparent_hide, IntArray & out_force_transparent) const;
1460 
1464  bool ShowMissingGeometryFailure(bool & out_fail_on_missing_geometry) const;
1465 
1471  bool ShowOverlappingBehavior(Line::OverlappingBehavior & out_overlapping_behavior, IntArray & out_indices_one, IntArray & out_indices_two) const;
1472  };
1473 
1474 
1476  class PARASOLID_API ExportOptionsKit : public HPS::Sprocket
1477  {
1478  public:
1480  ExportOptionsKit();
1481 
1484  ExportOptionsKit(ExportOptionsKit const & in_kit);
1485 
1489  ExportOptionsKit(ExportOptionsKit && in_that);
1490 
1494  ExportOptionsKit & operator=(ExportOptionsKit && in_that);
1495 
1496  virtual ~ExportOptionsKit();
1497 
1498  HPS::Type ObjectType() const { return HPS::Type::ParasolidExportOptionsKit; }
1499 
1503  static ExportOptionsKit GetDefault();
1504 
1507  void Set(ExportOptionsKit const & in_kit);
1508 
1511  void Show(ExportOptionsKit & out_kit) const;
1512 
1516  ExportOptionsKit & operator=(ExportOptionsKit const & in_kit);
1517 
1520  bool Empty() const;
1521 
1525  bool Equals(ExportOptionsKit const & in_kit) const;
1526 
1530  bool operator==(ExportOptionsKit const & in_kit) const;
1531 
1535  bool operator!=(ExportOptionsKit const & in_kit) const;
1536 
1543  ExportOptionsKit & SetFormat(Parasolid::Format in_format);
1544 
1549  ExportOptionsKit & SetUserFields(bool in_export_user_fields);
1550 
1551 
1554  ExportOptionsKit & UnsetFormat();
1555 
1558  ExportOptionsKit & UnsetUserFields();
1559 
1562  ExportOptionsKit & UnsetEverything();
1563 
1564 
1568  bool ShowFormat(Parasolid::Format & out_format) const;
1569 
1573  bool ShowUserFields(bool & out_user_fields) const;
1574  };
1575  };
1576 }
1577 
1578 #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:66
Radial
Definition: sprk_parasolid.h:207
Definition: sprk_parasolid.h:170
Definition: sprk_parasolid.h:1476
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:464
Definition: hps.h:1497
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:684
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:1103
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:306
Definition: sprk_parasolid.h:1081
Definition: sprk.h:1614
Definition: hps.h:43052
Planar
Definition: sprk_parasolid.h:199
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:436
Definition: sprk.h:445
Definition: sprk_parasolid.h:39
CompoundBodyBehavior
Definition: sprk_parasolid.h:80
Definition: sprk_parasolid.h:334
ComponentType
Definition: sprk.h:1619
Definition: sprk_parasolid.h:285
Shape
Definition: sprk_parasolid.h:121
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:1498
OverlappingBehavior
Definition: sprk_parasolid.h:269
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:515
IncrementalFaceting
Definition: sprk_parasolid.h:162
Ignore
Definition: sprk_parasolid.h:108
Definition: sprk_parasolid.h:662
Definition: sprk.h:2372
Visibility
Definition: sprk_parasolid.h:231
static Model CreateModel(char const *in_name="")
Definition: sprk_parasolid.h:408
Region
Definition: sprk_parasolid.h:247
Definition: sprk_parasolid.h:493