================================================================================ File: Readme.txt/htm Subject: ICE Author: jibe Email: jibe@planetquake.com Web: http://planetquake.com/ice Version: 1.0 Build Time: considerable...
If you have any comments, contributions, questions or suggestions, contact me via the address above. The ICE bot and ICER Launcher are original works, written from scratch by jibe. Copyright (c) jibe 1998 ================================================================================
CONTENTS
What's New in v1.0 What is ICE? Features Installation Requirements Starting the Game Right Now! ICE Files and Folders Maps & ICE Creating Route Tables How to Route a New Map Route Building Tips Route Table Commands Advanced Rote Table Commands ICE Commands ICE Bot Personalities Gameplay Deathmatch CTF Features in Deathmatch Teamplay Capture The Flag Advanced CTF Settings ICE CTF Strategy Dedicated Server Support Internet Play Other ICE Features Grapple Auto Grapple Bot Chat Bot Gloating Bot Stats Bot Velocity Modes of Play Advanced Information Management (AIM) Camera ChatCentre Welcome Banner Client Commands Human Invisibility Map Cycling Pausing the Game Radio Viewable Weapons Frequently Asked Questions - FAQ Credits Version History DISCLAIMER COPYRIGHT DISTRIBUTION
WHAT'S NEW IN VERSION ICE 1.0 - Please see below for detailed commands and info. ================================================================================
================================================================================
Note About ICER - the ICE Bot Launcher The ICE bot can be setup and run using ICER: the ICE bot Launcher, which can be found at the web address above. You do not have to use the launcher to get ICE up and running, but it might make things simpler...
================================================================================
What is ICE? The ICE Bot is a simulated player, capable of most human player behaviour within the Quake2 environment. ICE will play DeathMatch, CTF and it's own blend of Teamplay. You can use ICER: the ICE Bot Launcher to get ICE up and running quickly.
================================================================================
FEATURES * Human-like roaming ai. - Bots move directly between objectives, using only 'realistic' movements * Highly customisable, individual skill set: - Aggression - Agility - Accuracy - Cunning - Favourite Weapon * Melee skills include: - circle strafing - best weapon selection - target leading (anticipates enemy motion) - rocket dodging - crouching - rockets aimed at enemy feet - may pursue enemy until kill (if possible) * Uses all weapons / most items, including Grapple. * Create your own route-table for any map. * Dynamic skill - ICE bots can adjust their skill to give you a good game. * Map rotations. * Follow the bot action with ICE Camera. * Globally change bot skills with a single command. * Hazard avoidance. * Increasingly happy in water. Goes for air if necessary / able. * Supports Hentai's Viewable Weapons. * Supports Zoid's Threewave CTF 1.02 - option to use CTF features in Deathmatch (id, grapple, techs) *'Advanced' CTF strategy code includes: - Team ORDERS - available to humans & bots: + coordinated attacks on base + squadron forming, and leading to objective + retreats to base defence - Allocate ROLES to your teammembers + command certain players to guard the base + designate players to attack + choose members of the team to roam - Alternative team strategy screen which displays your colleagues' plans, actions and status * Custom Teamplay mode with: - Custom Teamplay scoreboard - Custom skins or ICE managed skins * Internet Play management: - Adjusts bot skills based on your connection quality - Configurable features such as + Weapon reload / fire speed + Weapon fire travel speed + Grapple Speed * Chat: Bots will threaten, welcome, gloat etc. All comments are customisable. * AutoGrapple - Allows use of grapple whilst firing another weapon. * ICE Modes of Play - Challenge Mode & Training variations on regular play.
================================================================================
REQUIREMENTS The registered version of id software's Quake2. v3.20 point release upgrade (although ICE should run on earlier versions AFTER 3.15). The ICE Bot currently runs only on the Win95/98/NT platforms. ICE supports Zoid's CTF and Hentai's Viewable Weapons. *If you wish to use ICE's CTF and Viewable Weapons features, then you must obtain the appropriate .pak files from their respective authors. See above for URLs. For info., ICE was written on an AMD K6 200 MHZ with 32 Meg Ram, and on that platform seems to handle decent numbers of bots just fine (ie up to 20 in DM, 14 in CTF)
================================================================================
INSTALLATION Unzip the files contained in ICE_xxxx.zip into your Quake2 directory. You MUST RESTORE PATHNAMES. (Winzip users select the "Use Folder Names" option when extracting. PKunzip users use the -d option.) After extracting, confirm successful installation by checking for the existence of the "ICE" folder within your Quake2 directory.
================================================================================
STARTING THE GAME RIGHT NOW! If you aren't using ICER: the ICE bot launcher, then start the ICE Bot by creating a shortcut to the file quake2.exe in your Quake2 folder. The shortcut should read:
quake2 +set game ICE +set deathmatch 1 +map <mapname>
You may specify other commands as detailed below, but this is sufficient to start up the ICE Bot.
Once inside the game, you can type at the console:
bnum xxx
where xxx is the number of bots you wish ICE to randomly choose and load (max 32 per command)
*or*
bload xxx xxx xxx...
where xxx is the name of any bot contained in the file bots.cfg (bots.cfg is stored in the ICE folder)
================================================================================
MAPS & THE ICE BOT The ICE Bot can play on any map, once a suitable route table exists to support it. Read the section below (ROUTE TABLES) for advice on using the ICE Bot in any map other than those detailed here.
ROUTE TABLES CONTAINED IN THIS RELEASE This release of the ICE Bot contains route tables for the following maps:
DM: Q2DM1 Q2DM2 Q2DM3 Q2DM4 Q2DM5 Q2DM6 Q2DM7 Q2DM8
Evilq2dm
CTF: Q2CTF1 Q2CTF2 Q2CTF3 Q2CTF4 Q2CTF5
starctf2
Read the section below (CREATING ROUTE TABLES) for advice on using the ICE Bot in any map other than those detailed above. ================================================================================
ICE BOT FILES/FOLDERS Everything used by ICE is contained in the ICE folder within your Quake2 directory. The .qit and .qrt files in the ROUTES subdirectory are generated by ICE, and should not be altered manually.
BOTS.CFG ...contains details about all the ICE Bots. You may, of course, add to and adjust the data in this text file (notepad.exe will do as an editor). YOU MUST, however, keep to the exact structure as detailed within the file itself. A replacement copy of BOTS.CFG is available from the ICE homepage.
LOADER.CFG ... is contained within the ICE folder, and CAN be read in each time the game starts, and each time there is a map change (depending on your run_loader setting - see below). You can populate this file with any ICE Bot 'console' commands as detailed in this file. Useful for loading bots in teams, etc. YOU MUST specify whether or not LOADER.CFG should be executed (using +set run_loader 0/1) as detailed below. Default is NOT to execute it. Remember that the ORDER of commands is important.. eg you must load a team ('team' command) before you can change it's skin ('teamskin' command). ================================================================================
ICE BOT PERSONALITIES ICE bots have a variety of personality traits, bad habits etc. which can all be set within BOTS.CFG, or by using ICER. These settings are:
Aggression How likely the bot is to start a fight. Agility How well the bot dodges, jumps, strafes, grapples. Accuracy From 'inaccurate' to 'oh so accurate' Cunning Brainpower. eg. Shall I attack, or get health and armour first? Favourite Weapon The weapon the bot will always aim to use first. Bear in mind that the most aggressive bot won't always win over the cunning bot who leaves the melee in search of health. Bear in mind also that the bot with highest aim accuracy and the railgun as a favourite weapon will almost ALWAYS win if he sees you first...
================================================================================
COMMANDS Note: Where applicable, commands are given for console and command line use. Where a 0/1 toggle is offered as the command argument, the first of the toggle options is the default if not specified. Eg in the case of '+set camera 1/0', camera will be enabled even if the variable is never set. Some commans MUST be run from the command line (ie before the game starts) Some commands are for Dedicated Servers (eg dedicated: sv red) but they usually work on the console in single player games.
command line: +set run_loader 0/1 console: run_loader 0/1
LOADER.CFG ... is contained within the ICE folder, and MAY be read in each time the game starts, and each time there is a map change. This command tells ICE whether or not to load the file. The file can contain any number of Console commands, an example might be:
Bload arc brag chog bot_dynamic 1 map_change 1 fraglimit 25
This will load the bots arc, brag & chog. Dynamic skill changing will be enabled, and the map will rotate every 25 frags. Note that map_change must be set to 1 or the maps in the maps.cfg file will not be used when rotating (instead the same map will just be reloaded).
console: bload xxx xxx xxx xxx... dedicated: sv bload xxx xxx xxx xxx...
For loading bots into the game. Where xxx is the name(s) of a bot contained within the bots.cfg file. Separate the bot names with a space.
console: bremove xxx xxx xxx xxx... [all] dedicated: sv bremove xxx xxx xxx xxx... [all]
For removing bots from the game. Where xxx is the name(s) of each bot you wish to remove. 'bremove all' will remove every bot.
console: bnum xxx dedicated: sv bnum xxx
where xxx is the number of bots you wish ICE to randomly choose and load. The maximum *per command* is 32. This just limits the loading traffic, you can add 10 lots of 32 if you wish (er, and you are running a Kray)
command line: +set bot_skill -2 -1 0 1 2 console: bot_skill -2 -1 0 1 2
You can alter the skill of all bots using the global bot_skill setting.
2 will INCREASE bot skills quite a lot. 1 will INCREASE all bot skills a little. 0 is normal. Bot skills are unchanged. -1 will DECREASE all bot skills a little. -2 will DECREASE bot skills quite a lot.
Values outside these ranges will have no effect. The default is 0
command line: +set bot_dynamic 0/1 console: bot_dynamic 0/1
NB: DeathMatch ONLY.
By allowing the bots to adjust their skills dynamically, ICE will try to provide the most balanced game for YOU. If, on the whole, you're whipping your opponents, the bots will try and make life harder for you. Alternatively, they will ease up if your score becomes embarrassing. If there is more than one human player in the game, bots will try to match the average human ability.
================================================================================
DEDICATED SERVER SUPPORT As of version 0.3, ICE can be run in the dedicated environment (using the '+set dedicated 1' argument on the quake2.exe command line, or by using ICER v0.2 and later) All bot loading and configuration commands MUST be run with the prefix 'sv '. Commands are:
sv bload sv bnum sv bremove sv red sv blue sv team sv teamskin
You ONLY need to use the 'sv ' prefix if you are running a dedicated server, but the commands are also valid in the non-dedicated environment. Clients MUST still use the standard command WITHOUT 'sv ', and client_commands must be enable for this.
Manually added loader.cfg commands should usually employ 'sv ' format just in case. (ICER v0.2 and later uses sv format)
TIPS
For maximum server control, run a dedicated server and then connect to it yourself, as opposed to running a regular game and having other join your game. Then disable 'client_commands' and control all server setting via the dedicated server.
All potentially game damaging commands (like 'showbotroutes') can now ONLY be run from the server whilst in dedicated mode.
If using ICER to launch a dedicated server, specify NONE for YOUR TEAM in both TEAMPLAY and CTF or you will certainly get error messages like "can't find a bot named xxx"
You can't use the 'join' command for Teamplay when launching a dedicated game.
Bots will now play a dedicated server without any human players in the game.
Maps will Rotate and Reload if a human player clicks their fire button to exit the level intermission. If, however, bots are playing and force respawn is set, the level will reload without waiting for human click.
================================================================================
GAMEPLAY ICE supports DEATHMATCH, TEAMPLAY, and CAPTURE THE FLAG.
DEATHMATCH This is the default mode of play. Every man (bot) for himself.
TEAMPLAY ICE currently supports up to four teams playing simultaneously, up to 16 players in each. Teamplay is initiated automatically, as soon as there is 1 team containing 1 player. All team commands start with the same root: team
You can not yet delete a team, you must instead reload the map. (ie type: map x At the console, where x is the mapname)
console: team dedicated: sv team
Lists all the current teams.
console: team xxx dedicated: sv team
Creates a team of name xxx. If the team exists, lists all the players in that team.
console: team xxx yyy yyy yyy yyy... dedicated: sv team xxx yyy yyy yyy yyy...
Creates a team of name xxx (if it doesn't already exist). Adds all the players named yyy (separated by a space) to that team.
If the bot players specified are not already in the game, they will be spawned.
Include human player names in the argument to add them to a team. Or use the 'join' command below.
If any player specified is currently playing in another team, he will be removed from that team, and added to the new team as instructed.
console: teamskin xxx yyy dedicated: sv teamskin xxx yyy
Skins are allocated automatically to teams as they are created. This is intended to prevent any potential confusion. You can, however, change a team's skin AFTER it has joined the game, using the teamskin command.
Where xxx is the teamname and yyy is the skin.
eg. 'teamskin baddudes kw_black'
If you specify an invalid skin, ICE will allocate the default skin. Team members who join after the teamskin command will be allocated the new skin you have specified.
console: join xxx
For human players only. Adds the player who typed the command (ie you) to the team specified in xxx. An alternative to including your name with the team command. eg. join baddudes
NB: the team xxx must already exist, so use this command AFTER the appropriate 'team' command. To change teams, just change xxx and repeat the command. This command does NOT work on a dedicated server!
Scoring in Teamplay The teamplay scoreboard groups players by team, and places the teams in order of highest score first. Within in each team players are then sorted by score; highest first. The leader in each team also appears on the right of the screen as an icon.
If the friendly fire dm flag is not set, then you will lose a point for fragging your teammates.
================================================================================
CAPTURE THE FLAG As in regular CTF, ICE CTF supports two teams, red and blue. ICE also offers a host of bot AI/commands specific to CTF play.
Note: You MUST copy Zoid's pak0.pak file (~12 Meg) from your CTF installation folder into the ICE folder in your Quake2 directory.
The general bot commands (bload, bremove, bnum) all work in ctf mode, as well as the ctf specific commands below. In ctf, bots loaded using 'bload' or 'bnum' will automatically be assigned a team (red or blue). ICE will automatically keep the team numbers even (assuming, that is, that there are an even number of bots to split!).
When a CTF map is loaded, ICE will first try to find a route between the two flags. If it is unsuccessful, the following message will appear:
'WARNING: there is no complete route between flags'
This message will therefore appear when you first initialise a new route table for a CTF map. Ignore it. If, however, you are not creating a new route-table and you see this, see the notes on ROUTE TABLES below. Bear in mind that the bots will not capture many flags until this is remedied!
command line: +set ctf 0/1
You MUST enable CTF at the command line. It cannot be properly initiated from within the game (console: ctf 1), UNLESS you then reload a CTF map.
console: ctfteam red
Adds YOU to the red team (regular ctf command for this is just team).
console: ctfteam blue
Adds YOU to the blue team (regular ctf command for this is just team).
console: red xxx xxx xxx... dedicated: sv red xxx xxx xxx...
Adds bots to the red team. If they aren't playing already, they will be spawned.
console: blue xxx xxx xxx... dedicated: sv blue xxx xxx xxx...
Adds bots to the blue team. If they aren't playing already, they will be spawned.
console: flagroute
Ensures there is a route for the bots from one flag to another. It is called automatically at startup, but can be called anytime. There will ONLY be a response if there is NO route. By design, ICE bots will NOT always employ the same route from one flag to another.
================================================================================
ADVANCED CTF SETTINGS
ROLES console: role attack yyy console: role guard yyy console: role roamer yyy
Where yyy is the name of the bot.
*ROLES... By default, ICE ctf bots are given a role to play in a ctf game. This will be one of:
attack guard roamer
Roles are handed out in this order, so if there are 5 bot players on a team, two will be in 'attack', two will be on 'guard', and only one will be a 'roamer'.
'Attackers' will consistently arm themselves as necessary, and then go for the flag.
'Baseguards' stay close to their own flag, straying only occasionally to find weapons and ammo for defensive purposes.
'Roamers' will support the other team members, retrieve lost flags, divert enemy attention whilst attackers make their bid for the flag.
As bots players leave and join a team, roles will be adjusted accordingly. Roles can easily be changed manually, however, to suit a particular style of play.
Note: you can store your favourite settings to a file, and then execute it from the console (use exec xxx where xxx is the name of a file in the ICE directory). You CAN, of course, use LOADER.CFG for this purpose, but remember that roles MUST be assigned AFTER the bot has been spawned, and AFTER it has joined either the red or blue team.
As an example content for LOADER.CFG (exact order):
red arc brag chog blue arabella dilla emmie role guard arc role guard emmie
Subsequent addition/removal from the team WILL reset any manual changes.
*ADVANCED CTF SETTINGS...ORDERS Orders can be issued to your teammates at any point during the game (and bots will form their own attack formations etc from time to time, informing you of status). Bots will keep their orders until the objective is completed (eg retreating to base) or until you dismiss them.
ADVANCED CTF SETTINGS SOUND All orders are accompanied by an audio message. For instance, when a bot called to group with you arrives, he will say "Reporting".
console: group xxx xxx xxx... []
Without any arguments, 'group' will instruct any and all of your 'available' teammates to join you. Availability is determined by proximity, existing orders etc. Bots currently engaged in melee are unlikely to respond. Bots carrying the flag will NOT respond.
If you specify a teammate name (xxx), they are much more likely to drop what they are doing (unless they are actually returning to the base with the flag).
If you move around, after issuing the command, the bots will adjust to your new position, but will obviously take longer to reach you.
As each grouping bot arrives, they will get into formation and follow you around until you issue a dismiss command (see below).
If any of your 'followers' becomes engaged in battle, they will rejoin the group when the fight is over (if they die, they will respawn and set about finding you again).
console: groupvisible
This command has been substituted for follow_me command below. it will behave in exactly the same way as the 'follow_me' command.
console: attack xxx xxx xxx...[]
Without any arguments, 'attack' will instruct any and all of your 'available' teammates to attack the enemy base.
Availability is determined by proximity, existing orders etc. Bots currently engaged in melee are unlikely to respond.
If you specify a teammate name (xxx), they are much more likely to drop what they are doing (unless they are actually returning to the base with the flag).
This command is very effective when used in conjunction with the GROUP command. Call a number of teammates to group with you outside the enemy base. When they have arrived, issue an ATTACK command. This is a good way to ensure that the ATTACK is coordinated with all bots hitting the target at the same time. It may be the only way to overcome a heavily defended base, and it is a strategy that Leading bots will use from time to time.
console: retreat xxx xxx xxx...[]
Without any arguments, 'retreat' will instruct any and all of your 'available' teammates to return immediately to base.
Availability is determined by proximity, existing orders etc. Bots currently engaged in melee are unlikely to respond.
If you specify a teammate name (xxx), they are much more likely to drop what they are doing (unless they are actually returning to the base with the flag).
console: dismiss xxx xxx xxx...[]
Without any arguments, 'dismiss' will dismiss all teammates who are currently in your command (following one of the above orders). They will go about their business as dictated by their roles.
Alternatively, specify bots by name.
console: support_me xxx xxx xxx... []
WARNING! 'support_me' is a POWERFUL command which will give you serious control over your teammates. Use with care!
Without any arguments, 'support_me' will instruct *ALL* of your teammates to join you. *All* members of your team will drop what they are doing and come to your aid - unless they have existing orders (This prevents humans accidentally stealing each other's recruits!)
This INCLUDES GUARDS! (but not FLAG CARRIERS) If you don't want EVERYONE to come, use the standard GROUP command.
Recruited bots will NOT engage in melee again until they find you. They will not respond to pain caused by enemies either. Nor will they collect items on their way to you. They come direct. You are now their priority.
If you move around, after issuing the command, the bots will adjust to your new position, but will obviously take longer to reach you.
As each grouping bot arrives, they will get into formation and follow you around until you issue a dismiss command (see below).
If any of your 'followers' becomes engaged in battle, they will rejoin the group when the fight is over (if they die, they will respawn and set about finding you again).
console: follow_me
WARNING! 'follow_me' is a POWERFUL command which will give you serious control over your teammates. Use with care!
'support_me' will instruct ANY teammates *under your crosshair* at time of order to join you in a group - unless they have existing orders (This prevents humans accidentally stealing each other's recruits!)
*All* applicable recruits will drop what they are doing and come to your aid. This INCLUDES GUARDS AND FLAG CARRIERS! If you don't want EVERYONE to come, use the standard GROUP command.
As each grouping bot arrives, they will get into formation and follow you around until you issue a dismiss command (see below).
If any of your 'followers' becomes engaged in battle, they will rejoin the group when the fight is over. UNLIKE other orders, however, if they die, they will NOT set about finding you again, but will instead dismiss themselves.
console: arm_me
WARNING! 'arm_me' is a POWERFUL command which will give you serious control over your teammates. Use with care!
Without any arguments, 'arm_me' will instruct any and all available Roamers to bring ammo to you, wherever you are, wherever you go. Availability is determined existing orders etc.
When an 'arming' ROAMER finds you, he will drop a percentage of his ammunition stock, and inform you with the standard 'reporting' sound. A message will appear centrescreen, for example:
DROPPING
Grenades, Cells, Rockets, Slugs, Shells
for jibe.
The Roamer will then dismiss himself. If you call him back, he'll drop some more. The premise for the command is that you need the ammo more than he does, so he'll keep dropping it until he runs out. ROAMERS with NO ammo will not be much use as flag run support!
Bots currently engaged in melee are unlikely to respond. Bots carrying the flag will NOT respond.
If you specify a teammate name (xxx), they are much more likely to drop what they are doing (unless they are actually returning to the base with the flag).
If you move around, after issuing the command, the bots will adjust to your new position, but will obviously take longer to reach you.
As each grouping bot arrives, they will get into formation and follow you around until you issue a dismiss command (see below).
If any of your 'armers' becomes engaged in battle, they will start searching for you again when the fight is over (if they die, they will respawn and set about finding you again).
console: strategy console: invnext console: invprev
This will call up the 'strategy' screen which shows statistics on all your teammates. So called as it is intended to allow a more strategic coordination of your team. It is an alternative to the regular CTF score screen, and the two cannot be shown at the same time. A maximum of six players can be displayed at one time (by default the first six that were loaded - see below for scroll commands). The display shows a model icon (mini photo) for each player, and a coloured letter representing their role
G for Guard (RED) A for Attacker (GREEN) R for Roamer (YELLOW)
Also displayed against each is their name, distance from you (in approximate 'virtual' metres), and their most recent message to the rest of the team (if applicable). These messages also appear at the top of the screen as regular chat. The model icon and the role letter will be highlighted with coloured frames at certain times in the game. When bots in your team are recruited by other bots or player (but not you) a RED frame appears around their model icon. If a bod is LEADING a group, the RED frame will be splashed with blue. If the frames are RED, the bots are effectively busy, and will not respond to your general orders unless you call them specifically by name. When you do recruit a bot (to attack, retreat or group), a YELLOW frame will appear around their icon. This means they have responded to your command. If the order was "Group" then the frame will be YELLOW while they are looking for you, but will change to green when they find you. A small letter will appear in the bottom right corner of each model icon to show its current orders (L, Leading Group, A: Attacking enemy base, R: Retreating to home base, G: Grouping with you or another Leader). Finally, if the bot is in a melee, a pale blue frame will appear around the ROLE Letter (G, A, or R).
You can scroll the display using these commands:
invnext -or- invprev
These are the standard Q2 commands for scrolling through your inventory (and are usually bound to [ and ] respectively.
>> or << will appear over the top and bottom player icons respectively if there are more players to display.
ICE BOT CTF STRATEGY The ICE bot is capable of independently issuing any of the commands above. It will happily lead or join groups, attacks, retreats, as instructed by you, or by another bot on the team.
You can change a bot's existing orders (ie those given to it by another bot) by instructing it by name.
ONLY bots with the 'attack' role will actually issue orders to the other members of the team. Guards will NOT take orders from other bots. Attackers and Roamers WILL.
To see the ROLES and ORDERS of all of your teammates, just call up the scores screen. After each ICE bot's name is a dash, followed by their ROLE, then another dash, followed by their current ORDER.
eg. Arabella-a-l Barb-a-g Dilla-r-g Emmie-g-d
Above, Arabella(attacker) is leading Barb(attacker) and Dilla(roamer) in group formation. Emmie(baseguard) is dismissed (default if without orders).
By design, ICE bots will NOT always employ the same route from one flag to another.
Scoring operates as in conventional CTF, with points awarded for assists etc.
================================================================================
INTERNET PLAY ICE contains a number of features intended to assist human clients who are suffering the effects of high ping and lag during Internet play with the ICE bot (Inspired by personal experience).
The aim is FAIRNESS. If a number of human players are sitting on the server, along with the bot clients, players accessing via the Internet are always at a disadvantage. ICE INTERNET PLAY seeks to address the imbalance where it is significant. It's an imperfect alternative to NOT joining the server at all!
NONE of these features are enabled by default. The console commands are ONLY valid on the server.
*INTERNET PLAY Initialisation...
command line: +set internet_play 0/1 console: internet_play 0/1
Enables/Disables all the features of Internet Play, for ALL HUMAN PLAYERS. YOU MUST ENABLE this for the following features to work. If you then enable features such as weapon_travel_speed WITHOUT enabling 'ping proportional advantage' (below), ALL HUMAN PLAYERS will enjoy rockets travelling with the speed of chaingun fire.
command line: +set ping_prop_adv 0/1 console: ping_prop_adv 0/1
With Internet Play enabled, 'ping proportional advantage' will adjust each player's Internet Play features accordingly, in an attempt to assist those human players suffering from sluggish controls and the other side effects of a high ping. The assistance is directly proportional to the player's ping. Those with normal (low) pings will NOT see any of the effects of the features below. All players will be reminded from time to time if there is any 'assistance' in effect.
*INTERNET PLAY Features...
command line: +set handicap 0-4 console: handicap 0-4
Essentially numbs bots' reaction time, slows their movement etc. Influences ALL bots in the game. Reduces the likelihood of bots seemingly vanishing, common in games where players have poor Internet connections.
command line: +set weapon_repeat_speed 1-3 console: weapon_repeat_speed 1-3
Reduces reloading time, firing time, weapon change time etc. A useful edge on other players. Similar to the Haste tech in CTF, and great with a ping of 400+. (amusing with no ping, too)
command line: +set weapon_travel_speed 1-3 console: weapon_travel_speed 1-3
Increases weapon fire travel speed. Renders the rocket launcher closer to its Quake (1) counterpart. Opponents have less time to dodge, and are more likely to be in the same place even after high ping has trounced your aiming/firing reaction time. A setting of 3 or more effectively converts the blaster into a hyperblaster. You can slow weapons down too (er, why?) by specifying a point value of less than 1, but more than 0.
command line: +set grapple_speed 1..4 console: grapple_speed 1..4
Everybody has an opinion about the speed of the grapple. YOU decide! NB MAX is 4 or the mechanism goes pear shaped.
================================================================================
CREATING ROUTE TABLES ICE bots use route tables to find their way around maps. You can create a route table for any map; DM or CTF (this includes Maps created for such mods as Loki's Minions etc). Route table management is handled automatically by ICE.
If you still have questions about creating a route table after reading this section and the FAQ, contact me using the address at the top of the file.
Human players create the tables as they play. You are, however, STRONGLY advised to create route tables for new maps WITHOUT first loading any bots, and to make the learning process an end in itself (ie don't play the map until you have created a good route table). ICE will actually try to prevent bots from joining the game whilst a new route table is being created.
HOW TO ROUTE A NEW MAP
Load up a map using ICER or an appropriate command line. Remember to include +set ctf 1 on the command line if the map has ctf flags on it.
You will see "Dynamic Learning Enabled" appear at the top of the screen. The node count will start at 1, unless you are continuing an old route. Continuing an old route is not advised - If the total node count ever exceeds 250 I strongly recommend that you delete the .qrt and .qit files for the new map from your ice\routes folder. Then restart the game and nodes will be reset to 1.
Walk around the whole map. Don't Run. Try to go everywhere once and once only. This will create an efficient route for ICE. The better the route, the better the game will be.
ICE will disable learning automatically. (You can start it up again if you like, to add to the route for instance. See below.)
When you see the "Routemap Complete. Dynamic Learning Disabled" message, you can reload the map and spawn some bots. That's all you have to do.
At load time, the statistics for the map will be shown. Based on this information, ICE will decide whether or not to continue updating the map's route table as you move around the map. Occasionally ICE will reenable Learning after the "Routemap Complete. Dynamic Learning Disabled" message has appeared. Just play the game, ICE will Disable the Learning when the time is right.
After a route table has been successfully stored, you can TWEAK it as little Or as much as you like. Tweaking is certainly NOT necessary but in some circumstances, the realignment of a node or two may ease a bot's progress. See below for commands.
Read the tips below!
ROUTE BUILDING TIPS
DON'T DIE! if you do, bots subsequently using the route table will behave strangely...
Check out one of the route demos on the ICE downloads page.
When you've finished creating a route, RELOAD the map before adding any bots.
Every item which CANNOT be reached by the ICE bot will have a bright blue aura. Once it is accessible, the aura will vanish. It is NOT necessary to actually touch or pick up ALL the items on a map. If an item is glowing, get closer to it. The aura will probably disappear before you actually touch it anyway. Route 'Learning' will then deactivate automatically once a satisfactory table is in place - ie once the ICE Bot is able to find its way to NEARLY ALL the items on a map. The blue glow will only appear on the unreachable items when Dynamic Learning is enabled. You can, however, force it on and off using showglow and hideglow.
ICE will stop learning once 90% of a map's items are reachable. Often a few items remain hidden or hard to reach. The 10% threshold allows learning to be disabled even if a few items are out of the ICE bot's reach - thereby freeing up processing power for improved gameplay. Remember that on CTF maps, many items may be available only via use of the GRAPPLE. ICE bots will probably be able to reach these items - but they will Still appear as unreachable (blue glow) when the map loads. If you wish to track down the remaining 10%, simple use the 'learn toggle' command (detailed below). Doing so DISABLES automatic learning - meaning that YOU must manually disable learning ('learn toggle' again) if you wish to stop the incremental learning. Loading a map, or reloading Quake2 will also reset automatic learning. If you don't know where the remaining unreachable nodes are, use the 'unreachable' command below.
If 90% of items isn't good enough for you, then you can track down the remaining 10% using the unreachable command. NOT ALL ITEMS ARE NECESSARILY REACHABLE! and a 90% is normal. For instance some CTF maps have items which can only be grappled to. ICE bots will find their own way to these things even if they're not officially reachable.
If you wish to disable automatic route learning at any time, simple use the 'learn toggle' command (detailed below).
The larger a route table is, the longer it will take ICE to determine its path. Only VERY large maps should have more than 200 nodes in total. The number of nodes in each route table is displayed as the map is loaded.
If you don't complete the route table in one go, ICE will continue recording nodes where it left off the last time it used the current map - but this will invariably result in a less efficient route table. RECORDING THE ROUTE IN ONE SWOOP IS THEREFORE THE PREFERRED OPTION.
Route learning requires some processing power - motion may be a little jerky during 'learning'.
When stepping on and off platforms/elevators, wait until the machine has stopped moving, before you get on or off.
Move on and off ladders cleanly - no jumping. Go UP ladders, NEVER go down them.
Only jump of ledges if you have to. Always walk down steps or up steps if it's possible. Bots will jump if they need to , but they need to know how to use the stairs first.
No grappling please! Bots will use the grapple without training.
You can use the tools below to evaluate the status of your current route table.
If a given table is large and therefore inefficient (manifest: bots will 'think' longer before moving), delete the route table from the quake2\ICE\routes directory. The route table file will have the same name as the map, and the extension .qrt. You can also delete the .qit file but it is not necessary. When you reload the map in Quake2, a new table will be initiated.
Bots will only go to places that YOU have been. Bear that in mind when creating the route table.
ICE will load any existing route table at startup, or whenever a new map is loaded from within the game.
CTF SPECIFIC... When a CTF map is loaded, ICE will first try to find a route between the two flags using the map's route table (since this is an important part of ctf). If it is unsuccessful, the following message will appear:
'WARNING: there is no complete route between flags'This message will therefore appear when you first create a route table for a new CTF map. Ignore it. If, however, you are not creating a new route-table and you see this, it means that the bots are unlikely to capture many flags. SO... *When creating a route table for a ctf map, the first thing to do is walk from one flag to the other. The more routes that exist between the flags, the more 'unpredictable' bots will be as they attack the enemy base, so recording several different routes is also a good idea. One solid route between the flags will do, however. *You can force the route learning on (see 'learn toggle' command below) or you can delete the route table altogether and start again (often the best plan). You can also test the route quality using the tools below.
ROUTE TABLE COMMANDS: The following commands are available if you wish to override ICE's automatic settings.
console: learn toggle
You can toggle route learning on and off with this command.
console: loadroute
Manually loads/reloads a route (specific to the current map).
console: showallnodes
Toggle. Will show every node recorded on a map. Nodes will be green Unless they must be jumped to, in which case they are red. Beware of using this when lots of bots are playing as it is quite Demanding on the game.
console: showroute
Toggle. First call sets the start point, second call sets the end point. Wait a few seconds, and if able, ICE will light up the nodes & route between the two points. Toggle once more to deactivate the highlighted route.
console: show_bot_routes
Toggle. Shows the route and nodes taken by the bot who most recently chose a path somewhere.
console: evaluateroutestatus
This is the route table loading mechanism, and is called every time a map is loaded. It provides feedback on the current route table status, and lights up all the map items which cannot be reached by the ICE bot. Remember that having a few unreachable items on a map is normal - especially if it is a CTF map where grapple use may be required. The bots will usually find a way to these "unreachable" items. Regular reloading of the map is advised when making any node changes - and is essential before any bots are loaded.
console: hideglow
Hides the blue glow on items which indicates that bots will get to these items using 'unconventional means' By default: The glow is DEACTIVATED at startup on 'complete' routemaps.
console: showglow
Shows the blue glow on items which indicates that bots will get to these items using 'unconventional means' By default: The glow is ACTIVATED at startup on 'incomplete' routemaps.
ADVANCED ROUTE COMMANDS WARNING: ADVANCED USERS ONLY!!!
console: forcenode
Will force a node to be recorded at your current position. Used to force Bots to take a certain route.
console: movenode
For tweaking specific nodes when the route table is complete. This command will select the nearest node to your current position, and transport you to it. The active node will be represented as a red ball, and nodes connected to it will be blue. Using the command a second time will actually move the node. The change is effective immediately. Remember that the red node (the one you are moving) MUST remain in view of the blue nodes. MAKE A BACKUP OF YOUR ROUTE TABLE BEFORE USING THIS COMMAND. It is useful when moving nodes about to activate the "showallnodes" Command - 'movenode' will do this automatically. The number of the selected node will be displayed at the top of the screen.
console: unreachable
After "evaluateroutestatus" is run (automatically when a map is loaded) the number of items which are unreachable is displayed. To move directly to each of these items in turn, use "unreachable" at the console. Make sure learning is deactivated before using this command (use "learn toggle"). ICE will try to ensure it is disabled automatically.
================================================================================
OTHER ICE FEATURES
VIEWABLE WEAPONS command line: +set view_weapons 0/1
This MUST be set on the command line. ICE fully supports Hentai's Viewable Weapons mod. Note: You MUST copy the vwep pak2.pak file (~2 Meg) into the ICE folder in your Quake2 directory.
MAP CYCLING command line: +set map_change 0/1 console: map_change 0/1
You can instruct ICE to cycle through the list of maps contained in maps.cfg (in the ICE folder). You can store up to 50 maps, in any order, each one on a NEW line. When ICE reaches the end of the list, it restarts at the top. When the change is triggered (by 'fraglimit' or 'timelimit' or 'capturelimit') then if the "Force Respawn" DM Flag is set, the next map will load immediately. Otherwise, the next map will not load until a human player hits their fire button. This means that if you want the maps to keep cycling on an empty dedicated server, you must set the "Force Respawn" flag.
'map_change' is used in conjunction with 'fraglimit' & 'timelimit' & 'capturelimit' detailed below. NB: maps in maps.cfg will NOT be used unless 'map_change' is set to 1
command line: +set fraglimit xxx console: fraglimit xxx
Map changes when a player gets this many frags. NB: you MUST also set map_change 1
command line: +set timelimit xxx console: timelimit xxx
Map changes when this many minutes have passed. NB: you MUST also set map_change 1
command line: +set capturelimit xxx console: capturelimit xxx
Map changes after this many captures. CTF ONLY! NB: you MUST also set map_change 1
CAMERA command line: +set camera 1/0 console: camera 1/0
To initialise the camera on the server. You must do this in order for the client 'cam' commands to work at all.
console: cam xxx console: cam on console: cam off console: invnext console: invprev
You may choose WHO to watch, and HOW to watch them*
WHO: Once the camera is initialised by the server, use 'cam' at the console with one of these options to choose WHO you want to watch:
1. 'cam xxx' is the name of the bot you want to follow. 2 'cam on' will start the camera in auto mode when you first use it. In auto mode, ICE will move the camera from bot to bot depending on a variety of criteria intended to show where the action is (eg who is fighting with the biggest weapon, who has the flag etc) Typing 'cam on' repeatedly will allow you to manually move the focus from bot to bot, until the last bot is reached, whereupon the camera will deactivate itself. 3. Whilst in camera mode, you can also move the display from player to player using the inventory commands,
invnext -or- invprev
These are the standard Q2 commands for scrolling through your inventory (and are usually bound to ] and [ respectively.) 4. 'cam' without any arguments will instantly deactivate the camera. So will 'cam off'.
HOW: There are three camera modes, and you can scroll through them using your *fire* button:
1. Hollywood MODE: ICE automatically pans, zooms and follows the action from all angles. 2. Eye MODE: Gives you the bot's eye view. Full on! 3. Freemouse MODE: Places you just above the bot, and allows you to control the view angle with your mouse.
Whenever you use the camera, information will appear in the lower left corner of your screen, detailing who you are watching and how they are doing. If you call up the scores screen at anytime (or the strategy screen in CTF) the camera info will disappear and not return until you hit *fire* or type 'cam on' again.
GRAPPLE ICE bots will use the grapple by default. They will use it in DM too, if enabled (see 'dmgrapple' below)
command line: +set bot_grapple 1/0 console: bot_grapple 1/0
ICE bots will happily get from a to b using the grapple. Or you can stop them doing so.
command line: +set bot_spiderman 1/0 console: bot_spiderman 1/0
ICE Bots can also swing around the map like Peter Parker (aka Spiderman!). This includes using the grapple to: ...get out of nasty situations ...get into position or chase an inaccessible enemy ...show off in general
AUTO GRAPPLE console: auto_grapple 0/1 console: auto_grapple_go, auto_grapple_stop (SEE BELOW FOR USAGE INFO)
auto_grapple allows the grapple to be used concurrently with another weapon (as in LMCTF). In order to do this, you must add some commands to your autoexec.cfg in the ICE folder (as you may have done for Zoid's standard grapple). It should look something like this:
bind "shift" +auto_grapple alias +auto_grapple "auto_grapple_go" alias -auto_grapple "auto_grapple_stop"
The only parts you mustn't change are the words auto_grapple_go and auto_grapple_stop. You can now fire the grapple whilst still using your active weapon (and without actually selecting the grapple as a weapon first). Hold down the auto_grapple key ('shift' in my example above) for as long as you want the grapple activated. Of course you can still make the grapple your active weapon if you like ("use grapple"), and the command above will operate the regular grapple just fine. You MUST set the 'auto_grapple 1' server setting to enable this option - or just choose Auto Grapple from the bot options page in ICER (v0.11 and above). The bots will use auto_grapple themselves and attack you whilst grappling!
CTF FEATURES IN DEATHMATCH command line: +set dmgrapple 0/1
Allows use of the CTF grapple in DM games.
command line: +set dmtech 0/1
Allows use of the four CTF techs in DM games.
command line: +set dmtech 1/0
Adds the handy player identification option to DM games.
CHATCENTRE command line: +set chatcentre 1/0 console: chatcentre 1/0
To enable/disable the realignment of human chat from the top of the screen to the centre of the screen. Useful if there are only a few (non-malicious) players who miss each others comments during play.
RADIO command line: +set radio 1/0 console: radio 1/0
Plays 'radio' sound when messages from human (NOT bot) players are received.
WELCOME BANNER command line: +set show_banner 1/0 console: show_banner 1/0
Displays the ICE welcome banner to clients as they connect.
CLIENT COMMANDS command line: +set client_commands 1/0 console: client_commands 1/0
Determines whether or not clients (rather than just the server) can add or remove bots. By default they can.
BOT CHAT The bots will use chat in a variety of circumstances. All the comments are held in chat.cfg in the ICE folder. See the file for details on creating your own chat for the bots to use.
command line: +set bot_chat 1/0 console: bot_chat 1/0
Toggles the bots' verbosity. Useful in CTF if you're not interested in hearing about their planned attack on the enemy base etc... Shuts them up in DM too.
BOT STATS console: bot_display_toggle
With the scores screen *visible* toggles between: *display of player scores *statistics of bots currently in the game *camera screen if activated *ctf strategy screen
PAUSING the GAME console: bot_pause 0/1
Pauses ALL playing bots - but not human players. If you want to use bot_pause or bot_invisibility as toggles (ie press a key once to turn invisibilty or pause on, press the same key again to turn it off) then you need to add an alias/binding to your autoexec.cfg file in the ICE folder. Something like this:
alias invis0 "bot_pause 0;echo bot_pause OFF;wait;bind i invis1" alias invis1 "bot_pause 1;echo bot_pause ON;wait;bind i invis0" bind i invis0
HUMAN INVISIBILITY console: bot_invisibility 0/1
Makes ALL humans invisible to bots. They won't attack you unless you attack them first!
BOT VELOCITY console: bot_velocity 0-3
Where 0 is FASTEST, 3 is SLOWEST. Bot Velocity is now configurable using 'bot_velocity'. By default, bots always run flat out (bot_velocity 0), which makes them harder targets but isn't completely realistic.
BOT GLOATING console: bot_gloat_glow 1/0
You can prevent ICE bots from flashing blue after they score a kill, using this command. Default is 'bot_gloat_glow 1' which is ON. This will NOT stop them insulting you!
MODES OF PLAY console: bot_mode 0-2 console: challenge
Additional, custom ICE modes of play exist for Deathmatch Only.
0 : Normal mode Regular DM. No changes applied 1 : Training Mode This is intended to help those who are new to ICE/Q2 or want to improve their game without being repeatedly killed and continually having to respawn and collect weapons/armour/health. Gameplay ensues as normal in DM, but you receive no pain from bot attacks. Instead a warning message appears centrescreen, displaying the damage that would have been done to you in normal mode. You also see who took it. eg:
"Eskimo takes 25 with a Rocket Launcher"
If you hurt yourself somehow, then you'll be told about that too.
2 : Challenge Mode Just how good are you? It's hard to say against human players with inconsistent play and circumstances. ICE Challenge Mode removes the uncertainty. The skill level of your competition is determined by ICE and then rated against your peformance. You are on your own. Every ICE bot player is out to get you. Factors taken into account:
- Number of enemies. - The various skill settings of each enemy. - Time. Your score falls off over time. - Number of human players. As such, the better the enemies are, the more points you get for a kill. Likewise the more enemies on the map, the faster your score will grow. If you have human help, your score will reflect this. If you camp or sit around, your score will drop - quickly. Scores will be between 0 and 999. Your score will appear in the top right hand corner of the screen. You can also type 'challenge' at the console (at any time) in order to see the highest score you have had during the game. Rate yourself.
ADVANCED INFORMATION MANAGEMENT (AIM)
console: bot_aim 0/1
This option will speed up certain key elements of bot behaviour, namely:
- Increases bot reaction times.
- Reduces bot route
calculation delays.
- Improves bot perception of
techs & flags.
There is, however, a minor CPU overhead, and on slower processors (less than 200MHz)
there may be some jerkiness or other noticeable
slowdown. For this reason, bot_aim is not
enabled by default. Try both settings at the
consloe. bot_aim should be enabled if possible,
as it will ultimately render a more challenging
ICE opponent.
================================================================================
VERSION HISTORY
0.2
Much improved obstacle handling (other players, corners ...)
CTF flag carrying bots will try to run backwards and engage the enemy from time to time when being pursued. They particularly like dropping pineapples...
CTF Squadron forming is tighter and smarter, bots will get out of your way if obstructing your path. CTF As well as arming up, Baseguards now roam for other items within the local vicinity of their flag (without compromising base defense).
Railgun fire is no longer disproportionately good when used by bots with high accuracy skill.
CTF Bots won't mess about with grapple near enemy base when they have the flag (unless really necessary!) but will return to home base directly.
CTF Baseguards won't grapple too much around the flag area.
CTF Bots drop from grapple when hurt by another player - instead of resisting pain.
CTF map rotations now complete properly. Bots reload automatically.ICE performs more rigorous check on map type (DM or CTF) and switches game mode accordingly (ie CTF or not CTF)
'bot_pause' and 'bot_invisibility' are now regular server commands (not toggles) which allows them to be disabled for client use with the client_commands server setting.
New Auto Grapple. ICE already supports variable grapple fire speed. It now allows the grapple to be used concurrently with another weapon (as in LMCTF). Optionally fire the grapple whilst still using your active weapon (and without actually selecting the grapple as a weapon first). The bots will use auto_grapple themselves and attack you whilst grappling!
Bot Velocity (running speed) is now configurable using 'bot_velocity'.
0.3
ICE bots go to Hollywood with the all new ICE CAMERA. 3 modes of viewing: Hollywood, Eye & FreeMouse Use fire button and inventory keys to move through the bots. See 'cam' command below.
Dedicated Server Support: With prefix 'sv ', key bot commands can now be called from a dedicated setup. Loader.cfg commands set by ICER will also run properly now, also employing 'sv ' format (see Dedicated Server section below to see which commands now have dedicated alternatives)
NEW CTF commands - these are *POWERFUL* and give you serious control of your team. Please read the detailed section on each command! They are: - arm_me: All available Roamers will bring ammo to you, wherever you are, wherever you go. - follow_me: Anyone under your crosshair will be recruited to follow you immediately. Includes the flag carrier! - support_me: *All* members of your team will drop what they are doing and come to your aid.
Fixed sound support for non-standard models (PPMs) (NB as ever, PPMs must have their own sound files in the appropriate folder)
Removed Bot Weapon Limit, refined it to a true Weapon Preference so ALL bots will now use ALL weapons (with degrees of skill ranging from 'clueless' to 'frightening') Renders a more dynamic game...
CTF skin/model support fixed.
Moderated ICE aiming of HyperBlaster, ChainGun, and RailGun (again!).
Dead bot bodies can now be gibbed!
Fixed Hyperblaster fire which was actually a fastblaster!
Scroll CTF 'strategy' screen using inventory keys when you have more than 6 teammates. See below.
Fixed "Gun" sounds.
Improved 'incoming' projectile avoidance.
There is no longer an overflow limit on Obituary messages - so they should ALL appear. Any problem with overflow? Let me know...
You can now add unlimited messages to the chat.cfg file - all categories.
Capturelimit will now rotate maps as well as fraglimit and timelimit. Set it in ICER.
Bots crouch in low headroom areas.
Reporting bots salute more conservatively!
New commands 'hideglow' and 'showglow'. The blue glow on certain items which indicates that bots will get to these items using 'unconventional means' can be hidden or displayed with console commands 'hideglow' and 'showglow' respectively. in 0.3 the glow is now DEACTIVATED on 'complete' routemaps.
New command 'bot_gloat_glow'. You can prevent ICE bots from flashing blue after they score a kill, using 'bot_gloat_glow'. Default is 'bot_gloat_glow 1' which is ON.
Fixed shallow water handling. Only applies to routes created using ICE 0.3 and later. Applies to all routes included as part of ICE 0.3 complete download.
Improved bot handling of doors.
Important CTF 'order' messages are now printed centrescreen.
Converted documentation to much nicer HTML format. Thanks Jinx.
Bot names in bots.cfg can be UPPERCASE and lower case (or AnY cOmbinAtioN) In fact you could always do this, though the notes said you shouldn't!
Added Teamplay 'join' command to simplify joining and changing teams for human player.
================================================================================
Q: ICE just
doesn't work. Why not?
-or-
Q: When I type bnum or bload in the console, nothing happens.
A: Firstly, check to see if there is a gamex86.dll file in your
quake2 folder. If there is, remove it,
rename it or delete it.
If that doesn't apply, check your folder structure.
The ICE folder must be in the QUAKE2 folder.
ICER should be in the ICE folder (if you are using
it) eg c:\quake2\ice\icer
Finally, what version of Quake2 are you running. Make
sure that you have the v3.19 point
release installed BEFORE you install ICE. If you've
upgraded Q2 after installing ICE, reinstall the
ICE zips.
Q: The bots seem
to carry a large white diamond shaped object instead of a weapon. Why?
A: You have enabled Viewable Weapons, but haven't copied the
viewable weapons .pak file
to your ICE folder. If you are using custom
models (eg. not Male/Female or Cyborg) then
they must have their own viewable weapons
models in their own model folder (see previous Q)
Q: When I start the game, it stops, and gives me the message:
"ERROR: Game is version 3.xx not 3.yy"
Why is this?
A: See above. You must have version 3.19 of Quake2 for ICE to
run properly.
Q: None of my
custom models appear in the game. Instead the are all bald, male players.
A: Have you installed the models in the
quake2\baseq2\players\<modelname> folder? Each model
must have its own folder, and the folder must also
contain the sounds for that model,
or they will use the default male sounds.
Q: What are these
kw_ skins?
A: I am distributing Grimlock's Coloured Skin Pack with ICE so
that teams of ICE players can each
sport the same clothing in a Teamplay game. The kw_
files (eg. kw_blue, kw_green) are all
copied to your
quake2\baseq2\players\<male/female/cyborg> folders when you install ICE.
This means that you can compose teams of Males,
Females and Cyborgs and they can all
have the same skin colour. This is not possible with
the basic skins like Viper and Sniper
that come with Quake2.
Q: I started the game, but where are the ICE bots?
A: Use bnum <number of bots> -or- bload <bot name>
to load some bots from the console. Read
about these commands above.
Q: The game is a bit jerky for the first few seconds. Why?
A: This is normal. When Quake2 starts, ICE loads the route
table for the map you chose,
and then loads any bots in loader.cfg. This is
demanding stuff. The jerkiness will pass in
a minute.
Q: When I load a CTF map, no flags appear. Why not?
A: You must add +set ctf 1 to the command line, or designate
the map you are loading as a CTF type
map in ICER.
ICE will try and determine the gametype automatically
when the map is loaded (ie CTF or not)
but it is best to use the correct command line/ICER
setup. If you are creating a route for a new CTF
map, then when the route is complete, you should
reload the map before playing it.
Q: My friend wants to join me in my ICE game. Can he do this
over the Internet?
A: Every time you play a standard ICE Quake2 game on your pc,
you are actually running your
own server. If you are connected to the internet
whilst running the game, you will have an
IP address - something like 198.162.166.222
If your friend knows this IP, he can connect to your
game with a shortcut that looks something
like this:
quake2.exe +set game ice +set game deathmatch +connect 198.162.166.222
Both players must be online for this to work. You can also use the connect option in ICER 0.2
Q: I want to play
a map that isn't yet supported in the ICE download. Where can I get routes from?
A: There are a number of sites dedicated to providing routes
for bots. Check them out. Or create
your own. Check out the instructions above.
Q: Can I use routes from other bots with ICE.
A: Nope. ICE navigation is unique, the routes have to be
created from new.
Q: When I use ICER, I get the message "Can't find [BOTS]
header". Why?
A: The bots.cfg file MUST contain this exact line BEFORE the
list of bots starts:
[BOTS]
Reinstall the file if you have to.
Q: When I use ICER, I get the message "Can't find file or
file in use". Why?
A: Make sure that the following files are in your ICE folder:
bots.cfg
chat.cfg
maps.cfg
Q: Sometimes the screen freezes and the message
"SZ_getspace" appears. What does it mean?
-or-
Q: The game is crashing with the error: "No more free
edicts". Why?
A: This should only appear if Quake2 is low on memory (shut
down ALL other apps when running ICE)
-or- there are just too many bots loaded for
the game to cope with. To give some idea of what is
reasonable, my AMD K6 200MHz with 32MB RAM will
play 20 DM bot no problem.
It could also happen on a very large map
containing lots of items. But I've never seen it...
Q: When I connect to an Internet server, I can't load any ICE
bots. Why not? I used ICER.
A: You can't load ICE bots on a server that isn't running the
ICE mod itself. Contact
the server administrator, or run your own ICE
server and have your friends connect to it.
(see above for details)
Q: When I set fraglimit/timelimit/capturelimit, I don't see any
ICE bots. When the map changes.
Why not?
A: You MUST set map_change 1 (see above for
details)
Q: This long list of Q and As still hasn't fixed my problem.
What should I do?
A: Write to me at the email address above. Provide as much
detail as you can about
what you tried, what your setup is, what has
worked and, of course what hasn't.
I reply to all constructive messages.
================================================================================
CREDITS
id Software - of course:
http://www.idsoftware.com/
PlanetQuake - The ICE Hosts:
http://www.planetquake.com/
Dave 'Zoid' Kirsch - top CTF:
ftp://ftp.idsoftware.com/idstuff/quake2/ctf/
Hentai - nice Viewable Weapons:
http://www.telefragged.com/tsunami/
Quake Devels - lots of useful info.:
http://www.planetquake.com/qdevels/
Quake2 DLLs - lots of useful info.:
http://www.quake2.com/dll/
Jinx - hours of beta testing, html documentation, chat.cfg & creative input.
Grimlock's essential Coloured Skin Pack.
ALL the other BOT authors out there - for inspiration and some cool ideas - especially
Ryan 'Ridah' Feltrin.
The ICE Beta Testers - thanks guys.
-&-
Everyone who has emailed ideas & bug reports, especially:
Terry Tor, Darkseid-D, Viper, Adam Ripley, Darrell Bynum
================================================================================
DISCLAIMER
THIS SOFTWARE IS MADE AVAILABLE "AS IS" AND WITHOUT WARRANTIES AS TO
PERFORMANCE OR MERCHANTABILITY OR ANY OTHER WARRANTIES WHETHER
EXPRESSED OR IMPLIED.
NO WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE IS OFFERED.
THE USER MUST ASSUME THE ENTIRE RISK OF USING THE PROGRAM.
Please bear in mind that this is a beta release, and is therefore in a continuous state of development. It may be unstable, though I am working hard to ensure that it is not. I accept no responsibility for any effect, detrimental or otherwise, which the ICE Bot or the ICER Launcher may have on your system, life, etc.
Other than that, enjoy.
================================================================================
COPYRIGHT The ICE bot and ICER: the ICE bot Launcher are Copyright (c) jibe 1998.
================================================================================
DISTRIBUTION Feel free to distribute this archive subject to the following conditions: 1. it remains PERFECTLY intact, as distributed on my web page: http://planetquake.com/ice 2. no money exchanges hands as part of the process. 3. any subsequent transfer of this software to another party must include their acceptance of the conditions stated under the disclaimer above.