1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-08-09 13:22:24 +03:00
Files
occt/src/Graphic3d/Graphic3d_ArrayOfPolygons.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

123 lines
4.7 KiB
Plaintext
Executable File

-- Created on: 2001-01-04
-- Copyright (c) 2001-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 ArrayOfPolygons from Graphic3d inherits ArrayOfPrimitives from Graphic3d
is
-- constructor
Create (
maxVertexs: Integer from Standard;
maxBounds: Integer from Standard = 0;
maxEdges: Integer from Standard = 0;
hasVNormals: Boolean from Standard = Standard_False;
hasVColors: Boolean from Standard = Standard_False;
hasBColors: Boolean from Standard = Standard_False;
hasTexels: Boolean from Standard = Standard_False;
hasEdgeInfos: Boolean from Standard = Standard_False)
returns mutable ArrayOfPolygons from Graphic3d;
---Purpose: Creates an array of polygons,
-- a polygon can be filled as:
-- 1) creating a single polygon defined with his vertexs.
-- i.e:
-- myArray = Graphic3d_ArrayOfPolygons(7)
-- myArray->AddVertex(x1,y1,z1)
-- ....
-- myArray->AddVertex(x7,y7,z7)
-- 2) creating separate polygons defined with a predefined
-- number of bounds and the number of vertex per bound.
-- i.e:
-- myArray = Graphic3d_ArrayOfPolygons(7,2)
-- myArray->AddBound(4)
-- myArray->AddVertex(x1,y1,z1)
-- ....
-- myArray->AddVertex(x4,y4,z4)
-- myArray->AddBound(3)
-- myArray->AddVertex(x5,y5,z5)
-- ....
-- myArray->AddVertex(x7,y7,z7)
-- 3) creating a single indexed polygon defined with his vertex
-- ans edges.
-- i.e:
-- myArray = Graphic3d_ArrayOfPolygons(4,0,6)
-- myArray->AddVertex(x1,y1,z1)
-- ....
-- myArray->AddVertex(x4,y4,z4)
-- myArray->AddEdge(1)
-- myArray->AddEdge(2)
-- myArray->AddEdge(3)
-- myArray->AddEdge(1)
-- myArray->AddEdge(2)
-- myArray->AddEdge(4)
-- 4) creating separate polygons defined with a predefined
-- number of bounds and the number of edges per bound.
-- i.e:
-- myArray = Graphic3d_ArrayOfPolygons(6,4,14)
-- myArray->AddBound(3)
-- myArray->AddVertex(x1,y1,z1)
-- myArray->AddVertex(x2,y2,z2)
-- myArray->AddVertex(x3,y3,z3)
-- myArray->AddEdge(1)
-- myArray->AddEdge(2)
-- myArray->AddEdge(3)
-- myArray->AddBound(3)
-- myArray->AddVertex(x4,y4,z4)
-- myArray->AddVertex(x5,y5,z5)
-- myArray->AddVertex(x6,y6,z6)
-- myArray->AddEdge(4)
-- myArray->AddEdge(5)
-- myArray->AddEdge(6)
-- myArray->AddBound(4)
-- myArray->AddEdge(2)
-- myArray->AddEdge(3)
-- myArray->AddEdge(5)
-- myArray->AddEdge(6)
-- myArray->AddBound(4)
-- myArray->AddEdge(1)
-- myArray->AddEdge(3)
-- myArray->AddEdge(5)
-- myArray->AddEdge(4)
-- <maxVertexs> defined the maximun allowed vertex number in the array.
-- <maxBounds> defined the maximun allowed bound number in the array.
-- <maxEdges> defined the maximun allowed edge number in the array.
-- Warning:
-- When <hasVNormals> is TRUE , you must use one of
-- AddVertex(Point,Normal)
-- or AddVertex(Point,Normal,Color)
-- or AddVertex(Point,Normal,Texel) methods.
-- When <hasVColors> is TRUE , you must use one of
-- AddVertex(Point,Color)
-- or AddVertex(Point,Normal,Color) methods.
-- When <hasTexels> is TRUE , you must use one of
-- AddVertex(Point,Texel)
-- or AddVertex(Point,Normal,Texel) methods.
-- When <hasBColors> is TRUE , <maxBounds> must be > 0 and
-- you must use the
-- AddBound(number,Color) method.
-- When <hasEdgeInfos> is TRUE , <maxEdges> must be > 0 and
-- you must use the
-- AddEdge(number,visibillity) method.
-- Warning:
-- the user is responsible about the orientation of the polygon
-- depending of the order of the created vertex or edges and this
-- orientation must be coherent with the vertex normal optionnaly
-- given at each vertex (See the Orientate() methods).
end;