Jorge Vallejo Blog

Blog del creativo, ilustrador y profesor de videojuegos Jorge Vallejo

cortos

Unity Anima2D protocolo creación de personaje

Los pasos a seguir para crear un personaje utilizando el plugin de Anima2D son:

  1. Descargarse Anim2D desde el assets store de Unity
  2. Importar el sprite sheet de nuestro personaje en Unity
  3. Dividir los sriptes en partes utilizando el sprite Editor
  4. Comprobar el Canal Alfa para verificar que no hay ruido
  5. Comprobar que los cortes no interfieren unos en partes de otros
  6. Nombrar cada parte, de forma que se identifique claramente las partes y el personaje por ejemplo “X_cabeza” ,”X_pie_i” etc
  7. En el inspector del proyecto seleccionar el Sprite padre , boton derecho Create -> Anima2D-> Sprite Mesh
  8. Creara todos los sprites recortados pero que seran Skined Mesh para ser asociados a los huesos
  9. Creamos un objeto vacio, que será el padre de todos los elementos
  10. Añadimos los Sprites creados por Anima2D al padre
  11. Importamos la figura patrón y colocamos los elementos según la figura patrón
  12. Creamos un nuevo Sorting Layer como nuestro personaje , ya que nos permitirá usar el Order in Layer para ese personaje
  13. Seleccionamos todos los sprites y seleccionamos nuestro Sorting Layer
  14. Colocamos los Order in Layer, debemos hacer pruebas para ver si los brazos, piernas etc pasan por delante.
  15. Dentro de GameObject principal creamos un objeto vacío Huesos
  16. Importante, antes de empezar a crear los huesos deberíamos comprobar como funcionaran los puntos de pivote, ya que una vez colocados no podremos moverlos y tendremos que borrarlos y hacerlos nuevos.
  17. Creamos los huesos como hijos de ese GameObject con Botón Derecho -> 2D Object -> Bone
  18. Lo renombramos a Cintura y colocamos en su posición con la herramienta mover
  19. Importante No modificar la escala de los huesos,se modifica la longitud con la propiedad Length
  20. Seleccionando Cintura , creamos un nuevo Bone que será hijo de la misma y re nombraremos a Tronco
  21. Continuamos creando la jerarquia de huesos podemos usar  Alt + Shift + B​ como atajo de teclado
  22. Salvamos
  23. Comprobamos que los huesos estan bien colocados
  24. Unión Hueso -> Sprite Mesh
  25. Selecionamos en la Jerarquia el Sprite Mesh, en Bones damos a + para añadir el hueso al que va unido
  26. Arrastramos el hueso al componente , podemos borrar los huesos que no le afecten si es necesario.
  27. Si tiene más de un hueso asociado lo arrastramos directamente a Set Bones
  28. Enlazamos todos los Sprite Mesh con sus diferentes huesos
  29. Salvamos
  30. Creación de área de influencia del hueso
  31. Selecionamos el Sprite Mesh y vamos a Window -> Anima2D -> Sprite Mesh Editor
  32. Deberemos Dar a Bind para que cree el area de influencia, aparecerá una ventana para controlar los “pesos” de los diferentes huesos, si marcamos Overlay veremos su area de influencia.
  33. Damos a Apply
  34. Dejaremos la ventana Sprite Mesh Editor abierta para repetir el proceso
  35. Si nos equivocamos al añadir un hueso, tenemos que seleccionar el Sprite Mesh de la jerarquía ir de nuevo a Sprite Mesh Editor y dar a Unbind
  36. Si un Sprite tiene varios huesos, necesitaremos mejorar su malla , para ello podemos ir a Sprite Mesh Editor-> Slice y aumentar el Tessellation para cree más puntos en la malla
  37. Comprobamos que tenemos todos los Sprites Mesh enlazados, sino lo tuviéramos veríamos un Warrning
  38. Controles
  39. Creamos un objeto vacío llamado Controles
  40. Con él seleccionado Boton derecho 2d Object -> Ik Limb , es para controlar 2 huesos que nos servira para brazos y piernas controlando el pie y la mano mediante giros.
  41. Importante Colocar el Gizmo en su posición correcta antes de enlazarlo con los huesos
  42. Lo colocaremos normalmente sobre el punto de pivote del tobillo o la muñeca.
  43. Le pasaremos el segundo hueso, pierna2d o anted
  44. El Gizmo cambiará de color a Azul, podemos aumentar o disminuir su tamaño, desde el panel Escena -> Gizmos ->3D icons
  45. Si queremos controlar un elemento con más de huesos, creamos un control Ik CCD
  46. Seleccionamos control Boton Derecho -> Object 2D-> IK CCD le pasamos el  último hueso
  47. Tendremos que aumentar el Num Bones según lo huesos que tengamos.
  48. Salvamos
  49. Animación
  50. Importaremos imagenes de referencia, unas líneas guia, suelo etc e imagenes del ciclo que queramos animar.
  51. Podemos crear poses de las animaciones que luego se pueden reuilizar
  52. Para ello , con el personaje principal selecionado , añadiremos el componente Pose Manger
  53. Damos a create new pose y guardamos la pose como base.assets en nuestra carpeta del personaje
  54. Creamos las poses que consideremos necesarias siguiendo este procedimiento
  55. Para animar , con el personaje principal seleccionado , vamos Window -> Animation
  56. Le damos a crear una primera animación que será parado o Idle
  57. Nos creará un Animator que gobernará las diferentes animaciones
  58. Si queremos que la animación coincida en con el principio -> buscamos la animación es decir, .anim y en el Inspector marcamos Loop Pose
  59. Cuando queramos crear una nueva animación, con el personaje seleccionado vamos a Window -> Animation y Pinchamos en el nombre de la última animación creada para sacar el botón Create new clip y crear una nueva animación.
  60. Para animar “al vuelo”, es decir, que los cambios que se realicen en los controles o los huesos generen un nuevo fotograma simplemente debemos marcar el botón rojo rec.

