Skip to content

Latest commit

 

History

History
103 lines (70 loc) · 6.75 KB

README.MD

File metadata and controls

103 lines (70 loc) · 6.75 KB

Raf's MapVote

Logo

What is it?

Raf's MapVote is a server addon for Garry's Mod that allows players to vote for the next map to be played. This addon is specifically tailored for the Trouble in Terrorist Town (TTT) gamemode, but includes admin commands to be manually started with any gamemode. Steam Workshop page

Logo

Why?

The inspiration to create my own mapvote addon came from the flaws of other mapvote addons available in the Steam Community Workshop. Mainly:

  • The sheer amount of candidate maps. This leads to candidates receiving a maximum of 3-4 votes (depending on the server player count) and most of the candidates not receiving any votes at all, making voting not very competitive.
  • The candidates are often chosen randomly.
  • The UI isn't very pleasing to look at.

Features

  • Keeps track of how many times each map has been played.
  • Ability to choose specific maps to be in the mapvote rotation or use all the maps located on the server, with the ability to filter them by prefix (e.g. ttt_, cs_").
  • A static number of candidate maps (6). Candidates maps consist of 3 "popular" maps and 3 random maps. "Popular" maps have the highest play count on the current server. There's also a "random" button for the indecisive.
  • And "extend" button to vote for extending the current map.
  • Cooldown system. After a map has been played, it won't show up as a candidate for a number of maps (configurable).
  • Ability to use map thumbnails from other addons (e.g. ttt_map_icons) or insert a custom image for each map (this option would require to force the clients to download the image as well).
  • Rock the vote implementation, to skip a map, if the majority (configurable) votes to do so.
  • A map pool screen, that any player can open by typing "!rmvpool". This shows the maps currently included in the map pool, as well as tagging maps on cooldown.
  • Darkmode/lightmode color schemes that are saved as a convar "rmv_lightmode 1/0".
  • Admin console command "rmv_start" to manually start the mapvote.
  • ULX integration - ability for admins to manually start the mapvote with the "ulx rmvstart" command or through the graphical menu.

Config

The config file is automatically generated after running the server once with the addond installed in "garrysmod/data/rafsmapvote/config_rafs_mapvote.json".

  • MAPS : ["cs_office", "ttt_67thway_v3"] - Custom map pool. If left empty, will use every map on the server, taking into account the given map prefixes. If setting a custom map pool, you should always have at least 6 + MAP_COOLDOWN amount of maps in the map pool, to avoid potential issues.
  • MAP_PREFIX : ["ttt_", "cs_"] - Filters the map pool with the given prefixes.
  • MAP_COOLDOWN : 5 - Map changes before a recently played map can be as mapvote candidate.
  • TIMER : 45 - Vote time in seconds.
  • NO_VOTE_TO_RANDOM : true - If a player doesn't vote, does it vote go to a random candidate.
  • RTV_MIN : 3 - Minimal player count on the server, for RTV to be enabled.
  • RTV_TIME : 300 - Time in seconds after which RTV is enabled.
  • RTV_PERCENT: 0.6 - Percentage of players needed to RTV.
  • DATA_DIR : "rafsmapvote/" - Data directory. You shouldn't change this.
  • THUMBNAIL_DIR : "rafsmapvote/thumbnails" - Directory to place your custom thumbnails, they should with the filename ttt_mapname.jpg/.png. If placing images here, you are responsible for sending them to the client.
  • FORCE_VOTE_USER_GROUPS: ["superadmin"], ["admin"] - Roles that can force the mapvote by using the "rmv_start" console command.If using ULX, you should prefer to use the appropriate ULX command and setup permissions there.

Thumbnail icons are prioritized as follows:

  1. Custom .png or .jpg files under THUMBNAIL_DIR (e.g. data/rafsmapvote/thumbnails/ttt_MAPNAME.jpg)
  2. Map thumbnails in maps/thumb/ (this also usually includes addons like ttt_map_icons)
  3. Defaults to "no map preview" image

Installation

It is preferred to install the addon using the Steam Workshop.

If hosting a local server, you and your friends should have the addon installed through the Steam Workshop. If hosting a dedicated server you have to:

  • Add the addon to your servers workshop collection
  • Add the addon workshop ID manually in /garrysmod/lua/autorun/server/workshop.lua with resource.AddWorkshop("2894778408")

This will make all clients download the addon automatically through the Steam Workshop.

It is also possible to download this repo (check releases) and place it in your server's addons/ directory but you are then responsible for sending the custom thumbnails.

It is also recommended to install a Map Icon pack like the one made by Kirays. However, keep in mind that Raf's MapVote uses landscape images, and most of the Map Icon packs are small square images, causing them to look a bit low-res. This should inspire you to create your own Map Icon pack with landscape images and share them with everyone :)

If installed correctly, there should be a console splash screen when starting the server. Afterwards, you should probably change the config to your liking.

Chat commands

  • !rmvlist, !mappool, !rmvpool - Opens a map list window where the player can view the current server map pool.
  • !rtv - Vote to rock the vote.
  • !rmv [duration] [noVotesToRandomVotes] - Force starts the mapvote through ULX (ULX custom permissions apply).

Console commands

  • rmv_lightmode 0/1 - Toggles the "light mode" color scheme.
  • rmv_start - Force starts the mapVote, if player is under a FORCE_VOTE_USER_GROUPS (config) player group.
  • ulx rmvstart [duration] [noVotesToRandomVotes] - Force starts the mapvote through ULX (ULX custom permissions apply).

Links

Steam Workshop

Adding a server workshop collection

TTT map icon pack by Kirays

Icons used

Notes

This addon does not work in single player (and makes no sense to do so).

Licence

Feel free to use and modify the code to your own liking, following the guidelines of the MIT licence.