Ceibal Jam/Juegos: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
<noinclude>{{GoogleTrans-es | en =show | bg =show | zh-CN =show | zh-TW =show | hr =show | cs =show | da =show | nl =show | fi =show | fr =show | de =show | el =show | hi =show | it =show | ja =show | ko =show | no =show | pl =show | pt =show | ro =show | ru =show | sv =show}}</noinclude> |
<noinclude>{{GoogleTrans-es | en =show | bg =show | zh-CN =show | zh-TW =show | hr =show | cs =show | da =show | nl =show | fi =show | fr =show | de =show | el =show | hi =show | it =show | ja =show | ko =show | no =show | pl =show | pt =show | ro =show | ru =show | sv =show}}</noinclude> |
||
[[Image:Caibal-jam-rollogo.png]] |
|||
= Ceibal Rol = |
= Ceibal Rol = |
||
Ceibal rol es un proyecto comunitario de Ceibal-Jam en el que todos podemos participar, creando, diseñando, programando... |
Ceibal rol es un proyecto comunitario de Ceibal-Jam en el que todos podemos participar, creando, diseñando, programando... |
Revision as of 07:35, 19 August 2008
GoogleTrans-es -English -български -中文(中国大陆) -中文(臺灣) -hrvatski -čeština -dansk -Nederlands -suomi -français -Deutsch -Ελληνικά -हिन्दी -italiano -日本語 -한국어 -norsk -polski -português -română -русский -svenska
Ceibal Rol
Ceibal rol es un proyecto comunitario de Ceibal-Jam en el que todos podemos participar, creando, diseñando, programando... El objetivo es lograr un potente motor de alto nivel para facilitar a maestros y docentes a crear juegos a través de esta plataforma.
Requerimientos
- Python 2.5
- PyGame
- Perspectiva isometrica/ortogonal en 2D.
- Mantener documentación en esta wiki.
- Licenciar a través de GPL v2 o equivalente. http://es.wikipedia.org/wiki/GNU
Análisis y Diseño
Introducción al análisis
A pesar de que las técnicas en que se basara el diseño son muy antiguas o mejor dicho clásicas, es justo ahí de donde radica la belleza de utilizarlas, son muy probadas y demostraron ser casos de éxito en un pasado y lo serán ahora.
Frente a nuevos problemas y complejidades sera necesario crear nuevas soluciones que se adapten a nuestro proyecto para impulsarlo a las faces de su evolución.
El código ejemplo propuesto aquí sera inicialmente meta-código, esperamos a futuro implementar código en python Creemos que es la forma de ejemplificar lo mas posible su claridad para toda la gama de voluntarios sean idóneos a la programación informática o no.
Abstracciones
Partiendo desde el requerimiento de desarrollar un motor capaz de desplegar desde una perspectiva isometrica/ortogonal, nuestro argumento es justificar el uso de coordenadas enteras y limitar los cálculos flotantes(float, etc...) por que estos agregarían una carga extra a los procesos y demorar los cálculos mas importantes del juego en si como serian la interaccio'n continua, eventos y un flujo dinámico de información ínter-comunicada entre diferentes XO para actualizar la información de el entorno y sus relaciones a otras entidades dentro del juego.
Mapas o Universo y sus Entidades
Crear las fronteras de adonde puede ir cada jugador es primordial para llegar a algo. Necesitamos un limite para concentrarnos en su implementación.
La representación de nuestro universo se limitara a un vector y su representación en un array bidimencional. Las ventajas en velocidad y trato de información sin necesidad de grandes complejidades se denotan por su forma.
- Se ve muy bien y ademas podemos compactar mucha información.
- Son rápidos si son utilizados con datos nativos.
- Nos permite reutilizar herramientas echas para tales fines (editar mapas de caracteres como niveles de juego) o directamente desarrollarlas nosotros.
map[x][y]
El tipo de información de que hay en ese lugar del mapa estará contenida en un entero sin signo (unsigned int), cada bloque (coordenada) de información vector pocicio'n(x, y) tendrá' un numero y este representara su imagen.
clase map x : entero (sin coma, sin signo) y : entero (sin coma, sin signo) + getvalue(map[x][y]) : entero --> este entero representa que dato existe en el vector. return (entero)
Supongamos entonces que deseamos crear un mapa / nivel del juego del tamaño 3 x 3 bloques, entonces tendríamos 9 bloques donde cada uno representa un lugar posible o no donde nuestro jugador podría estar.
map[3][3]
[0][1][2] [0] 0 0 0 [1] 0 1 0 [2] 0 0 0 1 = libre 0 = obstruido
map[0][0].getvalue = 1 map[1][1].getvalue = 0
Donde cada numero en cada casillero representara de una forma mas amplia el tipo de objeto que estará situado ahí.
Extendamos un poco nuestra tabla de posibles valores para nuestro mapa/nivel con el limite 1024.
desde hasta descripción --------------------------------------------------- 0 vació 1 <= 200 obstáculos 201 <= 400 pisos 401 <= 600 players/jugadores. 601 <= 800 objetos/items. 801 <= 1024 eventos ---------------------------------------------------
El motivo de el gran rango de posibles tipos de objetos en cada valor se debe a que fácilmente podríamos crear a futuro una extensión en caracteres o códigos donde el rango se aumentaría potencialmente facilitando mas recursos.
Por ahora nos limitaremos a utilizar 1024 atajos a diferentes representaciones en nuestro juego.
Ahora concentrémonos en el orden de cada objeto, donde 0 es vació del '1' al '200' inclusive tendremos obstáculos, entonces en estos lugares no se podrá ni mover ni estar nuestro personaje, es ahí donde nos encontramos con una propiedad para cada rango de valores.
"caminable" o "no caminable"... suena un poco extraño pero utilizaremos un valor boolean (verdadero / falso) y le pondremos un nombre en ingles porque queda mas lindo, walkable.
Como es notable cada valor necesita un campo externo donde definirse, por ello apartir de ahora nos referiremos estos elementos como sprite, un sprite es simplemente un dibujo de algo, un personaje un objeto u cualquier cosa, en este caso seran objetos donde el personaje otro sprite no puede moverse, entonces definamos estos objetos graficos(sprite).
clase floor sub-clase sprite + id : entero # representa el valor del bloque que representa. + walklable : (true or false)
Ahora ya establecida una propiedad (walkable) podremos concentrarnos en el jugador que las recorre. donde getpos debuelve un valor de vector posicion y mover(xy) aumenta o disminuye su valor de referencia en el mapa.
clase player() sub-clase sprite x y + getpos(self) : (x,y) - mover((+/-x),(+/-y)) : null
Como denotamos no podemos sobrescribir valores dentro de nuestro vector bidimencional mapa, por motivos claros, estariamos borrando información importante de su estructura, entonces crearemos la capa de objetos-entidades y objetos-items para su posterior implementacio'n.
sera entonces una capa superior imaginaria a la del mapa, por ahora sera una 'p' para facilitar su representación. aunque p = alt+80 no tomaremos como referencia su valor en el proyecto.
0 = null 1 = floor @ = player 0123456789 0123456789 map = 0 0000000000 player = 0 0000000000 1 0001111110 1 0001111110 2 0111111110 2 0111111110 3 0111111110 3 01111p1110 4 0000111110 4 0000111110 5 0000000000 5 0000000000
entonces si hacemos una llamada a la función de la clase player getpos(self) retornaría un valor igual a (renglón 3, columna 5)
...
Ahora crearemos un constructor de mapas en la clase map, se llamara 'buildmap' y construye un mapa...
clase map x : entero (sin coma, sin signo) y : entero (sin coma, sin signo) + buildmap() : map[][] # constructor de mapas + getvalue(map[x][y]) : entero