1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-07 18:30:55 +03:00
occt/src/BndLib/BndLib_Add3dCurve.cdl
bugmaster b311480ed5 0023024: Update headers of OCCT files
Added appropriate copyright and license information in source files
2012-03-21 19:43:04 +04:00

96 lines
4.3 KiB
Plaintext
Executable File

-- Created on: 1993-07-08
-- Created by: Isabelle GRIGNON
-- Copyright (c) 1993-1999 Matra Datavision
-- Copyright (c) 1999-2012 OPEN CASCADE SAS
--
-- The content of this file is subject to the Open CASCADE Technology Public
-- License Version 6.5 (the "License"). You may not use the content of this file
-- except in compliance with the License. Please obtain a copy of the License
-- at http://www.opencascade.org and read it completely before using this file.
--
-- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
-- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
--
-- The Original Code and all software distributed under the License is
-- distributed on an "AS IS" basis, without warranty of any kind, and the
-- Initial Developer hereby disclaims all such warranties, including without
-- limitation, any warranties of merchantability, fitness for a particular
-- purpose or non-infringement. Please see the License for the specific terms
-- and conditions governing the rights and limitations under the License.
class Add3dCurve from BndLib
---Purpose: Computes the bounding box for a curve in 3d.
-- Functions to add a 3D curve to a bounding box.
-- The 3D curve is defined from a Geom curve.
uses Box from Bnd,
Curve from Adaptor3d
is
Add(myclass; C : Curve from Adaptor3d;
Tol : Real from Standard;
B : in out Box from Bnd);
---Purpose: Adds to the bounding box B the curve C
-- B is then enlarged by the tolerance value Tol.
-- Note: depending on the type of curve, one of the following
-- representations of the curve C is used to include it in the bounding box B:
-- - an exact representation if C is built from a line, a circle or a conic curve,
-- - the poles of the curve if C is built from a Bezier curve or a BSpline curve,
--- if not, the points of an approximation of the curve C.
-- Warning
-- C is an adapted curve, that is, an object which is an interface between:
-- - the services provided by a 3D curve from the package Geom
-- - and those required of the curve by the computation algorithm.
-- The adapted curve is created in the following way:
-- Handle(Geom_Curve) mycurve = ... ;
-- GeomAdaptor_Curve C(mycurve);
-- The bounding box B is then enlarged by adding it:
-- Bnd_Box B;
-- // ...
-- Standard_Real Tol = ... ;
-- Add3dCurve::Add ( C, Tol, B );
-- Exceptions
-- Standard_Failure if the curve is built from:
-- - a Geom_Line, or
-- - a Geom_Parabola, or
-- - a Geom_Hyperbola,
-- and P1 and P2 are either two negative infinite real
-- numbers, or two positive infinite real numbers.
Add(myclass; C : Curve from Adaptor3d;
U1,U2 : Real from Standard;
Tol : Real from Standard;
B : in out Box from Bnd);
---Purpose: Adds to the bounding box B the curve C
-- the arc of the curve C limited by the two parameter values P1 and P2.
-- Note: depending on the type of curve, one of the following
-- representations of the curve C is used to include it in the bounding box B:
-- - an exact representation if C is built from a line, a circle or a conic curve,
-- - the poles of the curve if C is built from a Bezier curve or a BSpline curve,
--- if not, the points of an approximation of the curve C.
-- Warning
-- C is an adapted curve, that is, an object which is an interface between:
-- - the services provided by a 3D curve from the package Geom
-- - and those required of the curve by the computation algorithm.
-- The adapted curve is created in the following way:
-- Handle(Geom_Curve) mycurve = ... ;
-- GeomAdaptor_Curve C(mycurve);
-- The bounding box B is then enlarged by adding it:
-- Bnd_Box B;
-- // ...
-- Standard_Real Tol = ... ;
-- Add3dCurve::Add ( C, Tol, B );
-- Exceptions
-- Standard_Failure if the curve is built from:
-- - a Geom_Line, or
-- - a Geom_Parabola, or
-- - a Geom_Hyperbola,
-- and P1 and P2 are either two negative infinite real
-- numbers, or two positive infinite real numbers.
end Add3dCurve;