taller

Taller Crea tu propio juego de Spectrum (capítulo 1)

Una de las características más recordada de nuestra querida Microhobby fue aquella que nos permitió a muchos hacer nuestros pinitos en programación y hardware. Entre otras cosas, y casi siempre en forma de talleres breves, podíamos «picar» líneas y líneas de código para hacer nuestros propios juegos. Luego podíamos modificarlos y hasta aprender de forma autodidacta. Fue lo más parecido a aquella promesa eterna de «cómprame el Spectrum que me ayudará a estudiar». Pues bien, salvando las distancias, siempre hemos querido tener en El Mundo del Spectrum una sección técnica y hoy, gracias a los Mojon Twins, da comienzo una nueva sección de Taller en la que podréis aprender a hacer vuestro propio juego para Spectrum. Nunca es tarde si la dicha es buena. Es el momento para que os quitéis esa espinita clavada desde hace 20 ó 30 años y por fin seáis autores de vuestra propia obra maestra spectrumera.

Dividido en capítulos, los Mojon Twins irán contándonos, con su tradicional estilo surrealista y mucho humor, el método para usar su Churrera v3.99b. Veréis lo sencillo que es cuando te lo explican. Y si tenéis alguna duda podéis preguntar lo que sea por medio de los comentarios para que un profesor Mojono, simio o persona, conteste u os venda una moto seminueva, eso ya no lo sabemos.

Sin más, aquí tenéis el primer capítulo de La Churrera v3.99b – Tutorial y mandanga – Copyleft 2013 The Mojon Twins.

Pulsa aquí para ver el capítulo 1 del Taller Crea tu propio juego de Spectrum.

Capítulo 1: Introducción

¿Pero qué seto?

Eso digo yo ¿Pero qué seto? Ufff… Hay tanto que decir, y tan poco espacio. Podría tirarme horas charlando y diciendo chorradas, pero intentaré no hacerlo. Me han dicho que tengo que ser claro y conciso y, aunque me cueste, trataré de serlo.

Empecemos por el principio. En realidad un poquito más adelante, que hay mucha gresca entre creacionistas y evolucionistas. Vayámonos a 2010… (Aquí suena la música típica de poner imagenes del pasado, esa que hace taaaa, tararará taráaaa, tararara taráaaa… )

A principios de año tuvimos una idea en Mojonia. Básicamente estábamos hartos de copiar y pegar a la hora de hacer güegos. Porque, a ver, no todo es cuestión de copiar y pegar, pero bien es cierto que cantidad de cosas siempre se hacen igual, cambiando varios parámetros. A ver, si te piensas que los que hacemos güegos escribimos la misma rutina de pintar la pantalla con tiles cada vez que hacemos un güego… po no. También estábamos hartos del arduo trabajo manual. Que si pasar a mano los sprites al formato de la splib2, que si ordenar a mano los tiles para que SevenuP los cogiese en el orden correcto, que si pasar el mapa, que si colocar enemigos con una hoja de cuadritos… Había mil quehaceres a la hora de hacer güegos que resultaban tediosos y aburridos. ¿Y quién quiere aburrirse mientras hace algo que supuestamente le gusta? Nosotros no. Y tú tampoco, supongo.

Ya lo sé. Que eso de diseñar el güego y hacer las cosas en papel milimetrado es muy de los 80 y tal pero, a ver, en serio, es un coñazo. Uno puede ser friki, pero masoquista no.

Se nos ocurrió que lo que necesitábamos era un framework, que le llaman ahora, que nos permitiese disponer de los módulos de código que queríamos utilizar de forma sencilla, y que nos hiciese llevadero todo el tema de la conversión e integración de datos (gráficos, mapas, posicionamiento de enemigos y objetos…). Empezamos tímidamente escribiendo las utilidades de conversión, para luego ir levantando, usando trocitos de aquí y de allá, un engine que sirviese como base.

Teníamos un montón de ideas para el engine. Podríamos habernos puesto a desarrollarlo poco a poco y luego sacar el güego definitivo, pero nosotros no funcionamos así. Como se nos iban ocurriendo paranoias, íbamos sacando güegos cada vez que le metíamos una cosa nueva al engine. Así, en cuanto estuvo listo el “mínimo operativo”, lo estrenamos con Lala the Magical, Cheril of the Bosque, Sir Ababol y Viaje al Centro de la Napia.

