source: trunk/source/tracking/src/G4VTrajectory.cc@ 1104

Last change on this file since 1104 was 1011, checked in by garnier, 17 years ago

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. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26//
27// $Id: G4VTrajectory.cc,v 1.12 2006/10/16 13:45:01 allison Exp $
28// GEANT4 tag $Name: geant4-09-02-ref-02 $
29//
30// ---------------------------------------------------------------
31//
32// G4VTrajectory.cc
33//
34// Contact:
35// Questions and comments to this code should be sent to
36// Katsuya Amako (e-mail: Katsuya.Amako@kek.jp)
37// Makoto Asai (e-mail: asai@kekvax.kek.jp)
38// Takashi Sasaki (e-mail: Takashi.Sasaki@kek.jp)
39//
40// ---------------------------------------------------------------
41
42#include "G4VTrajectory.hh"
43#include "G4VTrajectoryPoint.hh"
44#include "G4AttDefStore.hh"
45#include "G4AttDef.hh"
46#include "G4AttValue.hh"
47#include "G4AttCheck.hh"
48#include "G4VVisManager.hh"
49#include "G4VisAttributes.hh"
50#include "G4Polyline.hh"
51#include "G4Polymarker.hh"
52#include "G4Colour.hh"
53
54G4VTrajectory::G4VTrajectory() {;}
55G4VTrajectory::~G4VTrajectory() {;}
56
57G4bool G4VTrajectory::operator == (const G4VTrajectory& right) const
58{
59 return (this==&right);
60}
61
62void G4VTrajectory::ShowTrajectory(std::ostream& os) const
63{
64 // Makes use of attribute values implemented in the concrete class.
65 // Note: the user needs to follow with new-line or end-of-string,
66 // depending on the nature of os.
67
68 std::vector<G4AttValue>* attValues = CreateAttValues();
69 const std::map<G4String,G4AttDef>* attDefs = GetAttDefs();
70
71 // Ensure validity...
72 if (G4AttCheck(attValues,attDefs).Check("G4VTrajectory::ShowTrajectory")) {
73 return;
74 }
75
76 os << "Trajectory:";
77
78 std::vector<G4AttValue>::iterator iAttVal;
79 for (iAttVal = attValues->begin();
80 iAttVal != attValues->end(); ++iAttVal) {
81 std::map<G4String,G4AttDef>::const_iterator iAttDef =
82 attDefs->find(iAttVal->GetName());
83 os << "\n " << iAttDef->second.GetDesc()
84 << " (" << iAttVal->GetName()
85 << "): " << iAttVal->GetValue();
86 }
87
88 delete attValues; // AttValues must be deleted after use.
89
90 //Now do trajectory points...
91 for (G4int i = 0; i < GetPointEntries(); i++) {
92
93 G4VTrajectoryPoint* aTrajectoryPoint = GetPoint(i);
94 std::vector<G4AttValue>* attValues
95 = aTrajectoryPoint->CreateAttValues();
96 const std::map<G4String,G4AttDef>* attDefs
97 = aTrajectoryPoint->GetAttDefs();
98
99 // Ensure validity...
100 if (G4AttCheck(attValues,attDefs).Check("G4VTrajectory::ShowTrajectory")) {
101 return;
102 }
103
104 std::vector<G4AttValue>::iterator iAttVal;
105 for (iAttVal = attValues->begin();
106 iAttVal != attValues->end(); ++iAttVal) {
107 std::map<G4String,G4AttDef>::const_iterator iAttDef =
108 attDefs->find(iAttVal->GetName());
109 os << "\n " << iAttDef->second.GetDesc()
110 << " (" << iAttVal->GetName()
111 << "): " << iAttVal->GetValue();
112 }
113
114 delete attValues; // AttValues must be deleted after use.
115 }
116}
117
118void G4VTrajectory::DrawTrajectory(G4int i_mode) const
119{
120 G4VVisManager* pVVisManager = G4VVisManager::GetConcreteInstance();
121
122 if (0 != pVVisManager) {
123 pVVisManager->DispatchToModel(*this, i_mode);
124 }
125}
Note: See TracBrowser for help on using the repository browser.