Darkest Dungeon reinvención del Dungeon

Darkest Dungeon es un buen ejemplo de lo que un videojuego indie puede llegar a conseguir, salio en Kickstarter y consiguió triplicar su objetivo de financiación y consolidarse como un buen rpg por turnos.

El videojuego tiene una estética marcada próxima al comic, ello habría dificultado realizar animaciones complejas por lo que el equipo de Red Hook Studios decidió hacer unas animaciones sencillas y complementar con movimientos de cámara y partículas, utilizando un sistema de combate por turnos , la principal baza del juego es la estrategia, la exploración, el desarrollo de los personajes y la historia, que avanza hacia la oscuridad y la locura Lovercrafianas.

Darkest Dungeon es un buen ejemplo de que los videojuegos en 2D pueden tener mucho que decir dentro de la industria.

 

Referencias para videojuego tipo beat’em up

Fighter sprite sheetPor mucho que avance la tecnología siempre vamos a necesitar referencias para crear animaciones, ya sean estas vídeos , secuencias de imágenes o hojas de personaje.

La animación para videojuegos 2D suele ser bastante más sencilla que las animaciones para televisión o cine, y se basa en principios como la reutilización, la optimización y un uso bajo de memoria.

Dungeons & Dragons: Chronicles of Mystara alcanzó la gloria de los llamados  beat’em up , tanto por su excelente diseño de juego que utilizaba reglas del juego de rol D&D simplificadas como sobre todo por un cuidado diseño de personajes y animaciones que enriquecía enormemente la experiencia.

Por eso recomiendo los sprite sheet de este juego con solera que llego a tener un “remake” para Playstation con un videojuego claramente inspirado en el mismo Dragon’s crown 

Sprites Sheet en Sprite DataBase

 

Crear un sprite sheet desde photoshop

Existen muchas herramientas especificas para crear sprites, casi todos los programas de animación permiten exportar la secuencia de imágenes como un sprite sheet , es decir , una imagen con todos los sprites.

Sin embargo puede que queramos trabajar con photoshop directamente para crear nuestros sprites, afortunadamente el proceso para crear el sprite sheet es sencillo, aunque requiere de ayuda externa.
El workflow de exportación de animación en photoshop a sprite sheet seria el siguiente:

  1. En  photoshop CS6, crearemos un archivo nuevo, tendremos en cuenta que el tamaño que le demos sera la base para crear el sprite sheet
  2. En photoshop CS6 , abrimos la Ventana -> linea de tiempo y creamos una linea de tiempo basada en capas
  3. Cada fotograma se crea añadiendo un nuevo cuadro, los cuadros son visualizadores de capas las capas que estén visibles se verán en el cuadro y el resto no, por lo que es común trabajar con una sola capa por cuadro, para animaciones sencillas.
  4. Podemos comprobar como queda nuestra animación pulsando play.
  5. Guardaremos nuestro psd y haremos una copia para no destruir el trabajo.
  6. Trabajaremos sobre la copia , ahora si, cada capa debera corresponder a un único fotograma.
  7. Nos descargamos Sprite Sheet Generator que es un archivo de comandos de photoshop que nos permitirá automatizar la tarea.
  8. En photoshop CS6 vamos a Archivo-> Secuencia de comandos-> Explorar cargamos el Sprite Sheet Generator jsx , nos saldra una ventanita donde elegir columnas, filas y fotogramas a exportar.
  9. Pulsamos en Generate Document, para comprobar que nos genera lo que queremos.
  10. Guardamos como PNG.

20 Webs para buscar Sprites

Lo reconozco me encantan los Sprites, esas imágenes que contienen los elementos de un videojuego 2D y que para mi alcanzaron su época dorada con las recreativas de finales de los 80 y comienzos de los 90.
Y es que los videojuegos 2D nunca pasaran de moda, gracias precisamente al arte que hay en esas animaciones, estilos y diseños.

Os dejo webs 20 webs donde podréis encontrar recursos de sprites sheets y gifs animados de videojuegos de todas las plataformas.

  1. Sprite Database
  2. The Shyguy Kingdom
  3. The Spriters Resource
  4. Sprite Land
  5. HasGrafics
  6. Vgmuseum
  7. OpenGameArt
  8. Game Art Guppy
  9. HellSoft
  10. Videgame Sprites
  11. Blogleech
  12. Retro Game Zone
  13. CG Textures
  14. Fightersgeneration.com
  15. Spiral Graphics
  16. RMXP Resources
  17. RPG Palace
  18. Lost Garden
  19. Videogame Sprites
  20. Pygame

Ayudas en el Inspector de Unity: Añadiendo atributos

En Unity podemos añadir ayudas al inspector cuando estamos utilizando un script para que nos recuerde que hace determinada variable, poner un rango para un número, hacer una caja de texto más grande etc.

Estas ayudas se llaman Atributos, la información que proporciona Unity sobre este tema puede encontrase aquí, aun que algunos no están muy bien explicados.