Como la gracieta, dentro de la retroescena, era que nosotros hacíamos juegos “como churros” (¡pero qué churros, señora!), decidimos llamarle al sistema “la Churrera”. Y así empezó todo…

Pero entonces ¿qué es exactamente la Churrera?

Pues eso mismo: la Churrera es un framework que se compone de varias cosas muy chulas:

1. El engine, o “motor”, el corazón de la Churrera. Se trata de un pifostio de código bestial que se “gobierna” mediante un archivo principal llamado “config.h” en el que decimos qué partes del motor usaremos en nuestro güego y cómo se comportarán.

2. Las utilidades de conversión, que nos permiten diseñar nuestro güego en nuestros editores preferidos y, de forma incolora, inodora e insípida, meter todos esos datos en nuestro güego.

3. Un montón de monos, imprescindibles para cualquier cosa que se quiera hacer en condiciones.

La Churrera ha tenido muchas versiones a lo largo de los últimos tres años. De forma interna hemos llegado a la versión 4.7, pero el pifostio se nos lió tanto que no es, para nada, presentable. Tiene demasiados hacks y está muy desordenada. Así que cuando se nos ocurrió hacer un tutorial decidimos irnos para atrás un poco, a un punto del pasado en el que el tema era aún manejable: la versión 3.1 (Trabajo Basura, Zombie Calavera Prologue). Pero no os penséis que nos hemos limitado a daros nuestra “versión vieja” y santas pascuas. No, nada de eso.

Durante un par de meses nos hemos dedicado exclusivamente a coger la versión 3.1, corregirle todas las cosas que estaban chungas, cambiar la mitad de los componentes para hacerlos más rápidos y más compactos, y añadir un montón de características. Así construímos la versión 3.99b, que es la que ponemos a vuestra disposición y que, en muchísimos sentidos, es más avanzada, más rápida, y hace más cosas que la versión 4.7. De hecho, nos ha salido tan bien que continuaremos el desarrollo a partir de esta versión 3.99b, incluyendo las mejoras de la “rama 4” (Ramiro el Vampiro) que consideremos interesantes.

La versión 3.99b está tan optimizada que, si recompilamos los viejos juegos con ella, obtenemos binarios entre 2 y 5Kb más pequeños, con movimientos más rápidos y mucho más fluidos. Y está a vuestra disposición.

Además, grabada en un diskette da la consistencia necesaria al material magnético para que, lanzado en plan ninja, cercene limpiamente las cabezas de los enemigos.

Pero ¿qué se puede hacer con esto?

Pues un montón de cosas. A nosotros se nos han ocurrido ya un montón. Si bien es cierto que hay elementos comunes y ciertas limitaciones, muchas veces te puedes sacar de la manga una paranoia nueva solamente combinando de forma diferente los elementos que tienes a tu disposición. ¿Quieres ejemplos? Pues para eso mismo hemos lanzado la Mojon Twins Covertape #2. Si todavía no la tienes, bájatela. AHORA.

Para la Mojon Twins Covertape #2 lo que hicimos fue contratar a una tribu de indios pies-sucios (oriundos de la Jungla de Badajoz). A cada uno le escribimos una característica de la churrera en la espalda y otra en el pecho, y les animamos a descender por las colinas haciendo la croqueta. Cuando llegaban abajo hacíamos una foto y anotábamos las combinaciones. Con esas combinaciones hacíamos un güego. Luego llamábamos Alberto, el Mono Tuerto, que el tío se inventa una historias de la leche, para que las justificase con un argumento convincente. Y funciona, en serio.

Vamos a echarle un vistazo a las cosas que tenemos.

1. Valores: Todos los valores relacionados con el movimiento del protagonista son modificables. Podemos hacer que salte más o menos, que caiga más despacio, que resbale más, que corra poco o mucho, y más cosas.

2. Orientación: Podemos hacer que nuestro güego se vea de lado o desde arriba (lo que, en mojonia, conocemos como “perspectiva genital”). Es lo primero que tendremos que decidir, porque esto condicionará todo el diseño del güego.

