mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 06:00:33 +05:00
removed angle argument from arcto
This commit is contained in:
parent
c9fb364cc0
commit
539798971c
@ -83,7 +83,6 @@ class WorkPlane : public enable_shared_from_this<WorkPlane>
|
|||||||
gp_Ax3 axis;
|
gp_Ax3 axis;
|
||||||
gp_Ax2d localpos;
|
gp_Ax2d localpos;
|
||||||
gp_Pnt2d startpnt;
|
gp_Pnt2d startpnt;
|
||||||
gp_Dir2d oldDir;
|
|
||||||
Handle(Geom_Surface) surf;
|
Handle(Geom_Surface) surf;
|
||||||
// Geom_Plane surf;
|
// Geom_Plane surf;
|
||||||
|
|
||||||
@ -103,7 +102,6 @@ public:
|
|||||||
auto MoveTo (double h, double v)
|
auto MoveTo (double h, double v)
|
||||||
{
|
{
|
||||||
startpnt = gp_Pnt2d(h,v);
|
startpnt = gp_Pnt2d(h,v);
|
||||||
oldDir = gp_Dir2d(1,0);
|
|
||||||
localpos.SetLocation(startpnt);
|
localpos.SetLocation(startpnt);
|
||||||
return shared_from_this();
|
return shared_from_this();
|
||||||
}
|
}
|
||||||
@ -154,15 +152,12 @@ public:
|
|||||||
|
|
||||||
auto Rotate (double angle)
|
auto Rotate (double angle)
|
||||||
{
|
{
|
||||||
oldDir = localpos.Direction();
|
|
||||||
localpos.Rotate(localpos.Location(), angle*M_PI/180);
|
localpos.Rotate(localpos.Location(), angle*M_PI/180);
|
||||||
return shared_from_this();
|
return shared_from_this();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto ArcTo (double h, double v, const gp_Vec2d t, double angle)
|
auto ArcTo (double h, double v, const gp_Vec2d t)
|
||||||
{
|
{
|
||||||
double newAngle = fmod(angle,360);
|
|
||||||
|
|
||||||
gp_Pnt2d P1 = localpos.Location();
|
gp_Pnt2d P1 = localpos.Location();
|
||||||
|
|
||||||
localpos.SetLocation (gp_Pnt2d(h,v));
|
localpos.SetLocation (gp_Pnt2d(h,v));
|
||||||
@ -195,7 +190,9 @@ public:
|
|||||||
cout << "p12n = (" << p12n.X() <<", " << p12n.Y() << ")"<<endl;
|
cout << "p12n = (" << p12n.X() <<", " << p12n.Y() << ")"<<endl;
|
||||||
|
|
||||||
gp_Pnt2d P3;
|
gp_Pnt2d P3;
|
||||||
if(t.Angle(p12n) > -M_PI/2 && t.Angle(p12n) < M_PI/2)
|
|
||||||
|
double angletp12n = t.Angle(p12n);
|
||||||
|
if(angletp12n > -M_PI/2 && angletp12n < M_PI/2)
|
||||||
P3 = gp_Pnt2d(M.X() + r * p12n.X() , M.Y() + r * p12n.Y());
|
P3 = gp_Pnt2d(M.X() + r * p12n.X() , M.Y() + r * p12n.Y());
|
||||||
else
|
else
|
||||||
P3 = gp_Pnt2d(M.X() - r * p12n.X() , M.Y() - r * p12n.Y());
|
P3 = gp_Pnt2d(M.X() - r * p12n.X() , M.Y() - r * p12n.Y());
|
||||||
@ -205,7 +202,7 @@ public:
|
|||||||
cout << "P3 = (" << P3.X() <<", " << P3.Y() << ")"<<endl;
|
cout << "P3 = (" << P3.X() <<", " << P3.Y() << ")"<<endl;
|
||||||
cout << "dist(M,P3) = " << P3.Distance(M) <<endl;
|
cout << "dist(M,P3) = " << P3.Distance(M) <<endl;
|
||||||
|
|
||||||
//Draw 2d arc of circle from P1 to P2 trough P3
|
//Draw 2d arc of circle from P1 to P2 through P3
|
||||||
Handle(Geom2d_TrimmedCurve) curve2d = GCE2d_MakeArcOfCircle(P1, P3, P2).Value();
|
Handle(Geom2d_TrimmedCurve) curve2d = GCE2d_MakeArcOfCircle(P1, P3, P2).Value();
|
||||||
|
|
||||||
//create 3d edge from 2d curve using surf
|
//create 3d edge from 2d curve using surf
|
||||||
@ -213,8 +210,20 @@ public:
|
|||||||
BRepLib::BuildCurves3d(edge);
|
BRepLib::BuildCurves3d(edge);
|
||||||
wire_builder.Add(edge);
|
wire_builder.Add(edge);
|
||||||
|
|
||||||
//TODO: compute newAngle using P1, M, and P2. Remove angle function argument
|
//compute angle of rotation
|
||||||
Rotate(newAngle);
|
//compute tangent t2 in P2
|
||||||
|
gp_Vec2d p2 = gp_Vec2d(P1.X()-P2.X(),P1.Y()-P2.Y());
|
||||||
|
gp_Vec2d t2;
|
||||||
|
if(t.Angle(p2) >=0)
|
||||||
|
t2 = gp_Vec2d((P2.Y()-M.Y()),-(P2.X()-M.X()));
|
||||||
|
else
|
||||||
|
t2 = gp_Vec2d(-(P2.Y()-M.Y()),(P2.X()-M.X()));
|
||||||
|
double angle = -t2.Angle(t); //angle \in [-pi,pi]
|
||||||
|
cout << "angle t2,t = " << angle*180/M_PI << endl;
|
||||||
|
|
||||||
|
//update localpos.Direction()
|
||||||
|
Rotate(angle*180/M_PI);
|
||||||
|
|
||||||
return shared_from_this();
|
return shared_from_this();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -245,7 +254,7 @@ public:
|
|||||||
cout << "t = (" << tangv.X() << ", " << tangv.Y() << ")" << endl;
|
cout << "t = (" << tangv.X() << ", " << tangv.Y() << ")" << endl;
|
||||||
|
|
||||||
//add arc
|
//add arc
|
||||||
return ArcTo (oldp.X(), oldp.Y(), tangv, newAngle*180/M_PI);
|
return ArcTo (oldp.X(), oldp.Y(), tangv);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto Rectangle (double l, double w)
|
auto Rectangle (double l, double w)
|
||||||
|
Loading…
Reference in New Issue
Block a user