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

Last change on this file since 1337 was 1337, checked in by garnier, 14 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.