3. ¿Sartar? ¿Volar? ¿cómor?: Si elegimos una perspectiva lateral (que el güego se vea de lado) tendremos que decidir cómo se moverá el muñeco. Podemos hacer que sarte cuando se pulse salto (Lala Lah, Julifrustris, Journey to the Centre of the Nose, Dogmole Tuppowski…), que sarte siempre (Bootee), o que cada vez sarte más, como ganando fuerza (Monono). También podemos hacer que vuele (Jetpaco).

4. Rebotar contra las paredes. Si elegimos que nuestro güego tenga perspectiva genital, podemos hacer que el prota rebote un poco cuando se choque con una pared.

5. Bloques especiales. Podemos activar o desactivar llaves y cerrojos, o bloques que se pueden empujar. Esto funciona para ambas orientaciones, si bien en la vista lateral los bloques solo pueden empujarse lateralmente.

6. Disparar. También podemos hacer que el prota dispare. En los güegos de vista genital disparará en cualquiera de las cuatro direcciones principales. También podemos indicarle al motor qué dirección (vertical u horizontal) tiene preferencia en las diagonales. En los de vista lateral, disparará en un sentido u otro según mire a izquierda o derecha.

7. Enemigos voladores: que te persiguen sin tregua.

8. Enemigos perseguidores: parecidos pero diferentes… Ya hablaremos de ellos.

9. Pinchos y cosas del escenario que te matan, no necesariamente pinchos.

10. Matar: en los güegos de perspectiva lateral podemos hacer que los enemigos, un cierto tipo de enemigos, se mueran si les pisas la cabeza.

11. Objetos: para que haya cosas que ir recopilando y guardándose en la buchaca.

12. Scripting Si lo de arriba no es suficiente, podemos inventarnos muchas más cosas usando el sencillo lenguaje de scripting incorporado.

Y más cosas que ahora mismo no recuerdo pero que irán surgiendo a medida que vayamos haciendo cosas.

El truco está en combinar estas cosas, echarle imaginación, timar un poco con los gráficos, y, en definitiva, ser un poco creativo. Por ejemplo, si ponemos una gravedad débil (que hará que el prota caiga muy lentamente) y habilitamos la capacidad de volar con muy poca aceleración, ponemos un fondo azul y el personaje tiene forma de buzo, podemos hacer como si estuviésemos debajo del agua. También se pueden probar cosas extremas, como por ejemplo poner los valores de aceleración vertical y de gravedad en negativo, con lo que el muñeco se vería empujado hacia arriba y haría fuerza para hundirse… cosa que, por cierto, no hemos probado nunca y que me acaba de dar una idea… En cuanto hable con Alberto y se invente un argumento tenemos güego nuevo.

¿Véis? ¡Así funciona! Mandadme un email y os doy el teléfono de Alberto.

Entonces ¿Cómo empezamos?

Con imaginación. No me vale que cojas un juego nuestro que ya esté hecho y le cambies cosas. No. Así no vas a llegar a ningún sitio. La gente se cree que sí, pero NO. Invéntate algo, empieza de cero, y lo vamos construyendo poco a poco.
Si no se te da bien dibujar, búscate a un amigo que sepa, que siempre hay. En serio, siempre hay. Si no encuentras a nadie, no pasa nada: puedes usar cualquier gráfico que hayamos hecho nosotros. En los paquetes de código fuente de todos los güegos están todos los gráficos en png y tal. Aprender a recortar y pegar con un editor de gráficos es un mínimo que deberás aprender.

De todos modos, para empezar, y siendo conscientes de que realmente no sabéis qué se puede y qué no se puede hacer, os invito a que vayamos construyendo, poco a poco, el Dogmole Tuppowski. ¿Por qué este? Pues porque usa un montón de cosas, incluyendo el scripting. Pero no quiero que vayas, te pilles el paquete de fuentes de la Covertape #2, y te limites a seguir el tutorial mirando los archivos y tal. No. Lo suyo es que empieces con el paquete del engine vacío que os vamos a ofrecer más abajo, y que, para cada capítulo, vayas obteniendo los diferentes recursos y realizando las acciones necesarias, como si realmente estuvieses creando el juego desde cero.

¿Para qué tanto teatro? Pues porque cuando te quieras poner a hacer el tuyo ya no será la primera vez y, créeme, es toda una ventaja. Y porque el teatro mola. ¡Salen tetas!

Venga, va. Vamos a ello

