Warning, file /include/opencascade/HLRBRep_SLProps.hxx was not indexed
or was modified since last indexation (in which case cross-reference links may be missing, inaccurate or erroneous).
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _HLRBRep_SLProps_HeaderFile
0018 #define _HLRBRep_SLProps_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022
0023 #include <Standard_Integer.hxx>
0024 #include <gp_Pnt.hxx>
0025 #include <gp_Vec.hxx>
0026 #include <gp_Dir.hxx>
0027 #include <LProp_Status.hxx>
0028 class LProp_BadContinuity;
0029 class Standard_DomainError;
0030 class Standard_OutOfRange;
0031 class LProp_NotDefined;
0032 class HLRBRep_SLPropsATool;
0033 class gp_Pnt;
0034 class gp_Vec;
0035 class gp_Dir;
0036
0037
0038
0039 class HLRBRep_SLProps
0040 {
0041 public:
0042
0043 DEFINE_STANDARD_ALLOC
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056 Standard_EXPORT HLRBRep_SLProps(const Standard_Address& S, const Standard_Real U, const Standard_Real V, const Standard_Integer N, const Standard_Real Resolution);
0057
0058
0059
0060 Standard_EXPORT HLRBRep_SLProps(const Standard_Address& S, const Standard_Integer N, const Standard_Real Resolution);
0061
0062
0063
0064
0065 Standard_EXPORT HLRBRep_SLProps(const Standard_Integer N, const Standard_Real Resolution);
0066
0067
0068
0069 Standard_EXPORT void SetSurface (const Standard_Address& S);
0070
0071
0072
0073 Standard_EXPORT void SetParameters (const Standard_Real U, const Standard_Real V);
0074
0075
0076 Standard_EXPORT const gp_Pnt& Value() const;
0077
0078
0079
0080 Standard_EXPORT const gp_Vec& D1U();
0081
0082
0083
0084 Standard_EXPORT const gp_Vec& D1V();
0085
0086
0087
0088 Standard_EXPORT const gp_Vec& D2U();
0089
0090
0091
0092 Standard_EXPORT const gp_Vec& D2V();
0093
0094
0095
0096 Standard_EXPORT const gp_Vec& DUV();
0097
0098
0099
0100
0101 Standard_EXPORT Standard_Boolean IsTangentUDefined();
0102
0103
0104 Standard_EXPORT void TangentU (gp_Dir& D);
0105
0106
0107
0108
0109 Standard_EXPORT Standard_Boolean IsTangentVDefined();
0110
0111
0112 Standard_EXPORT void TangentV (gp_Dir& D);
0113
0114
0115 Standard_EXPORT Standard_Boolean IsNormalDefined();
0116
0117
0118 Standard_EXPORT const gp_Dir& Normal();
0119
0120
0121 Standard_EXPORT Standard_Boolean IsCurvatureDefined();
0122
0123
0124
0125 Standard_EXPORT Standard_Boolean IsUmbilic();
0126
0127
0128 Standard_EXPORT Standard_Real MaxCurvature();
0129
0130
0131 Standard_EXPORT Standard_Real MinCurvature();
0132
0133
0134
0135 Standard_EXPORT void CurvatureDirections (gp_Dir& MaxD, gp_Dir& MinD);
0136
0137
0138 Standard_EXPORT Standard_Real MeanCurvature();
0139
0140
0141 Standard_EXPORT Standard_Real GaussianCurvature();
0142
0143
0144
0145
0146 protected:
0147
0148
0149
0150
0151
0152 private:
0153
0154
0155
0156 Standard_Address mySurf;
0157 Standard_Real myU;
0158 Standard_Real myV;
0159 Standard_Integer myDerOrder;
0160 Standard_Integer myCN;
0161 Standard_Real myLinTol;
0162 gp_Pnt myPnt;
0163 gp_Vec myD1u;
0164 gp_Vec myD1v;
0165 gp_Vec myD2u;
0166 gp_Vec myD2v;
0167 gp_Vec myDuv;
0168 gp_Dir myNormal;
0169 Standard_Real myMinCurv;
0170 Standard_Real myMaxCurv;
0171 gp_Dir myDirMinCurv;
0172 gp_Dir myDirMaxCurv;
0173 Standard_Real myMeanCurv;
0174 Standard_Real myGausCurv;
0175 Standard_Integer mySignificantFirstDerivativeOrderU;
0176 Standard_Integer mySignificantFirstDerivativeOrderV;
0177 LProp_Status myUTangentStatus;
0178 LProp_Status myVTangentStatus;
0179 LProp_Status myNormalStatus;
0180 LProp_Status myCurvatureStatus;
0181
0182
0183 };
0184
0185
0186
0187
0188
0189
0190
0191 #endif