Camera
Overview
The camera is a rectangular shape that determines the visible part of the map. There is always exactly one camera on the current map. The camera is automatically created by the engine when loading a map. You cannot create or remove it. To access the camera of the map from one of your scripts, you can use map:get_camera().
The camera can work in two states. It can be either centered on an entity and track it automatically, or it can be controlled manually by your scripts or by the engine.
When a map starts, its camera is initially set to track the hero.
Use camera:start_manual() to switch to manual state, and camera:start_tracking() to switch to tracking state. Starting a movement on the camera also switches it to manual state.
Movements and constraints
Separators and map limits are obstacles for the camera.
It means that if the camera is close to a separator or to a limit of the map, its movement stops as you would expect, independently of its state.
Remember however that obstacles can be explicitly ignored with movement:set_ignore_obstacles(true). For a camera, it means that you can ignore separators and even map limits if you want. Parts of the camera that are outside the map are displayed with the background color of the tileset.
Camera size
By default, the size of the camera is the quest size, meaning that the camera occupies the whole screen.
It is possible to set a smaller size to the camera, in order to show the map only on a subpart of the screen. You can then use the rest of the screen to display some information like a HUD. Use camera:set_size() and camera:set_position_on_screen() to indicate the exact subpart of the screen where you want the camera to be displayed.
Suspending the game
Moving the camera does not automatically suspends the game, except when it is scrolling on a separator in tracking state. You can call game:set_suspended() if you want the game to be suspended during your camera sequence. Note that unlike most entities, the camera can still move when the game is suspended.
Methods Inherited from map entity
A camera is a particular map entity. Therefore, it inherits all methods from the type map entity.
See entity to know these methods.
Methods of the type camera
The following methods are specific to cameras.
camera:get_position_on_screen()
Returns where the camera is displayed on the quest screen.
The default position is 0, 0, meaning that the upper left corner of the camera is displayed on the upper left corner of the screen.
- Return value 1 (number)
- X coordinate of the camera on the screen, in quest screen coordinates.
- Return value 2 (number)
- Y coordinate of the camera on the screen, in quest screen coordinates.
camera:set_position_on_screen(x, y)
Sets where the camera is displayed on the quest screen.
You can use this function in conjunction with camera:set_size() to display the camera only on a subpart of the screen and for example keep the rest of the space for the HUD.
The default position is 0, 0, meaning that the upper left corner of the camera is displayed on the upper left corner of the screen.
- x(number)
- X coordinate of the camera on the screen, in quest screen coordinates.
- y(number)
- Y coordinate of the camera on the screen, in quest screen coordinates.
camera:get_position_to_track(entity), camera:get_position_to_track(x, y)
Returns the coordinates this camera should have in order to track the given entity or point, respecting constraints of map limits and separators.
The returned coordinates make their best to have the entity or point centered in the camera, but make sure that the camera does not cross separators or map limits. This function can be used to compute legal coordinates for the camera, and for example pass them to camera:set_position() or start a movement.
To get coordinates that center the camera on a map entity:
- entity(entity)
- The entity to center the camera on.
To get coordinates that center the camera on a point:
- x(number)
- X coordinate of the point to center the camera on.
- y(number)
- Y coordinate of the point to center the camera on.
camera:get_state()
Returns the name of the current state of the camera.
- Return value (string)
- The current camera state: "tracking"or"manual".
camera:start_tracking(entity)
Switches the camera to tracking state.
The camera will be focused on an entity to track, and follow it when it moves.
When the tracked entity crosses a separator, the engine automatically starts a scrolling movement on the camera. The game is automatically suspended during the scrolling. After the scrolling, the camera continues to normally track the entity on the other side of the separator.
- entity(entity)
- The entity to track.
camera:get_tracked_entity()
Returns the entity currently tracked by this camera, if any.
- Return value (entity)
- The tracked entity if the camera is in tracking state, or nilif the camera is not in tracking state.
camera:start_manual()
Switches the camera to manual state.
Note
The camera automatically switches to manual state if you start a movement on it.
camera:get_surface()
Returns the surface this camera draws its content to.
The size of this surface is the size of the camera.
- Return value (surface)
- The camera's surface.
camera:set_viewport(x, y, w, h)
Sets the viewport of the camera, only has an effect if sol.video.set_geometry_mode() is set to "dynamic_quest_size" or "dynamic_absolute".
- x(nomber)
- Relative horizontal position of the viewport on screen [0, 1].
- y(number)
- Relative vertical position of the viewport on screen [0, 1].
- w(number)
- Relative width of the viewport on screen [0, 1].
- h(number)
- Relative height of the viewport on screen [0, 1].
camera:get_viewport(0)
Returns the viewport of the camera
- Return value 1 (number)
- Relative horizontal position of the viewport on screen [0, 1].
- Return value 2 (number)
- Relative vertical position of the viewport on screen [0, 1].
- Return value 3 (number)
- Relative width of the viewport on screen [0, 1].
- Return value 4 (number)
- Relative height of the viewport on screen [0, 1].
camera:set_zoom(zoomx, zoomy)
Sets the zoom factors of the camera. Values greater than 1 zoom in.
- zoomx(number)
- Scaling of the camera along x axis.
- zoomy(number)
- Scaling of the camera along y axis.
camera:get_zoom()
Gets the zoom factors of the camera.
- Return value 1 (number)
- Scaling of the camera along x axis.
- Return value 2 (number)
- Scaling of the camera along y axis.
camera:set_rotation(angle)
Sets the camera rotation around its center.
- angle(number)
- Rotation angle, positive is counter-clockwise.
camera:get_rotation(angle)
Gets the camera rotation around its center.
- Return value (number)
- Rotation angle, positive is counter-clockwise.
camera:teleport(map_id, destination_id)
Teleports the camera to another map and destination.
- map_id(string)
- Id of the map to teleport the camera into.
- destination_id(string)
- Name of the destination to place the camera on on arrival.
- transition_style(string)
- "immediate"(no transition effect),- "fade"(fade-out and fade-in effect) or- "scrolling". No value means- game:get_transition_style(), which is- "fade"by default.
Events inherited from map entity
Events are callback methods automatically called by the engine if you define them.
A camera is a particular map entity. Therefore, it inherits all events from the type map entity.
See entity to know these events.
Events of the type camera
The following events are specific to cameras.
camera:on_state_changing(state_name, next_state_name)
Called when the state of the camera is about to change.
- state_name(string)
- Name of the current state. See camera:get_state()for the list of possible state names.
- next_state_name(string)
- Name of the state about to start. See camera:get_state()for the list of possible state names.
camera:on_state_changed(new_state_name)
Called when the state of the camera has just changed.
- new_state_name(string)
- Name of the new state. See camera:get_state()for the list of possible state names.
Note
When the map starts, the initial state of the camera always "tracking", because the camera initially tracks the hero.