Lo primero es inventarse una historia que apunte al gameplay. No vamos a escribir todavía una historia para el güego (porque ahora no la necesitamos) – eso vendrá dentro de poco. Primero vamos a decidir qué hay que hacer.
Vamos a hacer un güego con Dogmole Tuppowski, un personaje que nos inventamos hace tiempo y que tiene esta pinta:

En primer lugar vamos a hacer un juego de perspectiva lateral, de plataformas, en el que el personaje salte. No saltará demasiado, pongamos que podrá cubrir una distancia de unos cuatro o cinco tiles horizontalmente y dos tiles verticalmente. Esto lo tenemos que decidir en este punto porque tendremos que diseñar el mapa y habrá que asegurarse de que el jugador podrá llegar a los sitios a los que decidamos que se puede llegar.

Vamos a hacer que en el juego haya que llevar a cabo dos misiones para poder terminarlo. Esto lo conseguiremos mediante scripting, que será algo que dejaremos para el final del desarrollo. Las dos misiones serán sencillas y emplearán características automáticas del motor para que no haya que hacer un script demasiado complicado:

1. Habrá cierto tipo de enemigos a los que tendremos que eliminar. Una vez eliminados, tendremos acceso a la segunda misión, porque se eliminará un bloque de piedra en la pantalla que da acceso a una parte del mapa.

2. Habrá que llevar, uno a uno, objetos a la parte del mapa que se desbloquea con la primera misión.

Para justificar esto, explicaremos que los enemigos que hay que eliminar son unos brujos o monjes o algo así mágico que hacen un podewwwr que mantiene cerrada la parte del escenario donde hay que llevar los objetos. ¡La historia se nos escribe sola!

Por tanto, ya sabemos que tendremos que construir un güego de vista lateral, con saltos, que se pueda pisar a cierto tipo de enemigos y matarlos, que sólo se pueda llevar un objeto encima, y que necesitaremos scripting para que se pinte la piedra en la entrada del sitio donde hay que llevar los objetos si no hemos matado a los enemigos. Además, el hecho de llevar las cosas una a una para dejarlas en un sitio necesitará otro poquito de scripting también.

Como lo tenemos a huevo, nos inventamos la historia, que, si te leíste en su día la ficha del Covertape #2, ya conocerás:

Dogmole Tuppowski es el patrón de un esquife de lata que hace transportes de extraperlo de objetos raros y demás artefactos de dudosa procedencia (algunos dicen que con propiedades mágicas) para cierto departamento de la Universidad de Miskatonic (provincia de Badajoz). Sin embargo, una noche, justo cuando iba a hacer su entrega con cajas repletas de misteriosos y mágicos objetos, se levantó una tempestad del copetín que estrelló su barco contra un montón de pieras hostioneras con lo que el reventón fue de aúpa, y todas las cajas quedaron desperdigadas por la playa y alrededores.

La señorita Meemaid de Miskatonic, que se encontraba peinando sus Nancys a la luz de la luna llena en su torreón del acantilado, lo vio todo y, consciente de que el contenido de las cajas podría ser muy preciado por ocultistas y demás gente raruna, decidió llevárselas para ella. Como su camión estaba roto y reparándose y no lo tendría hasta el día siguiente, puso a sus esbirros de dudosa procedencia a guardar las cajas, y, por si acaso, también mandó a los veinte Brujetes de la Religión de Petete que hicieran un hechizo mental para cerrar las puertas de la Universidad.

La misión de Dogmole, por tanto, es doble: primero tiene que eliminar a los veinte Brujetes de la Religión de Petete y, una vez abierta la puerta de la Universidad, tendrá que buscar y llevar, una por una, cada una de las diez cajas al vestíbulo del edificio, donde deberá dejarlas en donde pone “BOXES” pulsando “A”.

Y ya, con esto, podemos empezar a diseñar nuestro juego. En realidad el tema suele salir así. En nuestro a veces hacemos trampas y jugamos con ventaja: muchos de nuestros juegos han surgido porque hemos añadido una nueva capacidad a la churrera y había que probarla, como ocurrió con Bootee, Balowwwn, Zombie Calavera o Cheril the Goddess. El proceso creativo es insondable y requiere que tengas algo de inventiva e imaginación y eso, desgraciadamente, no es algo que se pueda enseñar.

Ah, que se me olvidaba. También hicimos un dibujo de la Meemaid. Es esta:

