File indexing completed on 2025-01-31 09:22:53
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030 #include "HodoscopeHit.hh"
0031
0032 #include "G4AttDef.hh"
0033 #include "G4AttDefStore.hh"
0034 #include "G4AttValue.hh"
0035 #include "G4Colour.hh"
0036 #include "G4LogicalVolume.hh"
0037 #include "G4SystemOfUnits.hh"
0038 #include "G4Transform3D.hh"
0039 #include "G4UIcommand.hh"
0040 #include "G4UnitsTable.hh"
0041 #include "G4VVisManager.hh"
0042 #include "G4VisAttributes.hh"
0043 #include "G4ios.hh"
0044
0045 namespace B5
0046 {
0047
0048
0049
0050 G4ThreadLocal G4Allocator<HodoscopeHit>* HodoscopeHitAllocator;
0051
0052
0053
0054 HodoscopeHit::HodoscopeHit(G4int id, G4double time) : fId(id), fTime(time) {}
0055
0056
0057
0058 G4bool HodoscopeHit::operator==(const HodoscopeHit& ) const
0059 {
0060 return false;
0061 }
0062
0063
0064
0065 void HodoscopeHit::Draw()
0066 {
0067 auto visManager = G4VVisManager::GetConcreteInstance();
0068 if (!visManager) return;
0069
0070 G4Transform3D trans(fRot.inverse(), fPos);
0071 G4VisAttributes attribs;
0072 auto pVA = fPLogV->GetVisAttributes();
0073 if (pVA) attribs = *pVA;
0074 attribs.SetColour(G4Colour::Cyan());
0075 attribs.SetForceSolid(true);
0076 visManager->Draw(*fPLogV, attribs, trans);
0077 }
0078
0079
0080
0081 const std::map<G4String, G4AttDef>* HodoscopeHit::GetAttDefs() const
0082 {
0083 G4bool isNew;
0084 auto store = G4AttDefStore::GetInstance("HodoscopeHit", isNew);
0085
0086 if (isNew) {
0087 (*store)["HitType"] = G4AttDef("HitType", "Hit Type", "Physics", "", "G4String");
0088
0089 (*store)["ID"] = G4AttDef("ID", "ID", "Physics", "", "G4int");
0090
0091 (*store)["Time"] = G4AttDef("Time", "Time", "Physics", "G4BestUnit", "G4double");
0092
0093 (*store)["Pos"] = G4AttDef("Pos", "Position", "Physics", "G4BestUnit", "G4ThreeVector");
0094
0095 (*store)["LVol"] = G4AttDef("LVol", "Logical Volume", "Physics", "", "G4String");
0096 }
0097 return store;
0098 }
0099
0100
0101
0102 std::vector<G4AttValue>* HodoscopeHit::CreateAttValues() const
0103 {
0104 auto values = new std::vector<G4AttValue>;
0105
0106 values->push_back(G4AttValue("HitType", "HodoscopeHit", ""));
0107 values->push_back(G4AttValue("ID", G4UIcommand::ConvertToString(fId), ""));
0108 values->push_back(G4AttValue("Time", G4BestUnit(fTime, "Time"), ""));
0109 values->push_back(G4AttValue("Pos", G4BestUnit(fPos, "Length"), ""));
0110
0111 if (fPLogV)
0112 values->push_back(G4AttValue("LVol", fPLogV->GetName(), ""));
0113 else
0114 values->push_back(G4AttValue("LVol", " ", ""));
0115
0116 return values;
0117 }
0118
0119
0120
0121 void HodoscopeHit::Print()
0122 {
0123 G4cout << " Hodoscope[" << fId << "] " << fTime / ns << " (nsec)" << G4endl;
0124 }
0125
0126
0127
0128 }