Es/Inputs and Outputs
Cuando un niño se asusta de un sonido, en la informática se suele decir, que el niño ha cometido una entrada (reacción) al escuchar el sonido (acción del sonido, que es, asustar)
Entrada y salida, o mejor entendido "Hecho-consecuencia", reacción-acción (y no al revés) (conjuntamente "E/S" o en inglés "I/O") son términos para describir los medios por los cuales las entidades se comunican entre ellas en mapas. Las entidades tienen dos métodos para comunicarse: enviar una "salida" (señal que sale) a otra entidad, o a una "entrada" receptiva de otra entidad. Por ejemplo, una entidad puede mandar una salida cuando es eliminada a otra entrada de entidad que causa que cambie de color.
Imagina una entidad como un logic_timer. Podría estar configurada para "activar" su entrada OnTimer
cuando llegue a un límite de tiempo, el cual activa (o llama) la salida ShowSprite
de un "sprite" (env_sprite).
Entradas (acción/hecho)
Las entradas/acciones son comandos u acciones que causan que una entidad cambie lo que esté haciendo. Son activadas (o llamadas) por las salidas - no pueden ser manipuladas directamente.
En el Hammer Editor, puedes ver una lista de acciones que entidad (A) recibe, en la pestaña "Inputs", en las propiedades de un objeto. Haciendo clic en "Mark" te llevará a la entidad (B), que está activando la acción.
Salidas (reacción/consecuencia)
Las salidas/reacciones, son eventos, o sucesos, que se activan cuando hay un cambio en el estado de la entidad. Por así decirlo, un cronómetro (timer) podrá cometer una reacción al llegar al tiempo límite. Un botón (button) activará un evento al ser pulsado/apretado, o una pistola, desencadenará una reacción (disparar una bala) al apretar el gatillo.
Esto se entiende así:
- 1. Apretar el gatillo -> Acción
- 2. Una bala sale disparada -> Reacción
- 1. Cometer la acción, desencadenar algo = Acción
- 2. Consecuencia de la acción = Reacción
- 1. Un ejército verde invade el país azul = Acción
- 2. El ejército azul dispara contra el verde = Reacción
________________
Las reacciones son creadas en la pestaña "Outputs", en las propiedades de una entidad. Este menú te da una lista de reacciones, que están siendo emitidas, por la entidad que los emite, campos de texto para configurarlas y étcera. En el Hammer Editors, se entiende así:
- Output name (Nombre de la reacción)
- ¿Qué causa a esta reacción, activarse? Por ejemplo, un activador (trigger_multiple) puede activar un "al activar" (OnTrigger) una reacción cuando el jugador entra o interacciona en el activador.
- Target entity (Objetivo)
- El objetivo (targetname) o nombre de la clase (classname) de una entidad que recibirá la entrada/reacción. Se aceptan asteriscos (*) para buscar un objetivo con nombre incompleto/general.
- En el Hammer Editor, un objetivo en negrita, son múltiples entidades con el mismo nombre.
- Si se pone en rojo, significa que no encuentra una entidad que se llame como el objetivo.
Error:Los "classname" y valores "wildcard" y nombres (Targetname) especiales special targetnames aparecerán en rojo. ¡No te alarmes!: ¡El motor las reconocerá! [todo tested in ?]
- Input name (nombre de la acción)
- The input on the target entity that will be triggered. This too will be context sensitive. For example, if sending an output to a Door entity, some of the available inputs will be "Close" or "Open".
- Parameters (Parámetros)
- Puedes pasar información a un objetivo (targetname) con parámetros. Un parámetro puede ser cualquier cosa: el volumen de un sonido, el targetname de otra entidad, o quizá un color. Todo depende de lo que la acción acepte. Si no es posible poner parámetros, la casilla se volverá gris.
- Algunas reacciones, como contadores (math_counter) con
OutValue
, generan parámetros por su propia cuenta. Para usar un parámetro preparado, deja el campo de "Parameters" vacío. - Time delay (Tiempo de retraso)
- La cantidad de tiempo (en segundos) que tardará en hacer efecto la reacción.
- Fire once only (Activar sólo una vez)
- Significa que esta reacción, no podrá volver a ocurrir, más que una vez.
Cómo entenderlo mejor: Ejemplos
Para entenderlo mejor interpreta la tabla.
Preparando un activador
Esto será un ejemplo de cómo puedes crear un activador utilizando entradas y salidas, así que harás que un sonido se oiga, cuando el jugador entre en una zona.
Abre un mapa y añade un ambient_generic (en el campo "Name", pon el nombre del sonido, por ejemplo, "grito"). Vete a sus propiedades y elige un archivo de sonido para reproducir. En la pestaña Flags, activa la casilla "Start Silent". Selecciona la textura "tools/toolstrigger
" y crea un cubo que el jugador traspasará. Haz clic derecho sobre el sólido y haz clic en "Tie to Entity", y escribe trigger_once. Ve a la pestaña Outputs y haz clic en Add....
En donde pone "My output named" elige la opción "OnStartTouch
". Esto causará que la reacción sea "Al empezar a tocar el activador".
En donde pone "Targets entities named" escribe el nombre del sonido, o "grito
". Esto señalará qué objetivo hará la acción.
En la caja "Via this input" selecciona "PlaySound
". Esta caja, contiene todas las acciones que puede hacer el sonido. "PlaySound" significa "ReproducirSonido".
Dale al botón de Aplicar (Apply) para guardar los cambios, y cierra la ventana. Ya tenemos el activador colocado, para que, cuando el jugador lo toque (OnStartTouch), se empiece a reproducir (PlaySound), el sonido ("grito").
Si quieres compilar y comprobar tu activador, asegúrate de que tienes las cosas básicas, como el lugar del jugador, la luz, étcera. No te olvides de asignar un sonido a la entidad "grito".
Depurando
Source provides various debugging tools for when an I/O chain is not working as expected.
Foremost among them is the object properties dialog itself. Invalid inputs outputs are highlighted red in the entity's input or output list; the I/O icons at the bottom of the dialoge also change accordingly. Invalid outputs also show up in Check For Problems (Alt+P). It's a good idea check for problems before every compile.

Away from Hammer, there are a number of console commands and variables that will help you spot errors while your map is running:
developer <0-2>
- Developer mode reports all entity I/O to the console, and unless you're playing on a dedicated server that enables cheats (which is needed for all of the commands below). If you are in
developer 2
, you will also get the last eight lines of the console displayed at the top of your screen. ent_messages_draw <bool>
- This displays the same information as developer mode, except that instead of appearing in the console it's drawn in the 3D world at the location of the entities in question.
ent_fire <targetname or classname> <input> <parameter>
- This extremely useful command allows you to manually fire inputs on any entity at any time. If you want to unlock a door ahead of time, you would type
ent_fire my_door unlock
, followed if you're feeling lazy byent_fire my_door open
. - Like the "output target" field in Hammer,
ent_fire
supports classnames and wildcards. If you want toent_fire npc_* ignite
, you can!Consejo:
ent_fire
is where the special!picker
targetname comes in. Use it to target whatever is under your crosshair. ent_pause
- This command pauses all entities in the map except the player; submit it again to unpause. It is designed for use with
ent_step
. ent_step <number of steps>
- When used with
ent_pause
, this command makes entities perform a specified number of I/O steps before pausing again (default is 1).
See also
- Entity Creation
- List of entities
- Targetname
- User Inputs and Outputs Pendiente: Merge into this article
- AddOutput