0031642: Visualization - crash in Graphic3d_Structure::SetVisual() on redisplaying...
[occt.git] / src / TDataXtd / TDataXtd_PatternStd.hxx
1 // Created on: 2009-04-06
2 // Created by: Sergey ZARITCHNY
3 // Copyright (c) 2009-2014 OPEN CASCADE SAS
4 //
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and/or modify it under
8 // the terms of the GNU Lesser General Public License version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 #ifndef _TDataXtd_PatternStd_HeaderFile
17 #define _TDataXtd_PatternStd_HeaderFile
18
19 #include <Standard.hxx>
20 #include <Standard_Type.hxx>
21
22 #include <Standard_Integer.hxx>
23 #include <Standard_Boolean.hxx>
24 #include <TDataXtd_Pattern.hxx>
25 #include <TDataXtd_Array1OfTrsf.hxx>
26 #include <Standard_OStream.hxx>
27 class TNaming_NamedShape;
28 class TDataStd_Real;
29 class TDataStd_Integer;
30 class Standard_GUID;
31 class TDF_Label;
32 class TDF_Attribute;
33 class TDF_RelocationTable;
34 class TDF_DataSet;
35
36
37 class TDataXtd_PatternStd;
38 DEFINE_STANDARD_HANDLE(TDataXtd_PatternStd, TDataXtd_Pattern)
39
40 //! to create a PatternStd
41 //! (LinearPattern, CircularPattern, RectangularPattern,
42 //! RadialCircularPattern, MirrorPattern)
43 class TDataXtd_PatternStd : public TDataXtd_Pattern
44 {
45
46 public:
47
48   
49   Standard_EXPORT static const Standard_GUID& GetPatternID();
50   
51   //! Find, or  create,  a PatternStd  attribute
52   Standard_EXPORT static Handle(TDataXtd_PatternStd) Set (const TDF_Label& label);
53   
54   Standard_EXPORT TDataXtd_PatternStd();
55   
56   Standard_EXPORT void Signature (const Standard_Integer signature);
57   
58   Standard_EXPORT void Axis1 (const Handle(TNaming_NamedShape)& Axis1);
59   
60   Standard_EXPORT void Axis2 (const Handle(TNaming_NamedShape)& Axis2);
61   
62   Standard_EXPORT void Axis1Reversed (const Standard_Boolean Axis1Reversed);
63   
64   Standard_EXPORT void Axis2Reversed (const Standard_Boolean Axis2Reversed);
65   
66   Standard_EXPORT void Value1 (const Handle(TDataStd_Real)& value);
67   
68   Standard_EXPORT void Value2 (const Handle(TDataStd_Real)& value);
69   
70   Standard_EXPORT void NbInstances1 (const Handle(TDataStd_Integer)& NbInstances1);
71   
72   Standard_EXPORT void NbInstances2 (const Handle(TDataStd_Integer)& NbInstances2);
73   
74   Standard_EXPORT void Mirror (const Handle(TNaming_NamedShape)& plane);
75   
76     Standard_Integer Signature() const;
77   
78     Handle(TNaming_NamedShape) Axis1() const;
79   
80     Handle(TNaming_NamedShape) Axis2() const;
81   
82     Standard_Boolean Axis1Reversed() const;
83   
84     Standard_Boolean Axis2Reversed() const;
85   
86     Handle(TDataStd_Real) Value1() const;
87   
88     Handle(TDataStd_Real) Value2() const;
89   
90     Handle(TDataStd_Integer) NbInstances1() const;
91   
92     Handle(TDataStd_Integer) NbInstances2() const;
93   
94     Handle(TNaming_NamedShape) Mirror() const;
95   
96   Standard_EXPORT Standard_Integer NbTrsfs() const Standard_OVERRIDE;
97   
98   Standard_EXPORT void ComputeTrsfs (TDataXtd_Array1OfTrsf& Trsfs) const Standard_OVERRIDE;
99   
100   Standard_EXPORT const Standard_GUID& PatternID() const Standard_OVERRIDE;
101   
102   Standard_EXPORT void Restore (const Handle(TDF_Attribute)& With) Standard_OVERRIDE;
103   
104   Standard_EXPORT Handle(TDF_Attribute) NewEmpty() const Standard_OVERRIDE;
105   
106   Standard_EXPORT void Paste (const Handle(TDF_Attribute)& Into, const Handle(TDF_RelocationTable)& RT) const Standard_OVERRIDE;
107   
108   Standard_EXPORT virtual void References (const Handle(TDF_DataSet)& aDataSet) const Standard_OVERRIDE;
109   
110   Standard_EXPORT virtual Standard_OStream& Dump (Standard_OStream& anOS) const Standard_OVERRIDE;
111
112
113
114
115   DEFINE_STANDARD_RTTIEXT(TDataXtd_PatternStd,TDataXtd_Pattern)
116
117 protected:
118
119
120
121
122 private:
123
124
125   Standard_Integer mySignature;
126   Standard_Boolean myAxis1Reversed;
127   Standard_Boolean myAxis2Reversed;
128   Handle(TNaming_NamedShape) myAxis1;
129   Handle(TNaming_NamedShape) myAxis2;
130   Handle(TDataStd_Real) myValue1;
131   Handle(TDataStd_Real) myValue2;
132   Handle(TDataStd_Integer) myNb1;
133   Handle(TDataStd_Integer) myNb2;
134   Handle(TNaming_NamedShape) myMirror;
135
136
137 };
138
139
140 #include <TDataXtd_PatternStd.lxx>
141
142
143
144
145
146 #endif // _TDataXtd_PatternStd_HeaderFile