Metiendo la cara en el barro

Vamos a empezar a montar cosas. En primer lugar, necesitarás z88dk, que es un compilador de C y splib2, que es la biblioteca de gráficos que usamos. Como no tenemos ganas de que te compliques instalando cosas (sobre todo porque la splib2 es muy vieja y es complicado compilarla usando un z88dk moderno), hemos preparado, para los usuarios de Windows, este paquete que deberás descomprimir directamente sobre la raíz de C: y que contiene z88dk 1.10 y splib2. Si te sale bien, deberá aparecer una carpeta C:z88dk10 con cosas dentro.

http://www.mojontwins.com/churrera/mt-z88dk10.zip

Los usuarios de Linux y otros sistemas no deberían tener ningún problema en instalar la última versión de z88dk en sus sistemas y copiar el archivo splib2.lib y splib2t.lib en donde las clibs y spritepack.h en donde los includes. Estos dos archivos los he dejado, para ellos, aquí:

http://www.mojontwins.com/churrera/mt-splib2.zip

También vamos a necesitar un editor de textos. Si eres programador ya tendrás uno que te guste de la hostia. Si no lo eres, por favor, no utilices el bloc de notas de Windows. Bájate Crimson Editor, por ejemplo. En realidad cualquiera es mejor que el bloc de notas de Windows. Si tienes Linux ya tendrás al menos unos diecisiete editores de textos instalados que son mejores que el bloc de notas de Windows: ahí jugáis con ventaja, linuxeros.

Nos hará falta el editor Mappy para hacer los mapas del juego. Puedes bajarte la versión oficial, aunque es mejor usar la versión mojona que está modificada con las cosas que necesitamos y un par de características custom que vienen muy bien y que ya veremos.

http://www.mojontwins.com/churrera/mt-mappy.zip

Otra cosa que necesitaremos será SevenuP para realizar la conversión de gráficos. Bájatelo de su web oficial, aquí:

http://metalbrain.speccy.org/

Cuando lleguemos a la parte del sonido hablaremos de las utilidades Beepola y BeepFX. Puedes buscarlas y descargarlas ahora si quieres, pero no las utilizaremos hasta el final.

Otra cosa que necesitarás será un buen editor de gráficos para pintar los monitos y los cachitos de escenario. Te vale cualquiera que grabe en .png. Te reitero que si no sabes dibujar y no tienes ningún amigo que sepa puedes pillar los gráficos de Mojon Twins. Igualmente vas a necesitar un editor gráfico para recortar y pegar nuestros gráficos en los tuyos. Te vale cualquier cosa. Yo uso una versión super vieja de Photoshop porque es a lo que estoy acostumbrado. Mucha gente usa Gimp. Hay un montón, elije el que más te guste. Pero que grabe .png. Remember. Se bebes no kandusikas.
Una vez que eso esté instalado y tal, necesitaremos la Churrera. En la siguiente dirección está el paquete completo de la versión 3.99b:

http://www.mojontwins.com/churrera/mt-churrera-3.99b.zip

Para empezar a trabajar, descomprimimos el paquete de la Churrera en un sitio chuli y lo personalizamos para nuestro juego siguiendo estos pasos:

1. Le cambiamos el nombre al directorio principal Churrera3.99b por el de nuestro juego. Por ejemplo “Dogmole Tuppowski”.

2. Le cambiamos el nombre al módulo C principal por el de nuestro juego. Este módulo está en /dev/ y se llama churromain.c. Le cambiaremos el nombre a dogmole.c.

3. Editaremos el archivo make.bat que está en /dev/ con nuestro editor de texto para adaptarlo a nuestro juego. En primer lugar hay que sustituir donde pone %1 y poner el nombre que le pusiste a churromain.c. En nuestro caso, dogmole. Debería quedar así:

Cada vez que hagamos un juego nuevo tendremos que descomprimir una nueva copia de la Churrera y personalizarlo igualmente.

Ya estamos listos para empezar… Pero os tendréis que esperar al próximo capítulo.

Mojon Twins

El Mundo del Spectrum