ATRIBUTOS:
[HelpURL (“http://www.jorgevallejo.es/2017/10/unity-atributos.html”)]

¿Donde va?:
Antes de la declaración de la clase

¿Qué hace?
Permite generar un enlace desde el inspector a una URL, útil para generar ayudas internas.
Debermos pulsar sobre el botón interrogación del inspector

Ejemplo:
[HelpURL ("http://www.jorgevallejo.es/2017/10/unity-atributos.html")]
public class Menu_Inicio : MonoBehaviour {
}

[RequireComponent (typeof(Rigidbody))]
¿Donde va?:
Antes de la declaración de la clase

¿Qué hace?
Determina que el componente necesita otro y lo añade automáticamente cuando colocamos el script, de esta forma no olvidaremos un componente necesario.
Debemos hacer las referencias correspondientes para poder utilizarlo, es simplemente como si ubieramos añadido el componente manualmente.

Ejemplo:
[RequireComponent (typeof(Rigidbody))]
public class Menu_Inicio : MonoBehaviour {
Rigidbody rb;

void Start()
{
rb = GetComponent();
}
}

[Space(20)]
¿Donde va?:
Después de la declaración de la clase. Donde queremos que en el inspector haya un espacio.

¿Qué hace?
Permite crear un espacio entre bloques de variables.
Crea un espacio del tamaño indicado.

Ejemplo:
public class Menu_Inicio : MonoBehaviour {
[Space(120)]
public int fuerza;
}

[Header(“Boton de cierre”)]

¿Donde va?:
Después de la declaración de la clase. Donde queremos que en el inspector aparezca un texto.

¿Qué hace?
En el inspector nos aparecerá un label con el string que le pasemos al Header
Simplemente es informativo.

Ejemplo:
public class Menu_Inicio : MonoBehaviour {

....
[Header("Boton de cierre")]
}

[TextArea]
¿Donde va?:
Después de la declaración de la clase. Justo encima de la variable publica texto que queramos modificar.

¿Qué hace?
El texto aparecerá como un TextArea en un lugar de como InputField de una sola línea.
Útil para escribir textos desde el inspector.

Ejemplo:
public class Menu_Inicio : MonoBehaviour {
[TextArea]
public string texto="Aqui va un texto largo";
}

[Tooltip(“¿Tiene botón de cerrar?”)]
¿Donde va?:
Después de la declaración de la clase. Justo encima de la variable publica en la que se quiera que aparezca el tooltip o texto explicativo.

¿Qué hace?
Cuando mantengamos el cursor sobre la variable asignada, en el inspector nos aparecerá un tooltip explicativo.
Útil para variables complejas o cuando hay muchas parecidas.

Ejemplo:
public class Menu_Inicio : MonoBehaviour {
[Tooltip("¿Tiene botón de cerrar?")]
public bool tiene_cierra;
}

[Range(0.0F, 10.0F)]
¿Donde va?:
Después de la declaración de la clase. Justo encima de la variable publica.

¿Qué hace?
Aparezca un rango en forma de slider en lugar de un cajetin.
Valido para números enteros o decimales.

Ejemplo:
[Range(0.0F, 10.0F)]
public int fuerza;

[ExecuteInEditMode]
¿Donde va?:
Antes de la declaración de la clase.

¿Qué hace?
Permite ejecutar el script en modo edición, lo que puede ser extremadamente útil cuando el juego empiece a pesar y tarde en arrancar, muy útil también para hacer pruebas sin arrancar el juego.

Ejemplo:
[ExecuteInEditMode]
public class Menu_Inicio : MonoBehaviour {}

También podremos crear menus contextuales, es decir que aparezcan cuando pulsemos el botón derecho del ratón sobre una variable.
¿Qué necesita para funcionar?
Necesitaremos:
Declarar un [ContextMenuItem(“Reset”, “Borra”)]
Declarar un [ContextMenu (“Borra texto”)]
Tener una función asociada en este caso Borra

¿Donde va?:
Después de la declaración de la clase. En la variable que queramos que tenga el menu contextual.

¿Qué hace?
Aparecerá un menú contextual al pulsar el botón derecho del ratón, que contendrá minibotones asociados a funciones.
Útil para tareas repetitivas dentro del inspector como poner una variable a 0 , borrar un texto, etc

Ejemplo:
[ContextMenuItem("Reset", "Borra")]
[Multiline(8)]
public string texto_largo = "";
[ContextMenu ("Borra texto")]
void Borra() {
texto_largo = "";
}

Ponencia en las III Jornadas Educativas

III Jornadas Educativas

III Jornadas Educativas

El sábado 30 a las 14:05 estaré dando una ponencia sobre “Enseñanza Creativa” en las III JORNADAS EDUCATIVAS
Edificio Multiusos de La Vega. Avenida de Colón 80. Arroyo de la Encomienda.

La educación y la creatividad deberían ir de la mano sobre todo teniendo en cuenta el futuro que espera a las nuevas generaciones donde las tareas repetitivas cada vez serán mas susceptibles de ser automatizadas, y donde existen grandes retos que afrontar ,¿Qué hacer con  nuevas tecnologías como la visión artificial o la conducción autónoma? Donde ya no buscamos una solución , sino nuevos modelos de negocio , aplicaciones, por lo que es mas necesario que nunca tener desarrollada la creatividad.

La creatividad será necesaria para enfrentarse a los retos del nuevo modelo productivo

Hablare de tres aspectos fundamentales para poder desarrollar la creatividad:

1) El pensamiento critico , la capacidad de analizar la información y buscar diferentes soluciones , desarrollando en los alumnos un filtro que les permita generar su propio criterio.

2) El punto de visita, ampliar el punto de vista, ver las cosas con perspectiva y sobre todo ser capaces de empatizar con el otro, nos abre la mente y nos permite tener ideas que de otra forma seria imposible.

3) Tolerancia al fracaso, el fracaso es un tema que se suele esquivar, sin embargo cuando uno esta creando algo nuevo y diferente, ¿Cómo sabe si va a funcionar? Debemos aprender que la cultura del fracaso forma parte del proceso creativo y que el verdadero fracaso es no intentarlo.

Todo ello se explicara de una forma diferente, tratando de que esta ponencia resulte divertida, amena y casi mágica.

Las jornadas son gratuitas , se interesa la creatividad o los temas relacionados con la educación tanto en el ámbito docente como en la educación que ejercen los padres, puedes apuntarte en info@fluircentro.es

Workflow Unity e IOs : Expotación y subida al App Store

