Titulación universitaria
La mayor facultad de informática del mundo”
Presentación
Las empresas saben que la clave de un videojuego está en la programación. Especialízate y conviértete en el desarrollador más solicitado de tu entorno”
Detrás de cada gran videojuego hay un enorme equipo de profesionales especializados en cada área de trabajo que intentarán llevar al éxito a su empresa. Normalmente, los apartados más destacados para los aficionados son los que pueden percibir directamente, como los Visuales o los que están relacionados con el Control de los Personajes, las Mecánicas o la Interacción con Objetos.
Sin embargo, para que todos esos elementos funcionen y estén correctamente integrados hay una labor esencial que no se suele tener en cuenta: la programación. El desarrollo de un videojuego tiene diferentes fases e implica a diferentes departamentos, pero la programación es la que le da sentido a todo y la que forma el esqueleto básico sobre el que se van a incorporar el resto de áreas.
Por esa razón las empresas de la industria prestan tanta atención a este asunto, ya que saben que un desarrollo correcto y eficiente de sus videojuegos facilitará el avance del proyecto y evitará la aparición de errores y Bugs. Por ello buscan a los mejores programadores especializados en este ámbito.
Pero no es sencillo encontrar verdaderos especialistas en la materia. Y este Máster en Programación de Videojuegos responde a esa demanda, haciendo que sus alumnos se conviertan en grandes expertos en desarrollo de videojuegos que podrán desenvolverse en la industria con facilidad, obteniendo grandes oportunidades profesionales gracias a las competencias y habilidades que adquirirán a lo largo de esta titulación.
Desarrolla todo tipo de videojuegos en las mejores empresas del mundo gracias a este Máster”
Este Máster en Programación de Videojuegos contiene el programa educativo más completo y actualizado del mercado. Sus características más destacadas son:
- El desarrollo de casos prácticos presentados por expertos en programación y desarrollo de videojuegos
- Los contenidos gráficos, esquemáticos y eminentemente prácticos con los que está concebido recogen una información científica y práctica sobre aquellas disciplinas indispensables para el ejercicio profesional
- Los ejercicios prácticos donde realizar el proceso de autoevaluación para mejorar el aprendizaje
- Su especial hincapié en metodologías innovadoras
- Las lecciones teóricas, preguntas al experto, foros de discusión de temas controvertidos y trabajos de reflexión individual
- La disponibilidad de acceso a los contenidos desde cualquier dispositivo fijo o portátil con conexión a internet
La programación es cada vez más esencial en el desarrollo de un videojuego. Conviértete en alguien imprescindible en la industria gracias a esta titulación”
El programa incluye, en su cuadro docente, a profesionales del sector que vierten en esta capacitación la experiencia de su trabajo, además de reconocidos especialistas de sociedades de referencia y universidades de prestigio.
Su contenido multimedia, elaborado con la última tecnología educativa, permitirá al profesional un aprendizaje situado y contextual, es decir, un entorno simulado que proporcionará una capacitación inmersiva programada para entrenarse ante situaciones reales.
El diseño de este programa se centra en el Aprendizaje Basado en Problemas, mediante el cual el profesional deberá tratar de resolver las distintas situaciones de práctica profesional que se le planteen a lo largo del curso académico. Para ello, contará con la ayuda de un novedoso sistema de vídeo interactivo realizado por reconocidos expertos.
Los juegos son tu pasión y quieres convertirte en un gran desarrollador. No esperes más y matricúlate en este Máster"
Las mejores empresas de la industria te están esperando. Especialízate ya"
Temario
Los contenidos de este Máster en Programación de Videojuegos han sido diseñados cuidadosamente por un equipo de grandes especialistas en la materia que conocen a la perfección el estado actual de la industria. Así, gracias a este programa, los alumnos podrán aprender todos los conocimientos necesarios para poder responder a las demandas de las empresas del sector, puesto que han sido especialmente preparados para sus particularidades y especificidades, que son complejas y están en constante transformación.
Estos contenidos te convertirán en un gran experto en Programación de Videojuegos”
Módulo 1. Fundamentos de Programación
1.1. Introducción a la Programación
1.1.1. Estructura Básica de un Ordenador
1.1.2. Software
1.1.3. Lenguajes de Programación
1.1.4. Ciclo de vida de una Aplicación Informática
1.2. Diseño de Algoritmos
1.2.1. La resolución de Problemas
1.2.2. Técnicas Descriptivas
1.2.3. Elementos y Estructura de un Algoritmo
1.3. Elementos de un Programa
1.3.1. Origen y Características del Lenguaje C++
1.3.2. El Entorno de Desarrollo
1.3.3. Concepto de Programa
1.3.4. Tipos de Datos Fundamentales
1.3.5. Operadores
1.3.6. Expresiones
1.3.7. Sentencias
1.3.8. Entrada y Salida de Datos
1.4. Sentencias de Control
1.4.1. Sentencias
1.4.2. Bifurcaciones
1.4.3. Bucles
1.5. Abstracción y Modularidad: Funciones
1.5.1. Diseño Modular
1.5.2. Concepto de Función y Utilidad
1.5.3. Definición de una Función
1.5.4. Flujo de Ejecución en la llamada de una Función
1.5.5. Prototipo de una Función
1.5.6. Devolución de Resultados
1.5.7. Llamada a una Función: Parámetros
1.5.8. Paso de Parámetros por Referencia y por Valor
1.5.9. Ámbito Identificador
1.6. Estructuras de Datos Estáticas
1.6.1. Arrays
1.6.2. Matrices. Poliedros
1.6.3. Búsqueda y Ordenación
1.6.4. Cadenas. Funciones de E/S para Cadenas
1.6.5. Estructuras. Uniones
1.6.6. Nuevos tipos de Datos
1.7. Estructuras de Datos Dinámicas: Punteros
1.7.1. Concepto. Definición de Puntero
1.7.2. Operadores y Operaciones con Punteros
1.7.3. Arrays de Punteros
1.7.4. Punteros y Arrays
1.7.5. Punteros a Cadenas
1.7.6. Punteros a Estructuras
1.7.7. Indirección Múltiple
1.7.8. Punteros a Funciones
1.7.9. Paso de Funciones, Estructuras y Arrays como Parámetros de Funciones
1.8. Ficheros
1.8.1. Conceptos básicos
1.8.2. Operaciones con Ficheros
1.8.3. Tipos de Ficheros
1.8.4. Organización de los Ficheros
1.8.5. Introducción a los Ficheros C++
1.8.6. Manejo de Ficheros
1.9. Recursividad
1.9.1. Definición de Recursividad
1.9.2. Tipos de Recursión
1.9.3. Ventajas e Inconvenientes
1.9.4. Consideraciones
1.9.5. Conversión Recursivo-Iterativa
1.9.6. La pila de Recursión
1.10. Prueba y Documentación
1.10.1. Pruebas de Programas
1.10.2. Prueba de la Caja Blanca
1.10.3. Prueba de la Caja Negra
1.10.4. Herramientas para realizar las Pruebas
1.10.5. Documentación de Programas
Módulo 2. Estructura de Datos y Algoritmos
2.1. Introducción a las estrategias de Diseño de Algoritmos
2.1.1. Recursividad
2.1.2. Divide y conquista
2.1.3. Otras Estrategias
2.2. Eficiencia y Análisis de los Algoritmos
2.2.1. Medidas de Eficiencia
2.2.2. Medir el tamaño de la Entrada
2.2.3. Medir el tiempo de Ejecución
2.2.4. Caso Peor, Mejor y Medio
2.2.5. Notación Asintónica
2.2.6. Criterios de Análisis Matemático de Algoritmos No Recursivos
2.2.7. Análisis Matemático de Algoritmos Recursivos
2.2.8. Análisis Empírico de Algoritmos
2.3. Algoritmos de Ordenación
2.3.1. Concepto de Ordenación
2.3.2. Ordenación de la Burbuja
2.3.3. Ordenación por Selección
2.3.4. Ordenación por Inserción
2.3.5. Ordenación por Mezcla (merge_sort)
2.3.6. Ordenación Rápida (quick_sort)
2.4. Algoritmos con Árboles
2.4.1. Concepto de Árbol
2.4.2. Árboles Binarios
2.4.3. Recorridos de Árbol
2.4.4. Representar Expresiones
2.4.5. Árboles Binarios Ordenados
2.4.6. Árboles Binarios Balanceados
2.5. Algoritmos con Heaps
2.5.1. Los Heaps
2.5.2. El Algoritmo Heapsort
2.5.3. Las Colas de Prioridad
2.6. Algoritmos con Grafos
2.6.1. Representación
2.6.2. Recorrido en Anchura
2.6.3. Recorrido en Profundidad
2.6.4. Ordenación Topológica
2.7. Algoritmos Greedy
2.7.1. La estrategia Greedy
2.7.2. Elementos de la Estrategia Greedy
2.7.3. Cambio de Monedas
2.7.4. Problema del Viajante
2.7.5. Problema de la Mochila
2.8. Búsqueda de Caminos Mínimos
2.8.1. El Problema del Camino Mínimo
2.8.2. Arcos Negativos y Ciclos
2.8.3. Algoritmo de Dijkstra
2.9. Algoritmos Greedy sobre Grafos
2.9.1. El árbol de Recubrimiento Mínimo
2.9.2. El Algoritmo de Prim
2.9.3. El Algoritmo de Kruskal
2.9.4. Análisis de Complejidad
2.10. Backtracking
2.10.1. El Backtracking
2.10.2. Técnicas Alternativas
Módulo 3. Programación orientada a Objetos
3.1. Introducción a la Programación orientada a Objetos
3.1.1. Introducción a la Programación orientada a Objetos
3.1.2. Diseño de Clases
3.1.3. Introducción a UML para el Modelado de los Problemas
3.2. Relaciones entre Clases
3.2.1. Abstracción y Herencia
3.2.2. Conceptos Avanzados de Herencia
3.2.3. Polimorfismo
3.2.4. Composición y Agregación
3.3. Introducción a los Patrones de Diseño para Problemas orientados a Objetos
3.3.1. ¿Qué son los Patrones de Diseño?
3.3.2. Patrón Factory
3.3.4. Patrón Singleton
3.3.5. Patrón Observer
3.3.6. Patrón Composite
3.4. Excepciones
3.4.1. ¿Qué son las Excepciones?
3.4.2. Captura y Gestión de Excepciones
3.4.3. Lanzamiento de Excepciones
3.4.4. Creación de Excepciones
3.5. Interfaces de Usuarios
3.5.1. Introducción a Qt
3.5.2. Posicionamiento
3.5.3. ¿Qué son los Eventos?
3.5.4. Eventos: definición y captura
3.5.5. Desarrollo de Interfaces de Usuario
3.6. Introducción a la Programación Concurrente
3.6.1. Introducción a la Programación Concurrente
3.6.2. El concepto de Proceso e Hilo
3.6.3. Interacción entre Procesos o Hilos
3.6.4. Los Hilos en C++
3.6.5. Ventajas e inconvenientes de la Programación Concurrente
3.7. Gestión de Hilos y Sincronización
3.7.1. Ciclo de vida de un Hilo
3.7.2. La Clase Thread
3.7.3. Planificación de Hilos
3.7.4. Grupos Hilos
3.7.5. Hilos de Tipo Demonio
3.7.6. Sincronización
3.7.7. Mecanismos de Bloqueo
3.7.8. Mecanismos de Comunicación
3.7.9. Monitores
3.8. Problemas comunes dentro de la Programación Concurrente
3.8.1. El Problema de los Productores Consumidores
3.8.2. El Problema de los Lectores y Escritores
3.8.3. El Problema de la Cena de los Filósofos
3.9. Documentación y Pruebas de Software
3.9.1. ¿Por qué es importante Documentar el Software?
3.9.2. Documentación de Diseño
3.9.3. Uso de Herramientas para la Documentación
3.10. Pruebas de Software
3.10.1. Introducción a las Pruebas del Software
3.10.2. Tipos de Pruebas
3.10.3. Prueba de Unidad
3.10.4. Prueba de Integración
3.10.5. Prueba de Validación
3.10.6. Prueba del Sistema
Módulo 4. Consolas y Dispositivos para Videojuegos
4.1. Historia de la Programación en Videojuegos
4.1.1. Periodo Atari (1977-1985)
4.1.2. Periodo NES y SNES (1985-1995)
4.1.3. Periodo PlayStation / PlayStation 2 (1995-2005)
4.1.4. Periodo Xbox 360, PS3 y Wii (2005-2013)
4.1.5. Periodo Xbox One, PS4 y Wii U – Switch (2013-actualidad)
4.1.6. El futuro
4.2. Historia de la Jugabilidad en Videojuegos
4.2.1. Introducción
4.2.2. Contexto Social
4.2.3. Diagrama Estructural
4.2.4. Futuro
4.3. Adaptación a los Tiempos Modernos
4.3.1. Juegos basados en Movimiento
4.3.2. Realidad Virtual
4.3.3. Realidad Aumentada
4.3.4. Realidad Mixta
4.4. Unity: Scripting I y ejemplos
4.4.1. ¿Qué es un Script?
4.4.2. Nuestro primer Script
4.4.3. Añadiendo un Script
4.4.4. Abriendo un Script
4.4.5. MonoBehaviour
4.4.6. Debugging
4.5. Unity: Scripting II y ejemplos
4.5.1. Entrada de Teclado y Ratón
4.5.2. Raycast
4.5.3. Instanciación
4.5.4. Variables
4.5.5. Variables públicas y serializadas
4.6. Unity: Scripting III y ejemplos
4.6.1. Obteniendo Componentes
4.6.2. Modificando Componentes
4.6.3. Testeo
4.6.4. Múltiples Objetos
4.6.5. Colliders y Triggers
4.6.6. Cuaterniones
4.7. Periféricos
4.7.1. Evolución y clasificación
4.7.2. Periféricos e Interfaces
4.7.3. Periféricos actuales
4.7.4. Futuro próximo
4.8. Videojuegos: perspectivas futuras
4.8.1. Juego basado en la Nube
4.8.2. Ausencia de Controladores
4.8.3. Realidad Inmersiva
4.8.4. Otras Alternativas
4.9. Arquitectura
4.9.1. Necesidades especiales de los Videojuegos
4.9.2. Evolución de la Arquitectura
4.9.3. Arquitectura actual
4.9.4. Diferencias entre Arquitecturas
4.10. Kits de Desarrollo y su Evolución 4.10.1. Introducción
4.10.2. Tercera Generación de Kits de Desarrollo
4.10.3. Cuarta Generación de Kits de Desarrollo
4.10.4. Quinta Generación de Kits de Desarrollo
4.10.5. Sexta Generación de Kits de Desarrollo
Módulo 5. Ingeniería de Software
5.1. Introducción a la Ingeniería del Software y al Modelado
5.1.1. La Naturaleza del Software
5.1.2. La Naturaleza Única de las Webapps
5.1.3. Ingeniería del Software
5.1.4. El Proceso del Software
5.1.5. La práctica de la Ingeniería del Software
5.1.6. Mitos del Software
5.1.7. Cómo comienza todo
5.1.8. Conceptos orientados a Objetos
5.1.9. Introducción a UML
5.2. El Proceso del Software
5.2.1. Un Modelo General de Proceso
5.2.2. Modelos de Proceso prescriptivos
5.2.3. Modelos de Proceso Especializado
5.2.4. El Proceso Unificado
5.2.5. Modelos del Proceso Personal y del Equipo
5.2.6. ¿Qué es la Agilidad?
5.2.7. ¿Qué es un Proceso Ágil?
5.2.8. Scrum
5.2.9. Conjunto de herramientas para el Proceso ágil
5.3. Principios que guían la práctica de la Ingeniería del Software
5.3.1. Principios que guían el Proceso
5.3.2. Principios que guían la Práctica
5.3.3. Principios de Comunicación
5.3.4. Principios de Planificación
5.3.5. Principios de Modelado
5.3.6. Principios de Construcción
5.3.7. Principios de Despliegue
5.4. Comprensión de los Requisitos
5.4.1. Ingeniería de Requisitos
5.4.2. Establecer las Bases
5.4.3. Indagación de los Requisitos
5.4.4. Desarrollo de Casos de Uso
5.4.5. Elaboración del Modelo de los Requisitos
5.4.6. Negociación de los Requisitos
5.4.7. Validación de los Requisitos
5.5. Modelado de los Requisitos: Escenarios, Información y Clases de Análisis
5.5.1. Análisis de los Requisitos
5.5.2. Modelado basado en Escenarios
5.5.3. Modelos UML que proporcionan el Casos de Uso
5.5.4. Conceptos de Modelado de Datos
5.5.5. Modelado basado en Clases
5.5.6. Diagramas de Clases
5.6. Modelado de los Requisitos: Flujo, Comportamiento y Patrones
5.6.1. Requisitos que modelan las Estrategias
5.6.2. Modelado orientado al Flujo
5.6.3. Diagramas de Estado
5.6.4. Creación de un Modelo de Comportamiento
5.6.5. Diagramas de Secuencia
5.6.6. Diagramas de Comunicación
5.6.7. Patrones para el Modelado de Requisitos
5.7. Conceptos de Diseño
5.7.1. Diseño en el contexto de la Ingeniería del Software
5.7.2. El Proceso de Diseño
5.7.3. Conceptos de Diseño
5.7.4. Conceptos de Diseño orientado a Objetos
5.7.5. El modelo del Diseño
5.8. Diseño de la Arquitectura
5.8.1. Arquitectura del Software
5.8.2. Géneros Arquitectónicos
5.8.3. Estilos Arquitectónicos
5.8.4. Diseño Arquitectónico
5.8.5. Evolución de los Diseños Alternativos para la Arquitectura
5.8.6. Mapeo de la Arquitectura con el uso del Flujo de Datos
5.9. Diseño en el Nivel de Componentes y basado en Patrones
5.9.1. ¿Qué es un Componente?
5.9.2. Diseño de Componentes basados en Clase
5.9.3. Realización del Diseño en el Nivel de Componentes
5.9.4. Diseño de Componentes Tradicionales
5.9.5. Desarrollo basado en Componentes
5.9.6. Patrones de Diseño
5.9.7. Diseño de Software basado en Patrones
5.9.8. Patrones Arquitectónicos
5.9.9. Patrones de Diseño en el Nivel de Componentes
5.9.10. Patrones de Diseño de la Interfaz de Usuario
5.10. Calidad del Software y Administración de Proyectos
5.10.1. Calidad
5.10.2. Calidad del Software
5.10.3. El dilema de la Calidad del Software
5.10.4. Lograr la Calidad del Software
5.10.5. Aseguramiento de la Calidad del Software
5.10.6. El Espectro Administrativo
5.10.7. El Personal
5.10.8. El Producto
5.10.9. El Proceso
5.10.10. El Proyecto
5.10.11. Principios y Prácticas
Módulo 6. Motores de Videojuegos
6.1. Los Videojuegos y las TICs
6.1.1. Introducción
6.1.2. Oportunidades
6.1.3. Desafíos
6.1.4. Conclusiones
6.2. Historia de los Motores de Videojuegos
6.2.1. Introducción
6.2.2. Época Atari
6.2.3. Época de los 80
6.2.4. Primeros Motores. Época de los 90
6.2.5. Motores actuales
6.3. Motores de Videojuegos
6.3.1. Tipos de Motores
6.3.2. Partes de un Motor de Videojuegos
6.3.3. Motores actuales
6.3.4. Selección de un Motor para nuestro proyecto
6.4. Motor Game Maker
6.4.1. Introducción
6.4.2. Diseño de Escenarios
6.4.3. Sprites y Animaciones
6.4.4. Colisiones
6.4.5. Scripting en GML
6.5. Motor Unreal Engine 4: introducción
6.5.1. ¿Qué es Unreal Engine 4? ¿Cuál es su filosofía?
6.5.2. Materiales
6.5.3. UI
6.5.4. Animaciones
6.5.5. Sistema de Partículas
6.5.6. Inteligencia Artificial
6.5.7. FPS
6.6. Motor Unreal Engine 4: Visual Scripting
6.6.1. Filosofía de los Blueprints y el Visual Scripting
6.6.2. Debugging
6.6.3. Tipos de Variables
6.6.4. Control de Flujo Básico
6.7. Motor Unity 5
6.7.1. Programación en C# y Visual Studio
6.7.2. Creación de Prefabs
6.7.3. Uso de Gizmos para el Control del Videojuego
6.7.4. Motor Adaptativo: 2D y 3D
6.8. Motor Godot
6.8.1. Filosofía de Diseño de Godot
6.8.2. Diseño orientado a Objetos y Composición
6.8.3. Todo incluido en un paquete
6.8.4. Software Libre y Dirigido por la Comunidad
6.9. Motor RPG Maker
6.9.1. Filosofía de RPG Maker
6.9.2. Tomando como referencia
6.9.3. Crear un Juego con Personalidad
6.9.4. Juegos Comerciales de éxito
6.10. Motor Source 2
6.10.1. Filosofía de Source 2
6.10.2. Source y Source 2: evolución
6.10.3. Uso de la Comunidad: Contenido Audiovisual y Videojuegos
6.10.4. Futuro del Motor Source 2
6.10.5. Mods y Juegos de éxito
Módulo 7. Sistemas Inteligentes
7.1. Teoría de Agentes
7.1.1. Historia del Concepto
7.1.2. Definición de Agente
7.1.3. Agentes en Inteligencia Artificial
7.1.4. Agentes en Ingeniería de Software
7.2. Arquitecturas de Agentes
7.2.1. El Proceso de Razonamiento de un Agente
7.2.2. Agentes Reactivos
7.2.3. Agentes Deductivos
7.2.4. Agentes Híbridos
7.2.5. Comparativa
7.3. Información y Conocimiento
7.3.1. Distinción entre Datos, Información y Conocimiento
7.3.2. Evaluación de la Calidad de los Datos
7.3.3. Métodos de Captura de Datos
7.3.4. Métodos de Adquisición de Información
7.3.5. Métodos de Adquisición de Conocimiento
7.4. Representación del Conocimiento
7.4.1. La importancia de la Representación del Conocimiento
7.4.2. Definición de Representación del Conocimiento a través de sus Roles
7.4.3. Características de una Representación del Conocimiento
7.5. Ontologías
7.5.1. Introducción a los Metadatos
7.5.2. Concepto filosófico de Ontología
7.5.3. Concepto informático de Ontología
7.5.4. Ontologías de Dominio y Ontologías de Nivel superior
7.5.5. Cómo construir una Ontología
7.6. Lenguajes para Ontologías y Software para la Creación de Ontologías
7.6.1. Tripletas RDF, Turtle y N3
7.6.2. RDF Schema
7.6.3. OWL
7.6.4. SPARQL
7.6.5. Introducción a las diferentes herramientas para la creación de ontologías
7.6.6. Instalación y uso de Protégé
7.7. La Web Semántica
7.7.1. El estado actual y futuro de la Web Semántica
7.7.2. Aplicaciones de la Web Semántica
7.8. Otros modelos de Representación del Conocimiento
7.8.1. Vocabularios
7.8.2. Visión Global
7.8.3. Taxonomías
7.8.4. Tesauros
7.8.5. Folksonomías
7.8.6. Comparativa
7.8.7. Mapas Mentales
7.9. Evaluación e Integración de Representaciones del Conocimiento
7.9.1. Lógica de Orden Cero
7.9.2. Lógica de Primer Orden
7.9.3. Lógica Descriptiva
7.9.4. Relación entre diferentes Tipos de Lógica
7.9.5. Prolog: Programación basada en Lógica de Primer Orden
7.10. Razonadores Semánticos, Sistemas basados en Conocimiento y Sistemas Expertos
7.10.1. Concepto de Razonador
7.10.2. Aplicaciones de un Razonador
7.10.3. Sistemas basados en el Conocimiento
7.10.4. MYCIN, Historia de los Sistemas Expertos
7.10.5. Elementos y Arquitectura de Sistemas Expertos
7.10.6. Creación de Sistemas Expertos
Módulo 8. Programación en Tiempo Real
8.1. Conceptos básicos de la Programación Concurrente
8.1.1. Conceptos Fundamentales
8.1.2. Concurrencia
8.1.3. Beneficios de la Concurrencia
8.1.4. Concurrencia y Hardware
8.2. Estructuras básicas de Soporte a la Concurrencia en Java
8.2.1. Concurrencia en Java
8.2.2. Creación de Threads
8.2.3. Métodos
8.2.4. Sincronización
8.3. Threads, ciclo de vida, prioridades, interrupciones, estados, ejecutores
8.3.1. Threads
8.3.2. Ciclo de vida
8.3.3. Prioridades
8.3.4. Interrupciones
8.3.5. Estados
8.3.6. Ejecutores
8.4. Exclusión Mutua
8.4.1. ¿Qué es la Exclusión Mutua?
8.4.2. Algoritmo de Dekker
8.4.3. Algoritmo de Peterson
8.4.4. Exclusión Mutua en Java
8.5. Dependencias de Estados
8.5.1. Inyección de Dependencias
8.5.2. Implementación del Patrón en Java
8.5.3. Formas de inyectar las Dependencias
8.5.4. Ejemplo
8.6. Patrones de Diseño
8.6.1. Introducción
8.6.2. Patrones de Creación
8.6.3. Patrones de Estructura
8.6.4. Patrones de Comportamiento
8.7. Uso de Bibliotecas Java
8.7.1. ¿Qué son las Bibliotecas en Java?
8.7.2. Mockito-All, Mockito-Core
8.7.3. Guava
8.7.4. Commons-Io
8.7.5. Commons-Lang, Commons-Lang3
8.8. Programación de Shaders
8.8.1. Pipeline 3D y Rasterizado
8.8.2. Vertex Shading
8.8.3. Pixel Shading: Iluminación I
8.8.4. Pixel Shading: Iluminación II
8.8.5. Post-Effectos
8.9. Programación de Tiempo Real
8.9.1. Introducción
8.9.2. Procesamiento de Interrupciones
8.9.3. Sincronización y Comunicación entre Procesos
8.9.4. Los Sistemas de Planificación en Tiempo Real
8.10. Planificación de Tiempo Real
8.10.1. Conceptos
8.10.2. Modelo de referencia de los Sistemas de Tiempo Real
8.10.3. Políticas de Planificación
8.10.4. Planificadores Cíclicos
8.10.5. Planificadores con Propiedades Estáticas
8.10.6. Planificadores con Propiedades Dinámicas
Módulo 9. Diseño y Desarrollo de Juegos Web
9.1. Orígenes y Estándares de la Web
9.1.1. Orígenes de Internet
9.1.2. Creación de World Wide Web
9.1.3. Aparición de los Estándares Web
9.1.4. El auge de los Estándares Web
9.2. HTTP y estructura Cliente-Servidor
9.2.1. Rol Cliente-Servidor
9.2.2. Comunicación Cliente-Servidor
9.2.3. Historia reciente
9.2.4. Computación Centralizada
9.3. Programación Web: Introducción
9.3.1. Conceptos básicos
9.3.2. Preparando un Servidor Web
9.3.3. Conceptos básicos de HTML5
9.3.4. Formas HTML
9.4. Introducción a HTML y ejemplos
9.4.1. Historia de HTML5
9.4.2. Elementos de HTML5
9.4.3. APIS
9.4.4. CCS3
9.5. Modelo de Objeto de Documento
9.5.1. ¿Qué es el Modelo de Objetos del Documento?
9.5.2. Uso de DOCTYPE
9.5.3. La importancia de validar el HTML
9.5.4. Accediendo a los elementos
9.5.5. Creando elementos y textos
9.5.6. Usando InnerHTML
9.5.7. Eliminando un Elemento o Nodo de Texto
9.5.8. Lectura y Escritura de los Atributos de un Elemento
9.5.9. Manipulando los Estilos de los Elementos
9.5.10. Adjuntar Múltiples Ficheros a la vez
9.6. Introducción a CSS y ejemplos
9.6.1. Sintaxis CSS3
9.6.2. Hojas de Estilo
9.6.3. Etiquetas
9.6.4. Selectores
9.6.5. Diseño Web con CSS
9.7. Introducción a Javascript y ejemplos
9.7.1. ¿Qué es Javascript?
9.7.2. Breve historia del Lenguaje
9.7.3. Versiones de Javascript
9.7.4. Mostrar un Cuadro de Diálogo
9.7.5. Sintaxis de Javascript
9.7.6. Comprensión de Scripts
9.7.7. Espacios
9.7.8. Comentarios
9.7.9. Funciones
9.7.10. Javascript en la Página y Externo
9.8. Funciones en JavaScript
9.8.1. Declaraciones de Función
9.8.2. Expresiones de Función
9.8.3. Llamar a funciones
9.8.4. Recursividad
9.8.5. Funciones Anidadas y Cierres
9.8.6. Preservación de Variables
9.8.7. Funciones Multi-Anidadas
9.8.8. Conflictos de Nombres
9.8.9. Clausuras o Cierres
9.8.10. Parámetros de una Función
9.9. PlayCanvas para Desarrollar Juegos Web
9.9.1. ¿Qué es PlayCanvas?
9.9.2. Configuración del Proyecto
9.9.3. Creando un Objeto
9.9.4. Agregando Físicas
9.9.5. Añadiendo un Modelo
9.9.6. Cambiando los Ajustes de Gravedad y Escena
9.9.7. Ejecutando Scripts
9.9.8. Controles de Cámara
9.10. Phaser para Desarrollar Juegos Web
9.10.1. ¿Qué es Phaser?
9.10.2. Cargando Recursos
9.10.3. Construyendo el Mundo
9.10.4. Las Plataformas
9.10.5. El Jugador
9.10.6. Añadir Físicas
9.10.7. Usar el Teclado
9.10.8. Recoger Pickups
9.10.9. Puntos y Puntuación
9.10.10. Bombas de Rebote
Módulo 10. Redes y Sistemas Multijugador
10.1. Historia y evolución de Videojuegos Multijugador
10.1.1. Década 1970: Primeros Juegos Multijugador
10.1.2. Años 90: Duke Nukem, Doom, Quake
10.1.3. Auge de Videojuegos Multijugador
10.1.4. Multijugador Local y Online
10.1.5. Juegos de Fiesta
10.2. Modelos de Negocio Multijugador
10.2.1. Origen y funcionamiento de los Modelos de Negocio Emergentes
10.2.2. Servicios de Venta en Línea
10.2.3. Libre Para Jugar
10.2.4. Micropagos
10.2.5. Publicidad
10.2.6. Suscripción con Pagos Mensuales
10.2.7. Pagar por Juego
10.2.8. Prueba antes de Comprar
10.3. Juegos Jocales y Juegos en Red
10.3.1. Juegos Locales: inicios
10.3.2. Juegos de fiesta: Nintendo y la unión de la familia
10.3.3. Juegos en Red: inicios
10.3.4. Evolución de los Juegos en Red
10.4. Modelo OSI: Capas I
10.4.1. Modelo OSI: introducción
10.4.2. Capa Física
10.4.3. Capa de Enlace de Datos
10.4.4. Capa de Red
10.5. Modelo OSI: Capas II
10.5.1. Capa de Transporte
10.5.2. Capa de Sesión
10.5.3. Capa de Presentación
10.5.4. Capa de Aplicación
10.6. Redes de Computadores e Internet
10.6.1. ¿Qué es una Red de Computadoras?
10.6.2. Software
10.6.3. Hardware
10.6.4. Servidores
10.6.5. Almacenamiento en Red
10.6.6. Protocolos de Red
10.7. Redes Móviles e Inalámbricas
10.7.1. Red Móvil
10.7.2. Red Inalámbrica
10.7.3. Funcionamiento de las Redes móviles
10.7.4. Tecnología Digital
10.8. Seguridad
10.8.1. Seguridad Personal
10.8.2. Hacks y Cheats en Videojuegos
10.8.3. Seguridad Anti-Trampas
10.8.4. Análisis de Sistemas de Seguridad Anti-Trampas
10.9. Sistemas Multijugador: Servidores
10.9.1. Alojamiento de Servidores
10.9.2. Videojuegos MMO
10.9.3. Servidores de Videojuegos Dedicados
10.9.4. LAN Parties
10.10. Diseño de Videojuegos Multijugador y Programación
10.10.1. Fundamentos de Diseño de Videojuegos Multijugador en Unreal
10.10.2. Fundamentos de Diseño de Videojuegos Multijugador en Unity
10.10.3. ¿Cómo hacer que un Juego Multijugador sea divertido?
10.10.4. Más allá de un Mando: Innovación en Controles Multijugador
Si quieres desarrollar una gran carrera Programando Videojuegos famosos en todo el mundo esta es la titulación que buscas”
Máster en Programación de Videojuegos
¿Estás listo para sumergirte en el apasionante mundo de la creación de videojuegos? TECH Universidad te invita a explorar nuestro Máster en Programación de Videojuegos, una experiencia virtual que transformará tus habilidades informáticas y te llevará a un nivel completamente nuevo de destreza técnica. Nuestro programa te brinda la oportunidad de adquirir habilidades excepcionales en el campo de la creación de juegos digitales. Con un equipo docente altamente cualificado y con amplia experiencia en la industria, estarás respaldado por expertos que compartirán sus conocimientos y te guiarán en tu viaje hacia el éxito. Aprenderás técnicas de programación avanzadas, desarrollo de gráficos en 2D y 3D, inteligencia artificial aplicada a videojuegos y diseño de niveles emocionantes. Este posgrado te sumergirá en un entorno virtual interactivo, donde tendrás acceso a una amplia gama de recursos y herramientas de vanguardia. Podrás explorar las últimas tendencias en la industria de los videojuegos y aplicarlas en proyectos prácticos que desafiarán tu ingenio y creatividad. Desde la conceptualización hasta la implementación, desarrollarás habilidades integrales que te permitirán crear experiencias de juego inolvidables.
¡El futuro de la industria está en tus manos!
Al finalizar el programa recibirás un certificado de reconocimiento de TECH, respaldado por nuestra reputación de excelencia académica. Este certificado será tu pasaporte hacia un mundo de oportunidades profesionales. Podrás trabajar como desarrollador de videojuegos, diseñador de niveles, programador de IA o incluso emprender tu propio estudio de desarrollo de juegos. El objetivo principal del Máster en Programación de Videojuegos de TECH Universidad es brindarte las habilidades y conocimientos necesarios para convertirte en un profesional altamente capacitado en el campo de la creación de videojuegos. Queremos potenciar tu talento y pasión por los juegos digitales y proporcionarte las herramientas para que puedas destacarte en esta industria en constante evolución. ¿Estás listo para convertir tu pasión por los videojuegos en una carrera gratificante? No pierdas esta oportunidad increíble de estudiar en TECH, donde la innovación y la calidad educativa son nuestra máxima prioridad. Únete a nosotros y desbloquea tu potencial en la programación de videojuegos.