The General Preferences are used to define the general behaviour of the GameMaker Studio 2 IDE. The most general ones are listed on the main page while many others are split into multiple sub-categories, explained further down this page.
Hey I just created an inventory system from Shuan Spaldings inventory tutorial (slightly modifide for drawing reasons) and I was wondering if there is a way to add an a equipment system that works with the inventory I have. I want it so u can drag a sword from your inventory and place it in the weapeon slot and if u try putting a mushroom or something in the wepeon slot it will not work. By default GameMaker Studio 2 will run and debug using the built in VM (virtual machine), which is more or less the same as running on the desktop OS being used. However GameMaker Studio 2 is a cross platform engine and you can test, debug and compile asset packages of your projects on a number of different target platforms (the exact platforms.
- IDE Language: This option permits you to select the language for the IDE from the list of options supplied. Default is English.
- IDE Skin: Here you can select from the different skins that the IDE can use. By default GameMaker Studio 2 comes with two skins, one light and one dark, and the initial setup uses the dark skin.
- Maximum Framerate of GameMaker Studio 2 Editor: This option permits you to set the maximum framerate that the GameMaker Studio 2 IDE will update at, permitting you to set the framerate to match the update speed of your monitor. Default value is 60.
- Default Audio Device: Here you can choose the default audio device for the GameMaker Studio 2 IDE to use. You can refresh the list by clicking the Refresh Button
- Automatic Response to Exit Confirmation: This option permits you to set whether a confirmation message should be shown when you exit GameMaker Studio 2. By default this is set to 'show message', but can be set to skip the message as if you'd clicked OK.
- Automatic Response to The System Font Changed Dialog: This option permits you to set whether a confirmation message should be shown when a system font has been added, removed or edited. By default this is set to 'show message', but can be set to skip the message as if you'd clicked OK.
- Enable notifications: Checking this will enable the IDE to show notifications about new runtimes, etc... This is on by default.
- Notification timeout (ms): This sets the length of time (in milliseconds) that a notification is shown for. Default is 6000.
- Logout on exit: If this option is checked then the IDE will automatically log out the user session when GameMaker Studio 2 is closed. This is primarily aimed at Education users, as - when checked - this means that whenever the program shuts down the user would be logged out and so free up the session seat for other users to use. This is off by default.
- Enable DPI Override: This option lets you override the default DPI setting with your own. You must first enable the option and then set either the Raw DPi Override value (the default value is 96) or set the Percentage of the native DPi (default value 100%), and once changed you will be prompted to restart the IDE, which may require you to save any work being done on the currently open project. Note that the DPi has a minimum percentage of 50% and a maximum of 500%, and if you you mouse over the information icon you can see the recommended maximum setting for the display being used: Note that if you go above the recommended DPi setting for the monitor, you will be shown a notification that permits you to reset the DPi.
- Show welcome screen on startup: This is on by default and simply tells GameMaker Studio 2 to show a brief splash screen when you start the program. Un-checking this will prevent the splash screen from showing.
- Allow empty tabs to close via shortcut: You can close any open Tabs using the keyboard shortcut / + W, but if you disable this option that shortcut will no longer work. This is enabled by default.
- Open new resources for edit on dragging files into IDE: Certain resources (like sprites or sounds) can be dragged onto the main Workspace in the GameMaker Studio 2 IDE and will be detected and added as a new resource in the Resource Tree. By default the corresponding resource editor will also be opened for editing when this happens, but un-checking this option will prevent the editors from being opened and you will be required to open them manually.
- Open new resources for edit on creation: If this is checked, every time you create a new resource in the Resource Tree, the corresponding resource editor will be opened automatically. This is checked by default and un-checking it will mean that you have to manually open all newly created resources.
- Automatically reload changed files: If this is checked then the IDE will automatically scan and check files to see if any of them have been changed outside of GameMaker Studio 2 and reload them if they have.
- Disable IDE transition animations: The GameMaker Studio 2 IDE has a number of animated transitions for things like opening windows etc... however they are not to everyone's taste and you may experience a performance boost if they are disabled on older or underpowered machines if they are disabled. You can disable them here, and they are on by default.
- Opt-in To Feedback Surveys: When this option is checked, you are telling GameMaker Studio 2 that you wish to participate in feedback surveys, meaning that occaisionally while working a message will be shown about the area you are working on and request a rating and feedback. This option is on by default.
The options above are the main options available from the General preferences, but there are a number of extra options available to you in the sub-categories listed below:
When you go to add a sprite to an object or when you want to use a font in Drag and Drop or in any number of situations, you will be presented with the Asset Explorer:
By default it shows both a Tree View (on the left) and a List View (on the right) but using this preference you can choose to have it only show one or the other.
The Background preferences deal with the Workspace background and what it will display as well as how it will be displayed. The options are:
- Background Image: This is the image file that will be used as the background for the different Workspaces. There is a default image supplied and it is enabled by default, but you can select your own image here. The types of image that you can select from are *.png, *.gif, *.jpg, *.jpeg, *.tif, *.tiff, *.ico, *.bmp, *.2bp or *.mdi, but note that regardless of initial image format, all files will be saved out for use as *.png files, so animated *.gif files for example will only be rendered as a single initial frame.
- Image Scaling: This controls how the background image will be scaled within the different workspaces. The choices are:
- Stretch - The image will be stretched to fit the workspace, changing scale depending on the visible docks
- Tile - The image will be tiled to cover the workspace
- Best Fit - The image will be scaled to fit the workspace proportionally, with bars being added around the edge if it is not a 1:1 fit
- Desktop Stretch - The background will cover the whole workspace, and will move rather than change scale when docks are opened/closed
- Screen Stretch - The background will cover an area the size of the window and will be cropped/extended to show more or less of the image as docks are opened/closed.
- Show background images on workspaces: This option controls whether the selected background image should be shown or not. By default this is checked as on.
The Compiling preferences deal with certain options related to the output when compiling your game for testing or creating a package, as well as certain areas of the compiling process. The options are:
- Automatically open syntax error window on detection: Enable or disable syntax error notification when compiling. This is off by default.
- Show the compile window during compilation: By default the compile window will be shown when you compile your projects, even if the compile doc is closed (it will open for the compile). Unchecking this will switch this behavior off and the compile window will on be visible if open.
- Show compiler commands in compile output: This is checked by default and forces the compiler to show all relevant commands in the compile window. Un-checking this will make the output smaller and have less information.
- Show verbose compiler output: Checking this will force the compiler to show extra commands related to the compilation process. In general this is only required when debugging and may be requested by support should you have an issue. It is off by default (and this is the recommended setting).
- Use Subst for drive paths: When this is checked, GameMaker Studio 2 will create - and remove again when no longer required - virtual drives to use as a substitution for full file paths. These virtual drives bypass any potential issue with file paths being too long for the OS (particularly when compiling for Android or using extensions) and it is recommended to have this enabled. However, if you are having issues with GameMaker Studio 2 creating virtual drives like this, you can disable the option. By default, this is enabled.
- Show package in explorer on build completion: Checking this will make GameMaker Studio 2 open the OS explorer window at the location where the final executable package has been created. It is on by default.
- Clear output window on compile start: By default the compiler window will clear all previous messages from the compile output window at the start of each build, however un-checking this will maintain previous compiler logs. This is on by default and is the recommended configuration since large compiler logs can slow down compile times.
- Maximum parallel compile jobs: This value sets the maximum number of CPU cores to dedicate to compiling a project. The default value is 8 and in general you shouldn't have to change this, but if you are on a laptop or a lower end machine you may want to lower this value. The default is set to 8.
The Confirm Dialogue preferences deal with some of the general confirmation pop-ups that will appear when performing certain actions in the GameMaker Studio 2 IDE. The options are:
- Automatic response to closing a workspace via keyboard shortcut: The keyboard shortcut mentioned above can be used to close any open tab, but sometimes you may accidentally close an empty tab that you require. To prevent this you can set this option to 'Show message' (the default option) to ask if you really want to close that empty tab. The other settings are 'No', to simply do nothing if the shortcut is used, or 'Okay' to close the tab without any message.
- Automatic response to restarting a running build: When you restart a build and another previous one is still running, you will be asked whether you want to stop the current build first. Un checking this message will suppress that message and force GameMaker Studio 2 to assume you had clicked 'Okay' as a response. This option is set to 'Show Message' by default.
- Automatic response to warning when attempting to debug YYC: The YYC target compiles to native code and as such cannot be debugged using the built in debugger. When you try to use the debugger on the YYC target, you will get a warning informing you of this, and the fact that the project will be compiled using the VM instead. This option is set to 'Show Message' by default, but setting it to 'OK' will suppress this warning.
- Automatic response to resetting the project layout: When you select to reset the project layout (from the Layouts Menu) you will, by default, be shown a warning message about how this will close any open resource windows. However you can suppress this message and automatically reset the layout by selecting 'Okay', or have it do nothing by selecting 'No'. The default value is to have 'Show Message'.
- Automatic response to turning off anonymous statistics: When you disable anonymous game statistics in the General Game options, you will be shown a warning message asking you to consider the option carefully. You can suppress this message by selecting 'Okay' here, or have it do nothing by selecting 'No'. The default value is to have 'Show Message'.
The preferences here are related to the GameMaker Studio 2 Debugger and you have the following options:
- Automatic response to closing the debugger: This option permits you to set the automatic response when closing the debugger. If set to 'Show message', you will be shown the dialogue when you want to close the debugger, while setting it to 'Yes' or 'No' will not show this dialogue and perform the task as indicated.
- Enable real-time debugging: Checking this option will permit you to debug your game projects in real time as you run them from the IDE. This is checked by default.
- Debugger port: This sets the port number for the Debug Module to use. The default value is 6509.
- Show event icons in Debugger Resource View: Set whether icons should be shown in the Debugger resource view. This is checked by default.
The preferences here are for Go To window, which you can open using the keyboard shortcut / + T.
- Maximum number of search results to display: This option controls the maximum number of returned results when you use the Go To search window.
The helpfile is designed to operate like a web page and as such requires the use of the GameMaker Studio 2 micro web server, or the use of an external browser. These settings can be changed here:
- Manual Language: This sets language for the IDE to use. The default is 'English'.
- Help manual port: This sets the port number for the manual micro web server to use. The default value is 51291.
- Use an external browser for help: If this is checked then opening the help file will open it using the default browser for your system. This is on by default, and switching it off will force the help file to open in workspace within the IDE.
The Input preferences control certain aspects of the mouse and keyboard input within the IDE. The available options are:
- Slow double click time (ms): Some areas of the IDE require a slower double click to work correctly, for example when renaming a resource (a fast double click will open the resource editor, while a slow double click will permit you to rename it). This option permits you to set the detection speed, with a default value of 500ms.
- Scroll lock time (ms): This option deals with the time that GameMaker Studio 2 should wait between scrolling windows that are overlapping. Essentially, When you're scrolling in window 'A', the cursor might hover over another scrollable area in window 'B', so this preference defines how long you have to wait after you stop scrolling 'A' before you can then scroll 'B', so you don't accidentally start scrolling different panels. The default value is 500ms.
- Scroll speed: This controls the scrolling speed within the different workspaces. The default value is 1.
- Tab drag distance to un-maximise desktop (px): When you drag a workspace tab away from its default position within the IDE, if there is only one workspace active at that time then the GameMaker Studio 2 window will un-maximise and move with the mouse (if you have more than one workspace active a new instance of the IDE will be created to hold the workspace). This setting controls how far you have to drag the tab before the workspace recognises it, and the default value is 50px.
- Minimum zoom level for interacting with window contents (%): This option controls the zoom cut-off point at which the mouse will no longer be able to interact with workspace windows (ie: add nodes, drag windows, etc...). The default value is 40.
- Mouse wheel zoom requires Ctrl key: When this is checked all editors (and the main workspace) will have zoom enabled with / + the mouse wheel , while un-checking it will enable zoom with only the mouse wheel .
- Ctrl + MMB to open the inherited event instead of the manual: When this is checked, holding / key + the middle mouse button in an object will open the objects inherited event (if it has one) rather than the manual.
- Add bias to text selection to prevent line jumping: When this is checked, the conceived line height while selecting a single line in any text window will be padded, making it less prone to vertical imprecision. This is enabled by default.
- Enable laptop mode on all devices: Checking this will show the Laptop Mode button on the IDE, enabling you to switch it on or off as required regardless of whether the device running GameMaker Studio 2 is a laptop or not. This is unchecked by default.
The Output Window preferences control the different colour and formatting options for the various different output windows in the IDE. Each of the different windows has the same set of options, which are listed below:
- Colour: The default colour for the text being written to the window.
- Font Name: The name of the font to use (available fonts will depend on those installed on your system).
- Style: The font style to use, like bold or italics (note that not all windows will permit the same styles and it will also depend on the font used).
- Size: The size to set the font to for the given output window.
- Anti-Aliasing: Here you can set the anti-aliasing mode for the output windows font rendering. You can choose to let the IDE decide by selecting Use Default, or you can force it On or Off by selecting either of those options.
The Path preferences control the different file paths required by elements in the GameMaker Studio 2 IDE as well as for any external editors that you require. The following options exist for the IDE:
- Temp directory: The location for saving all the temporary folders. By default this is Users<Username>AppDataLocalTempGameMakerStudio2.
- IDE cache directory: The location for saving the IDE cache. By default this is Users<Username>AppDataRoamingGameMakerStudio2-DevCache.
- Asset cache directory: The location for saving the asset cache for each project. By default this is Users<Username>AppDataRoamingGameMakerStudio2-DevCache.
- 'My Projects' Location: The location where GameMaker Studio 2 will initially create new projects. By default this is Users<Username>DocumentsGameMakerStudio2.
- Automatically delete temp directory on close: Checking this will force GameMaker Studio 2 to automatically delete the Temp folder that it creates per project for compiling etc... This setting is on by default, and un-checking it will switch it off (meaning that you will have to manually remove any temp files later).
- Automatically delete asset cache on close: If this is checked then the asset compiler cache folder will be removed when you quit GameMaker Studio 2. This is off by default, and enabling it will mean that every time you load and run any project the cache will need to be rebuilt (which can take time depending on the size of the game).
- Automatically delete IDE cache on close: If this is checked then the IDE compiler cache folder will be removed when you quit GameMaker Studio 2. This is off by default, and enabling it will mean that every time you start GameMaker Studio 2 the cache will need to be rebuilt.
- Delete Temp Folder: Clicking this button will delete the temp folder for the project.
- Delete Asset Cache: Clicking this button will delete the compiler asset cache for the project.
- Delete IDE Cache: Clicking this button will delete the IDE cache.
The following options exist for setting paths to external editors:
- Path to external editor/viewer for SWF files: If you are working with SWF format sprites, you can set this to the path of your preferred viewer/editor and when you click the Edit Image button in the Sprite Editor then it will open the given program. The default value here is to have no path.
- Path to external editor/viewer for Spine files: If you are working with Spine format sprites, you can set this to the path of your preferred viewer/editor and when you click the Edit Image button in the Sprite Editor then it will open the given program. The default value here is to have no path.
The Power Saving preferences here will affect how much CPU power and GPU power will be used to generate the GameMaker Studio 2 IDE (essentially this will lower the base framerate at which the program runs and so lower power consumption). Note that some of these are specific to the File Watcher background process. The File Watcher scans the project folders for external changes - for example if you change a gml script in Notepad++ then the file watcher will detect this change and ask you if you want to reload it or discard it - and as such the frequency that this scan happens can severely impact performance and power consumption.
The options here are:
- AC power framerate (%): The base IDE framerate modifier when connected to a power input. Default is 100%.
- Battery power framerate (%): The base IDE framerate modifier when using battery to power the machine. Default is 35%.
- Background framerate (%): The base IDE framerate modifier when GameMaker Studio 2 is not in focus (regardless of the power supply). Default is 15%.
- File watcher frequency (ms): This is the frequency that the file watcher will run at when on desktop (or a docked laptop). Default is 2000.
- Laptop file watcher frequency (ms): This is the frequency that the file watcher will run at when in laptop mode. Default is 5000.
The preferences here contain options for how the Recent Windows list will display items:
- Open automatically on Project load: When enabled, the Recent Windows list will be shown when you load a new project. Default is disabled.
- Move focused windows to top: When this is enabled and you click on any item in the Recent Window list, the selected item will be moved to the top of the list. By default this is disabled.
- Display only currently open windows: Enabling this will make the Recent Windows list remove those items that are no longer open in a workspace (ie: closing any window will remove it from the list too). By default this is disabled.
- Maximum windows to display: This sets the maximum number of previously opened windows that will be shown within the Recent Windows list. Default is 10.
The preferences here contain options for how certain resources will be drawn in your projects:
- Initial default draw colour for new projects: When you use a font or draw a shape using the GameMaker Studio 2 functions or DnD™ actions without specifying a colour, the colour set here is the one that will be used. The default colour is white ($FFFFFFFF).
- Initial default window colour for new projects: This option is used to set the HTML page background colour for the HTML5 target, as well as set the colour shown outside of rooms on all targets (including HTML5). The default colour is black ($000000FF).
The preferences here will affect how you move around within the different GameMaker Studio 2 workspaces. The options are:
- Workspace keyboard navigation degree range: Within a workspace you can have multiple windows open for different objects and resources, and so to move around quickly between them you can use the keyboard shortcut / + + <Arrow Keys> to move between them. Given that the windows within a workspace are not grid aligned the IDE has to choose which window you mean when you press any of the possible 8 directions, and this option permits you to set the 'look angle' that is used. The default value is 40°.
- Workspace chain column padding (px): Workspace elements are often 'chained' to each other (for example, the Code Editor is chained to the Event Editor is chained to the Object Editor), and this option permits you to set the horizontal distance between any two chained windows. The default value is 30px.
- Workspace chain row padding (px): As mentioned above, workspace elements are often 'chained' to each other and this option permits you to set the vertical distance between any two chained windows. The default value is 20px.
- Workspace chain rendering segment count: Here you can set the maximum number of segments for render chains. Lowering this value may help performance on lower end machines. The default value is 20.
- Workspace chain link colour: This is the colour that will be used to display chains between workspace elements. Default colour is $99DD00 with an alpha of 153 ($99).
- Workspace keyboard navigation resets zoom: As mentioned above, you can skip from window to window within the workspace using keyboard shortcuts. You can also zoom the workspace in and out using the / + the mouse wheel . Setting this option will mean that if you have the workspace zoomed and use the shortcuts to skip to another window, then the workspace will be returned to a 1:1 view and centered on the selected window. This option is off by default.
- Workspace chains can overlap: When enabled this option will permit workspace chains to cross and overlap. This is off by default.
When creating rooms in GameMaker Studio 2 you need to set up different view ports and/or cameras to control what is displayed to the player. The view ports are, basically, little windows into your game world that enable you to show the player parts of a room, either scaled or 1:1, and as such they are essential when your game room is larger than the display size. The cameras are what define exactly what will be shown in each view port.
GameMaker Studio 2 permits you 8 independent view ports (numbered from 0 - 7) and an unlimited number of cameras, of which only 8 can be active at any one time - one assigned to each of the available ports - although normally you'll only need one or two view ports. Cameras can show different parts of the same room and can be activated and deactivated as well as assigned to view ports at any time, meaning that you can use cameras to draw HUD elements or to have split screen effects, or to create cut-scenes for example. Essentially, you position a camera within a room and define the 'view' (area) of the room that will be visible to it, and then this view is drawn to a view port - note that the view port can be a different size to the camera view and as such you can distort and scale the camera view if it is a size other than 1:1 with the view port.
IMPORTANT! It's easy to get confused when talking about cameras, views and view ports, so to clarify:- The Camera: A point within the room that will be used to set how the room is displayed - typically with position, orientation, field of view and aspect ratio
- The View: What the camera sees, based on the position, projection and rotation of the camera
- The View Port: The area of the screen where the camera view will be displayed
If you are adding cameras through the Room Editor then you can retrieve their camera ID value using the view_camera variable. You can then manipulate the view using the functions below and you can even destroy the default cameras if required, although you will need to assign a new camera to the view otherwise you will get some very unpredictable behaviour. Cameras added to a view port in the Room Editor are global in scope, meaning that they are created once when you start the game, and then as you enter each room they are set to the values set in the room editor, so if you destroy a default camera in any room, it will cease to exist for all rooms.
Something to note about cameras and view ports is that the total area of the bounding box for all active view ports in the first room of the game is what defines the background canvas size (or window size for MacOS, Ubuntu (Linux) and Windows), and any areas that are not covered by a view port will default to drawing using the window colour as illustrated by the image below:
You should take care when using multiple cameras as the draw event for all instances is called once for each visible view, so if you have three camera views active in one room, the draw event will be run three times every step (basically doing three times the work) which can be a cause for slowdown if the game is large or complex. The view_current variable can be used to help limit these draw calls however by checking which view is being drawn and only drawing items that are specific to a given view port. Also be careful when creating your own cameras, as if you create one in a room and don't remove it using the camera_destroy() you can get a memory leak.
You can find an overview of all the available functions from the different sections below, but it's worth noting that some of these functions require the setting up and use of different matrices, so you may want to look at the section of the manual for the Matrix Functions. Also note that there are a few room functions that can be used to get and set cameras and view port values in rooms other than the current one (see Creating And Changing Rooms).
Gamemaker Studio 2 Review
Game Maker Studio 2 Slot Machine Machines
View Ports And Camera View Variables
When working with cameras, you have to assign them to a view port for them to be 'active' and display anything. These view ports are numbered from 0 to 7 and can be changed and positioned using different variable arrays and functions, and you can also check to see which one is currently drawing or which camera is currently attached to it.
- view_surface_id