source: trunk/source/graphics_reps/src/G4PolyhedronArbitrary.cc@ 1273

Last change on this file since 1273 was 932, checked in by garnier, 17 years ago

John update

File size: 4.5 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration and of QinetiQ Ltd, *
20// * subject to DEFCON 705 IPR conditions. *
21// * By using, copying, modifying or distributing the software (or *
22// * any work based on the software) you agree to acknowledge its *
23// * use in resulting scientific publications, and indicate your *
24// * acceptance of all terms of the Geant4 Software license. *
25// ********************************************************************
26//
27//
28// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
29//
30// MODULE: G4PolyhedronArbitrary.cc
31//
32// Date: 15/06/2005
33// Author: P R Truscott
34// Organisation: QinetiQ Ltd, UK
35// Customer: UK Ministry of Defence : RAO CRP TD Electronic Systems
36// Contract: C/MAT/N03517
37//
38// This software is the intellectual property of QinetiQ Ltd, subject
39// DEFCON 705 IPR conditions.
40//
41// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
42//
43// CHANGE HISTORY
44// --------------
45//
46// 31 October 2004, P R Truscott, QinetiQ Ltd, UK
47// Created.
48//
49// %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
50//
51// DESCRIPTION
52// -----------
53//
54//
55//
56///////////////////////////////////////////////////////////////////////////////
57//
58//
59#include "G4PolyhedronArbitrary.hh"
60///////////////////////////////////////////////////////////////////////////////
61//
62G4PolyhedronArbitrary::G4PolyhedronArbitrary (const G4int nVertices,
63 const G4int nFacets)
64{
65 AllocateMemory(nVertices, nFacets);
66 nVertexCount = 0;
67 nFacetCount = 0;
68}
69///////////////////////////////////////////////////////////////////////////////
70//
71G4PolyhedronArbitrary::~G4PolyhedronArbitrary ()
72{;}
73///////////////////////////////////////////////////////////////////////////////
74//
75void G4PolyhedronArbitrary::AddVertex (const G4ThreeVector v)
76{
77 if (nVertexCount == nvert + 1)
78 {
79 G4cerr <<G4endl;
80 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddVertex" <<G4endl;
81 G4cerr <<"ATTEMPT TO EXCEED MAXIMUM NUMBER OF VERTICES : " << nVertexCount
82 <<G4endl;
83 G4cerr <<G4endl;
84 }
85 else
86 {
87 nVertexCount++;
88 pV[nVertexCount] = v;
89 }
90}
91///////////////////////////////////////////////////////////////////////////////
92//
93void G4PolyhedronArbitrary::AddFacet (const G4int iv1, const G4int iv2,
94 const G4int iv3, const G4int iv4)
95{
96 if (nFacetCount == nface)
97 {
98 G4cerr <<G4endl;
99 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
100 G4cerr <<"ATTEMPT TO EXCEED MAXIMUM NUMBER OF FACETS : " << nFacetCount
101 <<G4endl;
102 G4cerr <<G4endl;
103 }
104 else if (iv1 < 1 || iv1 > nvert || iv2 < 1 || iv2 > nvert ||
105 iv3 < 1 || iv3 > nvert || iv4 > nvert)
106 {
107 G4cerr <<G4endl;
108 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
109 G4cerr <<"ATTEMPT TO INDEX VERTEX NUMBER WHICH IS OUT-OF-RANGE : " <<G4endl;
110 G4cerr <<G4endl;
111 }
112 else if (iv1 > nVertexCount || iv2 > nVertexCount || iv3 > nVertexCount ||
113 iv4 > nVertexCount)
114 {
115 G4cerr <<G4endl;
116 G4cerr <<"ERROR IN G4PolyhedronArbitrary::AddFacet" <<G4endl;
117 G4cerr <<"VERTEX NEEDS TO BE DEFINED FIRST : " <<G4endl;
118 G4cerr <<G4endl;
119 }
120 else
121 {
122 nFacetCount++;
123 pF[nFacetCount] = G4Facet(iv1, 0, iv2, 0, iv3, 0, iv4, 0);
124 }
125}
126///////////////////////////////////////////////////////////////////////////////
127//
Note: See TracBrowser for help on using the repository browser.