Cuando hablamos del proceso de subida al App Store de un videojuego o aplicación creada con Unity debemos realizar una serie de pasos, lo que denominamos workflow o flujo de trabajo que nos permitirán llegar a buen puerto, es decir, conseguir que nuestro videojuego este publicado en el App Store. El proceso es bastante complejo por lo que he tratado de mostrar cada paso, algunos se pueden hacer antes o después, pero otros deben hacerse secuencialmente, así q es preferible que sigáis el orden a rajatabla para minimizar errores.

Una de las características fundamentales de Unity es la multiplataforma, es decir, la capacidad de poder exportar a diferentes plataformas haciendo un único desarrollo, a pesar de las singularidades de cada una, ello nos permite crear el videojuego por completo en Unity y sólo depender del Xcode para su subida al App Store.

Requerimientos:

Podemos exportar el videojuego desde un Pc, sin embargo el proceso de subida al App Store requiere de Xcode y licencia de desarrollador Apple Developer, Xcode sólo se puede instalar en Mac, ademas de que algunas partes del proceso requieren tener el sistema de llavero de Mac, que viene con los Mac.
La opción mas barata es un Mac mini, que podréis encontrar por unos 600$.
Para crear el videojuego:
Pc o Mac para la creación del videojuego.
Unity
SDK de IOs (Se descarga en el punto 3)

Para la subida al App Store:
Un ordenador Mac
Xcode instalado
Una cuenta activa en Apple , tendremos longeanos varias veces así que tener el password a mano
Estar dado de alta como desarrollador IOs https://developer.apple.com/ , al corriente de pago, actualmente son 99$ al año.
Recomendable:
Tener dos dispositivos para hacer pruebas un iphone y un ipad con IOs 8 instalado y sus cables de conexión.
Nota: Podemos desarrollar el videojuego sin ellos, son para testeo.

Workflow Unity App Store
En Unity
BLOQUE I
1) Desarrollar el videojuego en Unity.
2) Abrir el Panel Build Settings, añadir todas las escenas de nuestro videojuego, estas se pueden arrastrar directamente a la ventana de Build Settings.
3) Seleccionar la plataforma de IOs, Seleccionando IOs y pulsando Switch Platform
Unity colocara las librerías necesarias para la posterior exportación, si no las tenemos instaladas nos aparecerá un botón para descargarlas.
3.1) Pulsar el boton de descarga, una vez descargado, cerramos Unity.
3.2) Instalar el SDK de IOs
3.3) Abrir Unity de nuevo, comprobar que está instalado en Edit-> Preferences -> External Tools (Hacer la ventana más grande si no se ve) Aparecerá Xcode Default Settings
4) Este paso es muy importante dada la política de actualizaciones de IOs, ya que actualmente las apps que se suban deben incluir desarrollo de 64-bits e IOS 8 o superior.
Por lo que debemos ir al Build Settings de nuevo -> Player Settings y en Configuration cambiar Scriping Backend, de Monox2 que viene por defecto a IL2CPP, cuando hayamos seleccionado este sistema de scriping podremos elegir Architecture -> Universal La cual contiene los dos sistemas Armv7 y Arm64.

5) En Player Settings -> Other settings Cambiar el Identificator Bundle , personalmente utilizo la nomenglatura com.nombre_desarrollador.nombre_proyecto la cual me sirve tanto para Ios como para Android.
6) Cambiar el Nombre de la Compañia y del producto, en Player Settings arriba del todo.
7) Añadir iconos y pantallas de presentación, todo ello en el Player Settings.
Nota: Para no trabajar dos veces, y dado que Apple es riguroso con el tema de los tamaños , es interensate acudir a http://help.apple.com/itunes-connect/developer/#/devd274dd925 para ver los tamaños de las imagenes.
8) Repasar cada uno de los puntos anteriores.
9) Crear una carpeta vacía llamada Exportación
10) Crear una segunda carpeta vacia dentro de Exportación llamada Nombre_videojuego_IOs
11) En Build Settings, marcamos Build in Xcode Release y en Development Build marcada .
12) Dar al boton de Build y selecciona nuestra carpeta, la creamos vacía por que eliminara cualquier contenido que tenga.
Llegados aqui tendriamos nuestro videojuego preparado para ser abierto en Xcode.

BLOQUE II
Preparación para subida a App Store , Certificados
1) Nos longeamos en https://developer.apple.com/account
2) Vamos a Certificates
3) Comprobamos que tenemos un certificado de Desarrollador y un certificado de distribución
4) Si no los tenemos, Xcode nos podra generar uno en nuestro primer proyecto, veremos este punto cuando hablemos del proceso en Xcode.
5) Crear un App ID de nuestra aplicación, que será el Bundle Identificator
6) Para poder testear la aplicación, añadir Devices
7) Para la subida al App Store será necesario un Provisioning Profiles -> Distribution
8) Tendreis que bajaros ese Provisioning Profile para luego meterlo en el Xcode.

BLOQUE III
Preparación para subida a App Store en itunesconnect
1) Longearnos en itunesconnect.apple.com
2) Ir a Apps y dar al boton +
3) Rellenar los formularios, tener presente que hay que tener una política de privacidad por cada aplicación o videojuego, que como mínimo vas a necesitar 1 imagen de 1024×1024 del icono del videojuego, una imagen de captura para iphone y otra imagen para iPad que cumpla las especificaciones http://help.apple.com/itunes-connect/developer/#/devd274dd925
4) Calificar el contenido siguiendo el formulario.
5) Poner un precio a la aplicación así como la distribución por países.
6) Rellenar los campos que falten, tener poner un contacto de desarrollador.
7) Podemos ir guardando e ir comprobando si nos falta algo, dando a Enviar para revisión, ya que aun nos falta subir la app, nos apareceran en rojo los campos a completar.

