summaryrefslogtreecommitdiff
path: root/inc/IntImpParGen_ImpParTool.gxx
blob: 128b95f376cf5a95b104e6548762c916c3ba7201 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43

#include <gp_Vec2d.hxx>



IntImpParGen_ImpParTool::IntImpParGen_ImpParTool(const ImpTool& ITool,
						 const ParCurve& PC):
	 TheImpTool(ITool) 
{  
  TheParCurve = (Standard_Address)(&PC);
}


Standard_Boolean IntImpParGen_ImpParTool::Value(const Standard_Real Param,
				   Standard_Real& ApproxDistance) {
  
  ApproxDistance = TheImpTool.Distance(ParTool::Value((*((ParCurve *)(TheParCurve))),Param));
  return(Standard_True);
}

Standard_Boolean IntImpParGen_ImpParTool::Derivative(const Standard_Real Param,
					Standard_Real& D_ApproxDistance_DV) {
  
  gp_Pnt2d Pt;
  gp_Vec2d TanParCurve;
  gp_Vec2d Grad=TheImpTool.GradDistance(ParTool::Value((*((ParCurve *)(TheParCurve))),Param));
  ParTool::D1((*((ParCurve *)(TheParCurve))),Param,Pt,TanParCurve);
  D_ApproxDistance_DV = Grad.Dot(TanParCurve);
  return(Standard_True);
}


Standard_Boolean IntImpParGen_ImpParTool::Values(const Standard_Real Param,
				    Standard_Real& ApproxDistance,
				    Standard_Real& Deriv) {
  
  this->Value(Param,ApproxDistance);
  this->Derivative(Param,Deriv);
  return(Standard_True);
}