41 fWorldWithSdName =
"";
45 fpSpotS->SetPreStepPoint(fpSpotP);
46 fpSpotS->SetPostStepPoint(fpSpotP);
55 fpSpotS->ResetPreStepPoint();
56 fpSpotS->ResetPostStepPoint();
71 if (fWorldWithSdName.empty()) {
80 fpNavigator->SetWorldVolume(worldWithSD);
83 fTouchableHandle(),
false);
89 fpNavigator->LocateGlobalPointAndUpdateTouchable(
95 if (currentVolume !=
nullptr) {
98 if (fastSimSensitive !=
nullptr) {
99 fastSimSensitive->Hit(&aHit, &aTrack, &fTouchableHandle);
101 else if ((sensitive !=
nullptr)
104 fpSpotS->SetTotalEnergyDeposit(aHit.
GetEnergy());
111 fpSpotP->SetTouchableHandle(fTouchableHandle);
112 fpSpotP->SetProcessDefinedStep(fpProcess);
114 sensitive->
Hit(fpSpotS);
Minimal hit created in the fast simulation.
G4ThreeVector GetPosition() const
Get position.
G4double GetEnergy() const
Get energy.
void make(const G4FastHit &aHit, const G4FastTrack &aTrack)
const G4Track * GetPrimaryTrack() const
const G4AffineTransform * GetInverseAffineTransformation() const
G4VSensitiveDetector * GetSensitiveDetector() const
G4FastSimulationManager * GetFastSimulationManager() const
G4VPhysicalVolume * GetWorldVolume() const
G4double GetWeight() const
const G4ThreeVector & GetPosition() const
G4double GetGlobalTime() const
G4double GetProperTime() const
G4double GetLocalTime() const
G4VPhysicalVolume * GetParallelWorld(const G4String &worldName)
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
Base class for the sensitive detector used within the fast simulation.
G4LogicalVolume * GetLogicalVolume() const
G4bool Hit(G4Step *aStep)