Ir al contenido principal

Preparando un evento de videojuegos

Participar en un evento de videojuegos con un stand puede ser una oportunidad única para dar a conocer tus juegos, interactuar directamente con tu público objetivo, y generar un gran impacto en la comunidad. En este artículo, exploraremos cómo preparar un stand de 4x2 metros de manera efectiva, maximizar el uso de la cartelería de fondo, y atraer a los visitantes con técnicas sencillas y económicas de marketing. 1. Diseño y uso eficiente de la cartelería de fondo 1.1. La importancia de una lona reutilizable : La lona que utilices para el fondo de tu stand es una de las inversiones más importantes. Una lona de buena calidad y diseño profesional no solo refuerza tu marca, sino que también puede ser reutilizada en futuros eventos, lo que la convierte en una opción sostenible y económica. Asegúrate de que la lona cubra completamente el fondo de tu stand, ya que esto crea un ambiente inmersivo y profesional. 1.2. Elementos esenciales en la lona: En la cartelería de fondo, incluye: El logoti

Editor de niveles (Parte 1)

Hoy empezaremos con el editor de niveles. Este editor nos permitirá crear las etapas del juego a partir de ficheros JSON guardados en la carpeta de recursos. Este editor nos permitirá generar información parar poder proseguir con el juego donde lo habíamos dejado.


En este artículo sólo me centraré en la creación de la pantalla visual del editor, poniendo atención en la creación automática de cuadrículas (grids) a partir de una rutina pasando el objeto casilla como un prefab de la aplicación y definiendo el tamaño de cuadrícula con un Box collider.



Podéis ver el vídeo del proceso aquí.


Gizmo del Box Collider:
 using System.Collections;  
 using System.Collections.Generic;  
 using UnityEngine;  
 public class ShowColliders : MonoBehaviour {  
   private BoxCollider2D objectCollider2D;  
   private void OnDrawGizmos()  
   {  
     objectCollider2D = GetComponent<BoxCollider2D>();  
     Gizmos.color = Color.green;  
     Gizmos.DrawWireCube(objectCollider2D.bounds.center, new Vector2(objectCollider2D.size.x, objectCollider2D.size.y));  
   }  
 }  

Grid dinámico:
 using UnityEngine;  
 public class Grid : MonoBehaviour  
 {  
   //Grid  
   public int rows;  
   public int cols;    
   public Vector2 gridOffset;  
   public GameObject cell;  
   private BoxCollider2D gridSize;  
   private Vector2 originalCellSize;  
   private Vector2 cellScale;  
   private Vector2 cellSize;  
   private Vector2 offset;  
   // Start is called before the first frame update  
   void Start()  
   {  
     PaintCells();  
   }  
   public void Clean()  
   {  
     foreach (Transform child in gameObject.transform)  
     {  
       Destroy(child.gameObject);  
     }  
   }  
   public void PaintCells()  
   {  
     gridSize = GetComponent<BoxCollider2D>();  
     originalCellSize = cell.GetComponent<SpriteRenderer>().sprite.bounds.size;  
     cellSize = new Vector2(gridSize.size.x / (float)cols, gridSize.size.y / (float)rows);  
     cellScale.x = cellSize.x / (originalCellSize.x + gridOffset.x);  
     cellScale.y = cellSize.y / (originalCellSize.y + gridOffset.y);  
     cell.transform.localScale = new Vector2(cellScale.x, cellScale.y);  
     offset.x = gridSize.offset.x - ((gridSize.size.x) / 2 ) + cellSize.x / 2;  
     offset.y = gridSize.offset.y - ((gridSize.size.y) / 2 ) + cellSize.y / 2;  
     int sufixName = 0;  
     for (int row = 0; row < rows; row++)  
     {  
       for (int col = 0; col < cols; col++)  
       {  
         sufixName++;  
         //add the cell size so that no two cells will have the same x and y position  
         Vector2 pos = new Vector2(col * cellSize.x + transform.position.x + offset.x, row * cellSize.y + transform.position.y + offset.y);  
         //Add Cell information  
         cell.name = "Cell" + sufixName.ToString();  
         //instantiate the game object, at position pos, with rotation set to identity  
         GameObject cO = Instantiate(cell, pos, Quaternion.identity) as GameObject;  
         //set the parent of the cell to GRID so you can move the cells together with the grid;  
         cO.transform.parent = transform;  
       }  
     }      
   }  
 }  

El resto del editor sólo se utilizan elementos de la UI parar definir la interfaz de trabajo.

Comentarios

Entradas populares de este blog

Back to work!

¡Hola! Estoy emocionado de anunciar que he retomado la actividad en mi blog "Jugando Haciendo Juegos" después de una pausa. En esta nueva etapa, el blog se centrará en proporcionar información valiosa desde dentro de la industria de los videojuegos, incluyendo trucos, curiosidades, herramientas, recursos y consejos sobre cómo crear videojuegos desde la comodidad de tu habitación utilizando Unity. El blog ya cuenta con varios artículos útiles que pueden servir como recursos iniciales. Por ejemplo, hay guías detalladas sobre cómo hacer copias de seguridad de tu código de Unity con GitHub, lo que es crucial para la gestión de versiones y el trabajo colaborativo. También encontrarás tutoriales sobre el diseño de interfaces de usuario, el desarrollo de controladores de personajes y cómo crear un PressKit para tu juego. Mi objetivo es compartir conocimientos prácticos y experiencias personales para ayudar tanto a principiantes como a desarrolladores más avanzados a mejorar sus hab

El diseño de la interfaz de usuario

El estudio del diseño de interfaz de usuario en videojuegos es un tema que se ha estudiado en profundidad pero que muchos desarrolladores que empiezan no prestan mucha atención centrando su energía en las mecánicas del juego y especialmente el arte ya que muchas veces el éxito o el fracaso de un juego dependen de ello. Pero más lejos de la realidad la capacidad lúdica de un juego muchas veces también viene determinada por el diseño de la interfaz que hace de dialogo entre el jugador y el juego. Uno de los mejores análisis de las interfaces de usuario en videojuegos lo encontramos en los estudios realizados por Anthony Stonehouse y Marcus Andrews . El diseño de la interfaz de usuario en los juegos difiere de otro diseño de interfaz de usuario porque implica un elemento adicional: la ficción. La ficción involucra un avatar del usuario real, o jugador. El jugador se convierte en un elemento invisible, pero clave de la historia, como un narrador en una novela o película. Esta ficc

GitHub y Unity

Para el proyecto que estoy desarrollando voy a utilizar GitHub como repositorio de archivos y versiones. Aunque muchas veces uso el propio sistema de Unity, por el motivo que sea también vamos a utilizar un sistema general ampliamente utilizado por los desarrolladores de software. En primer lugar debemos tener una cuenta GitHub que nos podemos hacer gratuitamente. Una vez hecha vamos a utilizar un programa de gestión de versiones como es Sourcetree para gestionar el flujo de las versiones, ramas, etc. de nuestro juego. Una vez tenemos la cuenta de GitJub, si queremos utilizar SourcreTree necesitas una cuenta de Atlassian Bitbucket. Sin no disponemos de ella la podemos crear en el momento de la instalación o previamente a través de su página web. A partir de aquí solo tenemos que ejecutar Sourcetree y enlazar las cuentas. En el vídeo tenéis todo el proceso completo. Una vez tenemos en enlace hecho debemos enlazar con la cuenta de GitHub con la opción de Edit account