BLOQUE IV
En Xcode:
1) Cargamos el proyecto de Unity, simplemente con abrir nuestra carpeta videojuego_ios
2) Realizamos una primera compilación para ver si no hay errores Con Xcode -> Build
3) Realizamos los testeos necesarios , conectando nuestro iphone o ipad que previamente hemos añadido como Devices en BLOQUE II el punto 6.
4) Cambiamos el Team en General por nuestro Desarrollador
5) En Build Settings cambiamos Code Signing por nuestro Provisioning Profiles creado en el Bloque II punto 7.
5) Compilamos en Product-> Archive
6) Si todo ha ido bien, podremos subir nuestro proyecto al App Store, por lo que es necesario haber realizado previamente la configuración del mismo los pasos del Bloque III.
7) Window-> Organicer es el gestor de subidas al App Store, debera aprecernos nuestra compilación, podemos hacer una segunda comprobación dandole a Validate.
8) Pulsamos en Submit to App Store, atención es muy importante haber realizado los pasos del Bloque II, ya que hay que relacionar la aplicación a subir con su compilación.
9) Iniciamos la subida al Apple Store.

Bloque V
Subida a App Store en itunesconnect
1) Longearnos en itunesconnect.apple.com
2) Sólo nos queda seleccionar nuestra compilación, donde ponga Subida por Xcode o AppLaucher, hay un botón de más para seleccionar la que acabamos de subir.
3) Pulsamos en Enviar para revisión y rellenamos los formularios que nos faltan.

Ahora dependemos de que Apple nos valide la aplicación lo cual puede tardar entre dos días a una semana.
Para mi es un proceso excesivamente complejo, cuantos más pasos hay más posibilidades de que comentamos un error, pero no queda mas remedio que resignarse, tomárselo con calma y hacerlo, ya que con suerte solo tendremos que hacerlo una vez.

Espero que os haya servido, si tenéis cualquier duda, escribirme un comentario.

Un poco de arte Low Poly

isometrico blender

Un poco de arte Low Poly, creado con Blender , estética de colores planos y formas muy poligonales , con pocos triángulos.
La creación de modelos 3D simples con Blender forma parte del Máster en Diseño y Creación de Videojuegos que imparto en iVisual Formación, asi los alumnos pueden crear sus propios modelos sencillos para videojuegos tipo “vista isometrica”

Hearthstone Pelea de taberna heroica: un robo

Pelea de taberna heroicaComo todos los jueves en mi caso, aparece una nueva pelea de taberna, un sistema que estaba bien como estaba pues daba la posibilidad de ganar un sobre gratuito y jugar con mecanicas diferentes.

Pelea de taberna heroica:

Me lo pensé bastante antes de jugar principalmente por su coste 9,99€ o 1000 monedas, sin saber muy bien de qué iba la cosa decidí probar pensando iluso de mi, que en el peor de los casos me darían por lo menos unos cuantos sobres, pues bien , compro y empiezo a jugar a la pelea de taberna heroica, lo primero es crearse un mazo estándar que ademas luego no se puede cambiar cosa que no entiendo , pues en realidad es el mismo sistema de juego que cunado juega por rango en el estándar.

Me hago mi mazo que va a depender de las cartas que ya tenga, es decir, que es exactamente igual al mazo con el juego en el modo estándar.

Comienzo a jugar, por casualidad en la primera partida pierdo la conexión wifi, intento recuperarla con los datos del móvil, pero no se me re conecta, resultado pierdo la primera partida.

La segunda pierdo por una mala decisión contra otro Druida y la tercera me enfrento a un Paladin con todas las legendarias habidas y por haber que me funde, a pesar de que yo también llevo unas cuantos soy un Druida con Malygos..

Total muero en la tercera partida sin haber ganado ninguna, es mi primerito día y ¿que consigo? Un sobre.

He pagado casi diez euros por un #@&%&%& ¿¿sobre??

Sinceramente la Taberna Heroica me parece una estafa:

1) La taberna normal estaba bien, jugabas a algo diferente y conseguías un sobre semanal

2) Es imposible que un jugador novato pueda ganar, ya que se va a enfrentar contra mazos de leyenda y jugadores experimentados

3) 1,79€ o 150 monedas es la Arena, donde mínimo te van a dar un sobre es justo, Casi 10€ de la pelea heroica, por lo menos deberían dar unos sietes sobres, sino es superinjusto y esta fuera de la escala de valor que Hearthstone ha creado.

4) Se supone que ganar 12 partidas te da 50 sobres, 3 cartas legendarias y polvo arcano, digo que se supone por que encima esto no se explica al empezar a jugar, sólo ponen ganaras grandes premios.

Pelea de Taberna Heroica está fuera de la escala de valor que Hearthstone ha creado.

Ganar 12 partidas y sólo perder tres es muy , muy complicado, estamos hablando de que te vas a enfrentar a gente con mazos muy buenos.

CONCLUSIÓN:

Se han cargado la pelea de taberna, que era algo ocasional y divertido, y diferente, para “apostar” a ganar ya estaba la Arena que es más justa pues el mazo se crea con cartas aleatorias y la proporción esfuerzo recompensa esta equilibrada.

No creo que mucha gente lo juegue, yo desde luego no volveré a probarlo.

Hearthstone cambios de equilibrio 6.1.3

Si habéis seguido los anteriores artículos, ya comentábamos que hearstone tiene una política de tener cartas en desequilibrio, que al aportar una gran ventaja las hacen presentes en muchos mazos y crean estrategias basadas en ellos, lo que llamabamos estrategia dominante que hacen que el resto de cartas no se jueguen ya que son dominadas ,por lo que al final tienen que ir haciendo ajustes, y reequilibrar las cartas a fin de que dejen de ser dominantes para estar equilibradas.

Vamos a comentar los cambios que ha habido, y siguiendo las reglas de equilibrio comprobaremos si nos parecen justos o no.

Arma Muerdepiedras

muerdepiedraaumenta su coste a 2, nos parece bien, ya que era una carta demasiado rápida que permitía eliminar muy fácilmente esbirros en el turno 1 y por su bajo coste hacer combos con el terrible arma del Chaman que esa si que me parece una carta desequilibrada “El martillo maldito”.

