gtkradiant/docs/manual/Q3Rad_Manual/ch08/pg8_1.htm

347 lines
12 KiB
HTML
Raw Normal View History

<html>
<head>
<title>Q3Radiant Editor Manual: Page 8.1</title>
<link rel = "stylesheet" type = "text/css" href = "../styles/q3rad.css">
</head>
<body>
<h1 class = "MsoTitle">Q3Radiant Editor Manual</h1>
<hr>
<h1><a name = "tools5">Tools 5: Working with Entities</a></h1>
The entities in <i>Quake III Arena</i> are limited to those
defined by the game code. The editor can draws entity information
from the game code, or from special definition (.def) files.
Version 192 of the editor comes with a .def file developed from an
original supplied by EutecTic. Mods made to Quake III Arena
can add to and/or subtract from the entities used by a game. If you
plan to work on mods, you should create multiple project files
(copy and rename your project file) with the changes required for
the mod.
<p><img src = "../Q3Rad_Manual_files/image038.png" hspace = 2 vspace = 2 width = 293 height = 425 align = "left"><h2><a name = "entitywin">The Entity Window</a></h2>
You make game design decisions about entities and modify their
features within the Entity Window. The definition file that you
select on the Project Settings&hellip; window determines what
entities will be shown in the Entity List and what, if any,
property descriptions appear in the Key Descriptions and Check box
Spawn Flags.
<p><div class = "subheading">Entity List</div>
The Entity List is the field on the Entity Window. It
contains the "classnames" of all the entities defined by the
definition file in alphabetical order.
<p>You can use the scroll bar to scroll through the entities or,
after clicking on the field, type in the first letter of the class
you want to use (e.g.; type in "T" to select "target", or "A" for
ammo, "W" for weapon).
<p>Double-click on the classname to select it and enter it on the
first line of the Active Properties field.
<p>The <a href = "../appndx/appn_b_1.htm">Entities appendices</a> of this document contain a complete listing of all the entities used in Quake III Arena.
<p><div class = "subheading">Key Descriptions</div>
The entries in the Key Description field are the "rules of use"
for the hi-lighted classname in the Entity List field. You can use
the scroll bar to scroll up and down through the lines, but
the entries are not interactive. If you are using the .def file
accompanying release version 192 of the editor (or Eutectic's
original), all the key commands are described and their acceptable
values (or value ranges) are listed. If you are using the
descriptions in the .c game code file, they may be substantially
less descriptive.
<p><div class = "subheading">Check box Spawn Flags</div>
Spawn flags are properties assigned to entities by use of check
boxes. Check the box to set the feature for the selected entity.
Many entities have only a single spawn flag property, while others
have numerous ones. Note that the check boxes to the right are only
relevant for Quake 2 single player games and will not work for <i>Quake III Arena</i>.
<p><div class = "subheading">Active Properties</div>
This field shows all the properties currently assigned to the
selected (or newly-created) entity. Each property has two parts:
key and value. Once created or assigned, they appear on the same
line together. Only properties that are valid for an entity (that
is, ones that appear in the Key Descriptions field) will function
in game. Adding others may create error messages. You cannot
directly affect the properties in this field.
<p>Clicking on an active property hi-lights it and fills in the key
and value fields below. You can edit both the key and the
value in those fields, or use the Del Key/Pair button to delete it
altogether.
<p><div class = "subheading">Key &amp; Value Fields</div>
Keys (and their values) are assigned to entities by typing them
into the fields. There is no spell check or auto-correction, so
make sure that your typing is accurate. Start by typing in
the name of the key. Then hit TAB or ENTER to change to the value
field. This also clears the contents of the value field. Now type
in the value for the key (the Key Descriptions list the acceptable
value ranges for the keys). If you hit ENTER, the key and value
appear in the Active Properties field. If you hit TAB, the
cursor moves up to the key field. You can also click directly on a
field to edit it. The cursor will appear after the last character
in the field. Use arrow keys to position the cursor within the
field.
<p><div class = "subheading">Angle Buttons</div>
The Angle Buttons (below the value field) are used to assign a
facing direction (as is the case with player start spots or
misc_models) or movement direction to entities (such as doors and
buttons). Click on a button to create an Angle key with that
button's value in the Active Properties field. Clicking on
another key changes the angle value.
<p>There are two clusters of angle buttons. The first cluster
represents rotation around the Z-axis for entities like player
start or spawn spots or misc_models. The entity will face in the
selected direction. The buttons represent angle directions in
45 degree increments. There is a direct correspondance between the
angle that the entity will face (or move) and the position of the
button in the cluster. If you select the 90-degree button at the
top center of the cluster, the entity will face "up" on the XY 2D
Map. If you select the 180-degree button on the left side of
the cluster, the entity will face left on the XY 2D Map.
<p>For entities like doors or buttons, it represents the direction
that entity will move when activated.
<p>The second angle button cluster assigns an up (-1) or down
(-2) direction to the entity. Note that an entity can only have one
facing direction. It cannot face up and 45 degrees. It can only
affect one or the other.
<p>It is also possible to directly edit the angle value in the
value field. This allows for a much more precise angle
selection.
<p><div class = "subheading">The Other Buttons</div>
<p>A third cluster of buttons sits to the right of the Angle
buttons. Each has a unique function.
<p><strong>Reset</strong>
<br>Clicking on this button will reset all properties from the entity to the default values.
<p><strong>Del Key/Pair</strong>
<br>If you have selected an active property, clicking on this button
will delete the property.
<p><strong>Sound&hellip;</strong>
<br>This opens a Windows directory browser in the directory that
contains the map sounds. Double clicking on a sound file name
in the browser window creates an active property with the
appropriate key and the value as the path/name for that sound.
<p><strong>Model&hellip;</strong>
<br>This opens a Windows directory browser in the models/mapobjects
directory. Double clicking on an .md3 file name in the
browser window creates classname misc_model active property with
the value as the path/name for that model.
<h2><a name = "enttools">Entity Handling Tools</a></h2>
These tools manipulate the in game entities. The map component
handling tools that are described in the Working with Brushes
section also work with entities.
<p><div class = "subheading">Escape (ESC)</div>
This is the all-purpose deselect key. Use it to back out of
operations you don't want to complete or to stop working on an
entity.
<p><div class = "subheading">Connect Entities</div>
<div class = "menu">(Menu: Selection &gt; Connect Entities)
<br>(Shortcut: CTRL+ K)</div>
This targets one entity, typically an activating trigger, at
another entity, usually a target of some kind. Some entities
may be linked in multi-part chains, where each entity has some
effect on the one(s) that follow it. To use, do the following:
<ol>
<li>Hi-light the acting entity (usually a trigger, or a button).
<li>Hi-light the targeted entity (examples: target_position,
target_relay, a door).
<li>Select Connect Entities (or press CTRL + k).
<li>A path is drawn between the two entities. The first entity
selected always targets on the second.</ol>
Troubleshooting: If the connection is not made check the
following:
<ul><li>Are both objects already entities? Sometimes it's easy to forget
to make a trigger brush into a trigger.
<li>Did you select ONLY two objects? If you accidentally click
on something you don't intend to link, you have to start the
linkage over.
<li>Did you select the objects in the correct order?
<li>Is the second object something that can be triggered
remotely?</ul>
<p><div class = "subheading">Ungroup Entity </div>
<div class =- "menu">(Menu: Selection &gt; Ungroup Entity)
<br>(Shortcut: none)</div>
This unbinds an entity made of brushes, and/or patches, and md2
models back into separate map components. Once ungrouped, the
entity is no longer an entity and loses any and all key value
properties it may have had.
<p><div class = "tip"><b>Design Note:</b> If you intend to rebuild an entity after
ungrouping it, write down its key properties and values first.</div>
<p><div class = "subheading">Moving Selected Entity</div>
These keys move the Entity around the map in discrete map grid
increments.
<ul><strong>Move Selection Down</strong>
<div class = "menu">(Shortcut: Keypad MINUS)</div>
Each press moves the selected map component down along the
Z-axis by one grid position (at current grid setting). Not affected
by current 2D-map view.
<p><strong>Move Selection Up</strong>
<div class = "menu">(Shortcut: Keypad PLUS)</div>
Each press moves the selected map component up along the Z-axis
by one grid position (at current grid setting). Not affected by
current 2D-map view.</ul>
<p><div class = "subheading">Nudging the Entity</div>
These keys move the Entity around the map in discrete map grid
increments. The movement is in terms of the selected window, not in
terms of XYZ coordinates.
<ul><strong>Nudge Down</strong>
<div class = "menu">(Shortcut: ALT + DOWN ARROW)</div>
Each press moves the selected map component "down" the map view
by one grid position (at the current grid setting). The movement is
relative to the selected map view, not XYZ coordinates.
<p><strong>Nudge Up</strong>
<div class = "menu">(Shortcut: ALT + UP ARROW)</div>
Each press moves the selected map component "up" the map view by
one grid position (at the current grid setting). The movement is
relative to the selected map view, not XYZ coordinates.
<p><strong>Nudge Left</strong>
<div class = "menu">(Shortcut: ALT + LEFT ARROW)</div>
Each press moves the selected map component "left" the map view
by one grid position (at the current grid setting). The movement is
relative to the selected map view, not XYZ coordinates.
<p><strong>Nudge Right</strong>
<div class = "menu">(Shortcut: ALT + RIGHT ARROW)</div>
Each press moves the selected map component "right" the map view
by one grid position (at the current grid setting). The movement is
relative to the selected map view, not XYZ coordinates.</ul>
<p><div class = "subheading">Rotating Entities = BAD!</div>
All the commands that rotate brushes and patches will work on
entities. Unfortunately, what they do to some entities is BAD!
Don't use free rotate or menu rotation commands to rotate
Misc_models or any entity model represented by a wireframe model in
your map. The movement will separate the model wireframe from its
bounding box and will not actually change the facing of the
entity.
<p><div class = "subheading">Changing Facing = GOOD!</div>
To change the direction that a misc_model or entity with a
facing (such as a player start or spawn spot) faces, use Angle keys
and values. You should "rotate" (change facing) entities with
either the Angle buttons on the Entity Window or by entering an
Angle key and giving it a rotation value between 1 and 360
(inclusive).
<p><div class = "subheading">Mass Rotations</div>
If you are building a Capture the Flag map, or other map where
you only build one portion and rotate it to make the others,
consider doing the following. Change the display of all
non-misc_model entities to bounding boxes only. Select the
entities to be moved and clone them. Then rotate them using the
menu rotating commands. Position them in the new map
section. Next, move misc_models individually. Change
their facing and set them in place.
<p align = "center"><a href = "../ch07/pg7_1.htm">Back</a> | <a href = "../index.htm">Home</a> | <a href = "../ch09/pg9_1.htm">Next</a>
</body>
</html>