I'm a doctor, not a mechanic
Difference between revisions of "UE3:Mapping for Jailbreak (UT3)"
(→Concepts: added content) |
(→Reference: added actors) |
||
Line 83: | Line 83: | ||
==Reference== | ==Reference== | ||
+ | {{expand}} | ||
===Jailbreak-specific actors=== | ===Jailbreak-specific actors=== | ||
+ | |||
+ | ====JBExecution==== | ||
+ | A helper actor for execution sequences. The various subclasses provide more specific executions, like depresurization or burning. | ||
+ | |||
+ | ====JBInfoEscapeRoute==== | ||
+ | Info actor for alternate escape routes. Works exactly like a JBInfoJail. | ||
+ | |||
+ | ====JBInfoJail==== | ||
+ | Info actor for jails. See [[#Jail setup|Jail setup]] for details on using it. | ||
+ | |||
+ | ====JBJumpPad==== | ||
+ | A jumppad that can be Kismet toggled and optionally made team-specific. | ||
+ | |||
+ | ====JBObjectiveRelease==== | ||
+ | The release switch. There are subclasses for neutral, blue and red switches. See [[#Release setup|Release setup]] for details on using them. | ||
+ | |||
+ | ====JBTeleporter==== | ||
+ | A teleporter that can be Kismet toggled and optionally made team-specific. | ||
+ | |||
+ | ====JBTurret==== | ||
+ | An automatic turret. | ||
+ | |||
+ | ====JBVehicleFactory_NighShade==== | ||
+ | Spawns a special version of the [[liandri:Nightshade|Nightshade]] that can deploy an X-Ray Field instead of Spidermine Traps. | ||
+ | |||
+ | ====JBVehicleFactory_StealthBender==== | ||
+ | Spawns a special version of the [[liandri:Stealthbender|Stealthbender]] that can deploy an EMP Mine instead of Spidermine Traps. | ||
+ | |||
+ | ===Jailbreak-specific volumes=== | ||
+ | ====JBKillZVolume==== | ||
+ | A [[UE3:KillZVolume (UT3)|KillZVolume]] that only affects specific classes. | ||
+ | |||
+ | ====JBLadderVolume==== | ||
+ | A [[UE3:LadderVolume (UT3)|LadderVolume]] that allows the mapper to modify the ladder direction. | ||
+ | |||
+ | ====JBSlowVolume==== | ||
+ | A permanent version of the [[liandri:Slow Field|Slow Field]], but without the green cube visuals. (It's up to the mapper to provide visual effects.) | ||
+ | |||
+ | ====JBVolumeJail==== | ||
+ | This volume ''does not'' define a jail area, but is a [[#JBVolumeTransportRestriction|JBVolumeTransportRestriction ]] preconfigured for use as a jail-defining volume. There's also a dynamic version of this volume that can be attached to InterpActors. | ||
+ | |||
+ | ====JBVolumeTransportRestriction==== | ||
+ | Imposes certain restrictions on players inside this volume. The restrictions are configurable and include: | ||
+ | * using the Hoverboard | ||
+ | * throwing Translocator discs while in the volume | ||
+ | * translocating while in the volume | ||
+ | * translocating to a disc in the volume | ||
+ | * transforming into a Titan or Behemoth | ||
+ | Players from one team can be excluded from these restrictions and the restrictions can be turned off entirely via Kismet Toggle. There's also a dynamic version of this volume that can be attached to InterpActors. | ||
+ | |||
+ | ====JBVolumeTunnelExit==== | ||
+ | Normally players can't fall off ledges while walking or crouching. This volume removes that feature in this area and thus allows players to exit low tunnels while crouching. | ||
+ | |||
+ | ====JBXRayVolume==== | ||
+ | A permanent version of the [[liandri:X-Ray Field|X-Ray Field]], but without the inverted vision effect. (It's up to the mapper to provide visual effects.) | ||
+ | |||
===Jailbreak-specific Kismet objects=== | ===Jailbreak-specific Kismet objects=== | ||
[[Category:Mapping tutorials|Jailbreak UT3 Mapping]] | [[Category:Mapping tutorials|Jailbreak UT3 Mapping]] |
Revision as of 12:20, 7 September 2009
This article gives a short overview about how to create maps for the custom UT3 gametype Jailbreak.
Please help improve this article or section by expanding it. |
Contents
Getting started
Before you start diving into the editor, get the latest version of UT3 Jailbreak first. (See sticky release threads for the download link.) You'll be needing actors and Kismet objects from the Jailbreak.u and JailbreakContent.u packages (and possibly from JailbreakTitanContent.u as well, depending on your map) to set up Jailbreak-specific things in your map. To load them automatically, open your UTEditor.ini (MyDocs\MyGames\UT3\UTGame\Config), find the [ModPackages]
section and add the following lines to it:
ModPackages=Jailbreak ModPackages=JailbreakContent ModPackages=JailbreakTitanContent
Now you can open the editor and map right away. See Spoondog's Guide to Mapping for Jailbreak for general considerations about Jailbreak maps, but keep in mind that it was written for JB2004.
As always in UT3 it's probably better to start out additive, i.e. with an empty world, because it saves you a lot of time when rebuilding lighting. If your Jailbreak map is going to be indoor, just add a cube of about the size your map will be and start subtracting from that. The first thing you should probably do when you start a new Jailbreak map is setting up the map info:
- Open View -> World Properties.
- Open the group WorldInfo, find the property MyMapInfo and click the blue triangle button.
- Select JBMapInfo from the pop-up menu. If it isn't listed, make sure you have loaded the Jailbreak package. (You can do so from the Actor Classes browser.)
In addition to the usual UTMapInfo properties for the radar map, music and level descriptions, the JBMapInfo also has some gameplay-related properties:
- Execution group
-
- ExecutionFallbackDelay
- Maximum time in seconds players are allowed to live during the execution sequence before they will definitely be killed by the game.
- JBMapInfo group
-
- bDarkMatch
- Whether "darkmatch" rules should be applied to the map. That means, players do not have any ambient glow and the area immediately surrounding your view is lit up a bit. Play DM-DarkMatch to get a feel for this mode.
- bStartWithLockerWeaps
- Whether free players should start with the weapons from the nearest weapon locker, like in VCTF or Warfare. Jailed players always only start with default weapons.
- TransportationDevice group
- See Transportation settings below for details.
- CustomTranslocatorClass
- An Inventory class to replace the Translocator on this map. If specified, and the game determines that the Translocator should be used, this inventory class is given to the player instead.
- DefaultTransportationDevice
- The default transportation device (Translocator or Hoverboard) to give players in this map. If Translocator and Hoverboard are both allowed (i.e. none of the "No Translocator/Hoverboard" mutators are in use), this property also tells which of the two to prefer.
- SupportedTransportationDevice
- What transportation devices are allowed on this map at all. Unsupported devices can't be forced, but if both are supported and forced (i.e. the "Force Translocator/Hoverboard" mutators are both in use), this property specifies which one to use.
Note that darkmatch, locker weapons and transportation settings are also available for arenas and will override the map settings there.
Jailbreak's music manager works a bit differently than the default UT3 music manager, so the standard music arrangements might not work as nicely for Jailbreak. No need to worry though, as there are custom arrangements of the stock music in the JailbreakMusicArrangements package.
Concepts
A classic Jailbreak map contains two bases, each with a release switch and a spawn area for one team, and two jails, each with player starts for one team. Jail locations are a frequent reason for debate, as they could be in the team's own base (not very realistic), in the enemy base (may cause "base swap", i.e. all players are in their respective enemy base and it's difficult to gain control over the own base again) or on neutral ground. The latter is usually the preferred way to do it because released players will not immediately gain control over either base.
The classic layout goes back to the UT version of Jailbreak, where only one switch per team was really supported and jail areas had to be assigned to a specific team. UT3 Jailbreak has come a long way since then. There can be more than one release switch per team, switches can change team ownership and even be neutral or disabled. Similarly, jail areas can contain player starts for both teams, allowing "shared jails" that can have separate exits for the two teams. Prisoners of both teams can't attack each other unless they pull out a melee weapon. This kind of jail fight is also allowed between players of the same team without penalty.
Jail setup
Jail areas are defined with volumes associated to a JBInfoJail, a subclass of Info. Any kind of volume can be used, but the preferred type is JBVolumeJail, because it prevents players from using the Translocator to escape. The names of the volumes can be entered in the JailVolumes list of the JBInfoJail, but a much easier way is to use Kismet. The JBInfoJail actor has a Kismet event called Jail Status, which controls most of the jail functionality. That Jail Status event can be used to assign volumes to the jail as well.
Jails are not owned by any team directly. To ensure only players of one team are put in a jail, simply place UTPlayerStarts for that specific team inside any of the volumes assigned to the JBInfoJail. There's a property called bReleasesBothTeams in JBInfoJail that should have the value True in most cases. Only set it to False if your jail prevents the opposite team from leaving this jail, for example if you have a shared jail with separate exits for both teams. Keep in mind that regular jails allow people to walk in while the door is open. Such jails, even though designed to only contain one team's players, should allow the enemy player to get out as well while the jail is open.
Release setup
Jails are opened by release switches, subclasses of UTGameObjective >> JBObjectiveRelease. The jails a release switch opens can be specified either by adding the JBInfoJail's Tag value to the JailTags list of the switch actor or in Kismet by linking the corresponding Jail Status events to the Jails connector of the release switch's Release event. It is recommended to set the value of the Jail Status property ReleasingTeam to 0 (red) or 1 (blue) so the game knows which team to open the jail for, especially if it's a neutral switch.
Jails will automatically monitor whether they are currently open and for which team. For this to work, the mapper needs to specify navigation points that act as jail exits via the Jail Doors connector of the Jail Status event. when the jail is closed, the navigation point must be blocked. Each jail door point must either be outside the jail volumes or must have a direct connection to a navigation point outside the jail volume. Almost all navigation point types support toggling of their blocked status, but only few make sense as jail door. The most obvious choice would be the DoorMarker of an InterpActor used as jail door. Other options include the JBJumpPad and the various JBTeleporter versions.
To start the mechanism that eventually allows players to leave the jail area, use the Activated output connector of the Jail Status event. This event should open the door or enable the teleporter, jumppad, lift or whatever else your jail uses. The Opened output of the Jail Status will activate once the first jail door navigation point is unblocked and the Closed output activates when the last jail door navigation point is blocked again. If you have multiple jail doors, make sure they are opened in a way that during the entire release (first open to last close) there is always at least one unblocked jail door navigation point, otherwise you may confuse the release mechanism.
Execution setup
When all players of a single team are captured, the Start execution output of all Execution events is activated. The execution script should take care of killing captured prisoners in all jails. The execution sequence should activate an execution camera via the Set execution camera action. Players of the capturing team, spectators and dead players of the captured team will be viewing the execution through the specified camera actor. This camera can be animated via Matinee and Set execution camera can be used throughout the entire execution sequence to switch to a different camera.
If your execution script should not end right when all players are dead, use the End of execution action to explicitly specify the end of your script. Note however, that if you use End of execution anywhere in your script, it must always be used to signal the end of the execution script. Also be sure to set the ExecutionFallbackDelay in your JBMapInfo to a value that won't interfere with your execution script. Be generous with the time margin here, a weird online bug on an early version of JB-Pagoda was caused by the fallback execution (players just falling over) kicking in at approximately the same time as the execution script trying to gib players.
Arena setup
Arenas are almost entirely set up in Kismet via the Arena Fight event. The only thing you need to place in the map are the arena PlayerStarts. To make things interesting, arenas can be integrated into the main area of the map, like it is done on JB-FacingWorlds. It is common practice to have the arena area completely separated from everything else, though. JB-Gasoline, for example, has a separate arena room that is neither visible nor reachable in any way from the main playing area. Arena winners and losers can be respawned as special startspots that don't necessarily have to be PlayerStarts.
UT3 Jailbreak not only supports one-on-one deathmatch arenas, but also x-on-x team deathmatch arenas and "challenge" arenas where killing the opponents isn't the primary goal. Challenge arenas might also be for one team only, with your only enemy being the arena timer. Challenge arenas could be anything from a race track to an obstacle course. A one-team challenge could e.g. be used to activate an alternate escape route for the remaining players in jail.
Arena fights aren't started automatically, but should be activated via a Kismet script. Use the Schedule arena fight action to let the game find players for an arena fight and start the fight after a short countdown. You can use the Request arena fight and Ignore for arena fight actions to let players volunteer for or opt out from being selected for an arena fight respectively. To cancel a scheduled arena fight during the start countdown, use the Cancel arena fight action. To end an arena fight in progress, especially for declaring the winner of a challenge arena, use the End of arena fight action.
For arenas involving certain powerups, it might be a good idea to ensure those are available when the arena fight starts. You can use the Respawn pickup action to ensure a pickup is available.
Alternate escapes
Instead of (or in addition to) arena fights, a mapper might include an alternate escape route for the jails. This feature must be well-balanced or it can make a map unplayable because either team can capture the opponent. Therefore activating or using alternate escapes should be made sufficiently difficult or expensive. Ideally an escape route is shut down during execution and any players inside should be executed as well.
For example, JB-FacingWorlds has a second jumppad exit, but that one can only be activated by doing a Titan melee attack on the titan pad inside the jail/arena tower. Activating it and using the jumppad to escape is relatively easy, but the player activating the alternate escape is killed and usually doesn't have enough time to reach the jumppad because the titan explosion is in the way. The balance here is that the escape requires you to spend a whole Titan transformation and that it's extremely difficult to use it to release yourself. And of course it is only available if the Titan mutator is active.
Other alternate escapes might require prisoners to form a human ladder. In Jailbreak players can stand on each others' shoulders to reach a small hole in the wall that can only be entered when the player is crouched. You can only crouch while standing on something, so a human ladder is the only way to get into the escape route.
The escape route itself should be set up like a jail area, but with a JBInfoEscape instead of a JBInfoJail. The JBInfoEscape's Tag should be added to the JBInfoJail's EscapeRouteTags so the game knows how the escape is connected. Like regular jails, escape routes might have to be opened in order for players to escape. If a JBObjectiveRelease (with bIsPrimaryRelease set to False) is used to perform this activation, the activating player is remembered as assister. Similarly, any players forming a human ladder to help a player enter an escape route are remembered as assisters as well. If a player manages to reach freedom, any assisting players score a point and receive one hero point.
Transportation settings
Unlike the artificial separation between CTF and VCTF, Jailbreak is a single vehicle-supporting gametype where the mapper decides whether to include vehicles or not. Matching this philosophy, Jailbreak also allows the mapper to decide whether to give players a Translocator like in CTF and a Hoverboard like in VCTF, but this mapper decision isn't set in stone. The "transportation device" settings can be a bit confusing at first, but they actually provide a great amount of flexibility to the mapper and the player or server admin.
Mappers are encouraged to always support both transportation devices, even if the map will be using only one or neither of them by default. Maps with a default transportation device should also stay playable if the player decides to play with both devices disabled. That means it should be possible to reach the release switches and exit jails without a Translocator or Hoverboard. If an arena definitely won't work at all without a specific transportation device, you can either set that device as required for the arena or disable the arena if the transportation device is not available.
In addition to the default "No Translocator" mutator included in UT3, Jailbreak also provides a "No Hoverboard" mutator (which could also be used in VCTF or Warfare) and the "Force Hoverboard/Translocator" mutators, which only really work in Jailbreak. These four mutators interact with the map's (or arena's) transportation settings in a well-defined (and hopefully obvious) way. A transportation device is "available" if the corresponding "No" mutator isn't used and a device is "forced" if the corresponding "Force" mutator is active.
- If an arena requires a specific device, it will ignore the default and supported device settings and the four mutators.
- Conflicts between the supported devices and default devices settings (i.e. a device is specified as default, but is not supported) are resolved in favor of the supported devices.
- Unsupported devices cannot be forced via mutator.
- If both devices are supported, forcing either of them will enable that device even if the default device setting would prefer the other device if both are available.
For the special case when both devices are forced, the supported device setting has the options "Both (prefer Translocator if forced)" and "Both (prefer Hoverboard if forced)" to let the mapper resolve this ambiguity.
Reference
Please help improve this article or section by expanding it. |
Jailbreak-specific actors
JBExecution
A helper actor for execution sequences. The various subclasses provide more specific executions, like depresurization or burning.
JBInfoEscapeRoute
Info actor for alternate escape routes. Works exactly like a JBInfoJail.
JBInfoJail
Info actor for jails. See Jail setup for details on using it.
JBJumpPad
A jumppad that can be Kismet toggled and optionally made team-specific.
JBObjectiveRelease
The release switch. There are subclasses for neutral, blue and red switches. See Release setup for details on using them.
JBTeleporter
A teleporter that can be Kismet toggled and optionally made team-specific.
JBTurret
An automatic turret.
JBVehicleFactory_NighShade
Spawns a special version of the Nightshade that can deploy an X-Ray Field instead of Spidermine Traps.
JBVehicleFactory_StealthBender
Spawns a special version of the Stealthbender that can deploy an EMP Mine instead of Spidermine Traps.
Jailbreak-specific volumes
JBKillZVolume
A KillZVolume that only affects specific classes.
JBLadderVolume
A LadderVolume that allows the mapper to modify the ladder direction.
JBSlowVolume
A permanent version of the Slow Field, but without the green cube visuals. (It's up to the mapper to provide visual effects.)
JBVolumeJail
This volume does not define a jail area, but is a JBVolumeTransportRestriction preconfigured for use as a jail-defining volume. There's also a dynamic version of this volume that can be attached to InterpActors.
JBVolumeTransportRestriction
Imposes certain restrictions on players inside this volume. The restrictions are configurable and include:
- using the Hoverboard
- throwing Translocator discs while in the volume
- translocating while in the volume
- translocating to a disc in the volume
- transforming into a Titan or Behemoth
Players from one team can be excluded from these restrictions and the restrictions can be turned off entirely via Kismet Toggle. There's also a dynamic version of this volume that can be attached to InterpActors.
JBVolumeTunnelExit
Normally players can't fall off ledges while walking or crouching. This volume removes that feature in this area and thus allows players to exit low tunnels while crouching.
JBXRayVolume
A permanent version of the X-Ray Field, but without the inverted vision effect. (It's up to the mapper to provide visual effects.)