El Mundo del Spectrum es un medio digital dedicado al Sinclair ZX Spectrum, a los 80 y al Retro en general. Nació como homenaje a Microhobby en 1996 en formato revista mensual evolucionando hasta esta cuarta época. Como medio audiovisual se publica regularmente el Podcast llamado El Mundo del Spectrum Podcast y material en vídeo en el canal de Youtube. Publicados dos libros de gran éxito editorial. Si te gusta el Retro y el Spectrum en particular, esta es tu web. Bienvenido/a.

Publicaciones relacionadas

32 comentarios

  1. Al ataqueeeeeeeerl!!!

    Muchas gracias por el taller. Tiene muchas letricas para leer así que luego cuando lo devore, os digo que tal.

    Pero seguro que genial, ya se ve a simple vista.

    A ver si nos salen cosas la mitad de chulas que a estos "mostrus".

    Y ahora, os dejo que tengo clase Mojónica!

    XD

  2. Ya está todo leído, descargado los archivos necesarios y renombradas las carpetas y %1 correspondientes.

    Como em esperaba, por ahora las explicaciones son muy claras y con ese sentido del humor característico de los Mojon Twins.

    De esta forma se hace muy fácil de seguir y muy ameno.

    Tanto… que se me ha hecho corto!!

    Queremos más clases ya!!

    Jejeje, es broma, se que montar este tinglado y que quede coherente no es moco de pavo y requiere su tiempo.

    Muchas gracias compañeros! y seguid así!

  3. Ahora mismito me lo voy a leer enterito, pero no podía evitar escribir primero para alabar esta gran iniciativa. espero que sirva de precedente para el resto de cracks que rondan por ahí y saben un güevo.

  4. Aquí otro alumno, si el tiempo (piscina) y el otro tiempo, lo permiten.
    Explicación clara para torpes como yo, me encanta. La primera clase superada, esperando al segunda.
    Seguid así de geniales.

  5. Madre mía ,que corto se me ha hecho…Quiero máaaassss.. Es la Piedra Rosetta Mojona, ahora podremos entender esas "cosas raras" que veíamos en el código fuente de los juegos. Gracias por el taller y ánimo a todos…

  6. Siguiendo a la manada bajo la tutela de los gemelos seguidores de va kah, con fidelidad devocion y un par de armas de matar, construiremos un universo mojon. Excelente iniciativa . Bravo colegas!!!

  7. Otro fiel seguidor que se une al curso¡¡¡¡, muchas gracias mojones por compartir vuestra sibiduria con nosotros.
    Después del parón que le hemos dado a cpc bros para Amstrad tenia mono de hacer grafiquillos,jejeje.

  8. Oh! No sabéis lo feliz que me hace leer un taller para esto… en serio. Me he leído ya el capítulo 1, y apenas tenga tiempo seguiré con los demás, a ver si saco tiempo y sigo. Muchísimas gracias, de verdad.

  9. Acabo de descubrir este manual, y pretendo ponerme en serio con él.
    Ya me he liquidao la primera entrega, y tan pronto como pueda sacar un rato, me pondré con la siguiente.
    Aprovecho para felicitaros por vuestra gran labor y aportes a la comunidad de la retroinformática, y del mundo de los videojuegos en general.

  10. Muy contento de dar con este blog, desde que conoci esta consola he quedado encantado, en Chile no fue muy famosa por que reinaba atari, he podido conseguir una despues de muchos años de busqueda aunque estaba con problemas he logrado repararla y ya me quedan problemas menores que corregir, estoy con muchas ansias de metermano y picar teclas y este taller viene de lujo, un saludo desde Chile!

  11. Buenísimo !!, Acabo d descubrirlo !, Mil gracias por estas sagradas escrituras…me podré kitar esa espina clavada, junto a libros d básic y algún programa más q toy recopilando,q gozada !, Gracias con mayúsculas!!

  12. Voy a hacer el curso de la churrera para ver si llego a tiempo para la bitbitjam de este año.
    Mi intención es aprender ensamblador, pero como eso me llevará bastante tiempo, y quiero presentar algo ya, me voy a poner con la churrera.

    La pena es que los mojon twins no llegaran a hacer un capitulillo más, indicando cómo meter en el juego nuestras propias músicas y efectos de sonido.

Deja una respuesta



Embalaje protección
Embalajes para la protección de mercancía
Páginas web Zaragoza
Páginas web de calidad Zaragoza
Polietileno reticulado
Todo sobre Polietileno reticulado
Botón volver arriba