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

Last change on this file since 1339 was 1337, checked in by garnier, 15 years ago

tag geant4.9.4 beta 1 + modifs locales

File size: 5.1 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.16 2010/06/16 20:03:00 allison Exp $
28// GEANT4 tag $Name: geant4-09-04-beta-01 $
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
118/***
119void G4VTrajectory::DrawTrajectory() const
120{
121 G4VVisManager* pVVisManager = G4VVisManager::GetConcreteInstance();
122
123 if (0 != pVVisManager) {
124 pVVisManager->DispatchToModel(*this);
125 }
126}
127***/
128
129void G4VTrajectory::DrawTrajectory(G4int i_mode) const
130{
131 G4VVisManager* pVVisManager = G4VVisManager::GetConcreteInstance();
132
133 static G4bool warnedAboutIMode = false;
134 if (!warnedAboutIMode && i_mode != 0) {
135 G4Exception
136 ("G4VTrajectory::DrawTrajectory",
137 "",
138 JustWarning,
139"WARNING: DEPRECATED: The use of i_mode argument in DrawTrajectory"
140"\n is deprecated and will be removed at the next major release.");
141 warnedAboutIMode = true;
142 }
143
144 if (0 != pVVisManager) {
145 pVVisManager->DispatchToModel(*this, i_mode);
146 }
147}
Note: See TracBrowser for help on using the repository browser.