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  static const HPS::Type staticType = HPS::Type::ParasolidComponent;
307  HPS::Type ObjectType() const { return staticType; }
308 
309 #ifndef _MSC_VER
310  Component & operator=(Component const & in_that) = default;
311 #endif
312 
316  Component & operator=(Parasolid::Component && in_that);
317 
318 
321  ParasolidEntity GetParasolidEntity() const;
322 
328  void Tessellate(Parasolid::FacetTessellationKit const & in_facet_options, Parasolid::LineTessellationKit const & in_line_options);
329  };
330 
331  typedef std::vector<Component, HPS::Allocator<Component>> ComponentArray;
332 
335  class PARASOLID_API CADModel : public HPS::CADModel
336  {
337  public:
339  CADModel();
340 
345  CADModel(Component const & in_that);
346 
351  CADModel(HPS::CADModel const & in_that);
352 
355  CADModel(Parasolid::CADModel const & in_that);
356 
359  CADModel(Parasolid::CADModel && in_that);
360 
361  virtual ~CADModel();
362 
363  static const HPS::Type staticType = HPS::Type::ParasolidCADModel;
364  HPS::Type ObjectType() const { return staticType; }
365 
366 #if !defined(_MSC_VER) || _MSC_VER >= 1900
367  CADModel & operator=(Parasolid::CADModel const & in_that) = default;
368 #endif
369 
373  CADModel & operator=(Parasolid::CADModel && in_that);
374 
378  Component GetComponentFromEntity(ParasolidEntity in_entity);
379 
387  Component AddEntity(ParasolidEntity in_entity_to_add, FacetTessellationKit const & in_facet_tessellation, LineTessellationKit const & in_line_tessellation, Component const & in_owner = Component());
388 
392  void Tessellate(Parasolid::FacetTessellationKit const & in_facet_options, Parasolid::LineTessellationKit const & in_line_options);
393  };
394 
396  class PARASOLID_API Factory : public Sprocket
397  {
398  public:
403  static Component CreateComponent(HPS::Component const & in_owner, HPS::Component::ComponentType in_type, ParasolidEntity in_entity = 0);
404 
407  static CADModel CreateCADModel(Model const & in_model = HPS::Factory::CreateModel());
408 
409  private:
411  Factory();
412  };
413 
415  class PARASOLID_API ImportNotifier : public IONotifier
416  {
417  public:
419  ImportNotifier();
420 
423  ImportNotifier(ImportNotifier const & in_that);
424 
429  ImportNotifier(IONotifier const & in_that);
430 
434  ImportNotifier(ImportNotifier && in_that);
435 
439  ImportNotifier & operator=(ImportNotifier && in_that);
440 
441  virtual ~ImportNotifier();
442 
443  static const HPS::Type staticType = HPS::Type::ParasolidImportNotifier;
444  HPS::Type ObjectType() const { return staticType; };
445 
449  ImportNotifier & operator=(ImportNotifier const & in_that);
450 
453  void Assign(ImportNotifier const & in_that);
454 
457  Parasolid::CADModel GetCADModel() const;
458 
461  Time GetImportTime() const;
462 
465  Time GetParseTime() const;
466  };
467 
468  class ImportOptionsKit;
469  class ExportOptionsKit;
470 
472  class PARASOLID_API File
473  {
474  public:
475 
480  static ImportNotifier Import(char const * in_file_name, ImportOptionsKit const & in_options);
481 
487  static ImportNotifier Import(EntityArray const & in_parts, FacetTessellationKit const & in_facet_options, LineTessellationKit const & in_line_options);
488 
493  static void Export(CADModel const & in_cad_model, char const * in_file_name, ExportOptionsKit const & in_options);
494 
495  private:
497  File();
498  };
499 
501  class PARASOLID_API ImportOptionsKit : public SprocketKit
502  {
503  public:
506 
509  ImportOptionsKit(ImportOptionsKit const & in_kit);
510 
515 
519  ImportOptionsKit & operator=(ImportOptionsKit && in_that);
520 
521  virtual ~ImportOptionsKit();
522 
523  static const HPS::Type staticType = HPS::Type::ParasolidImportOptionsKit;
524  HPS::Type ObjectType() const { return staticType; }
525 
529  static ImportOptionsKit GetDefault();
530 
533  void Set(ImportOptionsKit const & in_kit);
534 
537  void Show(ImportOptionsKit & out_kit) const;
538 
542  ImportOptionsKit & operator=(ImportOptionsKit const & in_kit);
543 
546  bool Empty() const;
547 
551  bool Equals(ImportOptionsKit const & in_kit) const;
552 
556  bool operator==(ImportOptionsKit const & in_kit) const;
557 
561  bool operator!=(ImportOptionsKit const & in_kit) const;
562 
569  ImportOptionsKit & SetFormat(Parasolid::Format in_format);
570 
577  ImportOptionsKit & SetUserFields(bool in_import_user_fields);
578 
585  ImportOptionsKit & SetAttributeMismatchBehavior(Parasolid::MismatchBehavior in_behavior);
586 
593  ImportOptionsKit & SetCompoundBodyBehavior(Parasolid::CompoundBodyBehavior in_behavior);
594 
599  ImportOptionsKit & SetFacetTessellation(Parasolid::FacetTessellationKit const & in_facet_tessellation_kit);
600 
605  ImportOptionsKit & SetLineTessellation(Parasolid::LineTessellationKit const & in_line_tessellation_kit);
606 
618  ImportOptionsKit & SetLocation(ComponentPath const & in_path, MatrixKit const & in_transform = MatrixKit());
619 
620 
623  ImportOptionsKit & UnsetFormat();
624 
627  ImportOptionsKit & UnsetUserFields();
628 
631  ImportOptionsKit & UnsetAttributeMismatchBehavior();
632 
635  ImportOptionsKit & UnsetCompoundBodyBehavior();
636 
639  ImportOptionsKit & UnsetFacetTessellation();
640 
643  ImportOptionsKit & UnsetLineTessellation();
644 
647  ImportOptionsKit & UnsetLocation();
648 
651  ImportOptionsKit & UnsetEverything();
652 
653 
657  bool ShowFormat(Parasolid::Format & out_format) const;
658 
662  bool ShowUserFields(bool & out_user_fields) const;
663 
667  bool ShowAttributeMismatchBehavior(Parasolid::MismatchBehavior & out_behavior) const;
668 
672  bool ShowCompoundBodyBehavior(Parasolid::CompoundBodyBehavior & out_behavior) const;
673 
677  bool ShowFacetTessellation(Parasolid::FacetTessellationKit & out_facet_tessellation) const;
678 
682  bool ShowLineTessellation(Parasolid::LineTessellationKit & out_line_tessellation) const;
683 
688  bool ShowLocation(ComponentPath & out_path, MatrixKit & out_transformation) const;
689 
690  };
691 
694  class PARASOLID_API FacetTessellationKit : public SprocketKit
695  {
696  public:
699 
703 
708 
712  FacetTessellationKit & operator=(FacetTessellationKit && in_that);
713 
714  virtual ~FacetTessellationKit();
715 
716  static const HPS::Type staticType = HPS::Type::ParasolidFacetTessellationKit;
717  HPS::Type ObjectType() const { return staticType; }
718 
722  static FacetTessellationKit GetDefault();
723 
726  void Set(FacetTessellationKit const & in_kit);
727 
730  void Show(FacetTessellationKit & out_kit) const;
731 
735  FacetTessellationKit & operator=(FacetTessellationKit const & in_kit);
736 
739  bool Empty() const;
740 
744  bool Equals(FacetTessellationKit const & in_kit) const;
745 
749  bool operator==(FacetTessellationKit const & in_kit) const;
750 
754  bool operator!=(FacetTessellationKit const & in_kit) const;
755 
756 
765  FacetTessellationKit & SetTessellationLevel(HPS::Parasolid::TessellationLevel in_tessellation_level, double in_chord = -1, double in_angle = -1, bool in_generate_line_tessellation = true);
766 
771  FacetTessellationKit & SetShapeGeneration(Facet::Shape in_shape);
772 
777  FacetTessellationKit & SetVertexMatching(Facet::Match in_vertex_matching);
778 
785  FacetTessellationKit & SetDensity(Facet::Density in_density, double in_density_tolerance = 0, double in_density_max_angle = 0, DVectorArray const & in_view_directions = DVectorArray());
786 
791  FacetTessellationKit & SetIgnoredLoops(IntArray & in_ignored_loops);
792 
798  FacetTessellationKit & SetFacetSize(double in_minimum_width, double in_maximum_width, int in_maximum_sides);
799 
805  FacetTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
806 
811  FacetTessellationKit & SetSurfacePlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
812 
817  FacetTessellationKit & SetFacetPlaneTolerance(double in_plane_tolerance, double in_max_plane_angle);
818 
822  FacetTessellationKit & SetDegeneracyBehavior(Facet::Degeneracy in_degeneracy_behavior);
823 
829  FacetTessellationKit & SetLocalTolerances(ToleranceArray const & in_tolerance_array, IntArray const & in_topology_array, IntArray const & in_tolerance_for_tolopoly);
830 
837  FacetTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0, bool in_treat_faces_individually = false);
838 
842  FacetTessellationKit & SetWireEdges(bool in_wire_edges);
843 
848  FacetTessellationKit & SetIncrementalFaceting(Facet::IncrementalFaceting in_faceting, bool refine_tessellation = false);
849 
853  FacetTessellationKit & SetInflection(bool in_refine);
854 
858  FacetTessellationKit & SetImprovedFacetQuality(bool in_improved_quality);
859 
863  FacetTessellationKit & SetFlattenVertices(bool in_flatten_vertices);
864 
868  FacetTessellationKit & SetOffsetFaces(bool in_offset_faces);
869 
873  FacetTessellationKit & SetNormals(bool in_normals);
874 
878  FacetTessellationKit & SetParameters(bool in_parameters);
879 
883  FacetTessellationKit & SetEdges(bool in_edges);
884 
890  FacetTessellationKit & SetStrips(bool in_strips, int in_max_facets_per_strip, bool in_split_strips);
891 
894  FacetTessellationKit & UnsetTessellationLevel();
895 
898  FacetTessellationKit & UnsetShapeGeneration();
899 
902  FacetTessellationKit & UnsetVertexMatching();
903 
906  FacetTessellationKit & UnsetDensity();
907 
910  FacetTessellationKit & UnsetIgnoredLoops();
911 
914  FacetTessellationKit & UnsetFacetSize();
915 
918  FacetTessellationKit & UnsetChordTolerance();
919 
922  FacetTessellationKit & UnsetSurfacePlaneTolerance();
923 
926  FacetTessellationKit & UnsetFacetPlaneTolerance();
927 
930  FacetTessellationKit & UnsetDegeneracyBehavior();
931 
934  FacetTessellationKit & UnsetLocalTolerances();
935 
938  FacetTessellationKit & UnsetIgnoreCriteria();
939 
942  FacetTessellationKit & UnsetWireEdges();
943 
946  FacetTessellationKit & UnsetIncrementalFaceting();
947 
950  FacetTessellationKit & UnsetInflection();
951 
954  FacetTessellationKit & UnsetImprovedFacetQuality();
955 
958  FacetTessellationKit & UnsetFlattenVertices();
959 
962  FacetTessellationKit & UnsetOffsetFaces();
963 
966  FacetTessellationKit & UnsetNormals();
967 
970  FacetTessellationKit & UnsetParameters();
971 
974  FacetTessellationKit & UnsetEdges();
975 
978  FacetTessellationKit & UnsetStrips();
979 
982  FacetTessellationKit & UnsetEverything();
983 
984 
991  bool ShowTessellationLevel(TessellationLevel & out_tessellation_level, double & out_chord, double & out_angle, bool & out_generate_line_tessellation) const;
992 
996  bool ShowShapeGeneration(Facet::Shape & out_shape) const;
997 
1001  bool ShowVertexMatching(Facet::Match & out_vertex_matching) const;
1002 
1009  bool ShowDensity(Facet::Density & out_density, double & out_density_tolerance, double & out_density_max_angle, DVectorArray & out_view_directions) const;
1010 
1014  bool ShowIgnoredLoops(IntArray & out_ignored_loops) const;
1015 
1021  bool ShowFacetSize(double & out_minimum_width, double & out_maximum_width, int & out_maximum_sides) const;
1022 
1028  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1029 
1034  bool ShowSurfacePlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1035 
1040  bool ShowFacetPlaneTolerance(double & out_plane_tolerance, double & out_max_plane_angle) const;
1041 
1045  bool ShowDegeneracyBehavior(Facet::Degeneracy & out_degeneracy_behavior) const;
1046 
1052  bool ShowLocalTolerances(ToleranceArray & out_tolerance_array, IntArray & out_topology_array, IntArray & out_tolerance_for_tolopoly) const;
1053 
1060  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value, bool & out_treat_faces_individually) const;
1061 
1065  bool ShowWireEdges(bool & out_wire_edges) const;
1066 
1071  bool ShowIncrementalFaceting(Facet::IncrementalFaceting & out_faceting, bool & out_refine_tessellation) const;
1072 
1076  bool ShowInflection(bool & out_refine) const;
1077 
1081  bool ShowImprovedFacetQuality(bool & out_improved_quality) const;
1082 
1086  bool ShowFlattenVertices(bool & out_flatten_vertices) const;
1087 
1091  bool ShowOffsetFaces(bool & out_offset_faces) const;
1092 
1096  bool ShowNormals(bool & out_normals) const;
1097 
1101  bool ShowParameters(bool & out_parameters) const;
1102 
1106  bool ShowEdges(bool & out_edges) const;
1107 
1113  bool ShowStrips(bool & out_strips, int & out_max_facets_per_strip, bool & out_split_strips) const;
1114 
1115  };
1116 
1118  class PARASOLID_API LineTessellationKit : public SprocketKit
1119  {
1120  public:
1123 
1126  LineTessellationKit(LineTessellationKit const & in_kit);
1127 
1132 
1136  LineTessellationKit & operator=(LineTessellationKit && in_that);
1137 
1138  virtual ~LineTessellationKit();
1139 
1140  static const HPS::Type staticType = HPS::Type::ParasolidLineTessellationKit;
1141  HPS::Type ObjectType() const { return staticType; }
1142 
1146  static LineTessellationKit GetDefault();
1147 
1150  void Set(LineTessellationKit const & in_kit);
1151 
1154  void Show(LineTessellationKit & out_kit) const;
1155 
1159  LineTessellationKit & operator=(LineTessellationKit const & in_kit);
1160 
1163  bool Empty() const;
1164 
1168  bool Equals(LineTessellationKit const & in_kit) const;
1169 
1173  bool operator==(LineTessellationKit const & in_kit) const;
1174 
1178  bool operator!=(LineTessellationKit const & in_kit) const;
1179 
1180 
1181 
1186  LineTessellationKit & SetEdges(bool in_draw_edges, bool in_internal_edges);
1187 
1193  LineTessellationKit & SetSilhouetteEdges(bool in_draw_silhouette_edges, bool in_draw_circles_as_arcs);
1194 
1201  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));
1202 
1212  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);
1213 
1221  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);
1222 
1227  LineTessellationKit & SetUnfixedBlends(Line::UnfixedBlends in_unfixed_blends, double in_spacing = 0);
1228 
1236  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());
1237 
1242  LineTessellationKit & SetSmoothEdges(Line::Smooth in_smooth, double in_tolerance = 0);
1243 
1247  LineTessellationKit & SetRegionalData(Line::Region in_region);
1248 
1252  LineTessellationKit & SetHierarchicalOutput(Line::Hierarchical in_hierarchical_output);
1253 
1257  LineTessellationKit & SetBCurveRenderingMethod(Line::BCurveRendering in_bcurve_rendering_method);
1258 
1265  LineTessellationKit & SetViewports(bool in_use_viewports, bool in_is_3d = true, bool viewport_clipping = false, ViewportArray in_viewports = ViewportArray());
1266 
1272  LineTessellationKit & SetChordTolerance(double in_chord_tolerance, double in_maximum_chord_length, double in_maximum_chord_angle);
1273 
1279  LineTessellationKit & SetIgnoreCriteria(bool in_ignore, Ignore in_ignore_criteria = Ignore::Absolute, double in_minimum_value = 0);
1280 
1285  LineTessellationKit & SetMemoryLimit(bool in_use_memory_limit, size_t in_limit = 0);
1286 
1292  LineTessellationKit & SetTransparentBodies(bool in_allow_transparency, bool in_transparent_hide, IntArray in_transparent_bodies = IntArray());
1293 
1297  LineTessellationKit & SetMissingGeometryFailure(bool in_fail_on_missing_geometry);
1298 
1304  LineTessellationKit & SetOverlappingBehavior(Line::OverlappingBehavior in_overlapping_behavior, IntArray in_indices_one = IntArray(), IntArray in_indices_two = IntArray());
1305 
1306 
1307 
1310  LineTessellationKit & UnsetEdges();
1311 
1314  LineTessellationKit & UnsetSilhouetteEdges();
1315 
1318  LineTessellationKit & UnsetPlanarHatching();
1319 
1322  LineTessellationKit & UnsetRadialHatching();
1323 
1326  LineTessellationKit & UnsetParametericHatching();
1327 
1330  LineTessellationKit & UnsetUnfixedBlends();
1331 
1334  LineTessellationKit & UnsetVisibilityEvaluation();
1335 
1338  LineTessellationKit & UnsetSmoothEdges();
1339 
1342  LineTessellationKit & UnsetRegionalData();
1343 
1346  LineTessellationKit & UnsetHierarchicalOutput();
1347 
1350  LineTessellationKit & UnsetBCurveRenderingMethod();
1351 
1354  LineTessellationKit & UnsetViewports();
1355 
1358  LineTessellationKit & UnsetChordTolerance();
1359 
1362  LineTessellationKit & UnsetIgnoreCriteria();
1363 
1366  LineTessellationKit & UnsetMemoryLimit();
1367 
1370  LineTessellationKit & UnsetTransparentBodies();
1371 
1374  LineTessellationKit & UnsetMissingGeometryFailure();
1375 
1378  LineTessellationKit & UnsetOverlappingBehavior();
1379 
1382  LineTessellationKit & UnsetEverything();
1383 
1384 
1385 
1386 
1391  bool ShowEdges(bool & out_draw_edges, bool & out_internal_edges) const;
1392 
1398  bool ShowSilhouetteEdges(bool & out_draw_silhouette_edges, bool & out_draw_circles_as_arcs) const;
1399 
1406  bool ShowPlanarHatching(Line::Hatching::Planar & out_planar_haching, double & out_planar_spacing, DPoint & out_point_through, DVector & out_direction) const;
1407 
1417  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;
1418 
1426  bool ShowParametericHatching(Line::Hatching::Parametric & out_parametric_hatching, double & out_u, double & out_u_start, double & out_v, double & out_v_start) const;
1427 
1432  bool ShowUnfixedBlends(Line::UnfixedBlends & out_unfixed_blends, double & out_spacing) const;
1433 
1441  bool ShowVisibilityEvaluation(Line::Visibility & out_visibility, bool & out_draw_invisible, bool & out_drafting, bool & out_self_hidden, IntArray & out_suppressed_indices) const;
1442 
1447  bool ShowSmoothEdges(Line::Smooth & out_smooth, double & out_tolerance) const;
1448 
1452  bool ShowRegionalData(Line::Region & out_region) const;
1453 
1457  bool ShowHierarchicalOutput(Line::Hierarchical & out_hierarchical_output) const;
1458 
1462  bool ShowBCurveRenderingMethod(Line::BCurveRendering & out_bcurve_rendering_method) const;
1463 
1470  bool ShowViewports(bool & out_use_viewports, bool & out_is_3d, bool & out_viewport_clipping, ViewportArray & out_viewports) const;
1471 
1477  bool ShowChordTolerance(double & out_chord_tolerance, double & out_maximum_chord_length, double & out_maximum_chord_angle) const;
1478 
1484  bool ShowIgnoreCriteria(bool & out_ignore, Ignore & out_ignore_criteria, double & out_minimum_value) const;
1485 
1490  bool ShowMemoryLimit(bool & out_use_memory_limit, size_t & out_limit) const;
1491 
1497  bool ShowTransparentBodies(bool & out_allow_transparency, bool & out_transparent_hide, IntArray & out_force_transparent) const;
1498 
1502  bool ShowMissingGeometryFailure(bool & out_fail_on_missing_geometry) const;
1503 
1509  bool ShowOverlappingBehavior(Line::OverlappingBehavior & out_overlapping_behavior, IntArray & out_indices_one, IntArray & out_indices_two) const;
1510  };
1511 
1512 
1514  class PARASOLID_API ExportOptionsKit : public SprocketKit
1515  {
1516  public:
1518  ExportOptionsKit();
1519 
1522  ExportOptionsKit(ExportOptionsKit const & in_kit);
1523 
1527  ExportOptionsKit(ExportOptionsKit && in_that);
1528 
1532  ExportOptionsKit & operator=(ExportOptionsKit && in_that);
1533 
1534  virtual ~ExportOptionsKit();
1535 
1536  static const HPS::Type staticType = HPS::Type::ParasolidExportOptionsKit;
1537  HPS::Type ObjectType() const { return staticType; }
1538 
1542  static ExportOptionsKit GetDefault();
1543 
1546  void Set(ExportOptionsKit const & in_kit);
1547 
1550  void Show(ExportOptionsKit & out_kit) const;
1551 
1555  ExportOptionsKit & operator=(ExportOptionsKit const & in_kit);
1556 
1559  bool Empty() const;
1560 
1564  bool Equals(ExportOptionsKit const & in_kit) const;
1565 
1569  bool operator==(ExportOptionsKit const & in_kit) const;
1570 
1574  bool operator!=(ExportOptionsKit const & in_kit) const;
1575 
1582  ExportOptionsKit & SetFormat(Parasolid::Format in_format);
1583 
1588  ExportOptionsKit & SetUserFields(bool in_export_user_fields);
1589 
1590 
1593  ExportOptionsKit & UnsetFormat();
1594 
1597  ExportOptionsKit & UnsetUserFields();
1598 
1601  ExportOptionsKit & UnsetEverything();
1602 
1603 
1607  bool ShowFormat(Parasolid::Format & out_format) const;
1608 
1612  bool ShowUserFields(bool & out_user_fields) const;
1613  };
1614  };
1615 }
1616 
1617 #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:236
Definition: sprk_parasolid.h:1514
Degeneracy
Definition: sprk_parasolid.h:152
TessellationLevel
Definition: sprk_parasolid.h:51
Format
Definition: sprk_parasolid.h:63
Definition: sprk_parasolid.h:396
Definition: sprk_parasolid.h:472
Definition: hps.h:1556
Hierarchical
Definition: sprk_parasolid.h:254
Definition: sprk_parasolid.h:196
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:6628
Density
Definition: sprk_parasolid.h:141
Definition: sprk_parasolid.h:193
Match
Definition: sprk_parasolid.h:131
Definition: hps.h:15474
std::vector< int, Allocator< int > > IntArray
Array of type int.
Definition: hps.h:6630
Definition: sprk_parasolid.h:1118
Definition: sprk.h:1739
Definition: hps.h:47733
Planar
Definition: sprk_parasolid.h:199
Definition: sprk.h:481
Definition: sprk_parasolid.h:39
CompoundBodyBehavior
Definition: sprk_parasolid.h:80
Definition: sprk.h:2065
Definition: sprk_parasolid.h:335
ComponentType
Definition: sprk.h:1755
Definition: sprk_parasolid.h:285
Shape
Definition: sprk_parasolid.h:121
OverlappingBehavior
Definition: sprk_parasolid.h:269
IncrementalFaceting
Definition: sprk_parasolid.h:162
Ignore
Definition: sprk_parasolid.h:108
Definition: sprk_parasolid.h:694
Definition: sprk.h:2634
Visibility
Definition: sprk_parasolid.h:231
static Model CreateModel(char const *in_name="")
Definition: sprk_parasolid.h:415
Region
Definition: sprk_parasolid.h:247
Definition: sprk_parasolid.h:501