mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-09-08 14:17:06 +03:00
0024761: Convertation of the generic classes to the non-generic. Part 5
1) Generic class "GccEnt_QualifiedCurv" from "GccEnt" package converted to the non-generic class and moved to the "Geom2dGcc" package. Name of this class was changed to "Geom2dGcc_QCurve". 2) Generic classes "HatchGen_ElementGen", "HatchGen_ElementsGen", "HatchGen_HatchingGen" and "HatchGen_Hatcher" from "HatchGen" package converted to the non-generic classes and moved to the "Geom2dHatch" package. Names of this classes were changed to "Geom2dHatch_Element", "Geom2dHatch_Elements", "Geom2dHatch_Hatching" and "Geom2dHatch_Hatcher". Also all instantiations of the "internal" classes of this classes were moved to the "Geom2dHatch.cdl". 3) Generic classes "Extrema_GExtCC", "Extrema_GExtCC2d", "Extrema_GLocateExtCC" and "Extrema_GLocateExtCC2d" from "Extrema" package converted to the non-generic classes. Names of this classes were changed to "Extrema_ExtCC", "Extrema_ExtCC2d", "Extrema_LocateExtCC" and "Extrema_LocateExtCC2d". Also all instantiations of the "internal" classes of this classes were moved to the "Extrema.cdl".
This commit is contained in:
67
src/Extrema/Extrema_LocateExtCC.cxx
Normal file
67
src/Extrema/Extrema_LocateExtCC.cxx
Normal file
@@ -0,0 +1,67 @@
|
||||
// Created on: 1994-07-06
|
||||
// Created by: Laurent PAINNOT
|
||||
// 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 <Extrema_LocateExtCC.ixx>
|
||||
|
||||
#include <StdFail_NotDone.hxx>
|
||||
#include <Extrema_POnCurv.hxx>
|
||||
#include <Precision.hxx>
|
||||
|
||||
#include <Adaptor3d_Curve.hxx>
|
||||
#include <Extrema_LocECC.hxx>
|
||||
|
||||
Extrema_LocateExtCC::Extrema_LocateExtCC (const Adaptor3d_Curve& C1,
|
||||
const Adaptor3d_Curve& C2,
|
||||
const Standard_Real U0,
|
||||
const Standard_Real V0)
|
||||
{
|
||||
Standard_Real TolU = C1.Resolution(Precision::Confusion());
|
||||
Standard_Real TolV = C2.Resolution(Precision::Confusion());
|
||||
Extrema_POnCurv P1, P2;
|
||||
|
||||
// Non implemente pour l instant: l appel a Extrema_ELCC.
|
||||
|
||||
Extrema_LocECC Xtrem(C1, C2,
|
||||
U0, V0, TolU, TolV);
|
||||
// Exploitation
|
||||
|
||||
myDone = Xtrem.IsDone();
|
||||
if (Xtrem.IsDone()) {
|
||||
mySqDist = Xtrem.SquareDistance();
|
||||
Xtrem.Point(P1, P2);
|
||||
myPoint1 = P1;
|
||||
myPoint2 = P2;
|
||||
}
|
||||
}
|
||||
|
||||
Standard_Boolean Extrema_LocateExtCC::IsDone () const {
|
||||
|
||||
return myDone;
|
||||
}
|
||||
|
||||
Standard_Real Extrema_LocateExtCC::SquareDistance() const {
|
||||
|
||||
if (!myDone) { StdFail_NotDone::Raise(); }
|
||||
return mySqDist;
|
||||
}
|
||||
|
||||
void Extrema_LocateExtCC::Point (Extrema_POnCurv& P1, Extrema_POnCurv& P2) const {
|
||||
|
||||
if (!myDone) { StdFail_NotDone::Raise(); }
|
||||
P1 = myPoint1;
|
||||
P2 = myPoint2;
|
||||
}
|
||||
|
Reference in New Issue
Block a user