Golem Totémico

golemPor 3 de mana una carta 3/2 que podía conseguir invocar una 3/4 sin pagar nada mas era una autentica pasada, proporcionaba una ventaja enorme al Chaman con una carta muy barata, sin embargo el cambio reduce mucho el valor de carta, aunque sigue combando bien con la estrategia general del chaman de invocar muchos esbirros y totems, creo que muchos seguidores del mazo Chaman aggro se habran sentido defraudados con este cambio, pero en general me parece correcto.

Llamada de lo Salvaje

invoca

Es una de las mejores cartas de todo el juego, por 8 de mana tenemos Un jabalí 5/2 con cargar , un 5/4 con provocar y 2/4 que otorga +1 de ataque a los demás, realmente era impensable que un cazador no llevase 2 en su mazo, pues es una carta con suficiente poder como para ser legendaria y encima podías llevar 2!!!.

Seguro que se les paso por la cabeza subirla a coste 10, que seria su valor real, pero ya que el mazo de Cazador es bastante rápido han decidido subirla solo 1, lo que no es tan sangrante, y da la oportunidad de prepararse algo mejor, por que a pesar del cambio, sigue siendo muy buena, y seguirá estando en todos los mazos de cazador.

Llamada de lo Salvaje es una de las mejores cartas del juego

Ejecutar

ejecutarEs una carta poderosa pero que necesita ser combada, es decir, necesitamos haber hecho daño al esbirro para poder ejecutarlo, por lo que añadir un punto de coste puede hacernos tener que esperar un turno mas, creo que estaba bien como estaba, el guerreo no tiene tantas opciones de eliminar enemigos y suele ser lento, por lo que este cambio le hace aun mas lento.

Estaba bien como estaba.

Cargar

cargar

Alguna vez me he enfrentado contra un mazo OTK o muerte en un turno, una estrategia que dependía de crear un combo con suficiente daño y que ahora pierde toda su eficacia, ya que la nueva carta impide atacar a la cara, un handicap demasiado grande, que precisamente elimina la ventaja de la sorpresa de la carta, para mi es el mayor error de cambios pues destruyen un tipo de estrategia completamente que requería aguantar de vida hasta poder completar el combo y que ahora no tendrá sentido.

Creo que el juego nunca debe eliminar por completo ese tipo de estrategias, aunque se le haya bajado de coste , viendo claramente la desventaja que supone , ahora es una carta bastante pobre.

Han eliminado todo un estilo de juego el OTK

Sargento Abusón

sargento_abusoEra una carta algo desequilibrada desde el principio , pero que daba mucho juego, por lo que todos los mazos agros y face la llevaban, ahora pierde algo de fuelle pero es el poder de otorgar +2 y su bajo coste lo que realmente dan ventaja, por lo que al mantener estos parámetros, han conseguido equilibrarla bien. Seguirá estando presente, pero ya no abusara tanto (Chiste facil).

 

Yogg-Saron, Fin de la Esperanza

yogg

Mas que un cambio de equilibrio se trata de ajuste de la lógica del juego, si Yogg muere es logico que deje de tirar hechizos por lo que el ajuste es correcto.

Para mi Yogg es una de las cartas mas divertidas por su componente aleatorio, no creo tanto que pueda proporcionar un giro de 180 en la partida, aun que alguna vez ocurre, como dar un empujon, la mayoria de las veces en las que Yogg era mi unica salvacion he muerto, mientras que si llevaba algo de ventaja y lo usaba me ha proporcionado mas beneficios que hadicaps.

 

Y vosotros que pensáis ¿Estáis de acuerdo con estos cambios? Deja tus respuestas en los comentarios.

Hearthstone: Diseño de juego II Mejores Armas

martillo malditoContinuamos viendo Hearthstone desde una perspectiva de análisis y teoría de videojuegos, que también servirá a todos los jugadores de Hearthstone para conocer mejor el juego y así poder tomar mejores decisiones sobre la elección de cartas, como habíamos visto en anteriores artículos
Hearthstone: Diseño de juego II Armas y Hearthstone: Diseño de juego I Balance o Equilibrio
Hearthstone tiene tendencia a crear cartas con valores superiores a los de equilibrio, por lo que siguiendo con la temática de las armas vamos a ver las mejores armas del Hearthstone,  las de la clase Guerrero las teneis en este articulo.

Mejores armas del Chaman

Garras espiritualesGarras espirituales

Por 1 de mana, teóricamente deberíamos de tener entre un arma 1/2 ,2/1 tenemos ya de serie un arma 1/3 que con daño con hechizos se puede convertir en una 3/3 , es un arma con un coste muy bajo y muchísimo potencial, q nos puede salvar en los primeros turnos, se puede combinar muy bien con Arma Muerdepiedras, este arma hace que el pobre Pícaro con su poder de héroe coste 2 un arma 1/2 se eche a llorar.

Coste Daño Durabilidad Poder
3 3 2 Tiene +2 p. de ataque mientras tengas daño con hechizos.

 

 

Martillo malditomartillo maldito

Por 5 de mana y 2 sobrecargas tenemos una carta 2/8 , es decir por 7 de mana una 2/8 esta bastante equilibrada, sin embargo al

leer la descripción nos damos cuenta de que es muchísimo mas que eso, es un arma con viento furioso lo que le permite atacar dos veces por turno, tiene 16 daños potenciales, haciendo 4 por turno, si esto no fuera suficientemente bueno el combo con Arma Muerdepiedras es brutal, ya que se convertiría en una 5/8 durante un turno pudiendo hacer 10 de daño.

Es una de las mejores armas, sino la mejor, primero por que si misma ya que es un arma súper barata 5 polvos y tremendamente efectiva y segundo por que al tener un coste 5 es fácil combarla.

Coste Daño Durabilidad Poder
5 2 8 Viento Furioso, Sobrecarga: (2)

 

 

