API Search || Global Search
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 #if !defined(_MSC_VER) || _MSC_VER >= 1900
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 
390  void Tessellate(Parasolid::FacetTessellationKit const & in_facet_options, Parasolid::LineTessellationKit const & in_line_options);
391  };
392 
394  class PARASOLID_API Factory : public Sprocket
395  {
396  public:
401  static Component CreateComponent(HPS::Component const & in_owner, HPS::Component::ComponentType in_type, ParasolidEntity in_entity = 0);
402 
405  static CADModel CreateCADModel(Model const & in_model = HPS::Factory::CreateModel());
406 
407  private:
409  Factory();
410  };
411 
413  class PARASOLID_API ImportNotifier : public IONotifier
414  {
415  public:
417  ImportNotifier();
418 
421  ImportNotifier(ImportNotifier const & in_that);
422 
427  ImportNotifier(IONotifier const & in_that);
428 
432  ImportNotifier(ImportNotifier && in_that);
433 
437  ImportNotifier & operator=(ImportNotifier && in_that);
438 
439  virtual ~ImportNotifier();
440 
441  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportNotifier; };
442 
446  ImportNotifier & operator=(ImportNotifier const & in_that);
447 
450  void Assign(ImportNotifier const & in_that);
451 
454  Parasolid::CADModel GetCADModel() const;
455 
458  Time GetImportTime() const;
459 
462  Time GetParseTime() const;
463  };
464 
465  class ImportOptionsKit;
466  class ExportOptionsKit;
467 
469  class PARASOLID_API File
470  {
471  public:
472 
477  static ImportNotifier Import(char const * in_file_name, ImportOptionsKit const & in_options);
478 
484  static ImportNotifier Import(EntityArray const & in_parts, FacetTessellationKit const & in_facet_options, LineTessellationKit const & in_line_options);
485 
490  static void Export(CADModel const & in_cad_model, char const * in_file_name, ExportOptionsKit const & in_options);
491 
492  private:
494  File();
495  };
496 
498  class PARASOLID_API ImportOptionsKit : public SprocketKit
499  {
500  public:
503 
506  ImportOptionsKit(ImportOptionsKit const & in_kit);
507 
512 
516  ImportOptionsKit & operator=(ImportOptionsKit && in_that);
517 
518  virtual ~ImportOptionsKit();
519 
520  HPS::Type ObjectType() const { return HPS::Type::ParasolidImportOptionsKit; }
521 
525  static ImportOptionsKit GetDefault();
526 
529  void Set(ImportOptionsKit const & in_kit);
530 
533  void Show(ImportOptionsKit & out_kit) const;
534 
538  ImportOptionsKit & operator=(ImportOptionsKit const & in_kit);
539 
542  bool Empty() const;
543 
547  bool Equals(ImportOptionsKit const & in_kit) const;
548 
552  bool operator==(ImportOptionsKit const & in_kit) const;
553 
557  bool operator!=(ImportOptionsKit const & in_kit) const;
558 
565  ImportOptionsKit & SetFormat(Parasolid::Format in_format);
566 
573  ImportOptionsKit & SetUserFields(bool in_import_user_fields);
574 
581  ImportOptionsKit & SetAttributeMismatchBehavior(Parasolid::MismatchBehavior in_behavior);
582 
589  ImportOptionsKit & SetCompoundBodyBehavior(Parasolid::CompoundBodyBehavior in_behavior);
590 
595  ImportOptionsKit & SetFacetTessellation(Parasolid::FacetTessellationKit const & in_facet_tessellation_kit);
596 
601  ImportOptionsKit & SetLineTessellation(Parasolid::LineTessellationKit const & in_line_tessellation_kit);
602 
603 
606  ImportOptionsKit & UnsetFormat();
607 
610  ImportOptionsKit & UnsetUserFields();
611 
614  ImportOptionsKit & UnsetAttributeMismatchBehavior();
615 
618  ImportOptionsKit & UnsetCompoundBodyBehavior();
619 
622  ImportOptionsKit & UnsetFacetTessellation();
623 
626  ImportOptionsKit & UnsetLineTessellation();
627 
630  ImportOptionsKit & UnsetEverything();
631 
632 
636  bool ShowFormat(Parasolid::Format & out_format) const;
637 
641  bool ShowUserFields(bool & out_user_fields) const;
642 
646  bool ShowAttributeMismatchBehavior(Parasolid::MismatchBehavior & out_behavior) const;
647 
651  bool ShowCompoundBodyBehavior(Parasolid::CompoundBodyBehavior & out_behavior) const;
652 
656  bool ShowFacetTessellation(Parasolid::FacetTessellationKit & out_facet_tessellation) const;
657 
661  bool ShowLineTessellation(Parasolid::LineTessellationKit & out_line_tessellation) const;
662 
663  };
664 
667  class PARASOLID_API FacetTessellationKit : public SprocketKit
668  {
669  public:
672 
676 
681 
685  FacetTessellationKit & operator=(FacetTessellationKit && in_that);
686 
687  virtual ~FacetTessellationKit();
688 
689  HPS::Type ObjectType() const { return HPS::Type::ParasolidFacetTessellationKit; }
690 
694  static FacetTessellationKit GetDefault();
695 
698  void Set(FacetTessellationKit const & in_kit);
699 
702  void Show(FacetTessellationKit & out_kit) const;
703 
707  FacetTessellationKit & operator=(FacetTessellationKit const & in_kit);
708 
711  bool Empty() const;
712 
716  bool Equals(FacetTessellationKit const & in_kit) const;
717 
721  bool operator==(FacetTessellationKit const & in_kit) const;
722 
726  bool operator!=(FacetTessellationKit const & in_kit) const;
727 
728 
737  FacetTessellationKit & SetTessellationLevel(HPS::Parasolid::TessellationLevel in_tessellation_level, double in_chord = -1, double in_angle = -1, bool in_generate_line_tessellation = true);
738 
743  FacetTessellationKit & SetShapeGeneration(Facet::Shape in_shape);
744 
749  FacetTessellationKit & SetVertexMatching(Facet::Match in_vertex_matching);
750 
757  FacetTessellationKit & SetDensity(Facet::Density in_density, double in_density_tolerance = 0, double in_density_max_angle = 0, DVectorArray const & in_view_directions = DVectorArray());
758 
763  FacetTessellationKit & SetIgnoredLoops(IntArray & in_ignored_loops);
764 
770  FacetTessellationKit & SetFacetSize(double in_minimum_width, double in_maximum_width, int in_maximum_sides);
771 
777  FacetTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
778 
783  FacetTessellationKit & SetSurfacePlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
784 
789  FacetTessellationKit & SetFacetPlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
790 
794  FacetTessellationKit & SetDegeneracyBehavior(Facet::Degeneracy in_degeneracy_behavior);
795 
801  FacetTessellationKit & SetLocalTolerances(ToleranceArray const & in_tolerance_array, IntArray const & in_topology_array, IntArray const & in_tolerance_for_tolopoly);
802 
809  FacetTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0, bool in_treat_faces_individually = false);
810 
814  FacetTessellationKit & SetWireEdges(bool in_wire_edges);
815 
820  FacetTessellationKit & SetIncrementalFaceting(Facet::IncrementalFaceting in_faceting, bool refine_tessellation = false);
821 
825  FacetTessellationKit & SetInflection(bool in_refine);
826 
830  FacetTessellationKit & SetImprovedFacetQuality(bool in_improved_quality);
831 
835  FacetTessellationKit & SetFlattenVertices(bool in_flatten_vertices);
836 
840  FacetTessellationKit & SetOffsetFaces(bool in_offset_faces);
841 
845  FacetTessellationKit & SetNormals(bool in_normals);
846 
850  FacetTessellationKit & SetParameters(bool in_parameters);
851 
855  FacetTessellationKit & SetEdges(bool in_edges);
856 
862  FacetTessellationKit & SetStrips(bool in_strips, int in_max_facets_per_strip, bool in_split_strips);
863 
866  FacetTessellationKit & UnsetTessellationLevel();
867 
870  FacetTessellationKit & UnsetShapeGeneration();
871 
874  FacetTessellationKit & UnsetVertexMatching();
875 
878  FacetTessellationKit & UnsetDensity();
879 
882  FacetTessellationKit & UnsetIgnoredLoops();
883 
886  FacetTessellationKit & UnsetFacetSize();
887 
890  FacetTessellationKit & UnsetChordTolerance();
891 
894  FacetTessellationKit & UnsetSurfacePlaneTolerance();
895 
898  FacetTessellationKit & UnsetFacetPlaneTolerance();
899 
902  FacetTessellationKit & UnsetDegeneracyBehavior();
903 
906  FacetTessellationKit & UnsetLocalTolerances();
907 
910  FacetTessellationKit & UnsetIgnoreCriteria();
911 
914  FacetTessellationKit & UnsetWireEdges();
915 
918  FacetTessellationKit & UnsetIncrementalFaceting();
919 
922  FacetTessellationKit & UnsetInflection();
923 
926  FacetTessellationKit & UnsetImprovedFacetQuality();
927 
930  FacetTessellationKit & UnsetFlattenVertices();
931 
934  FacetTessellationKit & UnsetOffsetFaces();
935 
938  FacetTessellationKit & UnsetNormals();
939 
942  FacetTessellationKit & UnsetParameters();
943 
946  FacetTessellationKit & UnsetEdges();
947 
950  FacetTessellationKit & UnsetStrips();
951 
954  FacetTessellationKit & UnsetEverything();
955 
956 
963  bool ShowTessellationLevel(TessellationLevel & out_tessellation_level, double & out_chord, double & out_angle, bool & out_generate_line_tessellation) const;
964 
968  bool ShowShapeGeneration(Facet::Shape & out_shape) const;
969 
973  bool ShowVertexMatching(Facet::Match & out_vertex_matching) const;
974 
981  bool ShowDensity(Facet::Density & out_density, double & out_density_tolerance, double & out_density_max_angle, DVectorArray & out_view_directions) const;
982 
986  bool ShowIgnoredLoops(IntArray & out_ignored_loops) const;
987 
993  bool ShowFacetSize(double & out_minimum_width, double & out_maximum_width, int & out_maximum_sides) const;
994 
1000  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1001 
1006  bool ShowSurfacePlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1007 
1012  bool ShowFacetPlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1013 
1017  bool ShowDegeneracyBehavior(Facet::Degeneracy & out_degeneracy_behavior) const;
1018 
1024  bool ShowLocalTolerances(ToleranceArray & out_tolerance_array, IntArray & out_topology_array, IntArray & out_tolerance_for_tolopoly) const;
1025 
1032  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value, bool & out_treat_faces_individually) const;
1033 
1037  bool ShowWireEdges(bool & out_wire_edges) const;
1038 
1043  bool ShowIncrementalFaceting(Facet::IncrementalFaceting & out_faceting, bool & out_refine_tessellation) const;
1044 
1048  bool ShowInflection(bool & out_refine) const;
1049 
1053  bool ShowImprovedFacetQuality(bool & out_improved_quality) const;
1054 
1058  bool ShowFlattenVertices(bool & out_flatten_vertices) const;
1059 
1063  bool ShowOffsetFaces(bool & out_offset_faces) const;
1064 
1068  bool ShowNormals(bool & out_normals) const;
1069 
1073  bool ShowParameters(bool & out_parameters) const;
1074 
1078  bool ShowEdges(bool & out_edges) const;
1079 
1085  bool ShowStrips(bool & out_strips, int & out_max_facets_per_strip, bool & out_split_strips) const;
1086 
1087  };
1088 
1090  class PARASOLID_API LineTessellationKit : public SprocketKit
1091  {
1092  public:
1095 
1098  LineTessellationKit(LineTessellationKit const & in_kit);
1099 
1104 
1108  LineTessellationKit & operator=(LineTessellationKit && in_that);
1109 
1110  virtual ~LineTessellationKit();
1111 
1112  HPS::Type ObjectType() const { return HPS::Type::ParasolidLineTessellationKit; }
1113 
1117  static LineTessellationKit GetDefault();
1118 
1121  void Set(LineTessellationKit const & in_kit);
1122 
1125  void Show(LineTessellationKit & out_kit) const;
1126 
1130  LineTessellationKit & operator=(LineTessellationKit const & in_kit);
1131 
1134  bool Empty() const;
1135 
1139  bool Equals(LineTessellationKit const & in_kit) const;
1140 
1144  bool operator==(LineTessellationKit const & in_kit) const;
1145 
1149  bool operator!=(LineTessellationKit const & in_kit) const;
1150 
1151 
1152 
1157  LineTessellationKit & SetEdges(bool in_draw_edges, bool in_internal_edges);
1158 
1164  LineTessellationKit & SetSilhouetteEdges(bool in_draw_silhouette_edges, bool in_draw_circles_as_arcs);
1165 
1172  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));
1173 
1183  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);
1184 
1192  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);
1193 
1198  LineTessellationKit & SetUnfixedBlends(Line::UnfixedBlends in_unfixed_blends, double in_spacing = 0);
1199 
1207  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());
1208 
1213  LineTessellationKit & SetSmoothEdges(Line::Smooth in_smooth, double in_tolerance = 0);
1214 
1218  LineTessellationKit & SetRegionalData(Line::Region in_region);
1219 
1223  LineTessellationKit & SetHierarchicalOutput(Line::Hierarchical in_hierarchical_output);
1224 
1228  LineTessellationKit & SetBCurveRenderingMethod(Line::BCurveRendering in_bcurve_rendering_method);
1229 
1236  LineTessellationKit & SetViewports(bool in_use_viewports, bool in_is_3d = true, bool viewport_clipping = false, ViewportArray in_viewports = ViewportArray());
1237 
1243  LineTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
1244 
1250  LineTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0);
1251 
1256  LineTessellationKit & SetMemoryLimit(bool in_use_memory_limit, size_t in_limit = 0);
1257 
1263  LineTessellationKit & SetTransparentBodies(bool in_allow_transparency, bool in_transparent_hide, IntArray in_transparent_bodies = IntArray());
1264 
1268  LineTessellationKit & SetMissingGeometryFailure(bool in_fail_on_missing_geometry);
1269 
1275  LineTessellationKit & SetOverlappingBehavior(Line::OverlappingBehavior in_overlapping_behavior, IntArray in_indices_one = IntArray(), IntArray in_indices_two = IntArray());
1276 
1277 
1278 
1281  LineTessellationKit & UnsetEdges();
1282 
1285  LineTessellationKit & UnsetSilhouetteEdges();
1286 
1289  LineTessellationKit & UnsetPlanarHatching();
1290 
1293  LineTessellationKit & UnsetRadialHatching();
1294 
1297  LineTessellationKit & UnsetParametericHatching();
1298 
1301  LineTessellationKit & UnsetUnfixedBlends();
1302 
1305  LineTessellationKit & UnsetVisibilityEvaluation();
1306 
1309  LineTessellationKit & UnsetSmoothEdges();
1310 
1313  LineTessellationKit & UnsetRegionalData();
1314 
1317  LineTessellationKit & UnsetHierarchicalOutput();
1318 
1321  LineTessellationKit & UnsetBCurveRenderingMethod();
1322 
1325  LineTessellationKit & UnsetViewports();
1326 
1329  LineTessellationKit & UnsetChordTolerance();
1330 
1333  LineTessellationKit & UnsetIgnoreCriteria();
1334 
1337  LineTessellationKit & UnsetMemoryLimit();
1338 
1341  LineTessellationKit & UnsetTransparentBodies();
1342 
1345  LineTessellationKit & UnsetMissingGeometryFailure();
1346 
1349  LineTessellationKit & UnsetOverlappingBehavior();
1350 
1353  LineTessellationKit & UnsetEverything();
1354 
1355 
1356 
1357 
1362  bool ShowEdges(bool & out_draw_edges, bool & out_internal_edges) const;
1363 
1369  bool ShowSilhouetteEdges(bool & out_draw_silhouette_edges, bool & out_draw_circles_as_arcs) const;
1370 
1377  bool ShowPlanarHatching(Line::Hatching::Planar & out_planar_haching, double & out_planar_spacing, DPoint & out_point_through, DVector & out_direction) const;
1378 
1388  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;
1389 
1397  bool ShowParametericHatching(Line::Hatching::Parametric & out_parametric_hatching, double & out_u, double & out_u_start, double & out_v, double & out_v_start) const;
1398 
1403  bool ShowUnfixedBlends(Line::UnfixedBlends & out_unfixed_blends, double & out_spacing) const;
1404 
1412  bool ShowVisibilityEvaluation(Line::Visibility & out_visibility, bool & out_draw_invisible, bool & out_drafting, bool & out_self_hidden, IntArray & out_suppressed_indices) const;
1413 
1418  bool ShowSmoothEdges(Line::Smooth & out_smooth, double & out_tolerance) const;
1419 
1423  bool ShowRegionalData(Line::Region & out_region) const;
1424 
1428  bool ShowHierarchicalOutput(Line::Hierarchical & out_hierarchical_output) const;
1429 
1433  bool ShowBCurveRenderingMethod(Line::BCurveRendering & out_bcurve_rendering_method) const;
1434 
1441  bool ShowViewports(bool & out_use_viewports, bool & out_is_3d, bool & out_viewport_clipping, ViewportArray & out_viewports) const;
1442 
1448  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1449 
1455  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value) const;
1456 
1461  bool ShowMemoryLimit(bool & out_use_memory_limit, size_t & out_limit) const;
1462 
1468  bool ShowTransparentBodies(bool & out_allow_transparency, bool & out_transparent_hide, IntArray & out_force_transparent) const;
1469 
1473  bool ShowMissingGeometryFailure(bool & out_fail_on_missing_geometry) const;
1474 
1480  bool ShowOverlappingBehavior(Line::OverlappingBehavior & out_overlapping_behavior, IntArray & out_indices_one, IntArray & out_indices_two) const;
1481  };
1482 
1483 
1485  class PARASOLID_API ExportOptionsKit : public SprocketKit
1486  {
1487  public:
1489  ExportOptionsKit();
1490 
1493  ExportOptionsKit(ExportOptionsKit const & in_kit);
1494 
1498  ExportOptionsKit(ExportOptionsKit && in_that);
1499 
1503  ExportOptionsKit & operator=(ExportOptionsKit && in_that);
1504 
1505  virtual ~ExportOptionsKit();
1506 
1507  HPS::Type ObjectType() const { return HPS::Type::ParasolidExportOptionsKit; }
1508 
1512  static ExportOptionsKit GetDefault();
1513 
1516  void Set(ExportOptionsKit const & in_kit);
1517 
1520  void Show(ExportOptionsKit & out_kit) const;
1521 
1525  ExportOptionsKit & operator=(ExportOptionsKit const & in_kit);
1526 
1529  bool Empty() const;
1530 
1534  bool Equals(ExportOptionsKit const & in_kit) const;
1535 
1539  bool operator==(ExportOptionsKit const & in_kit) const;
1540 
1544  bool operator!=(ExportOptionsKit const & in_kit) const;
1545 
1552  ExportOptionsKit & SetFormat(Parasolid::Format in_format);
1553 
1558  ExportOptionsKit & SetUserFields(bool in_export_user_fields);
1559 
1560 
1563  ExportOptionsKit & UnsetFormat();
1564 
1567  ExportOptionsKit & UnsetUserFields();
1568 
1571  ExportOptionsKit & UnsetEverything();
1572 
1573 
1577  bool ShowFormat(Parasolid::Format & out_format) const;
1578 
1582  bool ShowUserFields(bool & out_user_fields) const;
1583  };
1584  };
1585 }
1586 
1587 #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.h:234
Definition: sprk_parasolid.h:1485
Degeneracy
Definition: sprk_parasolid.h:152
TessellationLevel
Definition: sprk_parasolid.h:51
Format
Definition: sprk_parasolid.h:63
Definition: sprk_parasolid.h:394
Definition: sprk_parasolid.h:469
Definition: hps.h:1556
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:689
BCurveRendering
Definition: sprk_parasolid.h:262
UnfixedBlends
Definition: sprk_parasolid.h:224
std::vector< DVector, Allocator< DVector > > DVectorArray
Array of type HPS::DVector.
Definition: hps.h:6550
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:1112
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:306
std::vector< int, Allocator< int > > IntArray
Array of type int.
Definition: hps.h:6552
Definition: sprk_parasolid.h:1090
Definition: sprk.h:1724
Definition: hps.h:47271
Planar
Definition: sprk_parasolid.h:199
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:441
Definition: sprk.h:473
Definition: sprk_parasolid.h:39
CompoundBodyBehavior
Definition: sprk_parasolid.h:80
Definition: sprk_parasolid.h:334
ComponentType
Definition: sprk.h:1729
Definition: sprk_parasolid.h:285
Shape
Definition: sprk_parasolid.h:121
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:1507
OverlappingBehavior
Definition: sprk_parasolid.h:269
HPS::Type ObjectType() const
Definition: sprk_parasolid.h:520
IncrementalFaceting
Definition: sprk_parasolid.h:162
Ignore
Definition: sprk_parasolid.h:108
Definition: sprk_parasolid.h:667
Definition: sprk.h:2548
Visibility
Definition: sprk_parasolid.h:231
static Model CreateModel(char const *in_name="")
Definition: sprk_parasolid.h:413
Region
Definition: sprk_parasolid.h:247
Definition: sprk_parasolid.h:498