Overview | Package | Class | Source | Class tree | Glossary | UnrealScript Documentation |
previous class next class | frames no frames |
00001 00002 00003 00004 00005 00006 00007 00008 00009 00010 00011 00012 00013 00014 00015 00016 00017 00018 00019 00020 00021 00022 00023 00024 00025 00026 00027 00028 00029 00030 00031 00032 00033 00034 00035 00036 00037 00038 00039 00040 00041 00042 00043 00044 00045 00046 00047 00048 |
//============================================================================= // LineOfSightTrigger // triggers its event when player looks at it from close enough // ONLY WORKS IN SINGLE PLAYER (or for the local client on a listen server) // You could implement a multiplayer version using a tick function and PlayerCanSeeMe(), // but that would have more performance cost //============================================================================= class LineOfSightTrigger extends Triggers native; var() float MaxViewDist; // maximum distance player can be from this trigger to trigger it var float OldTickTime; var() bool bEnabled; var bool bTriggered; var() name SeenActorTag; // tag of actor which triggers this trigger when seen var actor SeenActor; var() int MaxViewAngle; // how directly a player must be looking at SeenActor center (in degrees) var float RequiredViewDir; // how directly player must be looking at SeenActor - 1.0 = straight on, 0.75 = barely on screen function PostBeginPlay() { Super.PostBeginPlay(); RequiredViewDir = cos(MaxViewAngle * PI/180); if ( SeenActorTag != '' ) ForEach AllActors(class'Actor',SeenActor,SeenActorTag) break; } event PlayerSeesMe(PlayerController P) { TriggerEvent(Event,self,P.Pawn); bTriggered = true; } function Trigger( actor Other, Pawn EventInstigator ) { bEnabled = true; } defaultproperties { MaxViewDist=+3000.0 bEnabled=true bCollideActors=false MaxViewAngle=15 } |
Overview | Package | Class | Source | Class tree | Glossary | UnrealScript Documentation |
previous class next class | frames no frames |