-
Notifications
You must be signed in to change notification settings - Fork 10
Game
static bool Game.ChangeSpeechVox(const string newVoxName)
Changes the active voice pack to a file called sp_newvoxname.vox, where "newvoxname" is passed as a function argument. E.g. if you have sp_francais.vox in your game file, then you can do Game.ChangeSpeechVox("francais") to switch to it. Passing a blank string will revert the game to the default voice pack called speech.vox.
Returns true if the voice pack was changed successfully, or false if there was a problem (for example, you specified an invalid filename). In case of failure this function will also try to revert to the default pack.
NOTE: the active voice pack is not tied to the active text translation. In your game you may have voice matching text, or separate languages for text and voices: e.g. French voice-over with English text.
Example:
if (Game.ChangeSpeechVox("Spanish")) {
Display("Changed the voice-over to Spanish!");
} else {
Display("Unable to change the voice-over.");
}
will attempt to change the voice pack to sp_spanish.vox.
Compatibility: Supported by AGS 3.6.0 and later versions.
See also:
Game.SpeechVoxFilename
,
IsSpeechVoxAvailable
,
Game.ChangeTranslation
,
Translations, Voice speech
static bool Game.ChangeTranslation(const string newTranslationName)
Changes the active translation to newTranslationName. This must be the file name without the extension, for example "French" or "Spanish". It can also be a blank string, in which case the current translation will be switched off and the game will revert to the default language.
Returns true if the translation was changed successfully, or false if there was a problem (for example, you specified an invalid translation).
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example below.
Example:
if (Game.ChangeTranslation("Spanish") == true)
{
Display("Changed the translation to Spanish!");
}
else
{
Display("Unable to change the translation");
}
will attempt to change the translation to Spanish
Compatibility: Supported by AGS 3.1.0 and later versions.
See also:
Game.TranslationFilename
,
GetTranslation
,
IsTranslationAvailable
,
Game.ChangeSpeechVox
,
Translations
static bool Game.DoOnceOnly(const string token)
This function gives you an easy way of making some code run only the first time that the player encounters it. It is commonly used for awarding points.
The token parameter is an arbitrary string. You can pass whatever you like in for this, but IT MUST BE UNIQUE. It is this string that allows AGS to determine whether this section of code has been run before, therefore you should make sure that you do not use the same token string in two different places in your game.
Returns true the first time that it is called with this token, and false thereafter.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example below.
Example:
if (Game.DoOnceOnly("open cupboard")) {
GiveScore(5);
}
will give the player 5 points the first time this script is run.
See also: Game.ResetDoOnceOnly
, GiveScore
(Formerly known as RawSetColorRGB
, which is now obsolete)
static int Game.GetColorFromRGB(int red, int green, int blue)
Gets the AGS Color Number for the specified RGB color. The red, green and blue components are values from 0 to 255. This function gives you a run-time equivalent to the Color Finder in the editor.
This command is slow in 256-color games, since the palette has to be scanned to find the nearest matching color.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example below.
Example:
DrawingSurface *surface = Room.GetDrawingSurfaceForBackground();
surface.DrawingColor = Game.GetColorFromRGB(0, 255, 0);
surface.DrawLine(0, 0, 50, 50);
surface.Release();
will draw a bright green line onto the room background
See also:
DrawingSurface.DrawingColor
(Formerly part of GetGameParameter
, which is now obsolete)
static int Game.GetFrameCountForLoop(int view, int loop)
Returns the number of frames in the specified loop of the specified view.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example for more.
Example:
int frameCount = Game.GetFrameCountForLoop(SWIMMING, 2);
Display("Loop 2 in SWIMMING view has %d frames.", frameCount);
See also:
Game.GetLoopCountForView
,
Game.GetRunNextSettingForLoop
,
Game.GetViewFrame
(Formerly known as global function GetLocationName
, which is now
obsolete)
static String Game.GetLocationName(int x, int y)
Returns the name of whatever is seen in the room under the given screen coordinates (x, y). This includes following:
- Characters,
- Hotspots,
- Room Objects,
- Inventory Items.
If there are multiple suitable objects under these coordinates, this function will select the one that is drawn topmost. If there is no suitable object, then function will return a blank string.
NOTE: The co-ordinates are SCREEN co-ordinates, NOT ROOM co-ordinates. This means that this function is suitable for use with the mouse cursor position variables.
This function may allow you, for instance, to create the LucasArts-style status lines reading "Look at xxx" as the player moves the cursor over them.
NOTE: When looking up for an object under coordinates, GetLocationName is affected by the game setting "Pixel-perfect click detection". It's possible to change this behavior in script by changing OPT_PIXELPERFECT option (see SetGameOption).
Example:
String location = Game.GetLocationName(mouse.x, mouse.y);
lblDescription.Text = location;
will get the name of whatever the mouse is over into the string variable and then assign to a label lblDescription.
See also: Hotspot.Name
,
InventoryItem.Name
,
GetLocationType
,
Object.Name
(Formerly part of GetGameParameter
, which is now obsolete)
static int Game.GetLoopCountForView(int view)
Returns the number of loops in the specified view.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example for more.
Example:
int loops = Game.GetLoopCountForView(SWIMMING);
Display("The SWIMMING view (view %d) has %d loops.", SWIMMING, loops);
See also:
Game.GetRunNextSettingForLoop
,
Game.GetFrameCountForLoop
,
Game.GetViewFrame
(Formerly part of GetGameParameter
, which is now obsolete)
static bool Game.GetRunNextSettingForLoop(int view, int loop)
Returns whether the specified loop in the specified view has the "Run the next loop after this one" option checked.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example for more.
Example:
if (Game.GetRunNextSettingForLoop(SWIMMING, 5) == true) {
Display("Loop 5 in view SWIMMING does have Run Next Loop set.");
}
else {
Display("Loop 5 in view SWIMMING does not have Run Next Loop set.");
}
See also:
Game.GetLoopCountForView
,
Game.GetFrameCountForLoop
,
Game.GetViewFrame
(Formerly known as global function GetSaveSlotDescription
, which is now
obsolete)
static String Game.GetSaveSlotDescription(int slot)
Gets the text description of save game slot SLOT.
If the slot number provided does not exist, returns null.
Example:
String description = Game.GetSaveSlotDescription(10);
will get the description of save slot 10 into the variable.
See also:
DynamicSprite.CreateFromSaveGame
,
RestoreGameSlot
,
SaveGameSlot
static int[] Game.GetSaveSlots(int min_slot, int max_slot, optional SaveGameSortStyle saveSortStyle, optional SortDirection sortDirection)
Returns a dynamic array of existing save slot numbers found in the requested range, optionally sorted using certain style and direction. By default the sorting order is unspecified. If no matching saves were found, returns an empty array (which Length is 0).
SaveGameSortStyle determines which save's property will be used when sorting the list of saves. It can be:
- eSaveGameSort_None - don't sort, the order will be unspecified;
- eSaveGameSort_Number - sort by the save slot number;
- eSaveGameSort_Time - sort by the save time (the time this save slot was last written at);
- eSaveGameSort_Description - sort by the save's description.
SortDirection determines the order of sorting:
- eSortNoDirection - unspecified;
- eSortAscending;
- eSortDescending.
Example 1:
int slotsFound[] = Game.GetSaveSlots(1, 100, eSaveGameSort_Time, eSortDescending);
if (slotsFound.Length > 0)
{
RestoreGameSlot(slotsFound[0]);
}
finds the most recent slot number in the range of 1 to 100, if any is found then restores that save.
Example 2:
int slotsFound[] = Game.GetSaveSlots(1, 100, eSaveGameSort_Time, eSortDescending);
listBox1.FillSaveGameSlots(slotsFound);
gets an array of save slots from Game.GetSaveSlots and then inserts them into the ListBox using FillSaveGameSlots function. Note that you if you do that, you don't have to provide sorting style for FillSaveGameSlots, as the slots will already be sorted by GetSaveSlots.
See also: Game.ScanSaveSlots
,
File.GetFiles
,
ListBox.FillSaveGameList
,
ListBox.FillSaveGameSlots
static DateTime* Game.GetSaveSlotTime(int slot)
Gets the write time of the specified save game slot.
Example:
int save_slot = 1;
DateTime* dt = Game.GetSaveSlotTime(save_slot);
if(dt == null)
{
Display("Save slot '%d' not found", save_slot);
}
else
{
Display("Save slot '%d' was created in\n%02d/%02d/%04d, at %02d:%02d:%02d",
save_slot, dt.DayOfMonth, dt.Month, dt.Year, dt.Hour, dt.Minute, dt.Second);
}
Compatibility: Supported by AGS 3.6.2 and later versions.
See also:
Game.GetSaveSlotDescription
,
DynamicSprite.CreateFromSaveGame
,
RestoreGameSlot
,
SaveGameSlot
(Formerly part of GetGameParameter
, which is now obsolete)
static ViewFrame* Game.GetViewFrame(int view, int loop, int frame)
Returns a ViewFrame instance for the specified frame in the specified loop of the specified view.
This instance allows you to query properties of the frame itself, such as its graphic, its frame-linked sound setting, and so forth.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example for more.
Example:
ViewFrame *frame = Game.GetViewFrame(SWIMMING, 2, 3);
Display("Frame 3 in loop 2 of view SWIMMING has sprite slot %d.", frame.Graphic);
See also:
Game.GetLoopCountForView
,
Game.GetRunNextSettingForLoop
,
Game.GetFrameCountForLoop
,
ViewFrame.Graphic
,
ViewFrame.Speed
(Formerly known as global function InputBox
, which is now obsolete)
static String Game.InputBox(string prompt)
Pops up a window asking the user to type in a string, with PROMPT as the text in the window. Whatever they type in will be returned from this function.
This command displays a very basic input box, mainly useful for debugging purposes. Due to the size of the window, only small strings up to about 20 characters can be typed in.
The recommended way to obtain user input is to create your own GUI with a text box on it, which allows you full customization of the look of the window.
TIP: If you add a '!' character to the start of the prompt, then a Cancel button will be available in the input box. If the player presses this Cancel button (or the ESC key), a blank string is returned.
Example:
String name = Game.InputBox("!What is your name?");
will prompt the user for his name and store it in the string NAME. If the user presses Cancel, the NAME string will be blank.
See also: String.AsInt
(Formerly known as IsMusicPlaying
, which is now obsolete)
(Formerly known as IsSoundPlaying
, which is now obsolete)
static bool Game.IsAudioPlaying(optional AudioType)
Returns true if there is currently audio playing of the specified type. If you don't supply an audio type, then true will be returned if there is any audio at all playing in the game.
If no audio of the specified type is playing, returns false. You can use this to wait for some music to finish playing, for example.
Example:
while (Game.IsAudioPlaying(eAudioTypeMusic))
{
Wait(1);
}
waits for any currently playing music to finish.
Compatibility: Supported by AGS 3.2.0 and later versions.
See also: Game.StopAudio
static bool Game.IsPluginLoaded(const string name)
Checks whether the plugin of the given name was present and loaded for the game.
IMPORTANT: If the plugin exports its own script functions that you used in your game script, and not found when the game is launched, then the game won't start up at all, exiting with error. IsPluginLoaded may therefore be useful to check for plugins that are not interacted with from game script, but just run on their own.
Example:
if (Game.IsPluginLoaded("my_plugin")) {
Display("My plugin is found and running!");
}
will display a message if plugin is present.
static AudioChannel* Game.PlayVoiceClip(Character* c, int cue, bool as_speech)
Plays a voice clip from the speech.vox in a non-blocking manner. It returns an AudioChannel pointer which you may use to control playback same way you control other clips, or null if it could not be started.
Character and "cue" arguments are used to find actual clip, this works the same way as when you do cEgo.Say("&10 speech text");
in which case "10" is a cue number. For more information about this see: Voice speech.
The "as_speech" argument tells whether playback has same effect on game as regular speech. At the moment this means that music volume will drop and restore after playback is finished. This parameter "as_speech" is TRUE by default and may be omitted.
This command will be ignored if a regular blocking voice is currently playing. Also, both blocking and non-blocking voice will interrupt non-blocking voice-over if one was playing.
NOTE: because of how audiochannels work internally right now voice is always played on the same channel 0, therefore you could also get it as System.AudioChannels[0]
, but it may not be a good idea to rely on this because channel behavior may change in future.
Compatibility: Supported by AGS 3.5.0 and later versions.
See also: Voice speech, AudioChannel
, AudioClip.Play
, Character.Say
static void Game.PrecacheSprite(int sprnum)
Loads a sprite into memory, prepares a texture (if necessary for the current graphics driver), and stores them in the engine's memory cache for later use.
This function is meant for preloading sprites and precreating textures that will be used during the next scene for displaying room objects or playing animations. Normally AGS loads sprites automatically, but sometimes loading is not fast enough and may cause visible slowdowns. In such cases you may use PrecacheSprite as a workaround and load certain sprites before the scene begins. For the best results this should be done during some kind of "Loading" screens, or in "Room enter before fade-in" events.
IMPORTANT: this function uses the standard sprite and texture caches, and its efficiency depends on the sizes of these caches. If player's config assigns low cache size, the preloaded sprites may exceed that limit, and previously loaded items will get unloaded. Keep this in mind when precaching many sprites at once, and perhaps set higher cache values in default game config.
Compatibility: Supported by AGS 3.6.1 and later versions.
See also: Game.PrecacheView
static void Game.PrecacheView(int view, int first_loop, int last_loop)
Loads all sprites used in the view's frames, in the range from first_loop to last_loop (inclusive), prepares textures for them (if necessary for the current graphics driver), and stores them in the engine's memory cache for later use.
This function is similar to PrecacheSprite, but simplifies loading a full animation into the cache. Everything said about PrecacheSprite applies to PrecacheView too.
IMPORTANT: this function uses the standard sprite and texture caches, and its efficiency depends on the sizes of these caches. If player's config assigns low cache size, the preloaded sprites may exceed that limit, and previously loaded items will get unloaded. Keep this in mind when precaching many sprites at once, and perhaps set higher cache values in default game config.
Compatibility: Supported by AGS 3.6.1 and later versions.
See also: Game.PrecacheSprite
static void Game.ResetDoOnceOnly()
This function resets all the token states from Game.DoOnceOnly("example token")
calls.
Example:
if (Game.DoOnceOnly("say hi once")) {
Display("Hi!");
}
Game.ResetDoOnceOnly()
if (Game.DoOnceOnly("say hi once")) {
Display("Hi again!");
}
will say hi twice, and also reset ALL do once only tokens.
Compatibility: Supported by AGS 3.6.1 and later versions.
See also: Game.DoOnceOnly
static void Game.ScanSaveSlots(int valid_slots[], int min_slot, int max_slot, optional SaveGameSortStyle saveSortStyle, optional SortDirection sortDirection, optional int user_param);
Scans any existing save slots in the requested range, tests each of them for validity, and fills ones that passed the test into the provided valid_slots dynamic array. Optionally sorts the result using certain style and direction.
IMPORTANT: for technical reasons this function does not do the scanning immediately, instead it waits until the current script completes. After it's done scanning engine will send a eEventSavesScanComplete
event, which you should receive and handle in on_event
script function. For this reason the dynamic array should be a global variable, not local variable, if you'd like to be able to read the results inside on_event
.
Multiple calls to Game.ScanSaveSlots within the same script function are allowed (see more details below).
This function is purposed to test which saves are valid to be restored by the current game. The validation is a two-step process:
First the engine checks whether it is capable of reading the save at all. If a save is of unsupported format, or cannot be read for any reason, then it will be immediately skipped.
Second step is more complicated. This is where the engine will compare the amounts of data of each kind found in the current game and this save: numbers of Characters, GUIs, controls per each GUI, script variables, and so forth. If the save has more data than the game, then such save will be skipped. If the save has equal or less data than the game, then the engine will try to run a special function in script called "validate_restored_save".
If such function is NOT present, then the saves with less data are skipped, and saves with equal amounts of data are automatically accepted.
If function "validate_restored_save" is present in script, then it's run for saves with equal or less data. This function must tell the engine whether to accept or skip this save. How to write such function is explained in the respective article.
The resulting list of accepted save slots is filled into the valid_slots dynamic array. valid_slots array must be created by user prior to calling Game.ScanSaveSlots, it is not created nor resized by the function itself! If array is not large enough to accomodate all the found and accepted saves, function fills only as much as possible and stops.
After the process is completed, this way or another, engine sends a eEventSavesScanComplete event, which may be handled in the on_event
script function.
You can pass an optional user_param value into ScanSaveSlots, in which case it will be sent along with the eEventSavesScanComplete event as its only parameter. This lets to distinguish different calls to ScanSaveSlots in case when you'd like to make multiple calls within a single script for some reason.
You can optionally use saveSortStyle and sortDirection to set how the resulting list of save slots will be sorted. See their explanation in the description to Game.GetSaveSlots
.
Example:
int saveScanResult[];
function ScanSaveGames()
{
saveScanResult = new int[100];
Game.ScanSaveSlots(saveScanResult, 1, 100, eSaveGameSort_Time, eSortDescending);
}
function on_event(EventType event, int data1, int data2)
{
if (event == eEventSavesScanComplete)
{
listBoxWithSaves.FillSaveGameSlots(saveScanResult);
}
}
will scan saves in range from 1 to 100, sort resulting saves list by time, and fill it into some ListBox.
See also: Game.GetSaveSlots
,
ListBox.FillSaveGameList
,
ListBox.FillSaveGameSlots
,
validate_restored_save
(Formerly known as game.speech_music_drop
, which is now obsolete)
static Game.SetAudioTypeSpeechVolumeDrop(AudioType, int volumeReduction)
Changes the VolumeReductionWhileSpeechPlaying of the specified AudioType. This changes the setting, initially set in the Audio Types part of the editor. It specifies how much the volume of clips of this type will be reduced by while speech is playing.
Specify 0 for no volume adjustment, up to 100 which will completely silence these audio clips while speech is playing.
Example:
Game.SetAudioTypeSpeechVolumeDrop(eAudioTypeMusic, 25);
will reduce the volume of Music audio clips by 25 percentage points while speech is playing.
Compatibility: Supported by AGS 3.2.0 and later versions.
See also: Game.SetAudioTypeVolume
(Formerly known as SetSoundVolume
, which is now obsolete)
static Game.SetAudioTypeVolume(AudioType, int volume, ChangeVolumeType)
Changes the default volume of the specified AudioType. This allows you to change the volume of all audio clips of a particular type, so that you can easily control sound and music volume separately, for example.
VOLUME ranges from 0-100, where 100 is the loudest, and 0 will mute sound of that type completely.
Possible values for ChangeVolumeType are:
eVolChangeExisting change the volume of currently playing audio clips
eVolSetFutureDefault change the default volume for clips of this type
eVolExistingAndFuture change both currently playing and future audio
Initially general AudioType volume is not set, meaning that all future audio will be playing using their own custom volumes. If you use the eVolSetFutureDefault or eVolExistingAndFuture, then the DefaultVolume property for all audio clips of this type will be overridden. This means that any DefaultVolume set up in the editor will be lost.
Example:
Game.SetAudioTypeVolume(eAudioTypeMusic, 20, eVolExistingAndFuture);
will change the volume of all currently playing and future music to
20%
.
Compatibility: Supported by AGS 3.2.0 and later versions.
See also: SetSpeechVolume
,
Game.SetAudioTypeSpeechVolumeDrop
,
AudioClip.Play
,
System.Volume
static bool Game.SetSaveGameDirectory(string directory)
Changes the directory where save game files are stored to the supplied directory. If the directory does not exist, AGS will attempt to create it.
You cannot use fully qualified directories with this command (e.g.
C:\Games\Cool\Saves
), because the player might have installed your
game to any folder, and they might not be running Windows.
Therefore, only two types of path are supported:
- Relative paths (e.g. "Saves"). This will create a subfolder inside
default game save folder
- The special tag
$MYDOCS$
which allows you to explicitly create a different folder for your save games inside the user's documents folder.
The actual folder referenced with $MYDOCS$
is different on every
platform: Windows XP: "My Documents"
Windows Vista and later: "Saved Games"
Linux: $XDG_DATA_HOME
/ags
MacOS: game installation folder.
Returns true if the save game directory has been changed successfully; false if not.
NOTE: We advise you against using this function without strong need. In the most cases setting the "Save games folder name" property in the General Settings of the editor should be sufficient.
Example:
Game.SetSaveGameDirectory("$MYDOCS$/My Cool Game Saves");
will change the save game directory to "My Cool Game Saves" in My Documents, and create the folder if it does not exist (might be useful to do this in game_start).
See also:
ListBox.FillSaveGameList
,
RestoreGameDialog
static Game.SimulateKeyPress(eKeyCode key)
Fires a keypress event. This is in all aspects identical to what would happen if a player pressed a key on keyboard. This function may be useful to simulate player actions in game, or create automatic demonstrations (like tutorials).
IMPORTANT: because of how AGS engine and scripts work the game will react to this keypress not before current script function finishes. Any things that normally react to keys (such as skippable speech, cutscenes, and certain GUI controls) will be affected only at the following internal game update.
Example:
Game.SimulateKeyPress(eKeySpace);
This simulates a "space" key press.
Compatibility: Supported by AGS 3.5.0 and later versions.
See also: Mouse.Click
, List of supported key codes
(Formerly known as Game.StopSound
, which is now obsolete)
(Formerly known as StopMusic
, which is now obsolete)
static Game.StopAudio(optional AudioType)
Stops all currently playing audio. If you pass no parameters, then all audio will be stopped. Alternatively, you can pass one of the AudioTypes which will only stop audio clips of that type.
If there are any audio clips queued up with PlayQueued, they will also be canceled.
Example:
Game.StopAudio();
will stop all currently playing audio.
Compatibility: Supported by AGS 3.2.0 and later versions.
See also: Game.IsAudioPlaying
,
AudioClip.Play
,
AudioChannel.Stop
readonly static int Game.AudioClipCount
Returns the number of audio clips in the game.
This is useful for script modules if you need to iterate through all the audio clips for some reason.
Compatibility: Supported by AGS 3.4.0 and later versions.
See also: Game.AudioClips
readonly static int Game.AudioClips[int slot]
Returns the AudioClip* pointer by its index in game resources.
Example:
int i = 0;
int music_count = 0;
while (i < Game.AudioClipCount)
{
if (Game.AudioClips[i].Type == eAudioTypeMusic)
music_count++;
i++;
}
Display("We have %d musical clips in our game", music_count);
Compatibility: Supported by AGS 3.4.0 and later versions.
See also: Game.AudioClipCount
static readonly Camera* Game.Camera;
Gets the primary camera. This is the default camera that is created automatically at the start of the game and cannot be deleted.
Compatibility: Supported by AGS 3.5.0 and later versions.
See also: Game.Cameras
, Camera
, Camera.Create
, Camera.Delete
, Viewport.Camera
static readonly int Game.CameraCount
Gets the number of cameras.
Compatibility: Supported by AGS 3.5.0 and later versions.
See also: Game.Cameras
static readonly Camera* Game.Cameras[int index];
Returns the Camera instance by its index. There's always at least primary camera at the index 0, more could be created in script using Camera.Create
.
IMPORTANT: with the current implementation when you delete a custom camera in the middle all the following cameras will be shifted towards beginning of array, changing their indexes.
Example:
for (int i = 0; i < Game.CameraCount; i++) {
Game.Cameras[i].SetAt(0, 0);
}
This script positions all existing cameras at the room's top-left corner.
Compatibility: Supported by AGS 3.5.0 and later versions.
See also: Game.Camera
, Game.CameraCount
, Camera.Create
, Camera.Delete
, Viewport.Camera
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.CharacterCount
Returns the number of characters in the game.
This is useful for script modules if you need to iterate through all the characters for some reason.
Example:
Display("The game has %d characters.", Game.CharacterCount);
readonly static int Game.DialogCount
Returns the number of dialogs in the game.
This is useful for script modules if you need to iterate through all the dialogs for some reason. Valid dialogs are numbered from 0 to DialogCount - 1.
Example:
Display("The game has %d dialogs.", Game.DialogCount);
Compatibility: Supported by AGS 3.0.2 and later versions.
readonly static String Game.FileName
Gets the filename that the game is running from. This will usually be the name of the EXE file, but could also be "ac2game.dat" if you are just running the game using ACWIN.EXE.
Example:
Display("The main game file is: %s", Game.FileName);
will display the game filename.
See also: Game.Name
readonly static int Game.FontCount
Returns the number of fonts in the game.
This is useful for script modules if you need to iterate through all the fonts for some reason.
Example:
Display("The game has %d fonts.", Game.FontCount);
(Formerly known as global function GetMessageText
, which is now
obsolete)
readonly static String Game.GlobalMessages[int message]
Gets the text of the specified global message. The message number is one of the global message numbers from 500 to 999.
If an invalid message number is supplied, null will be returned. Otherwise, the message contents will be returned.
NOTE: Global Messages were a feature of AGS 2.x and are now obsolete. You will not need to use this property in new games.
Example:
String message = Game.GlobalMessages[997];
Display("Global message 997 says: %s", message);
will display global message 997.
(Formerly known as GetGlobalString
, which is now obsolete)
(Formerly known as SetGlobalString
, which is now obsolete)
static String Game.GlobalStrings[index]
Gets/sets global string index.
NOTE: GlobalStrings are now considered obsolete. Consider using global variables instead, which allow you to name the variables.
Global strings provided a way to share string variables between scripts. There are 50 available global strings, with index values from 0 to 49.
Example:
Game.GlobalStrings[15] = "Joe";
Display("Global string 15 is now: %s", Game.GlobalStrings[15]);
will set global string 15 to contain "Joe".
See also: Global variables,
GetGlobalInt
,
SetGlobalInt
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.GUICount
Returns the number of GUIs in the game.
This is useful for script modules if you need to iterate through all the GUIs for some reason. Valid GUIs are numbered from 0 to GUICount minus 1.
Example:
Display("The game has %d GUIs.", Game.GUICount);
static int Game.IgnoreUserInputAfterTextTimeoutMs;
Gets/sets the length of time for which user input is ignored after some text is automatically removed from the screen.
When AGS is configured to automatically remove text after a certain time on the screen, sometimes the player might try to manually skip the text by pressing a key just as it is removed automatically, and thus they end up skipping the next text line by accident. This property is designed to eliminate this problem.
This property is specified in milliseconds (1000 = 1 second), and is set to 500 by default.
Example:
Game.IgnoreUserInputAfterTextTimeoutMs = 1000;
will tell AGS to ignore mouse clicks and key presses for 1 second after text is automatically removed from the screen.
Compatibility: Supported by AGS 3.2.0 and later versions.
See also:
Game.MinimumTextDisplayTimeMs
,
Game.TextReadingSpeed
,
Speech.SkipStyle
(Formerly known as game.in_cutscene
, which is now obsolete)
static bool Game.InSkippableCutscene
Returns whether the game is currently between a StartCutscene and EndCutscene, and therefore whether the player is able to skip over this part of the game.
When the player chooses to skip a cutscene all of the script code is run as usual, but any blocking commands are run through without the usual game cycle delays. Therefore, you should never normally need to use this property since cutscenes should all be handled automatically, but it could be useful for script modules.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example below.
Example:
if (Game.InSkippableCutscene)
{
Display("The player might never see this message!");
}
will display a message if we are within a cutscene
Compatibility: Supported by AGS 3.0.1 and later versions.
See also: StartCutscene
,
EndCutscene
,
Game.SkippingCutscene
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.InventoryItemCount
Returns the number of inventory items in the game. This is the total number of items that you created in the Inventory Items pane of the editor, not how many the player is currently carrying.
Example:
Display("The game has %d inventory items.", Game.InventoryItemCount);
static int Game.MinimumTextDisplayTimeMs;
Gets/sets the minimum length of time that text is displayed on the
screen. AGS automatically adjusts the length of time that text is
displayed for depending on the length of the text (and you can customize
this calculation with
Game.TextReadingSpeed
), but for very
short statements like "Hi!", you might want the text to remain for
longer.
This property is specified in milliseconds (1000 = 1 second), and is set to 1000 by default.
NOTE: This property is ignored if lip-sync is enabled, or if the General Settings are set not to allow text to be automatically removed.
Example:
Game.MinimumTextDisplayTimeMs = 2000;
will ensure that even the shortest "Hi!" text line will be displayed for at least 2 seconds
Compatibility: Supported by AGS 3.1.2 and later versions.
See also:
Character.SpeechAnimationDelay
,
Game.IgnoreUserInputAfterTextTimeoutMs
Game.TextReadingSpeed
readonly static int Game.MouseCursorCount
Returns the number of mouse cursors in the game.
This is useful for script modules if you need to iterate through all the cursors for some reason.
Example:
Display("The game has %d cursors.", Game.MouseCursorCount);
static String Game.Name
Gets/sets the game's name. This is initially set in the General Settings pane of the editor, but you can change it at run-time in order to change the window title of your game.
Example:
Display("The game name is: %s", Game.Name);
will display the game name.
See also: Game.FileName
(Formerly known as global function SetNormalFont
, which is now
obsolete)
static FontType Game.NormalFont
Gets/sets the font used for all in-game text, except speech. The font number must be a valid number from the Fonts pane of the editor.
More specifically, AGS uses the Normal Font for the following:
- Display
- DisplayTopBar
- dialog options text
- the built-in save and restore dialogs
The Normal Font is font 0 by default.
Example:
Game.NormalFont = eFontSpecial;
will change the normal font to the font "Special".
See also: Game.SpeechFont
(Formerly known as game.skipping_cutscene
, which is now obsolete)
static bool Game.SkippingCutscene
Returns whether the player has elected to skip the current cutscene. This will return true if the game is between a StartCutscene and EndCutscene command, and the player has chosen to skip it.
Although cutscene skipping is handled automatically by AGS, you can use this property to optimize the process by bypassing any lengthy blocks of code that don't need to be run if the cutscene is being skipped over.
NOTE: This is a static function, and thus need to be called with
Game.
in front of it. See the example below.
Example:
if (!Game.SkippingCutscene)
{
aScaryMusic.Play();
Wait(100);
Game.StopAudio();
}
will only attempt to play the music if the player is not skipping the cutscene.
Compatibility: Supported by AGS 3.0.1 and later versions.
See also: StartCutscene
,
EndCutscene
,
Game.InSkippableCutscene
(Formerly known as global function SetSpeechFont
, which is now
obsolete)
static FontType Game.SpeechFont;
Gets/sets the font used for character speech. The font number you supply must be a valid number from the Fonts pane of the editor.
The Speech Font is font 1 by default.
Example:
Game.SpeechFont = eFontStandard;
will change the speech font to "Standard".
See also: Game.NormalFont
readonly static String Game.SpeechVoxFilename;
Gets the name of the active voice package name. This is not equal to the full file name; assuming file is called "sp_name.vox", this function will return only the "name" part. If a default "speech.vox" is used (or no voice pack at all), a blank string is returned.
Example:
if (Game.SpeechVoxFilename== "German") {
Display("You are using the German voice.");
}
Compatibility: Supported by AGS 3.6.0 and later versions.
See also:
Game.ChangeSpeechVox
,
IsSpeechVoxAvailable
,
Game.ChangeTranslation
,
Game.TranslationFilename
,
Translation, Voice speech
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.SpriteHeight[int slot]
Returns the height of the specified sprite.
The height will be returned in the original sprite pixels (without any scaling). If an invalid sprite slot is supplied, 0 will be returned.
Example:
Display("Object 0's sprite is sized %d x %d.", Game.SpriteWidth[object[0].Graphic],
Game.SpriteHeight[object[0].Graphic]);
See also: Game.SpriteWidth
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.SpriteWidth[int slot]
Returns the width of the specified sprite.
The width will be returned in the original sprite pixels (without any scaling). If an invalid sprite slot is supplied, 0 will be returned.
Example:
Display("Object 0's sprite is sized %d x %d.", Game.SpriteWidth[object[0].Graphic],
Game.SpriteHeight[object[0].Graphic]);
See also: Game.SpriteHeight
(Formerly known as game.text_speed
, which is now obsolete)
static int Game.TextReadingSpeed;
Gets/sets the speed at which AGS assumes the player can read text, and therefore how long speech stays on the screen before it is automatically removed.
Specifically, the TextReadingSpeed is the number of characters of text that the player can read in a second. It is 15 by default. A higher number will therefore lead to the text being removed more quickly.
It is useful to link this setting to a GUI Slider on some sort of Control Panel GUI so that the player can adjust it depending on their reading speed.
NOTE: This property is ignored if lip-sync is enabled, or if the General Settings are set not to allow text to be automatically removed.
Example:
Game.TextReadingSpeed = 7;
sets the text reading speed to half the default, which will leave speech on-screen for twice as long as usual.
Compatibility: Supported by AGS 3.1.2 and later versions.
See also:
Character.SpeechAnimationDelay
,
Game.MinimumTextDisplayTimeMs
,
Speech.SkipStyle
(Formerly known as GetTranslationName
, which is now obsolete)
readonly static String Game.TranslationFilename;
Gets the name of the current translation filename (without the ".tra" extension). This may be useful if you want to use a different graphic somewhere depending on which translation is being used.
If no translation is in use, a blank string is returned.
Example:
if (Game.TranslationFilename == "German") {
Display("You are using the German translation.");
}
See also:
Game.ChangeTranslation
,
GetTranslation
,
IsTranslationAvailable
,
Game.SpeechVoxFilename
,
Translation Manual
readonly static bool Game.UseNativeCoordinates
Returns whether the game is using native co-ordinates. If native co-ordinates are in use, then all X, Y, Top, Bottom, Width and Height variables in the game will be expected to reflect the resolution of the game.
If this is false, then the game is operating in backwards-compatible mode where all co-ordinates are low-res.
If the game resolution is 320x200 or 320x240, this setting has no effect.
This property is read-only; it is not possible to change this setting at run-time.
Example:
if (Game.UseNativeCoordinates)
{
Display("The player is at %d, %d -- REALLY!", player.x, player.y);
}
else
{
Display("The player is at %d, %d in the old-school system", player.x, player.y);
}
Compatibility: Supported by AGS 3.1.0 and later versions.
(Formerly part of GetGameParameter
, which is now obsolete)
readonly static int Game.ViewCount
Returns the number of views in the game.
This is useful for script modules if you need to iterate through all the views for some reason. Valid views are numbered from 1 to ViewCount.
Example:
Display("The game has %d views.", Game.ViewCount);
readonly static int Game.BlockingWaitSkipped
Gets the code which describes how was the last blocking state skipped by a user (or autotimer).
Compatibility: Supported by AGS 3.6.0 and later versions.
See also:
WaitKey
,
WaitMouseKey
,
SkipWait
Getting Started in AGS
Editor
- New Game templates
- Editor Preferences
- General Settings
- Default Setup
- Colours Editor
- Room Editor
- Character Editor
- Cursor Editor
- Dialog Editor
- Font Preview
- GUI Editor
- Inventory Items Editor
- View Editor
- Sprite Manager
- Music and sound
- Voice speech
- Script Modules
- System limits
- Log Panel
- Plugins
- Other Features
Engine
Scripting
- Scripting Tutorial
- Scripting Language
-
Scripting API
- Script API Overview
- Standard Constants
- Standard Enumerated Types
- Standard Types
- Game variables
- Global arrays
- Global event handlers
- repeatedly_execute / repeatedly_execute_always
- Custom dialog options rendering
- Global functions: general
- Global functions: message display
- Global functions: multimedia actions
- Global functions: palette operations
- Global functions: room actions
- Global functions: screen effects
- Global functions: wait
- AudioChannel functions and properties
- AudioClip functions and properties
- Camera functions and properties
- Character functions and properties
- DateTime functions and properties
- Dialog functions and properties
- DialogOptionsRenderingInfo functions and properties
- Dictionary functions and properties
- DrawingSurface functions and properties
- DynamicSprite functions and properties
- File functions and properties
- Game functions and properties
- GUI functions and properties
- GUI control functions and properties
- GUI Button functions and properties
- GUI InvWindow functions and properties
- GUI Label functions and properties
- GUI List Box functions and properties
- GUI Slider properties
- GUI Text Box functions and properties
- Hotspot functions and properties
- Inventory item functions and properties
- Maths functions and properties
- Mouse functions and properties
- Object functions and properties
- Overlay functions and properties
- Parser functions
- Region functions and properties
- Room functions and properties
- Screen functions and properties
- Set functions and properties
- Speech functions and properties
- String functions
- System functions and properties
- TextWindowGUI functions and properties
- ViewFrame functions and properties
- Viewport functions and properties
- Obsolete Script API
- Event Types
- Key code table
- Audio in script
Legal Notice
Getting in touch
Misc
Hidden