-
Notifications
You must be signed in to change notification settings - Fork 4
Los objetos que el jugador puede manipular en el juego son instancias de Obj. Para crearlos, se utiliza la función ctrl.creaObj(). Sus parámetros son: nombre, sinónimos, descripción, localidad en la que se encuentra y Ent.Scenery o Ent.Portable según sea escenario o sea un objeto que se pueda transportar.
const objMesa = ctrl.creaObj( "mesa",
[],
"Una mesa antigua.",
locSalon,
Ent.Scenery
);
const objBotella = ctrl.creaObj( "botella",
[ "agua", "recipiente" ],
"Una botella llena de agua.",
ctrl.lugares.limbo,
Ent.Portable
);
Cuando por localidad se indica ctrl.lugares.limbo, la botella no será visible en ninguna localidad del juego, hasta que se mueva a alguna de ellas.
Nótese que los sinónimos se pasan utilizando un vector de JavaScript. Como cualquier otro objeto, se le pueden añadir atributos y métodos que sirvan a nuestros propósitos.
objBotella.llena = false;
objBotella.describe = function() {
let toret = "Una botella de vidrio. ";
if ( this.llena ) {
toret += "Está llena de agua.";
} else {
toret += "Está vacía.";
}
return toret;
};
objBotella.preExamine = function() {
return this.describe();
};
Ahora se puede llamar al método describe() para obtener una descripción detallada de la botella. Por ejemplo, podría ser llamado desde preExamine(), si se va a hacer algo más (al contrario que en el ejemplo). O, quizás, pueda ser llamada directamente, como se ve a continuación.
objBotella.llena = false;
objBotella.preExamine = function() {
let toret = "Una botella de vidrio. ";
if ( this.llena ) {
toret += "Está llena de agua.";
} else {
toret += "Está vacía.";
}
return toret;
};
Como se menciona más arriba, la botella tiene que moverse a la localidad del salón (locSalon), para que se vea allí.
objBotella.mueveA( locSalon );
Otra posibilidad es que la mesa sea un objeto contenedor. Para marcar Los objetos como contenedores se utiliza setContainer()/ponContenedor(), que por defecto, si no se les pasa un parámetro, se asume que este es true. Los métodos esContenedor()/isContainer() devuelven true o false según el objeto sea o no contenedor.
Estos objetos pueden contener otros objetos, y son visibles para el jugador si están abiertos (por defecto lo están). Para saber si un contenedor está abierto, se usa el método isOpen()/estaAbierto(). Se cambia el estado de abierto a cerrado con setOpen()/ponAbierto(). Por defecto, si no se pasa un parámetro, se entiende que es true.
Nótese que nada impide llamar a estaAbierto() o esContenedor() incluso aunque el objeto no sea un contenedor. Por defecto, los objetos no son contenedores y están abiertos. También es posible meter objetos dentro de otros, pero no serán manipulables si el contenedor no está marcado como tal y está abierto.
En el caso del salón, la mesa es un contenedor que siempre está abierto (para el usuario será un soporte, pero es indifirente). Solo lo siguiente obtiene ya el comportamiento deseado.
objMesa.ponContenedor();
objBotella.mueveA( objMesa );
Así, al jugar:
> m
Salón
Estás en el salón, hay una mesa.
> ex mesa
Una mesa antigua.
Tiene: botella.
> coge la botella
Cogida.
En lugar de una mesa, podría tratarse de un armario que puede abrirse y cerrarse.
const objArmario = ctrl.creaObj( "armario",
[],
"Un armario antiguo.",
locSalon,
Ent.Scenery
);
objArmario.ponContenedor();
objArmario.ponAbierto( false );
objArmario.preOpen = function() {
let toret = "Pero si ya está abierto...";
if ( !this.isOpen() ) {
this.setOpen();
toret = "El armario está ahora abierto.";
}
return toret;
};
objArmario.preExamine = function() {
let toret = this.desc;
if ( this.isOpen() ) {
toret += " Está abierto.";
} else {
toret += " Está cerrado.";
}
return toret;
}
objBotella.mueveA( objArmario );
Ahora, al jugar...
> m
Salón
Estás en el salón, hay una mesa flanqueada por un armario.
> ex mesa
Una mesa antigua.
> ex armario
Un armario antiguo. Está cerrado.
> abre el armario
El armario está ahora abierto.
> abre el armario
Pero si ya está abierto...
> ex armario
Un armario antiguo. Está abierto.
Tiene: botella.
> coge la botella
Cogida.
Finalmente, hay objetos que son manipulables del todo por el jugador, como la botella: puede cogerla, dejarla... o parcialmente manipulables, como la mesa: se puede examinar, y coger cosas de ella, pero no llevársela. Hay objetos que tienen una restricción más: ¿son o no son alcanzables? Por supuesto, por defecto sí lo son. ¿Qué es un objeto no alcanzable? Por ejemplo, podría ser una flor en lo alto de un acantilado, el sol o la luna...
Para manejar esta restricción extra, se utilizan isReachable()/esAlcanzable() para saber si el objeto está o no al alcance, y setReachable()/ponAlcanzable() para saber si está o no alcanzable. Por defecto, si no se le pasa ningún parámetro, se asume true, es decir, que el objeto es alcanzable. Es importante tener en cuenta, de nuevo, que los objetos son alcanzables por defecto.
Supongamos que en el salón hay una lámpara.
const objLampara = ctrl.creaObj( "lámpara",
[ "lampara", "arana" ],
"Una vieja araña.",
locSalon,
Ent.Scenery
);
objLampara.ponAlcanzable( false );
Ahora, al jugar...
> m
Salón
Estás en el salón, hay una mesa flanqueada por un armario. En el techo, puedes ver una antigua lámpara.
> ex lampara
Una vieja araña.
> ex mesa
Una mesa antigua.
> lame mesa
Al final, decides no hacerlo.
> lame lampara
Demasiado lejos.
> huele mesa
No huele a nada especial.
> huele lampara.
Demasiado lejos.
Este comportamiento puede por supuesto cambiarse con los métodos preExamine(), preTaste() o preSmell(), pero el objetivo es que las respuestas por defecto tengan sentido incluso cuando se estén utilizando aquellas por defecto.