Cazador

Arco de cuerno de águilaarco

Comparada con el arma del Guerrero Hacha Ígnea que mencionábamos en el anterior artículo 3/2 por 3 de mana seria un poco floja, pero el combo de aumentar la duración con el uso de secretos, casi todos los Cazadores llevan mínimo un par de ellos, la convierte en una carta interesante, sobre todo si tenemos en cuenta que el 80% de los cazadores van a hacer el mayor daño posible con los mínimos turnos.

Coste Daño Durabilidad Poder
3 3 2 Obtiene +1 p. de durabilidad cada vez que se revela un secreto amistoso

 

 

Paladín

Campeón de Veraplata

campeon VeraplataUn arma versátil con un coste equilibrado, una de las armas que todo Paladín que se precie lleva, y además te cura, que mas se le puede pedir.

Coste Daño Durabilidad Poder
4 4 2 Cada vez que tu héroe ataca, recupera 2 p. de salud.

 

 

Espada de Justiciaespada de la justicia

Por  3 de coste 1/5 es floja, nadie la llevaría pues el paladín tiene otra carta mas barata Justicia de la Luz que por 1 es 1/4 otra vez
oigo lloriquear al Pícaro, pero es que Espada de Justicia comba de forma genial con muchas cartas de Paladín, y con cualquier carta que invoque varios esbirros a la vez como Templaria Penumbría. Una carta que da ese punto de vida extra tan necesario en los primeros turnos.

Coste Daño Durabilidad Poder
3 1 5 Cuando invocas a un esbirro, el esbirro obtiene +1/+1 y esta arma pierde 1 p. de durabilidad.

 

 

Pícaro

Es curioso que una clase cuyo poder es poner un arma, bastante cutre por 2 de mana 1/2 , tenga luego unas armas con tan poca gracia, quizá la mejor arma sea

Hoja de Asesinohoja de asesino

Que si bien es un arma algo floja por que ya en el turno 5 vamos a necesitar mas daño puede combar muy bien con Veneno mortal pudiendo hacer 6×4= 24 daños

Coste Daño Durabilidad Poder
5 3 4

hoja_envenenadaComo estamos hablando de diseño de juego hay que comentar Hoja envenenada como una de las peores armas, me estas diciendo que por 4 de mana tengo 1/3 que voy a tener que gastarme otros dos de mana para hacerla un poderosísimo 2/3? Es en serio? Lo siento Pícaro pero sigue llorando.

 

 

Conclusión:

En mi opinión Martillo maldito es la mejor arma del juego, ya que es una carta lo suficientemente poderosa como para cambiar el rumbo de la partida.

La clase Pícaro siendo una de las cuatro que puede llevar armas de serie (algunas cartas permiten ponerse armas a cualquier clase) tiene unas armas muy pobres, que con las ultimas actualizaciones van siendo por comparación todavía peores, lo que nos hace darnos cuenta de que muchas cartas de Hearthstone dan mucha mas ventaja a unas clases sobre otras, lo que redunda en un desequilibrio del juego, atendiendo a costes de mana/ eficacia del arma ,afortunadamente hay muchas opciones dentro de las barajas para crear estrategias y combos que hagan funcionar las armas, pero mi consejo a la hora de decidiros es:

Un arma a partir de turno 5 pierde mucha efectividad , probablemente recibamos mas daño del que ejerzamos por lo que es preferible tener armas rápidas de coste bajo.

No es aconsejable llevar demasiadas armas (mas de tres), pues sólo podemos llevar un arma a la vez y las tendremos esperando en la mano.

¿Y cual que crees que es el mejor arma? ¿Y la peor? Déjanos un comentario.

 

Hearthstone: Diseño de juego I Balance o Equilibrio

hearthstoneTengo que reconocer que el juego de cartas Hearthstone es una de mis pasiones, me enganche desde el principio recordando los viejos tiempos cuando jugaba al magic the gathering, en ordenador, cuando salio el juego para movil me lo pille ilusionado pero como no me llego a engachar, Hearthstone más sencillo en cuanto a la gestion mana y el sistema de instantaneos si lo consiguió, la facilidad para jugar en móvil, tablet o pc con una sola cuenta es uno de sus grandes aciertos. También soy critico con muchas cuestiones del juego, sobre todo de su modelo de negocio, que como jugador no me acaba de convencer pero que se ve que funciona claramente con 20 millones de jugadores , y unas cifras de 20 millones de dolares al mes.

En este articulo no voy a hablar de mazos y estrategias, sino del propio diseño del juego, ya que una de las cuestiones mas importantes de todo videojuego es el balance o equilibrio de fuerzas, y que en un juego de estrategia por turnos como es el Hearthstone es fundamental.

¿Qué es el balance o equilibrio de elementos?

Imaginemos que eres un guerrero tienes fuerza 1 y llevas una espada básica +0 Fuerza ,en este maligno mundo que llamaremos Mor,  la mayoría de los monstruos tiene 5 puntos de vida, te enfrentas a uno, por simplificar, cada ataque que realizas es la suma de tu fuerza más el bonus del arma, así que para matarle tienes que golpearle mínimo 5 veces.

Al matarle registras su cuerpo , un clásico del mundo del videojuego, y te encuentras con un arma +5 Fue, ahora eres un Killer, al  volver a enfrentarte con otro enemigo lo ¡mataras de un golpe!

¿Que ha ocurrido? Has encontrado un arma que te aporta una gran ventaja, por que en la escala del juego has pasado de tener que asestarle 5 golpes a 1. Si ahora te enfrentases a un monstruo grande de 10 puntos de vida, lo matarías de dos golpes siendo muy fácil.

Ese +5 del arma, ha desequilibrado completamente la escala del juego haciendo que la ventaja del jugador sea enorme.

