1
0

1206 lines
42 KiB
Ucode
Raw Normal View History

2020-12-13 18:01:13 +03:00
//=============================================================================
// Engine: The base class of the global application object classes.
// Copyright 1998-2013 Epic Games, Inc. All Rights Reserved.
//=============================================================================
class Engine extends Subsystem
native(GameEngine)
abstract
config(Engine)
transient;
// Fonts.
var private Font TinyFont;
var globalconfig string TinyFontName;
var private Font SmallFont;
var globalconfig string SmallFontName;
var private Font MediumFont;
var globalconfig string MediumFontName;
var private Font LargeFont;
var globalconfig string LargeFontName;
var private Font SubtitleFont;
var globalconfig string SubtitleFontName;
/** Any additional fonts that script may use without hard-referencing the font. */
var private array<Font> AdditionalFonts;
var globalconfig array<string> AdditionalFontNames;
/** The class to use for the game console. */
var class<Console> ConsoleClass;
var globalconfig string ConsoleClassName;
/** The class to use for the game viewport client. */
var class<GameViewportClient> GameViewportClientClass;
var globalconfig string GameViewportClientClassName;
/** The class to use for managing the global data stores */
var class<DataStoreClient> DataStoreClientClass;
var globalconfig string DataStoreClientClassName;
/** The class to use for local players. */
var class<LocalPlayer> LocalPlayerClass;
var config string LocalPlayerClassName;
/** The material used when no material is explicitly applied. */
var Material DefaultMaterial;
var globalconfig string DefaultMaterialName;
/** The decal material used for fallback case of decals */
var Material DefaultDecalMaterial;
var globalconfig string DefaultDecalMaterialName;
/** A global default texture. */
var Texture DefaultTexture;
var globalconfig string DefaultTextureName;
/** The material used to render wireframe meshes. */
var Material WireframeMaterial;
var globalconfig string WireframeMaterialName;
/** A textured material with an instance parameter for the texture. */
var Material EmissiveTexturedMaterial;
var globalconfig string EmissiveTexturedMaterialName;
/** A translucent material used to render things in geometry mode. */
var Material GeomMaterial;
var globalconfig string GeomMaterialName;
/** The default fog volume material */
var Material DefaultFogVolumeMaterial;
var globalconfig string DefaultFogVolumeMaterialName;
/** Material used for drawing a tick mark. */
var Material TickMaterial;
var globalconfig string TickMaterialName;
/** Material used for drawing a cross mark. */
var Material CrossMaterial;
var globalconfig string CrossMaterialName;
/** Material used for visualizing level membership in lit viewport modes. */
var Material LevelColorationLitMaterial;
var globalconfig string LevelColorationLitMaterialName;
/** Material used for visualizing level membership in unlit viewport modes. */
var Material LevelColorationUnlitMaterial;
var globalconfig string LevelColorationUnlitMaterialName;
/** Material used for visualizing lighting only w/ lightmap texel density. */
var Material LightingTexelDensityMaterial;
var globalconfig string LightingTexelDensityName;
/** Material used for visualizing level membership in lit viewport modes. Uses shading to show axis directions. */
var Material ShadedLevelColorationLitMaterial;
var globalconfig string ShadedLevelColorationLitMaterialName;
/** Material used for visualizing level membership in unlit viewport modes. Uses shading to show axis directions. */
var Material ShadedLevelColorationUnlitMaterial;
var globalconfig string ShadedLevelColorationUnlitMaterialName;
/** Material used to indicate that the associated BSP surface should be removed. */
var Material RemoveSurfaceMaterial;
var globalconfig string RemoveSurfaceMaterialName;
/** Material that renders vertex colour as emissive. */
var Material VertexColorMaterial;
var globalconfig string VertexColorMaterialName;
/** Material for visualizing vertex colors on meshes in the scene (color only, no alpha) */
var Material VertexColorViewModeMaterial_ColorOnly;
var globalconfig string VertexColorViewModeMaterialName_ColorOnly;
/** Material for visualizing vertex colors on meshes in the scene (alpha channel as color) */
var Material VertexColorViewModeMaterial_AlphaAsColor;
var globalconfig string VertexColorViewModeMaterialName_AlphaAsColor;
/** Material for visualizing vertex colors on meshes in the scene (red only) */
var Material VertexColorViewModeMaterial_RedOnly;
var globalconfig string VertexColorViewModeMaterialName_RedOnly;
/** Material for visualizing vertex colors on meshes in the scene (green only) */
var Material VertexColorViewModeMaterial_GreenOnly;
var globalconfig string VertexColorViewModeMaterialName_GreenOnly;
/** Material for visualizing vertex colors on meshes in the scene (blue only) */
var Material VertexColorViewModeMaterial_BlueOnly;
var globalconfig string VertexColorViewModeMaterialName_BlueOnly;
/** Material used to render game stat heatmaps. */
var Material HeatmapMaterial;
var globalconfig string HeatmapMaterialName;
/** Material used to render bone weights on skel meshes */
var Material BoneWeightMaterial;
var globalconfig string BoneWeightMaterialName;
/** Material used to render tangents on skel meshes */
var Material TangentColorMaterial;
var globalconfig string TangentColorMaterialName;
/** The mobile emulation material for Additive. */
var Material MobileEmulationMasterMaterial;
var globalconfig string MobileEmulationMasterMaterialName;
/** Material used to render the low detail version of procedural buildings */
var Material ProcBuildingSimpleMaterial;
var globalconfig string ProcBuildingSimpleMaterialName;
/** Mesh used when we need a quad */
var StaticMesh BuildingQuadStaticMesh;
var globalconfig string BuildingQuadStaticMeshName;
/** Roughly how many texels per world unit when generating a building LOD color texture */
var globalconfig float ProcBuildingLODColorTexelsPerWorldUnit;
/** Roughly how many texels per world unit when generating a building LOD lighting texture */
var globalconfig float ProcBuildingLODLightingTexelsPerWorldUnit;
/** Maximum size of a building LOD color texture */
var globalconfig int MaxProcBuildingLODColorTextureSize;
/** Maximum size of a building LOD lighting texture */
var globalconfig int MaxProcBuildingLODLightingTextureSize;
/** Whether to crop building LOD textures to rectangular textures to reduce wasted memory */
var globalconfig bool UseProcBuildingLODTextureCropping;
/** Whether to force use of power-of-two LOD textures (uses more memory, but may have better performance) */
var globalconfig bool ForcePowerOfTwoProcBuildingLODTextures;
/** True if we should combine light/shadow maps together if they're very similar to one another */
var globalconfig bool bCombineSimilarMappings;
/** Maximum root mean square deviation of the image difference allowed for mappings to be combined. Requires bCombineSimilarLightAndShadowMappings to be enabled. */
var globalconfig float MaxRMSDForCombiningMappings;
/** Size of the texture generated by ImageReflectionSceneCapture actors. */
var globalconfig int ImageReflectionTextureSize;
var globalconfig LinearColor LightingOnlyBrightness;
/** The colors used to render light complexity. */
var globalconfig array<color> LightComplexityColors;
/** The colors used to render shader complexity. */
var globalconfig array<LinearColor> ShaderComplexityColors;
/**
* Complexity limits for the various complexity viewmode combinations.
* These limits are used to map instruction counts to ShaderComplexityColors.
*/
var globalconfig float MaxPixelShaderAdditiveComplexityCount;
/** Range for the texture density viewmode. */
var globalconfig float MinTextureDensity;
var globalconfig float IdealTextureDensity;
var globalconfig float MaxTextureDensity;
/** Range for the lightmap density viewmode. */
/** Minimum lightmap density value for coloring. */
var globalconfig float MinLightMapDensity;
/** Ideal lightmap density value for coloring. */
var globalconfig float IdealLightMapDensity;
/** Maximum lightmap density value for coloring. */
var globalconfig float MaxLightMapDensity;
/** If TRUE, then render grayscale density. */
var globalconfig bool bRenderLightMapDensityGrayscale;
/** The scale factor when rendering grayscale density. */
var globalconfig float RenderLightMapDensityGrayscaleScale;
/** The scale factor when rendering color density. */
var globalconfig float RenderLightMapDensityColorScale;
/** The color to render vertex mapped objects in for LightMap Density view mode. */
var globalconfig linearcolor LightMapDensityVertexMappedColor;
/** The color to render selected objects in for LightMap Density view mode. */
var globalconfig linearcolor LightMapDensitySelectedColor;
struct native StatColorMapEntry
{
var globalconfig float In;
var globalconfig color Out;
};
struct native StatColorMapping
{
var globalconfig string StatName;
var globalconfig array<StatColorMapEntry> ColorMap;
var globalconfig bool DisableBlend;
};
var globalconfig array<StatColorMapping> StatColorMappings;
/** A material used to render the sides of the builder brush/volumes/etc. */
var Material EditorBrushMaterial;
var globalconfig string EditorBrushMaterialName;
/** PhysicalMaterial to use if none is defined for a particular object. */
var PhysicalMaterial DefaultPhysMaterial;
var globalconfig string DefaultPhysMaterialName;
/** PhysicalMaterial used for landscape and terrain holes */
var PhysicalMaterial LandscapeHolePhysMaterial;
var globalconfig string LandscapeHolePhysMaterialName;
/** Optional damage mapping for Apex destructbile actors */
var ApexDestructibleDamageParameters ApexDamageParams;
var globalconfig string ApexDamageParamsName;
/** The material used when terrain compilation is too complex. */
var Material TerrainErrorMaterial;
var globalconfig string TerrainErrorMaterialName;
var globalconfig int TerrainMaterialMaxTextureCount;
/** This is the number of frames that are used between terrain tessellation re-calculations */
var globalconfig int TerrainTessellationCheckCount;
/**
* The radius from the view origin that terrain tessellation checks should be performed.
* If 0.0, every component will be checked for tessellation changes each frame.
*/
var globalconfig float TerrainTessellationCheckDistance;
/**
* Bool switch for SetRequestScreenshot function
*/
var bool bScreenshotRequested;
/** OnlineSubsystem class to use for netplay */
var class<OnlineSubsystem> OnlineSubsystemClass;
var globalconfig string DefaultOnlineSubsystemName;
/** Default engine post process chain used for the game and main editor view if none is specified in the WorldInfo */
var private{private} PostProcessChain DefaultPostProcess;
var private{private} config string DefaultPostProcessName;
/** post process chain used for skeletal mesh thumbnails */
var PostProcessChain ThumbnailSkeletalMeshPostProcess;
var config string ThumbnailSkeletalMeshPostProcessName;
/** post process chain used for particle system thumbnails */
var PostProcessChain ThumbnailParticleSystemPostProcess;
var config string ThumbnailParticleSystemPostProcessName;
/** post process chain used for material thumbnails */
var PostProcessChain ThumbnailMaterialPostProcess;
var config string ThumbnailMaterialPostProcessName;
/** post process chain used for rendering the UI */
var PostProcessChain DefaultUIScenePostProcess;
var config string DefaultUIScenePostProcessName;
/** Material used for drawing meshes when their collision is missing. */
var Material DefaultUICaretMaterial;
var globalconfig string DefaultUICaretMaterialName;
/** Material used for visualizing the reflection scene captures on a surface */
var Material SceneCaptureReflectActorMaterial;
var globalconfig string SceneCaptureReflectActorMaterialName;
/** Material used for visualizing the cube map scene captures on a mesh */
var Material SceneCaptureCubeActorMaterial;
var globalconfig string SceneCaptureCubeActorMaterialName;
/** Texture used to get random opacity values per-pixel for screen-door fading */
var Texture2D ScreenDoorNoiseTexture;
var globalconfig string ScreenDoorNoiseTextureName;
/** Texture used to get random image grain values for post processing */
var Texture2D ImageGrainNoiseTexture;
var globalconfig string ImageGrainNoiseTextureName;
/** Texture used to get random angles per-pixel by the Branching PCF implementation */
var Texture2D RandomAngleTexture;
var globalconfig string RandomAngleTextureName;
/** Texture used to get random normals per-pixel */
var Texture2D RandomNormalTexture;
var globalconfig string RandomNormalTextureName;
/** Texture used to get random rotation per-pixel */
var Texture2D RandomMirrorDiscTexture;
var globalconfig string RandomMirrorDiscTextureName;
/** Texture used as a placeholder for terrain weight-maps to give the material the correct texture format. */
var Texture WeightMapPlaceholderTexture;
var globalconfig string WeightMapPlaceholderTextureName;
/** Texture used to display LightMapDensity */
var Texture2D LightMapDensityTexture;
var globalconfig string LightMapDensityTextureName;
/** Texture used to display LightMapDensity */
var Texture2D LightMapDensityNormal;
var globalconfig string LightMapDensityNormalName;
`if(`__TW_CUSTOM_VIEWMODES_)
/** Texture used to display SplatterMapDensity */
var Texture2D SplatterMapDensityTexture;
var globalconfig string SplatterMapDensityTextureName;
`endif
`if(`__TW_PERSISTENT_SPLATTER_SYSTEM_)
/**
* Texture used by the persistent blood splatter system
* R Channel = Tiling Mask
* G Channel = Reflection (Faked Cubemap)
*/
var Texture2D PersistentBloodMasterTexture;
var globalconfig string PersistentBloodMasterTextureName;
`endif
`if(`__TW_SCREEN_SPACE_REFLECTIONS_)
var Texture2D DitherTexture;
var globalconfig string DitherTextureName;
`endif
/** White noise sound */
var SoundNodeWave DefaultSound;
var globalconfig string DefaultSoundName;
/** Time in seconds (game time) we should wait between purging object references to objects that are pending kill */
var(Settings) config float TimeBetweenPurgingPendingKillObjects;
// Variables.
/** Abstract interface to platform-specific subsystems */
var const client Client;
/** Viewports for all players in all game instances (all PIE windows, for example) */
var init array<LocalPlayer> GamePlayers;
/** the viewport representing the current game instance */
var const GameViewportClient GameViewport;
/** Array of deferred command strings/ execs that get executed at the end of the frame */
var init array<string> DeferredCommands;
var int TickCycles, GameCycles, ClientCycles;
var transient bool bUseSound;
/** Whether to allow background level streaming. */
var(Settings) config bool bUseBackgroundLevelStreaming;
/** Flag for completely disabling subtitles for localized sounds. */
var(Settings) config bool bSubtitlesEnabled;
/** Flag for forcibly disabling subtitles even if you try to turn them back on they will be off */
var(Settings) config bool bSubtitlesForcedOff;
/** Whether to enable framerate smoothing. */
var config bool bSmoothFrameRate;
/** Maximum framerate to smooth. Code will try to not go over via waiting. */
var config float MaxSmoothedFrameRate;
/** Minimum framerate smoothing will kick in. */
var config float MinSmoothedFrameRate;
/**
* Whether we should check for more than N pawns spawning in a single frame.
* Basically, spawning pawns and all of their attachments can be slow. And on consoles it
* can be really slow. If this bool is true we will display a
**/
var config bool bCheckForMultiplePawnsSpawnedInAFrame;
/** If bCheckForMultiplePawnsSpawnedInAFrame==TRUE, then we will check to see that no more than this number of pawns are spawned in a frame. **/
var config int NumPawnsAllowedToBeSpawnedInAFrame;
/**
* Whether or not the simple lightmaps should be generated during lighting rebuilds.
*/
var globalconfig bool bShouldGenerateSimpleLightmaps;
/**
* Flag for forcing terrain to be 'static' (MinTessellationLevel = MaxTesselationLevel)
* Game time only...
*/
var(Settings) config bool bForceStaticTerrain;
/** Entry point for RemoteControl, the in-game UI for the exec system. */
var native pointer RemoteControlExec{class FRemoteControlExec};
/** Pointer to a support class to handle mobile material emulation (created on demand) */
var native pointer MobileMaterialEmulator{class FMobileMaterialEmulator};
// Color preferences.
var(Colors) color
C_WorldBox,
C_BrushWire,
C_AddWire,
C_SubtractWire,
C_SemiSolidWire,
C_NonSolidWire,
C_WireBackground,
C_ScaleBoxHi,
C_VolumeCollision,
C_BSPCollision,
C_OrthoBackground,
C_Volume,
C_BrushShape;
/** Fudge factor for tweaking the distance based miplevel determination */
var(Settings) float StreamingDistanceFactor;
/** Class name of the scout to use for path building */
var const config string ScoutClassName;
/**
* A transition type.
*/
enum ETransitionType
{
TT_None,
TT_Paused,
TT_Loading,
TT_Saving,
TT_Connecting,
TT_Precaching
};
/** The current transition type. */
var ETransitionType TransitionType;
/** The current transition description text. */
var string TransitionDescription;
/** The gametype for the destination map */
var string TransitionGameType;
/** Level of detail range control for meshes */
var config float MeshLODRange;
/** Force to CPU skinning only for skeletal mesh rendering */
var config bool bForceCPUSkinning;
/** Whether to use post processing effects or not */
var config bool bUsePostProcessEffects;
/** whether to send Kismet warning messages to the screen (via PlayerController::ClientMessage()) */
var config bool bOnScreenKismetWarnings;
/** whether kismet logging is enabled. */
var config bool bEnableKismetLogging;
/** whether mature language is allowed **/
var config bool bAllowMatureLanguage;
/** camera rotation (deg) beyond which occlusion queries are ignored from previous frame (because they are likely not valid) */
var config float CameraRotationThreshold;
/** camera movement beyond which occlusion queries are ignored from previous frame (because they are likely not valid) */
var config float CameraTranslationThreshold;
/** The amount of time a primitive is considered to be probably visible after it was last actually visible. */
var config float PrimitiveProbablyVisibleTime;
`if(`__TW_LIGHT_CULLING_)
/** The amount of time a light is considered to be probably visible after it was last actually visible. */
var config float LightProbablyVisibleTime;
`endif
/** The percent of previously unoccluded primitives which are requeried every frame. */
var config float PercentUnoccludedRequeries;
/** Max screen pixel fraction where retesting when unoccluded is worth the GPU time. */
var config float MaxOcclusionPixelsFraction;
// NVCHANGE_BEGIN_TURB: Multiple PhysX levels
/** Level of PhysX content. 0 means no hardware acceleration. */
var globalconfig int PhysXLevel;
// NVCHANGE_END_TURB: Multiple PhysX levels
/** Do not use Ageia PhysX hardware */
var globalconfig bool bDisablePhysXHardwareSupport;
/** Whether to pause the game if focus is lost. */
var config bool bPauseOnLossOfFocus;
/** The most vertices a fluid surface can have. The number of verts is clamped to avoid running out of memory and exposing driver bugs. */
var config int MaxFluidNumVerts;
/**
* Time limit (in milliseconds) for a fluid simulation update, to avoid spiraling into a bad
* feedback-loop with slower and slower framerate. This value is doubled in debug builds.
*/
var config float FluidSimulationTimeLimit;
/**
* The maximum allowed size to a ParticleEmitterInstance::Resize call.
* If larger, the function will return without resizing.
*/
var config int MaxParticleResize;
/**
* If the resize request is larger than this, spew out a warning to the log
*/
var config int MaxParticleResizeWarn;
/**
* If TRUE, then perform particle size checks in non FINAL_RELEASE builds.
*/
var globalconfig bool bCheckParticleRenderSize;
/** The maximum amount of memory any single emitter is allowed to take for its vertices */
var config int MaxParticleVertexMemory;
var transient int MaxParticleSpriteCount;
var transient int MaxParticleSubUVCount;
/** The number of times to attempt the Begin*UP call before assuming the GPU is hosed */
var config int BeginUPTryCount;
/** Info about one note dropped in the map during PIE. */
struct native DropNoteInfo
{
/** Location to create Note actor in edited level. */
var vector Location;
/** Rotation to create Note actor in edited level. */
var rotator Rotation;
/** Text to assign to Note actor in edited level. */
var string Comment;
};
/** */
var transient array<DropNoteInfo> PendingDroppedNotes;
/** Overridable class for cover mesh rendering in-game, used to get around the editoronly restrictions needed by the base CoverMeshComponent */
var globalconfig string DynamicCoverMeshComponentName;
/**
* By default, each frame's initial scene color clear is disabled.
* This flag can be toggled at runtime to enable clearing for development.
*/
var globalconfig const bool bEnableColorClear;
/** Number of times to tick each client per second */
var globalconfig float NetClientTicksPerSecond;
/**
* The largest step-size allowed for lens flare occlusion results
* before using the incremental step method.
*/
var globalconfig float MaxTrackedOcclusionIncrement;
/**
* The incremental step size for the above.
*/
var globalconfig float TrackedOcclusionStepSize;
/** Keeps track whether actors moved via PostEditMove and therefore constraint syncup should be performed. */
var transient bool bAreConstraintsDirty;
/** TRUE if the engine needs to perform a delayed global component reattach (really just for editor) */
var transient bool bHasPendingGlobalReattach;
/** Default color of selected objects in the level viewport (additive) */
var globalconfig LinearColor DefaultSelectedMaterialColor;
/** Default color of hovered objects in the level viewport (additive) */
var globalconfig LinearColor DefaultHoveredMaterialColor;
/** Color of selected objects in the level viewport (additive) */
var transient LinearColor SelectedMaterialColor;
/** Color of unselected objects in the level viewport (additive) */
var transient LinearColor UnselectedMaterialColor;
/** If TRUE, then disable OnScreenDebug messages. Can be toggled in real-time. */
var globalconfig bool bEnableOnScreenDebugMessages;
/** If TRUE, then disable the display of OnScreenDebug messages (used when running) */
var transient bool bEnableOnScreenDebugMessagesDisplay;
/** If TRUE, then skip drawing map warnings on screen even in non FINAL_RELEASE builds */
var globalconfig bool bSuppressMapWarnings;
/** If DevAbsorbFuncs logging is unsuppressed and _DEBUG is defined in native, functions listed in this array will not throw a warning when they are absorbed for not being simulated on clients. Useful for functions like Tick, where this behaviour is intentional */
var globalconfig array<name> IgnoreSimulatedFuncWarnings;
/** if set, cook game classes into standalone packages (as defined in [Cooker.MPGameContentCookStandalone]) and load the appropriate
* one at game time depending on the gametype specified on the URL
* (the game class should then not be referenced in the maps themselves)
*/
var globalconfig bool bCookSeparateSharedMPGameContent;
/**
* If TRUE and build w/ WITH_RECAST enabled, use Recast for navmesh
*/
var globalconfig bool bUseRecastNavMesh;
/** determines whether AI logging should be processed or not */
var bool bDisableAILogging;
`if(`__TW_BASEAI_LEAN_)
/**
* AI interface instance
*/
var globalconfig string AISubsystemClassName;
var AISubsystem AISys;
`endif
/** Semaphore to control screen saver inhibitor thread access. */
var private{private} transient int ScreenSaverInhibitorSemaphore;
/** Thread preventing screen saver from kicking. Suspend most of the time. */
var private{private} transient pointer ScreenSaverInhibitor{FRunnableThread};
/** A global translation context handles simple translation scenarios. e.g. <Strings:A.B.C> */
var TranslationContext GlobalTranslationContext;
/** Enables normal map sampling when Lightmass is generating 'simple' light maps. This increases lighting build time, but may improve quality when normal maps are used to represent curvature over a large surface area. When this setting is disabled, 'simple' light maps will not take normal maps into account. */
var globalconfig bool bUseNormalMapsForSimpleLightMaps;
/** Timestamp for when a loading movie was started, based on appSeconds(). Cleared to 0.0 when no movies are playing anymore. */
var const transient double LoadingMovieStartTime;
/** determines if we should start the matinee capture as soon as the game loads */
var transient bool bStartWithMatineeCapture;
/** should we compress the capture */
var transient bool bCompressMatineeCapture;
/** the name of the matine that we want to record */
var transient string MatineeCaptureName;
/** The package name where the matinee belongs to */
var transient string MatineePackageCaptureName;
/** The visible levels that should be loaded when the matinee starts */
var transient string VisibleLevelsForMatineeCapture;
/** the fps of the matine that we want to record */
var transient int MatineeCaptureFPS;
/** The capture type 0 - AVI, 1 - Screen Shots */
var transient int MatineeCaptureType;
/** TRUE if the the user cannot modify levels that are read only. */
var transient bool bLockReadOnlyLevels;
//@HSL_BEGIN - BWJ - 8-19-16 - Server query support
/** Net driver for server query support */
var NetDriver QueryNetDriver;
//@HSL_END
//@HSL_BEGIN - BWJ - 2-27-17 - Support for safe frame scale
/** The safe frame scale. Currently only used for XB1 */
var float SafeFrameScale;
//@HSL_END
cpptext
{
// Constructors.
UEngine();
void StaticConstructor();
// UObject interface.
virtual void FinishDestroy();
// UEngine interface.
virtual void Init();
/**
* Called at shutdown, just before the exit purge.
*/
#if __TW_BASEAI_LEAN_
virtual void PreExit();
#else
virtual void PreExit() {}
#endif
virtual UBOOL Exec( const TCHAR* Cmd, FOutputDevice& Out=*GLog );
virtual void Tick( FLOAT DeltaSeconds ) PURE_VIRTUAL(UEngine::Tick,);
virtual void SetClientTravel( const TCHAR* NextURL, ETravelType TravelType ) PURE_VIRTUAL(UEngine::SetClientTravel,);
virtual FLOAT GetMaxTickRate( FLOAT /*DeltaTime*/, UBOOL bAllowFrameRateSmoothing = TRUE );
virtual void SetProgress( EProgressMessageType MessageType, const FString& Title, const FString& Message );
/**
* Called by Exec. Memory related execs.
*/
UBOOL ExecMemFunctions( const TCHAR* Cmd, FOutputDevice& Out=*GLog );
/**
* Called by Exec. Threading related execs.
*/
UBOOL ExecThreadFunctions( const TCHAR* Cmd, FOutputDevice& Out=*GLog );
/**
* Pauses / unpauses the game-play when focus of the game's window gets lost / gained.
* @param EnablePause TRUE to pause; FALSE to unpause the game
*/
virtual void OnLostFocusPause( UBOOL EnablePause );
#if DO_CHARTING
/**
* Ticks the FPS chart.
*
* @param DeltaSeconds Time in seconds passed since last tick.
*/
virtual void TickFPSChart( FLOAT DeltaSeconds );
/**
* Ticks the Memory chart.
*
* @param DeltaSeconds Time in seconds passed since last tick.
*/
virtual void TickMemoryChart( FLOAT DeltaSeconds );
/**
* Resets the FPS chart data.
*/
virtual void ResetFPSChart();
/**
* Dumps the FPS chart information to the passed in archive.
*
* @param bForceDump Whether to dump even if FPS chart info is not enabled.
*/
virtual void DumpFPSChart( UBOOL bForceDump = FALSE );
/** Dumps info on DistanceFactor used for rendering SkeletalMeshComponents during the game. */
virtual void DumpDistanceFactorChart();
/**
* Resets the Memory chart data.
*/
virtual void ResetMemoryChart();
/**
* Dumps the Memory chart information to various places.
*
* @param bForceDump Whether to dump even if no info has been captured yet (will force an update in that case).
*/
virtual void DumpMemoryChart( UBOOL bForceDump = FALSE );
private:
/**
* Dumps the FPS chart information to HTML.
*/
virtual void DumpFPSChartToHTML( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames, UBOOL bOutputToGlobalLog );
/**
* Dumps the FPS chart information to the log.
*/
virtual void DumpFPSChartToLog( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames );
/**
* Dumps the FPS chart information to the special stats log file.
*/
virtual void DumpFPSChartToStatsLog( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames );
/**
* Dumps the frame times information to the special stats log file.
*/
virtual void DumpFrameTimesToStatsLog( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames );
/**
* Dumps the Memory chart information to HTML.
*/
virtual void DumpMemoryChartToHTML( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames, UBOOL bOutputToGlobalLog );
/**
* Dumps the Memory chart information to the log.
*/
virtual void DumpMemoryChartToLog( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames );
/**
* Dumps the Memory chart information to the special stats log file.
*/
virtual void DumpMemoryChartToStatsLog( FLOAT TotalTime, FLOAT DeltaTime, INT NumFrames );
#endif // DO_CHARTING
public:
/**
* Spawns any registered server actors
*/
virtual void SpawnServerActors(void)
{
}
/**
* Loads all Engine object references from their corresponding config entries.
*/
void InitializeObjectReferences();
/**
* Construct a UNetDriver object based on an .ini setting
*
* @return The created NetDriver object, or NULL if it fails
*/
virtual class UNetDriver* ConstructNetDriver()
{
return NULL;
}
/**
* Clean up the GameViewport
*/
void CleanupGameViewport();
/** Get some viewport. Will be GameViewport in game, and one of the editor viewport windows in editor. */
virtual FViewport* GetAViewport();
/**
* Allows the editor to accept or reject the drawing of wireframe brush shapes based on mode and tool.
*/
virtual UBOOL ShouldDrawBrushWireframe( class AActor* InActor ) { return TRUE; }
/**
* Issued by code requesting that decals be reattached.
*/
virtual void IssueDecalUpdateRequest() {}
/**
* Returns whether or not the map build in progressed was cancelled by the user.
*/
virtual UBOOL GetMapBuildCancelled() const
{
return FALSE;
}
/**
* Sets the flag that states whether or not the map build was cancelled.
*
* @param InCancelled New state for the cancelled flag.
*/
virtual void SetMapBuildCancelled( UBOOL InCancelled )
{
// Intentionally empty.
}
/**
* Computes a color to use for property coloration for the given object.
*
* @param Object The object for which to compute a property color.
* @param OutColor [out] The returned color.
* @return TRUE if a color was successfully set on OutColor, FALSE otherwise.
*/
virtual UBOOL GetPropertyColorationColor(class UObject* Object, FColor& OutColor);
/** Uses StatColorMappings to find a color for this stat's value. */
UBOOL GetStatValueColoration(const FString& StatName, FLOAT Value, FColor& OutColor);
/**
* @return TRUE if selection of translucent objects in perspective viewports is allowed
*/
virtual UBOOL AllowSelectTranslucent() const
{
// The editor may override this to disallow translucent selection based on user preferences
return TRUE;
}
/**
* @return TRUE if only editor-visible levels should be loaded in Play-In-Editor sessions
*/
virtual UBOOL OnlyLoadEditorVisibleLevelsInPIE() const
{
// The editor may override this to apply the user's preference state
return TRUE;
}
/**
* Enables or disables the ScreenSaver (PC only)
*
* @param bEnable If TRUE the enable the screen saver, if FALSE disable it.
*/
void EnableScreenSaver( UBOOL bEnable );
/**
* Get the index of the provided sprite category
*
* @param InSpriteCategory Sprite category to get the index of
*
* @return Index of the provided sprite category, if possible; INDEX_NONE otherwise
*/
virtual INT GetSpriteCategoryIndex( const FName& InSpriteCategory )
{
// The editor may override this to handle sprite categories as necessary
return INDEX_NONE;
}
/**
* Trips a bool in engine side code to signal a screenshot request on next frame
*/
void SetRequestScreenshot();
/**
* Starts playing a loading movie from memory.
* Keeps track of the total time fullscreen movies are playing to cover loading.
*
* @param MovieName Name of the movie to play in its entirety
*/
void PlayLoadingMovie( const TCHAR* MovieName );
protected:
/**
* Handles freezing/unfreezing of rendering
*/
virtual void ProcessToggleFreezeCommand()
{
// Intentionally empty.
}
/**
* Handles frezing/unfreezing of streaming
*/
virtual void ProcessToggleFreezeStreamingCommand()
{
// Intentionally empty.
}
/**
* Updates all physics constraint actor joint locations.
*/
virtual void UpdateConstraintActors();
#if __TW_BASEAI_LEAN_
virtual void InitializeSubsystems();
#endif
}
/** @return the GIsEditor flag setting */
native static final function bool IsEditor();
/** @return the GIsGame flag is setting */
native static final function bool IsGame();
/**
* Returns a pointer to the current world.
*/
native static final function WorldInfo GetCurrentWorldInfo();
/**
* Returns version info from the engine
*/
native static final function string GetBuildDate();
/**
* Returns the UUID of the device (or empty if cannot be determined)
*/
native static final function string GetDeviceUUID();
/**
* Return OS version number
*/
native static final function float GetOSVersion();
/**
* Return TitleSafe Area Scale.
*/
native static final function float GetTitleSafeArea();
/**
* Returns the push notification token for the device + application
*/
native static final function string GetDevicePushNotificationToken();
/*
* Returns the proper formatting for a bug data export string
*/
native static final function string BuildBugSubmissionString(string BugField, string BugFieldData);
/**
* Return true if there is a network connection
*/
native static final function bool HasNetworkConnection();
/**
* Returns the engine's default tiny font
*/
native static final function Font GetTinyFont();
/**
* Returns the engine's default small font
*/
native static final function Font GetSmallFont();
/**
* Returns the engine's default medium font
*/
native static final function Font GetMediumFont();
/**
* Returns the engine's default large font
*/
native static final function Font GetLargeFont();
/**
* Returns the engine's default subtitle font
*/
native static final function Font GetSubtitleFont();
/**
* Returns the specified additional font.
*
* @param AdditionalFontIndex Index into the AddtionalFonts array.
*/
native static final function Font GetAdditionalFont(int AdditionalFontIndex);
/** @return whether we're currently running in splitscreen (more than one local player) */
native static final function bool IsSplitScreen();
/** @return whether we're currently running with stereoscopic 3D enabled */
native static final function bool IsStereoscopic3D();
/** @return whether we're currently running with the OpenGL ES2 renderer */
native static final function bool IsUsingES2Renderer();
/** @return the audio device (will be None if sound is disabled) */
native static final function AudioDevice GetAudioDevice();
`if(`__TW_BASEAI_LEAN_)
/** @return the AISubsystem instantiated in packages loaded later (None if not instantiated) */
native static final function AISubsystem GetAISubsystem();
`endif
/** @return Returns the name of the last movie that was played. */
native static final function string GetLastMovieName();
/**
* Play one of the LoadMap loading movies as configured by ini file
*
* @return TRUE if a movie was played
*/
native static final function bool PlayLoadMapMovie();
/**
* Stops the current movie
*
* @param bDelayStopUntilGameHasRendered If TRUE, the engine will delay stopping the movie until after the game has rendered at least one frame
*/
native static final function StopMovie(bool bDelayStopUntilGameHasRendered);
/**
* Removes all overlays from displaying
*/
native static final function RemoveAllOverlays();
/**
* Adds a text overlay to the movie
*
* @param Font Font to use to display (must be in the root set so this will work during loads)
* @param Text Text to display
* @param X X location in resolution-independent coordinates (ignored if centered)
* @param Y Y location in resolution-independent coordinates
* @param ScaleX Text horizontal scale
* @param ScaleY Text vertical scale
* @param bIsCentered TRUE if the text should be centered
*/
native static final function AddOverlay( Font Font, string Text, float X, float Y, float ScaleX, float ScaleY, bool bIsCentered );
/**
* Adds a wrapped text overlay to the movie
*
* @param Font Font to use to display (must be in the root set so this will work during loads)
* @param Text Text to display
* @param X X location in resolution-independent coordinates (ignored if centered)
* @param Y Y location in resolution-independent coordinates
* @param ScaleX Text horizontal scale
* @param ScaleY Text vertical scale
* @param WrapWidth Number of pixels before text should wrap
*/
native static final function AddOverlayWrapped( Font Font, string Text, float X, float Y, float ScaleX, float ScaleY, float WrapWidth );
// WITH_REALD BEGIN
/**
* Returns whether RealD stereo rendering is enabled or not
*/
native static final function bool IsRealDStereoEnabled();
// WITH_REALD END
/**
* returns GEngine
*/
native static final function Engine GetEngine();
/**
* Returns the defualt post process chain (loading it if it has not yet been loaded)
*/
native static final function PostProcessChain GetDefaultPostProcessChain();
/**
* Returns the post process chain to be used with the world.
*/
native static final function PostProcessChain GetWorldPostProcessChain();
/**
* Adds a world location as a secondary view location for purposes of texture streaming.
* Lasts one frame, or a specified number of seconds (for overriding locations only).
*
* @param InLoc Location to add to texture streaming for this frame
* @param BoostFactor A factor that affects all streaming distances for this location. 1.0f is default. Higher means higher-resolution textures and vice versa.
* @param bOverrideLocation Whether this is an override location, which forces the streaming system to ignore all other locations
* @param OverrideDuration How long the streaming system should keep checking this location if bOverrideLocation is TRUE, in seconds. 0 means just for the next Tick.
*/
native final function AddTextureStreamingSlaveLoc(vector InLoc, float BoostFactor, bool bOverrideLocation, float OverrideDuration);
/**
* Serializes an object to a file (object pointers to non-always loaded objects are not supported)
*
* @param Obj The object to serialize
* @param Pathname The path to the file to save
* @param bIsSaveGame If TRUE, FILEWRITE_SaveGame will be used to create the file writer
* @param Version A version number to save with the archive, so that we can safely fail when loading old versioned files
* @param bEncrypt - should file be encrypted? Loading it back will be automatic if encrypted.
*
* @return TRUE if successful
*/
native static final function bool BasicSaveObject(Object Obj, string Pathname, bool bIsSaveGame, int Version, optional bool bEncrypt=false);
/**
* Loads an object from a file (saved with the BasicSaveObject function). It should already be
* allocated just like the original object was allocated
*
* @param Obj The object to serialize
* @param Pathname The path to the file to read and create the object from
* @param bIsSaveGame If TRUE, FILEREAD_SaveGame will be used to create the file reader
* @param Version A version number to match with the version saved in the archive, so that we can safely fail when loading old versioned files
*
* @return TRUE if successful
*/
native static final function bool BasicLoadObject(Object Obj, string Pathname, bool bIsSaveGame, int Version);
/** Launches the specified platform via appLaunchURL (platform dependent support) */
native static final function LaunchURL(string URL);
// NVCHANGE_BEGIN_TURB: Multiple PhysX levels
/** Return level of PhysX content (0, 1, or 2). 0 means no hardware acceleration. */
native static final function int GetPhysXLevel();
// NVCHANGE_END_TURB: Multiple PhysX levels
/**
* Gets the value of the specified boolean System Setting
*
* @param SettingName - Name of the boolean System Setting to retrieve
*
* @return The value of the boolean System Setting
*/
native final function bool GetSystemSettingBool(string SettingName);
/**
* Gets the value of the specified integer System Setting
*
* @param SettingName - Name of the integer System Setting to retrieve
*
* @return The value of the integer System Setting
*/
native final function int GetSystemSettingInt(string SettingName);
/**
* Gets the value of the specified float System Setting
*
* @param SettingName - Name of the float System Setting to retrieve
*
* @return The value of the float System Setting
*/
native final function float GetSystemSettingFloat(string SettingName);
defaultproperties
{
C_WorldBox=(R=0,G=0,B=40,A=255)
C_BrushWire=(R=192,G=0,B=0,A=255)
C_AddWire=(R=127,G=127,B=255,A=255)
C_SubtractWire=(R=255,G=192,B=63,A=255)
C_SemiSolidWire=(R=127,G=255,B=0,A=255)
C_NonSolidWire=(R=63,G=192,B=32,A=255)
C_WireBackground=(R=0,G=0,B=0,A=255)
C_ScaleBoxHi=(R=223,G=149,B=157,A=255)
C_VolumeCollision=(R=149,G=223,B=157,A=255)
C_BSPCollision=(R=149,G=157,B=223,A=255)
C_OrthoBackground=(R=163,G=163,B=163,A=255)
C_Volume=(R=255,G=196,B=255,A=255)
C_BrushShape=(R=128,G=255,B=128,A=255)
bUseSound=true
}