C'est très la source.
Development builds available for each commit on our Jenkins server.
This plugin is available on BukkitDev.
Please note, this README reflects the last development version. Some features listed here may not be in the version published on BukkitDev.
For available configuration, please see directly the configuration file.
- Manages an UHC match.
- Cancels any regeneration by food (just like
/gamerule naturalRegeneration false
).
- Creation/deletion of colored teams, with or without name. Spaces allowed in the names.
- Players can be added to a team, or not (solo mode supported).
- The names of the players can be colored, according to the team, in the chat.
- The teams can be registered in the config file, in game, or both.
- The teams are managed through commands (to allow the use of command blocks).
- You can set a maximum size for the teams (to be able to give players command blocks to join the teams, without manual check, as example).
- Manual teleportation spots set in the config, in game, or both.
- Automatic set of teleportation spots following various shapes:
random
,grid
orcircular
.
All these shapes come with a minimal distance between two points, and the spots can be generated with any center, in any world (default: the sender's world, centered on the spawn of this world). - You can remove a spawn point, or all.
- The teams (or players, if solo) are automatically teleported to a random teleportation spot.
- Two teleportation modes available:
- a “direct” one, all players are teleported in the same time;
- a “slow” one, the teams are teleported with a delay, and the game is launched after; useful for smaller servers.
- The players state is reset when they are teleported: inventory cleaned, max food and health, no XP, no potion effects...
- Some players can be marked as “spectators”: they are not teleported and not counted as a player.
- Before the teleportation:
- players can't build in the world (except with a permission/op mode);
- the time is frozen at noon;
- the mobs don't spawn;
- the players can't be damaged.
- After the teleportation:
- 30 seconds after, the players can be damaged; before they are invulnerable.
- Displayed match info with a custom title
- The health of the players is displayed in the
Tab
list. This can be disabled.
- Configurable duration of an episode.
- A timer is displayed on the left of the player's screen.
- The timer can be synchronized with a clock (enabled by default, avoid long episodes due to the lag) or simply decremented every second.
- The end of an episode is broadcast in the chat to all players.
- An episode can be shifted using
/uh shift
. - You can disable this feature.
- You can generate a wall around the map following the size of the map set in the config file, centered on the world' spawn point.
- The generated wall is made of two blocks: one replaces the “air-like” blocks and the trees, and the other replaces solid blocks. This is useful to have a glass wall without light gaps in the caverns.
- Illustrations:
(using the default configuration). - The generated wall can be either circular or squared.
- The players are blocked inside the wall, even if the wall is broken or not generated, if WorldBorder is present (automatic configuration of the plugin).
- The border can easily be set during the game with
/uh border set <diameter>
- To anticipate a new border size, a warning can be send to all players out of this future border with
/uh border warning <futureDiameter>
every 90 seconds (by default, you can change the delay in the config). - You can list the players outside a given border with
/uh border check <diameter>
; this command gives a very light info (list of players outside plus "far", "close" or "very close") because the administrator can play.
All these gameplay tweaks are optional — see the configuration file.
- The golden melon is crafted using a gold block instead of eight gold nuggets.
- When a player die, his head is dropped (pvp-only flag available); this head can be used to craft a golden apple.
- The craft is the same as the normal golden apple, with a head instead of an apple.
You can use a player head or a wither head, and configure these two crafts independently.
- You can configure the number of apples crafted, the type (normal or Notch apple), and if a lore is added (saying “Made from the fallen head of ThePlayer”).
- There is a way to remove the lore (because two golden apple with a different lore are not stackable), either in the config (lore not added) or using a craft:
- The craft is the same as the normal golden apple, with a head instead of an apple.
- You can configure the number of half-hearts healed by a golden apple, enchanted golden apple, and the same for “golden heads”, independantely.
- You can disable the enchanted golden apples.
- The enderpearl damages can be removed.
- The ghast tears can be replaced by gold, to make Regeneration potions uncraftable.
- The level-II potions can be disabled.
- The compass behavior can be changed.
- New craft: an ingredient in the center; four iron ingots like in the vanilla compass recipe; bone, gunpowder, rotten flesh and spider eye in the corners.
- The four loots in the corners can be in any configuration (semi-shapeless recipe).
- There are three different ingredients in the center, for three levels of difficulty.
Simple
: redstone dust (just like the vanilla compass).Medium
: ender pearl.Hard
: eye of ender.
- If a player right-click with a compass, the compass shows the nearest player (team excluded).
- This consumes a rotten flesh.
- New craft: an ingredient in the center; four iron ingots like in the vanilla compass recipe; bone, gunpowder, rotten flesh and spider eye in the corners.
- The Witch spawn can be disabled (either the natural one, or the spawn from a villagers struck by a lightning bolt).
- The time can be frozen to any hour (eternal day/night), or not.
- The “bad” weather (rain, thunder) can be disabled.
- The players can be kicked (and eventually banned) after their death, with a configurable delay.
- The killer can receive some XP (other-team-only flag available).
- Announcements:
- The death messages can be more visible (format can be set in the config, including color).
- A team-death message can be sent when an entire team is dead.
- A death sound can be played (by default, WITHER_SPAWN), or not.
- You can send a lightning strike (only an effect, not a “real” one) when a player die, at the location of his death point.
- You can add arbitrary countdowns in game, displayed in the scoreboard or hidden.
- The timers are added in one time; started in another. So you can prepare all timers before the game.
- Each timer come with a title, displayed in the scoreboard; this title can be in colors using Minecraft's color codes with
&
(e.g.&4
for dark red). - You can pause a timer, resume it after; if you freeze the entire game all timers are paused.
- Integration of WorldBorder, as said in the Border section.
- Integration of SpectatorPlus for the spectators' management, if the plugin is present.
- Dynmap integration
/uh heal <player> [half-hearts=20]
to heal a player to the exact number of hearts given. Avoid trying to find the good health effect level/duration, the id of the effect, etc./uh healall [half-hearts=20]
: the same, for all players, because Bukkit does not allow the use of the @a selector out of a command block.- You cannot kill a player with these commands.
- With
/uh resurrect <player>
, you can resurrect (and deban, if he was banned) a player killed by lag (or other bug). - With
/uh tpback <player>
, you can teleport a player back to his death location.
- The players can send a private message to their team
- Use
/t <message>
to send such a private message. - Use
/togglechat
to lock this team-chat and use it without/t
. - From the locked team-chat, you can use
/g <message>
if you want to send a message to the main (global) chat. - An administrator can use
/togglechat <team ...>
to enter into the private chat of another team.
- Use
- You can broadcast the winner(s) of the game in the chat and launch some fireworks; either automatically, after the last death, or using
/uh finish
. - You can display hardcore hearts instead of normal ones.
- Possible automatic respawn after a delay, to avoid the interrogation about “Can I respawn?” (the client thinks the server is in hardcore mode, and so displays an hardcore death screen).
- ProTips can be sent automatically, at the good moment, to the players. A sound can be added (default: high-pitched
NOTE_PLING
)
Currently, ProTips about the team-chat, the crafts and the startup invincibility are sent. - The commands can be accessed using permissions (see subsection below).
- Autocompletion everywhere.
- Fully translated into English, French and Portuguese.
- For developers:
- the game can be controlled through the GameManager (
UHPlugin.getGameManager()
); - the teams, using the TeamManager (
UHPlugin.getTeamManager()
); - the scoreboard, using the... ScoreboardManager, yes (
UHPlugin.getGameManager().getScoreboardManager()
); - the wall generator, using the
UHWallGenerator
class; - the border, through the BorderManager (
UHPlugin.getBorderManager()
); - the freezer, using the Freezer (...yes) (
UHPlugin.getFreezer()
).
- the game can be controlled through the GameManager (
- Compatible with Bukkit 1.7.9+.
- Lightweight (as much as possible).
Documentation available via /uh
.
You can see the documentation of a command with sub-commands by executing the command without subcommand.
Example: /uh team
for the documentation of the team command.
Legend: /uh command <required> [optional=default]
.
/uh start
: launches the game./uh start slow
: launches the game slowly, in two steps, for smaller servers./uh shift
: shifts an episode./uh team
: manages the teams (add/remove team, add/remove a player into a team, list, reset)./uh spawns
: manages the spawn points (add, generate, list, dump, remove, reset)./uh spec
: manages the startup spectators (aka players ignored by /uh start) (add, remove, list)./uh border
: manages the border (current, set, warning, check)/uh generatewalls
: generates the walls according to the configuration.
/uh heal <player> [half-hearts=20|±diff]
: heals a player to the number of half-hearts provided (default 20)./uh healall [half-hearts=20|±diff]
: heals all players instead of only one./uh resurrect <player>
: resurrects a player./uh tpback <player> [force]
: safely teleports back a player to his death point.
/uh freeze
: used to (un)freeze the entire game or some players./uh tp <team|spectators>
: teleports a team or the spectators to a given location./uh finish
: broadcasts the winner(s) of the game, and sends some fireworks!- Team-chat commands
/t <message>
: sends a private message to the entire team of the sender./togglechat
: toggles the chat between the main chat and the private team chat./togglechat <team ...>
: enters the private team chat of another team./g <message>
: sends a message to the main chat.
/uh about
: prints informations about the plugin and the translations.
uh.build
: allows an user to build before the beginning of the game. Default: operator.uh.teamchat.self
: allows an user to send a private message to his own team. Default: everyone.uh.teamchat.others
: allows an user to enter into the private chat of another team. Default: operator.uh.<command>
: allows an user to use the command/uh <command>
. Default: everyone foruh.about
, operator else.
If you don't want to bother with permissions: the operators can do anything; the non-ops, nothing (except play and use the team-chat with /t
, /togglechat
and /g
— not /togglechat <team ...>
).
Download the latest version in the “releases” section and put the downloaded JAR file into the plugins/
folder of your Minecraft server.
This plugin is not compatible with Minecraft 1.7.4; Minecraft 1.7.9+ is needed.
The plugin was tested and works with both CraftBukkit and Spigot.
You can also install these plugins:
- WorldBorder, for all border-check-related tasks;
- SpectatorPlus, if you want to enable a spectator mode for dead players;
- dynmap, because the plugin can display the spawn & death points on the map.
This plugin is needed for some options:
- ProtocolLib, for the hardcore hearts and the automatic respawn.
After the installation, I recommend you to:
- teleport yourself to 0,0 (in creative,
/tp 0 100 0
); - set the world spawn point here (
/setworldspawn
); - reload the server (for the plugin to take into account the change) (
/rl
); - pregenerate the entire world (WorldBorder is preconfigured, just execute
/wb fill
); - only after that, generate the wall (
/uh generatewalls
) (don't forget to configure the shape and the size in the config file before). Otherwise, holes will be formed in the wall when Minecraft will populate the terrain.
It's pretty simple.
-
Duplicate a language file in the
plugins/UHPlugin/i18n/
folder of your server.
Name the filelanguage_COUNTRY.yml
(like the other ones). -
Open the new language file with a text editor (like notepad, gedit, kate, vi, etc.) and translate the strings.
DON'T change the keys, only the strings after the comas.
Also, never use tabulations in these files, don't change the indentation and don't remove the quotes around the sentences. -
When the translation is done, open the
manifest.yml
file (in the same folder) and add the name of the new language file (without the.yml
) in the list:version: 1.0 languages: - en_US - fr_FR - language_COUNTRY
-
In the
config.yml
, change thelang
key to the name of the new language. That's all!
Also, send me the translation, so I can integrate it inside the plugin!
While translating, you will see some special keys, like {0}
or {blue}
.
These values are replaced by the plugin; see below.
-
{0}
,{1}
, etc.: these values will be replaced with specific values by the plugin, depending on the context.
Example: in this string:unfrozen: "{cst}You where unfrozen by {0}."
you can guess that
{0}
will be replaced by the name of the player who unfrozen the recipient of this message. -
{blue}
,{white}
, etc.: these values will be replaced with Minecraft color codes. Available colors/formatting codes:Color Color Color Color Color {black}
{darkblue}
{darkgreen}
{darkaqua}
{darkred}
{darkpurple}
{gold}
{gray}
{darkgray}
{blue}
{yellow}
{green}
{aqua}
{red}
{lightpurple}
{bold}
{strikethrough}
{underline}
{italic}
{obfuscated}
{white}
{reset}
-
{ce}
,{cc}
, etc.: these values will be replaced by standardized colors for specific actions.Code Signification Color {ce}
Error Red {ci}
Information White {cs}
Success Green {cst}
Status Dark gray {cc}
Command Gold
- This work is a fork of the KTP plugin made by @Azenet.
- Special thanks to @jonyroda97, for many interesting suggestions and Portuguese translation.
GPLv3. Voir le fichier LICENSE pour détails.