Balance o Equilibrio es conseguir que las ventajas y desventajas que puedan proporcionar objetos, armas o en nuestro caso cartas, no desequilibren el juego permanentemente. Sino que se pueda volver a un estado 0 o de equilibrio.

Siguiendo con nuestro ejemplo, si el arma más 5 se destruyera tras usarla, estaríamos consiguiendo por un lado que el equilibrio del juego se recupere , por otro que el jugador se piense cuando será más útil usarla , es decir, planteándose estrategias.

Podemos extraer una primera regla dentro del balance:

Si un elemento genera desequilibrio tanto en positivo como en negativo , este debe ser temporal, su duración ira acorde con el grado de desequilibrio.

Por ejemplo:

Arma +5 / 1 turno. Arma +4 /2 turnos. Arma +3/3 turnos.

Como vemos un Arma 3/3 ofrece una buena ventaja, quizá demasiado buena, por lo que el diseñador de juego podría pensar en reducir en 1 el número de turnos y tener un Arma +3/2 turnos, pero que ocurre si la comparamos con la 4 /2 vemos que queda en desventaja, esto significa que si tuviera que elegir con cual quedarse siempre se quedaría con la 4/2, razón por la que todo el mundo llevaría ese arma, ¿cuantas veces has visto jugadores que llevan exactamente el mismo equipo? . Es lo que se llama estrategia dominada, cuando una estrategia es mejor o peor en todos los sentidos que otra.

Sigamos podríamos estar tentados de eliminar nuestro arma 3/2 , pero aun nos queda un as en la manga, el coste.

Hasta ahora estábamos regalando armas, como si nos sobraran, Ahora imaginemos que las tienes que comprar, con el dinero que has conseguido limpiamente matando paisanos.

El coste de una 3/2 podría ser de 200 monedas frente al coste de una 4/2 de 300.

Ahora si que parece estar equilibrado, si quiero un arma un poco mas fuerte he de pagar más y así conseguir mas ventaja.

El coste de adquisición de un elemento también nos sirve para equilibrarlo.

Hemos resuelto el problema del equilibrio pero tenemos un problema de monotonía, ya que un arma 3/2 y una 4/2 son bastante parecidas, el jugador preferirá tener mayor variedad y que las estrategias que pueda tener no se parezcan excesivamente por lo tanto un nuevo arma  podría ser 5/2 por 500 monedas.

Como vemos el balanceo es complejo, puesto que hay que tener en cuenta muchos factores y aun no hemos comentado nada de los combos.

Lo iremos viendo en sucesivos artículos.

¿Conoces algún arma , artefacto etc que desequilibro completamente el Hearthstone u otro videojuego? Dejanos tu comentario.

Generando Iconos para Apple Store y Xcode

Una de las tareas a mi parecer más pesadas es la de tener que generar todos los iconos que nos piden para poder subir nuestra aplicación al Apple Store desde Xcode, y es que en Apple les gusta el diseño purista por lo que tenemos que tener preparados los iconos con su resolución especifica, y no podremos hacer como en Android donde con tres resoluciones de icono de la aplicación lo resolvemos sino que tenemos que tener toda una pila de iconos ,tanto para la App como para su publicación en el Apple Store.
Afortunadamente hay gente generosa por el mundo, y gracias a los scripts de photoshop podemos exportar rápidamente los iconos partiendo de un primer diseño.

Pasos para exportar a los diferentes tamaños de iconos requeridos en el Apple Store desde Photoshop.
1) Bajaros https://gist.github.com/appsbynight/3681050 , si teneis cuenta en github darle las gracias al autor.
2) Crear el icono padre que debe ser de exactamente 1024×1024, en PNG.
3) Cargar el script en Photoshop mediante -> Archivos-> Secuencia de comandos -> Explorar
4) Elegir el icono padre, el de 1024
5) Elegir la carpeta de salida.
6) Vuala! los iconos creados.

POWER UP
Podéis editar fácilmente el script copiando y pegando en la declaración del array de icons , simplemente modificar la resolución,que siempre sera cuadrada y el nombre. Y listo podréis hacer una pila de iconos en unos segundos.
[…]
var icons = [
{“name”: “Icono_1024”, “size”:1024},

Si te ha gustado este post deja tu comentario.

Desarrollando para IOs y sobrevivir

Escribo este post para dejar constancia de la frustración que muchas veces sentimos los que desarrollamos para IOs , aunque sea la aplicación más sencilla que se pueda echar uno a la cara. Lo difícil debería ser hacer el videojuego , simulador o aplicación y no los rollos que se traen para poder subirla al Apple Store y es que todo el proceso para publicar no sólo es difícil sino que encima, se les ocurren cosas tan bonitas como cambiar el certificado de autentificación obligando al desarrollador a tener que volver a instalarlo, sin explicar minimamente como debe ser el protocolo.

https://developer.apple.com/support/certificates/expiration/

Básicamente el Apple Worldwide Developer Relations Intermediate Certificate expiro el  14 de Febrero de 2016, lo que significa que tras esa fecha, adiós amigo, deberéis eliminar el certificado que tengáis instalado e instalaros el nuevo.

Una gracia bastante particular, ya que en mi caso con ya mas de cuatro años como desarrollador Apple, que queda muy bonito pero que es un mundo de frustraciones y peleas con el código, resulta que no tienen la decencia de avisarnos de un cambio tan importante y que tienen a los desarrolladores varias horas e incluso días dando vueltas como peonzas sin encontrar el fallo, y cuando lo descubres, gracias algún foro lleno de quejas de otros desarrolladores, aun tienes que pegarte con el llavero de Mac para que los certificados sean reconocidos, tanto en usuario como en sistema.
Sinceramente creo que a día de hoy son las aplicaciones las que dan un valor añadido a un móvil, y prácticamente todo el valor a una tableta, así que ya podían tener un poco mas de consideración para con los desarrolladores, por que esos días que se pierden haciendo tramites, los deberían pagar los de Apple.