mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
"endl" manipulator for Message_Messenger is renamed to "Message_EndLine". The following entities from std namespace are now used with std:: explicitly specified (from Standard_Stream.hxx): std::istream,std::ostream,std::ofstream,std::ifstream,std::fstream, std::filebuf,std::streambuf,std::streampos,std::ios,std::cout,std::cerr, std::cin,std::endl,std::ends,std::flush,std::setw,std::setprecision, std::hex,std::dec.
188 lines
6.0 KiB
C++
188 lines
6.0 KiB
C++
// Created on: 1994-11-22
|
|
// Created by: Laurent BOURESCHE
|
|
// Copyright (c) 1994-1999 Matra Datavision
|
|
// Copyright (c) 1999-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
|
|
#include <Adaptor3d_HSurface.hxx>
|
|
#include <ChFiDS_Spine.hxx>
|
|
#include <ChFiDS_SurfData.hxx>
|
|
#include <ChFiKPart_ComputeData.hxx>
|
|
#include <ChFiKPart_ComputeData_Fcts.hxx>
|
|
#include <ElSLib.hxx>
|
|
#include <gce_MakeCirc.hxx>
|
|
#include <Geom2d_Curve.hxx>
|
|
#include <Geom2d_Line.hxx>
|
|
#include <Geom_Circle.hxx>
|
|
#include <Geom_Curve.hxx>
|
|
#include <Geom_SphericalSurface.hxx>
|
|
#include <GeomAdaptor_Curve.hxx>
|
|
#include <GeomAdaptor_Surface.hxx>
|
|
#include <gp.hxx>
|
|
#include <gp_Ax3.hxx>
|
|
#include <gp_Circ.hxx>
|
|
#include <gp_Dir.hxx>
|
|
#include <gp_Lin2d.hxx>
|
|
#include <gp_Pnt.hxx>
|
|
#include <gp_Pnt2d.hxx>
|
|
#include <gp_Vec2d.hxx>
|
|
#include <Precision.hxx>
|
|
#include <TopOpeBRepDS_DataStructure.hxx>
|
|
|
|
//=======================================================================
|
|
//function : ChFiKPart_Sphere
|
|
//purpose : Construction of a spherical fillet the contours which of
|
|
// are not all isos, from three tops.
|
|
//=======================================================================
|
|
Standard_Boolean ChFiKPart_Sphere(TopOpeBRepDS_DataStructure& DStr,
|
|
const Handle(ChFiDS_SurfData)& Data,
|
|
const Handle(Adaptor3d_HSurface)& S1,
|
|
const Handle(Adaptor3d_HSurface)& S2,
|
|
const TopAbs_Orientation OrFace1,
|
|
const TopAbs_Orientation /*OrFace2*/,
|
|
const TopAbs_Orientation Or1,
|
|
const TopAbs_Orientation,
|
|
const Standard_Real Rad,
|
|
const gp_Pnt2d& PS1,
|
|
const gp_Pnt2d& P1S2,
|
|
const gp_Pnt2d& P2S2)
|
|
{
|
|
// Construction of the sphere :
|
|
// - pole south on PS1
|
|
// - origine of u given by P1S2
|
|
// - u+ to P2S2
|
|
|
|
Standard_Real ptol = Precision::Confusion();
|
|
gp_Pnt p1,p2,p3;
|
|
gp_Vec v1,v2;
|
|
S1->D1(PS1.X(),PS1.Y(),p1,v1,v2);
|
|
gp_Dir ds1(v1.Crossed(v2));
|
|
gp_Dir df1 = ds1;
|
|
gp_Dir dnat1 = ds1;
|
|
if(Or1 == TopAbs_REVERSED) ds1.Reverse();
|
|
if(OrFace1 == TopAbs_REVERSED) df1.Reverse();
|
|
S2->D0(P1S2.X(),P1S2.Y(),p2);
|
|
S2->D0(P2S2.X(),P2S2.Y(),p3);
|
|
gp_Circ ci = gce_MakeCirc(p1,p2,p3);
|
|
gp_Dir di = ci.Axis().Direction();
|
|
gp_Pnt pp = ci.Location();
|
|
Standard_Real rr = ci.Radius();
|
|
Standard_Real delta = sqrt(Rad*Rad-rr*rr);
|
|
gp_Pnt cen(pp.X()+delta*di.X(),
|
|
pp.Y()+delta*di.Y(),
|
|
pp.Z()+delta*di.Z());
|
|
gp_Dir dz(gp_Vec(p1,cen));
|
|
if(Abs(ds1.Dot(dz)-1.)>ptol){
|
|
cen.SetCoord(pp.X()-delta*di.X(),
|
|
pp.Y()-delta*di.Y(),
|
|
pp.Z()-delta*di.Z());
|
|
dz = gp_Dir(gp_Vec(p1,cen));
|
|
if(Abs(ds1.Dot(dz)-1.)>ptol){
|
|
#ifdef OCCT_DEBUG
|
|
std::cout<<"center of the spherical corner not found"<<std::endl;
|
|
#endif
|
|
return Standard_False;
|
|
}
|
|
}
|
|
gp_Dir ddx(gp_Vec(cen,p2));
|
|
gp_Dir dddx = ddx;
|
|
gp_Dir ddy(gp_Vec(cen,p3));
|
|
gp_Dir dx = dz.Crossed(ddx.Crossed(dz));
|
|
gp_Dir ddz = dz.Reversed();
|
|
gp_Ax3 FilAx3(cen,dz,dx);
|
|
if (FilAx3.YDirection().Dot(ddy) <= 0.){
|
|
FilAx3.YReverse();
|
|
ddz.Reverse();
|
|
dddx.Reverse();
|
|
}
|
|
Handle(Geom_SphericalSurface)
|
|
gsph = new Geom_SphericalSurface(FilAx3,Rad);
|
|
Data->ChangeSurf(ChFiKPart_IndexSurfaceInDS(gsph,DStr));
|
|
|
|
// the normal of the sphere is compared to the normal of the face
|
|
// oriented to determine the final orientation of the fillet.
|
|
Standard_Boolean toreverse = ( ddz.Dot(df1) <= 0. );
|
|
if (toreverse) { Data->ChangeOrientation() = TopAbs_REVERSED; }
|
|
else { Data->ChangeOrientation() = TopAbs_FORWARD; }
|
|
|
|
// Parameters of p2 and p3 are calculated on the Sphere to have
|
|
// ranges of curves.
|
|
Standard_Real uu1,vv1,uu2,vv2;
|
|
ElSLib::SphereParameters(FilAx3,Rad,p2,uu1,vv1);
|
|
uu1 = 0.;
|
|
ElSLib::SphereParameters(FilAx3,Rad,p3,uu2,vv2);
|
|
|
|
// FaceInterferences are loaded with pcurves and curves 3d.
|
|
|
|
// Pointed side.
|
|
|
|
Handle(Geom_Curve) C;
|
|
Handle(Geom2d_Curve) C2d;
|
|
gp_Pnt2d p2dFil(0.,-M_PI/2.);
|
|
gp_Lin2d lin2dFil(p2dFil,gp::DX2d());
|
|
Handle(Geom2d_Curve) C2dFil = new Geom2d_Line(lin2dFil);
|
|
toreverse = ( ddz.Dot(dnat1) <= 0. );
|
|
TopAbs_Orientation trans = TopAbs_REVERSED;
|
|
if (toreverse) trans = TopAbs_FORWARD;
|
|
Data->ChangeInterferenceOnS1().
|
|
SetInterference(ChFiKPart_IndexCurveInDS(C,DStr),
|
|
trans,C2d,C2dFil);
|
|
|
|
// The other side.
|
|
|
|
Standard_Real ang = ddx.Angle(ddy);
|
|
gp_Dir dci = ddx.Crossed(ddy);
|
|
gp_Ax2 axci(cen,dci,ddx);
|
|
gp_Circ ci2(axci,Rad);
|
|
C = new Geom_Circle(ci2);
|
|
GeomAdaptor_Surface AS(gsph);
|
|
GeomAdaptor_Curve AC(C,0.,ang);
|
|
ChFiKPart_ProjPC(AC,AS,C2dFil);
|
|
gp_Pnt2d p2dbid = C2dFil->Value(0.);
|
|
gp_Pnt2d pp2dbid(uu1,vv1);
|
|
if(!pp2dbid.IsEqual(p2dbid,ptol)){
|
|
gp_Vec2d v2dbid(p2dbid,pp2dbid);
|
|
C2dFil->Translate(v2dbid);
|
|
}
|
|
gp_Vec2d v2d(P1S2,P2S2);
|
|
gp_Dir2d d2d(v2d);
|
|
if(Abs(v2d.Magnitude()-ang) <= ptol){
|
|
gp_Lin2d l2d(P1S2,d2d);
|
|
C2d = new Geom2d_Line(l2d);
|
|
}
|
|
else C2d = ChFiKPart_PCurve(P1S2,P2S2,0.,ang);
|
|
gp_Pnt pp1;
|
|
S2->D1(P1S2.X(),P1S2.Y(),pp1,v1,v2);
|
|
gp_Dir ds2(v1.Crossed(v2));
|
|
toreverse = (ds2.Dot(dddx) <= 0.);
|
|
trans = TopAbs_REVERSED;
|
|
if (!toreverse) trans = TopAbs_FORWARD;
|
|
Data->ChangeInterferenceOnS2().
|
|
SetInterference(ChFiKPart_IndexCurveInDS(C,DStr),
|
|
trans,C2d,C2dFil);
|
|
|
|
Data->ChangeVertexFirstOnS1().SetPoint(p1);
|
|
Data->ChangeVertexLastOnS1().SetPoint(p1);
|
|
Data->ChangeVertexFirstOnS2().SetPoint(p2);
|
|
Data->ChangeVertexLastOnS2().SetPoint(p3);
|
|
Data->ChangeInterferenceOnS1().SetFirstParameter(0.);
|
|
Data->ChangeInterferenceOnS1().SetLastParameter(uu2);
|
|
Data->ChangeInterferenceOnS2().SetFirstParameter(0.);
|
|
Data->ChangeInterferenceOnS2().SetLastParameter(ang);
|
|
|
|
return Standard_True;
|
|
}
|
|
|
|
|