-
Notifications
You must be signed in to change notification settings - Fork 10
Viewport
Viewport struct lets you manage screen viewports. Viewports are used to display contents of a Camera. You may think that the viewport is a "TV screen" that shows the image that the camera have captured in the room. Viewport is defined by a rectangle on the game screen, in screen coordinates, and a Camera link.
By default there is a single viewport called "primary viewport". This viewport may be accessed as Screen.Viewport
. But you may create more using Viewport.Create
.
Viewport has a link to camera through a Viewport.Camera
property. Same camera may be linked to multiple viewports at once. If no camera is linked then a viewport is not displayed at all. Viewports are allowed to go partially or fully offscreen, which may be useful to create transition effects, for example. Viewports may overlap, in which case their order of display is defined by ZOrder
property.
By default viewport covers whole game screen, but you may change that anytime using Width and Height properties, and also SetPosition function. Camera's contents are stretched to fill viewport's rectangle, and because of that the difference between viewport's and camera's sizes create zoom effect (scaling):
- If the camera is larger than the viewport the displayed image will be zoomed-out (scaled down)
- If the camera is smaller than the viewport the displayed image will be zoomed-in (scaled up)
Viewport's X, Y properties specify the position if its top-left corner on the game screen. You may use these to move the viewport around the screen.
IMPORTANT: The game starts in automatic viewport mode that snaps primary viewport and camera to the size of the game screen or size of a room background, whatever is smaller, each time new room is loaded. This is convenient in case you want to rely on a common behavior. If you prefer to customize viewports yourself standard behavior may be disabled using Screen.AutoSizeViewportOnRoomLoad
property.
Compatibility: Viewport struct is supported by AGS 3.5.0 and later versions.
See also: Camera
, Screen.AutoSizeViewportOnRoomLoad
, Screen.Viewport
, Screen.Viewports
static Viewport* Viewport.Create()
Creates a new viewport and returns a pointer which you may store in a variable (local or global one) and use to operate it. Any viewport created like this may be also accessed by Screen.Viewports
by its index.
The new viewport will cover whole game screen by default and does not have any camera linked initially. You may assign or reassign the camera and change any of its properties later.
You may always delete previously created viewport using Viewport.Delete
function.
Example:
// Create a new viewport and a new camera, and link them together
Viewport* myView = Viewport.Create();
Camera* myCam = Camera.Create();
myView.Camera = myCam;
// Set the viewport to half the screen size, centered and camera to half the room's
myView.SetPosition(Screen.Width / 4, Screen.Height / 4, Screen.Width / 2, Screen.Height / 2);
// Make sure that the new viewport is on top of the primary one
myView.ZOrder = Screen.Viewport.ZOrder + 1;
// Set the camera to half of the room size, placed at the right-bottom of the room
myCam.SetSize(Room.Width / 2, Room.Height / 2);
myCam.SetAt(Room.Width - myCam.Width, Room.Height - myCam.Height);
// Wait a little (or play a cutscene, and so on)
Wait(100);
// Delete temporary camera and viewport
myCam.Delete();
myView.Delete();
See also: Viewport.Camera
, Viewport.Delete
, Screen.Viewport
, Screen.Viewports
void Viewport.Delete();
Removes an existing viewport. This also removes this viewport's pointer from Screen.Viewports
array.
It's always safe to delete a viewport, even if it's the last viewport remaining: in such case the room will simply be not displayed on screen. You may create another viewport later and make the room show up again.
IMPORTANT: in Screen.Viewports array viewports are arranged in the order they were created. When you delete one in the middle all the following viewports will be shifted towards beginning of array.
See also: Viewport.Create
, Screen.Viewport
, Screen.Viewports
static Viewport* Viewport.GetAtScreenXY(int x, int y)
Finds if there's any viewport at the specified screen coordinates and returns the topmost one. Hidden viewports will not be tested, but those without camera will still be. If no viewport was found under provided coordinates then this function returns null.
Example:
Viewport* view = Viewport.GetAtScreenXY(mouse.x, mouse.y);
if (view != null)
{
view.Visible = false;
Wait(1);
view.Visible = true;
}
will find a viewport under the mouse cursor, and if there's one then make it "blink".
Point* Viewport.RoomToScreenPoint(int roomx, int roomy, bool clipViewport = true);
Returns the point on screen corresponding to the given room coordinates if seen through this viewport. Resulting Point struct will contain screen x and y coordinates.
Function does the conversion from room to screen's coordinate system, correctly taking into account viewport's position on screen, camera's position in the room and its transformation (scaling etc).
If clipViewport is true then this function will only return a point if given room coordinates are currently seen inside viewport and return null otherwise. If clipViewport is false then viewport's bounds will be ignored.
Example:
Point* pt = myViewport.RoomToScreenPoint(player.x, player.y);
if (pt != null) {
Display("Player character is displayed at (%d, %d) on screen.", pt.x, pt.y);
} else {
Display("Player character is currently offscreen.");
}
See also: Viewport.ScreenToRoomPoint
, Screen.RoomToScreenPoint
, Screen.ScreenToRoomPoint
void Viewport.SetPosition(int x, int y, int width, int height);
Changes viewport's position on the screen. Offscreen positons are valid, if a viewport is entirely offscreen it will simply not be drawn.
Example 1:
// Set the primary viewport to half the screen size, aligned in the center.
Screen.Viewport.SetPosition(Screen.Width / 4, Screen.Height / 4, Screen.Width / 2, Screen.Height / 2);
Example 2:
// Shrink the viewport towards the center of the screen,
// and then enlarge it back, while keeping the aspect ratio.
int w = Screen.Viewport.Width;
int h = Screen.Viewport.Height;
float aspect_ratio = IntToFloat(h) / IntToFloat(w);
while (h > Screen.Height / 4)
{
w -= 2;
h = FloatToInt(IntToFloat(w) * aspect_ratio, eRoundNearest);
Screen.Viewport.SetPosition((Screen.Width - w) / 2, (Screen.Height - h) / 2, w, h);
Wait(1);
}
Wait(60);
while (h < Screen.Height)
{
w += 2;
h = FloatToInt(IntToFloat(w) * aspect_ratio, eRoundNearest);
Screen.Viewport.SetPosition((Screen.Width - w) / 2, (Screen.Height - h) / 2, w, h);
Wait(1);
}
See also: Viewport.X
, Viewport.Y
, Viewport.Width
, Viewport.Height
, Viewport.ZOrder
, Screen.AutoSizeViewportOnRoomLoad
Point* Viewport.ScreenToRoomPoint(int scrx, int scry, optional bool clipViewport);
Returns the point in room corresponding to the given screen coordinates if seen through this viewport. Resulting Point struct will contain room x and y coordinates.
Function does the conversion from screen to room's coordinate system, correctly taking into account viewport's location on screen, camera's position in the room and its transformation (scaling etc).
If clipViewport is false then viewport's bounds will be ignored and this function returns valid point all the time. If it is true then this function will only return a point if given screen coordinates are inside viewport's rectangle and return null otherwise. The default is false.
Example:
Point* pt = myViewport.ScreenToRoomPoint(mouse.x, mouse.y, true);
if (pt != null) {
Display("Mouse cursor is over room location: (%d, %d).", pt.x, pt.y);
} else {
Display("Mouse cursor is currently outside the viewport.");
}
See also: Viewport.RoomToScreenPoint
, Screen.RoomToScreenPoint
, Screen.ScreenToRoomPoint
Camera *Viewport.Camera;
Gets/sets the camera to be displayed in this viewport. Changing cameras is safe anytime, and the looks inside viewport will be changed during next drawing frame.
Setting Viewport.Camera to null will make an empty viewport, which does not display anything.
Example:
Camera* myCam = Camera.Create();
myCam.SetSize(Room.Width / 2, Room.Height / 2);
Screen.Viewport.Camera = myCam;
Will create a new camera, half of the room's size, and assign it to the primary viewport.
See also: Camera.Create
, Game.Camera
, Game.Cameras
int Viewport.Height;
Gets/sets the viewport's height in screen coordinates.
See also: Viewport.SetPosition
, Viewport.X
, Viewport.Y
, Viewport.Width
, Viewport.ZOrder
, Screen.AutoSizeViewportOnRoomLoad
bool Viewport.Visible;
Gets/sets whether the viewport is enabled and drawn on screen.
int Viewport.Width;
Gets/sets the viewport's width in screen coordinates.
See also: Viewport.SetPosition
, Viewport.X
, Viewport.Y
, Viewport.Height
, Viewport.ZOrder
, Screen.AutoSizeViewportOnRoomLoad
int Viewport.X;
Gets/sets the X position on the screen where this viewport is located.
Example:
while (Screen.Viewport.X < Screen.Width)
{
Screen.Viewport.X += 1;
Wait(1);
}
will pan viewport right until it's completely offscreen.
See also: Viewport.SetPosition
, Viewport.Y
, Viewport.Width
, Viewport.Height
, Viewport.ZOrder
, Screen.AutoSizeViewportOnRoomLoad
int Viewport.Y;
Gets/sets the Y position on the screen where this viewport is located.
Example:
while (Screen.Viewport.Y < Screen.Height)
{
Screen.Viewport.Y += 1;
Wait(1);
}
will pan viewport down until it's completely offscreen.
See also: Viewport.SetPosition
, Viewport.X
, Viewport.Width
, Viewport.Height
, Viewport.ZOrder
, Screen.AutoSizeViewportOnRoomLoad
int Viewport.ZOrder;
Gets/sets the viewport's z-order relative to other viewports. This will be taken into account if multiple viewports overlap to define which should be displayed above and which below.
The z-order is an arbitrary number and only have meaning in comparison with other viewport's setting. The lower value puts viewport to the back and higher value to the top.
IMPORTANT: If two or more Viewports have equal ZOrder, their draw order is undefined, and should not be relied upon. This is because of how draw sort is done in the engine.
Example:
Viewport* myView = Viewport.Create();
myView.ZOrder = Screen.Viewport.ZOrder + 1;
will create a new viewport and place is on top of the primary one.
See also: Viewport.SetPosition
, Viewport.X
, Viewport.Y
, Viewport.Width
, Viewport.Height
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