mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-10 18:51:21 +03:00
Automatic upgrade of OCCT code by command "occt_upgrade . -nocdl": - WOK-generated header files from inc and sources from drv are moved to src - CDL files removed - All packages are converted to nocdlpack
260 lines
7.7 KiB
C++
260 lines
7.7 KiB
C++
// Created on: 1996-12-30
|
|
// Created by: Stagiaire Mary FABIEN
|
|
// Copyright (c) 1996-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 <BRep_Tool.hxx>
|
|
#include <BRepTools_GTrsfModification.hxx>
|
|
#include <Geom2d_Curve.hxx>
|
|
#include <Geom2d_TrimmedCurve.hxx>
|
|
#include <Geom_BezierCurve.hxx>
|
|
#include <Geom_BezierSurface.hxx>
|
|
#include <Geom_BSplineCurve.hxx>
|
|
#include <Geom_BSplineSurface.hxx>
|
|
#include <Geom_Curve.hxx>
|
|
#include <Geom_Line.hxx>
|
|
#include <Geom_Plane.hxx>
|
|
#include <Geom_Surface.hxx>
|
|
#include <Geom_TrimmedCurve.hxx>
|
|
#include <GeomLib.hxx>
|
|
#include <gp.hxx>
|
|
#include <gp_GTrsf.hxx>
|
|
#include <gp_GTrsf2d.hxx>
|
|
#include <gp_Pnt.hxx>
|
|
#include <gp_TrsfForm.hxx>
|
|
#include <gp_XYZ.hxx>
|
|
#include <Standard_NoSuchObject.hxx>
|
|
#include <Standard_Type.hxx>
|
|
#include <TopAbs.hxx>
|
|
#include <TopLoc_Location.hxx>
|
|
#include <TopoDS_Edge.hxx>
|
|
#include <TopoDS_Face.hxx>
|
|
#include <TopoDS_Vertex.hxx>
|
|
|
|
//=======================================================================
|
|
//function : BRepTools_GTrsfModification
|
|
//purpose :
|
|
//=======================================================================
|
|
BRepTools_GTrsfModification::BRepTools_GTrsfModification(const gp_GTrsf& T) :
|
|
myGTrsf(T)
|
|
{
|
|
// on prend comme dilatation maximale pour la tolerance la norme sup
|
|
Standard_Real loc1, loc2, loc3, loc4;
|
|
|
|
loc1 = Max(Abs(T.Value(1,1)), Abs(T.Value(1,2)));
|
|
loc2 = Max(Abs(T.Value(2,1)), Abs(T.Value(2,2)));
|
|
loc3 = Max(Abs(T.Value(3,1)), Abs(T.Value(3,2)));
|
|
loc4 = Max(Abs(T.Value(1,3)), Abs(T.Value(2,3)));
|
|
|
|
loc1 = Max(loc1, loc2);
|
|
loc2 = Max(loc3, loc4);
|
|
|
|
loc1 = Max(loc1, loc2);
|
|
|
|
myGScale = Max(loc1, Abs(T.Value(3,3)));
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : GTrsf
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
gp_GTrsf& BRepTools_GTrsfModification::GTrsf ()
|
|
{
|
|
return myGTrsf;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : NewSurface
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepTools_GTrsfModification::NewSurface
|
|
(const TopoDS_Face& F,
|
|
Handle(Geom_Surface)& S,
|
|
TopLoc_Location& L,
|
|
Standard_Real& Tol,
|
|
Standard_Boolean& RevWires,
|
|
Standard_Boolean& RevFace)
|
|
{
|
|
gp_GTrsf gtrsf;
|
|
gtrsf.SetVectorialPart(myGTrsf.VectorialPart());
|
|
gtrsf.SetTranslationPart(myGTrsf.TranslationPart());
|
|
S = Handle(Geom_Surface)::DownCast(BRep_Tool::Surface(F,L)->Copy());
|
|
|
|
Tol = BRep_Tool::Tolerance(F);
|
|
Tol *= myGScale;
|
|
RevWires = Standard_False;
|
|
RevFace = myGTrsf.IsNegative();
|
|
S = Handle(Geom_Surface)::DownCast(S->Transformed(L.Transformation()));
|
|
|
|
Handle(Standard_Type) TheTypeS = S->DynamicType();
|
|
if (TheTypeS == STANDARD_TYPE(Geom_BSplineSurface)) {
|
|
Handle(Geom_BSplineSurface) S2 = Handle(Geom_BSplineSurface)::DownCast(S);
|
|
for(Standard_Integer i = 1; i <= S2->NbUPoles(); i++)
|
|
for(Standard_Integer j = 1; j <= S2->NbVPoles(); j++) {
|
|
gp_XYZ coor(S2->Pole(i, j).Coord());
|
|
gtrsf.Transforms(coor);
|
|
gp_Pnt P(coor);
|
|
S2->SetPole(i, j, P);
|
|
}
|
|
}
|
|
else
|
|
if (TheTypeS == STANDARD_TYPE(Geom_BezierSurface)) {
|
|
Handle(Geom_BezierSurface) S2 = Handle(Geom_BezierSurface)::DownCast(S);
|
|
for(Standard_Integer i = 1; i <= S2->NbUPoles(); i++)
|
|
for(Standard_Integer j = 1; j <= S2->NbVPoles(); j++) {
|
|
gp_XYZ coor(S2->Pole(i, j).Coord());
|
|
gtrsf.Transforms(coor);
|
|
gp_Pnt P(coor);
|
|
S2->SetPole(i, j, P);
|
|
}
|
|
}
|
|
else{
|
|
Standard_NoSuchObject::Raise("BRepTools_GTrsfModification : Pb no BSpline/Bezier Type Surface");
|
|
}
|
|
|
|
L.Identity();
|
|
return Standard_True;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : NewCurve
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepTools_GTrsfModification::NewCurve
|
|
(const TopoDS_Edge& E,
|
|
Handle(Geom_Curve)& C,
|
|
TopLoc_Location& L,
|
|
Standard_Real& Tol)
|
|
{
|
|
Standard_Real f,l;
|
|
gp_GTrsf gtrsf;
|
|
gtrsf.SetVectorialPart(myGTrsf.VectorialPart());
|
|
gtrsf.SetTranslationPart(myGTrsf.TranslationPart());
|
|
Tol = BRep_Tool::Tolerance(E)*myGScale;
|
|
C = BRep_Tool::Curve(E, L, f, l);
|
|
|
|
if (!C.IsNull()) {
|
|
C = Handle(Geom_Curve)::DownCast(C->Copy()->Transformed(L.Transformation()));
|
|
Handle(Standard_Type) TheTypeC = C->DynamicType();
|
|
if (TheTypeC == STANDARD_TYPE(Geom_BSplineCurve)) {
|
|
Handle(Geom_BSplineCurve) C2 = Handle(Geom_BSplineCurve)::DownCast(C);
|
|
for(Standard_Integer i = 1; i <= C2->NbPoles(); i++) {
|
|
gp_XYZ coor(C2->Pole(i).Coord());
|
|
gtrsf.Transforms(coor);
|
|
gp_Pnt P(coor);
|
|
C2->SetPole(i, P);
|
|
}
|
|
}
|
|
else
|
|
if(TheTypeC == STANDARD_TYPE(Geom_BezierCurve)) {
|
|
Handle(Geom_BezierCurve) C2 = Handle(Geom_BezierCurve)::DownCast(C);
|
|
for(Standard_Integer i = 1; i <= C2->NbPoles(); i++) {
|
|
gp_XYZ coor(C2->Pole(i).Coord());
|
|
gtrsf.Transforms(coor);
|
|
gp_Pnt P(coor);
|
|
C2->SetPole(i, P);
|
|
}
|
|
}
|
|
else {
|
|
Standard_NoSuchObject::Raise("BRepTools_GTrsfModification : Pb no BSpline/Bezier Type Curve");
|
|
}
|
|
C = new Geom_TrimmedCurve(C, f, l);
|
|
}
|
|
L.Identity() ;
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : NewPoint
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepTools_GTrsfModification::NewPoint
|
|
(const TopoDS_Vertex& V,
|
|
gp_Pnt& P,
|
|
Standard_Real& Tol)
|
|
{
|
|
gp_Pnt Pnt = BRep_Tool::Pnt(V);
|
|
Tol = BRep_Tool::Tolerance(V);
|
|
Tol *= myGScale;
|
|
gp_XYZ coor(Pnt.Coord());
|
|
myGTrsf.Transforms(coor);
|
|
P.SetXYZ(coor);
|
|
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : NewCurve2d
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepTools_GTrsfModification::NewCurve2d
|
|
(const TopoDS_Edge& E,
|
|
const TopoDS_Face& F,
|
|
const TopoDS_Edge&,
|
|
const TopoDS_Face&,
|
|
Handle(Geom2d_Curve)& C,
|
|
Standard_Real& Tol)
|
|
{
|
|
TopLoc_Location loc;
|
|
Tol = BRep_Tool::Tolerance(E);
|
|
Tol *= myGScale;
|
|
Standard_Real f,l;
|
|
C = BRep_Tool::CurveOnSurface(E,F,f,l);
|
|
C = new Geom2d_TrimmedCurve(C, f, l);
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : NewParameter
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepTools_GTrsfModification::NewParameter
|
|
(const TopoDS_Vertex& V,
|
|
const TopoDS_Edge& E,
|
|
Standard_Real& P,
|
|
Standard_Real& Tol)
|
|
{
|
|
Tol = BRep_Tool::Tolerance(V);
|
|
Tol *= myGScale;
|
|
P = BRep_Tool::Parameter(V,E);
|
|
return Standard_True;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Continuity
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
GeomAbs_Shape BRepTools_GTrsfModification::Continuity
|
|
(const TopoDS_Edge& E,
|
|
const TopoDS_Face& F1,
|
|
const TopoDS_Face& F2,
|
|
const TopoDS_Edge&,
|
|
const TopoDS_Face&,
|
|
const TopoDS_Face&)
|
|
{
|
|
return BRep_Tool::Continuity(E,F1,F2);
|
|
}
|
|
|
|
|