D3D:Migración a RS de un vehículo ferroviario
De TrenSimpedia
Este artículo o sección es un miniesbozo en el que falta información esencial. Ampliándolo ayudarás a mejorar la TrenSimpedia.
|
Para el seguimiento de la migración mostrada en el presente artículo se recomienda la lectura previa del artículo Migración a RS de un edificio sencillo, pues algunos de los conceptos o procedimientos allí mostrados se dará por sabidos en el presente caso.
Contenido[ocultar] |
Descripción del modelo
Para empezar con un vehículo ferroviario he escogido un vagón de mercancías cerrado. Tiene alguna de las complejidades de un vehículo, pero no necesita todavía interiores, cabinas, ni especificaciones del aparato motor. Todo llegará.El elemento elegido es un vagón frigorífico particular de la compañía Beristain.
En el año 1947, Herederos de Ramón Múgica S.L. construyó, para la compañía BERISTAIN de San Sebastián, una serie muy corta de tres vagones frigoríficos sobre bastidor unificado. El revestimiento exterior de la caja era con friso de madera. Este tipo de vehículos mantenían a temperaturas bajo cero los pescados mediante bandejas, en las cuales se depositaban grandes bloques de hielo, aunque también estaban preparados para transportar carne colgada de ganchos de los que disponían. El aislamiento de las cajas se conseguía mediante corcho prensado y papel parafinado.
Tras su andadura a lo largo de más de 20 años todos ellos fueron desguazados en los años 70.
Preparación de la migración
Comenzaremos por crear una estructura de directorios de trabajo en la carpeta Source del directorio donde tengamos instalado el simulador, habitualmente C:\Archivos de Programa\Rail Simulator.En la carpeta Source debemos crear un directorio que determine el código de Provider bajo el cual actuaremos. Podemos tener tantos Providers como queramos, pero es una buena práctica identificar nuestras creaciones bajo un único Provider. Para determinar el código de Provider, si bien éste es totalmente libre, pudiera darse el caso de colisión entre dos creadores que hayan escogido el mismo código. Por tanto, como recomendación y buena práctica, desde Trensim solicitamos que el código de provider de un autor coincida con el código de usuario con el cual se ha debido dar de alta en el foro de la web Rail Simulator para poder proceder a descargarse el paquete de las Developer Tools, paquete sin el cual no tienen sentido los pasos que vamos a dar a continuación.
En la imagen asociada se puede comprobar que el Provider escogido en este caso ha sido Pere.
A continuación, en el directorio designado para el Provider que acabamos de mencionar deberemos crear un subdirectorio que determine el código de Product en el que vamos a encuadrar nuestra creación. Un Product es un conjunto de elementos, ya sean elementos estáticos, vehículos, vegetación, etc, que tienen una relación entre ellos. Este concepto se puede orientar al conjunto de elementos necesarios para una ruta completa, como en las originales que vienen con el juego, o cualquier otro concepto o agrupación que deseemos para nuestras creaciones. De esta forma podemos crear Products para las diferentes compañías de ferrocarril de las cuales vayamos a crear vehículos, o para el conjunto de elementos que elaboremos para una ruta concreta, o para todos los vehículos de una composición o tren concreto que deseemos publicar, etc. Cierto es que a la hora de generar un paquete de distribución de nuestras creaciones éste puede ser un elemento que determine la agrupación a crear, pero también se pueden crear paquetes distribuibles con objetos de diferentes Products, o incluso de diferentes Providers, si es necesario.
En la imagen asociada se puede comprobar que el Product definido en este caso ha sido RenfeIII.
Bajo las carpetas Provider y Product deberemos crear una carpeta RailVehicles, que contendrá los diferentes trabajos de material móvil que vayamos creando. Bajo esta carpeta crearemos otra denominada Freight para los proyectos de vagones de mercancías. Hasta aquí la estructura es la estándar que determina Rail Simulator, y que podemos observar en el Provider Developer que se crea por defecto y que contiene ejemplos de diferentes tipos de Assets.
Por último, y bajo esta jerarquía predefinida, crearemos un directorio para los archivos de nuestro proyecto, con un subdirectorio denominado Textures que contendrá las texturas del proyecto.
En este caso se ha denominado ESRNPR_Beristain, pero puede llamarse como consideremos más oportuno.
Una última observación, bajo el directorio para nuestro vagón es habitual encontrar la estructura de subdirectorios que se muesta en la imagen adjunta. La carpeta Default contiene a su vez una carpeta para los datos del vagón y una subcarpeta para las texturas, de la froma habitual. Su existencia nos permite tener diferentes versiones y/o repintados de un mismo vagón (es aplicable a cualquier tipo de material móvil) creando al nivel de la carpeta Default otra que contenga tan sólo los archivos diferenciales respecto al vagón base, de forma que todo archivo no hallado en la estructura de una versión se buscará en la estructura Default.
Preparación de la malla
Al directorio Wagon del proyecto copiaremos el archivo del proyecto TSM en formato .dst, para tenerlo listo para la migración.
Preparación de las texturas
En el directorio Textures copiaremos todos los archivos de texturas que sean necesarios para el proyecto, en los formatos originales, ya sean .bmp o .tga.
Una vez copiadas las texturas procederemos, en este mismo directorio, a convertirlas en archivos .ace con el mismo nombre de archivo que el original, operación que podemos realizar con la herramienta ToAce.exe, o con el plugin para Photoshop que se encuentra disponible en la web de Rail Simulator. Obtendremos para cada textura dos archivos: el original que usará el programa 3D Canvas, y su imagen en formato .ace que usará el Blueprint para su exportación a Rail Simulator.
Importación en 3D Canvas
Abrimos el programa 3D Canvas v7.1.2.0 (o superior), con los Trainworks activados, e importamos el archivo ya existente, del proyecto de la torre de enclavamientos en TSM, mediante File > Import > Trainworks > Trainsim Modeler (.dst).Tras seleccionar el archivo .dst a abrir, aparecerá una ventana de opciones de la importación.
Los valores que se proponen son los habituales para una migración normal, por lo que procederemos a aceptar las sugerencias sin alterar ninguno de los campos o valores que se muestran en dicha ventana.
El resultado será una malla en 3D Canvas idéntica al original en TSM que puede presentar algún fallo o problema de texturado, tal como se ha comentado en Conversión de proyectos TSM a Canvas 3D al señalar las tres reglas de la migración.
En este caso el modelo no parece presentar problemas, salvo porque si nos fijamos las zapatas de freno aparecen como unos enormes rectángulos, fruto de haber perdido este polígono su textura original con canal alpha (ver imagen adjunta). Efectivamente, en este modelo las zapatas no están modeladas si no que están representadas tan sólo por un polígono con transparencia, y éste, a su vez, comparte la pieza del conjunto de la caja de grasa y ballesta, pieza que usa otra textura sin canal alpha.
Corrección de problemas
En el presente caso el problema queda reflejado por haber incumplido la primera de las reglas: Una pieza en TSM (part) debe estar texturada a partir de una sola hoja de texturas.La corrección en este caso es simple. Basta ir en TSM a la pieza de la suspensión del vagón, seleccionar los polígonos de las zapatas del freno y separar éstos del resto de la pieza mediante el comando Split Part. Una vez modificado en TSM el archivo original podemos proceder a su importación sin problemas.
Como de costumbre, la escena generada en Canvas se verá oscura y deberemos "iluminarla", si lo deseamos, tal como ya se ha descrito en el caso de la Migración de la Torre de Enclavamientos.
La escena resultante la deberemos guardar en formato 3D Canvas para futuros usos. El mismo directorio del proyecto creado puede ser una buena opción para guardarlo.
Creación de LODs
La jerarquía de elementos importada a 3D Canvas se muestra en la siguiente imagen:
Se observa que se ha generado un grupo denominado Import, del cual depende un segundo grupo con el nombre de la primera pieza en la jerarquía de TSM (el MAIN tradicional) del cual dependen tantos grupos como piezas componían el proyecto original, cada uno con un elemento y con el nombre que tenían en TSM. Que los nombres de las piezas se conserven es una ventaja, sobre todo en elementos con gran número de piezas.
Tanto grupo no suele ser beneficioso para Rail Simulator, por lo que, en la medida de lo posible, deberemos ir moviendo las piezas del vehículo para agruparlos en menos grupos, buscando asociaciones de piezas que tengan relación entre si y que puedan compartir una misma distancia límite de visión:
La imagen anterior muestra una nueva jerarquía en la que las piezas ya han sido organizadas en nuevos grupos. Para ajustar dicha organización bastará que en el árbol de jerarquía de las piezas pinchemos sobre una de ellas (cubo marrón) y la arrastremos al grupo (cubo amarillo) al que deseemos que quede asociada.
Esta nueva jerarquía tiene muchos menos grupos (son los elementos que más comen recursos en el Rail Simulator), y estos están agrupados según nuestra conveniencia para establecer los LODs del objeto. Las piezas que siempre estarán a la vista (caja, techo, etc) están directamente bajo el grupo Import que define el vagón, o sea, estarán sujetas a la distanciade visión del propio vagón. El resto de piezas están bajo diferentes grupos.
Los LODs nos permitirán definir la carga gráfica del objeto en virtud de la distancia a la que se encuentre respecto del observador en el juego, según ya se ha expuesto en la Migración a RS de un edificio sencillo, por tanto, renombraremos los grupos según las distancias de visión que deseemos para cada uno de ellos:
Como podemos observar, el vagón será visible hasta los 1000 metros, pero los elementos más pequeños tan sólo lo serán hasta los 50 metros, los medianos hasta los 100 metros, y a partir de dicha distancia únicamente se representará la caja, el techo, las ruedas y los elementos del grupo principal pero no el resto.
Al grupo original Import también le hemos cambiado el nombre por otro que identifica el objeto.
Exportación a Rail Simulator
El modelo así preparado lo podemos exportar al formato intermedio de Rail Simulator .IGS.
Primero deberemos seleccionar el elemento de la escena que deseamos exportar. Bastará con que seleccionemos con el botón derecho del ratón el nodo raíz del vehículo: el denominado MAIN inicialmente, o bien 1_1000_Beristain una vez recompuesta la jerarquía.
Del el menú contextual desplegado en la anterior operación, seleccionaremos Select Group, y después nos dirigiremos al menú principal para seleccionar: File > Export > Trainworks > Rail Simulator Intermediary Geometry Format (.igs).
Una ventana nos preguntará por la ubicación y el nombre del archivo resultante. Deberemos guardar la exportación en el directorio del proyecto que hemos creado al principio y podemos darle el nombre que deseemos.
Una nueva ventana nos preguntará si deseamos crear LODs (Levels Of Detail) para el modelo. Aunque podemos obviar estos elementos, lo deseable es que el plugin de exportación cree LODs para el vagón, por lo que contestaremos que sí.
Finalmente una nueva ventana nos solicita si los LODs los queremos generar a partir de los niveles que hayamos introducido en los nombres de las piezas. En el presente caso, en que hemos llevado a cabo dicha creación de nombres, contestaremos que sí. Pero si no lo hubiéramos realizado, podemos contestar que no tenemos definidos LODs en el modelo, en cuyo caso la creación de los mismos seguirá las reglas indicadas para la Migración a RS de un edificio sencillo.
Creación del Blueprint
Una vez creado el archivo IGS ya podemos dejar el Canvas por el momento y pasar al Blueprint Editor de Rail Simulator que a partir de unas definiciones (los ficheros blueprint) generará los archivos necesarios para el simulador.Una vez arrancado el Asset Editor, observaremos que nos muestra un árbol jerárquico con los diferentes Providers que tengamos definidos, desplegaremos la jerarquía de nuestro código de Provider hasta llegar al directorio del proyecto, y nos situaremos en el subdirectorio Wagon donde con el botón derecho del ratón desplegaremos el menú contextual para seleccionar la opción New Blueprint. Se nos preguntará por el tipo de blueprint que deseamos generar, y deberemos elegir Wagon blueprint dado que vamos a crear un vagón de mercancías. Daremos nombre al blueprint creado y procederemos a cumplimentar aquellos campos que sean relevantes para nuestro proyecto (que no serán todos ni mucho menos).
Una vez terminada esta operación salvaremos el blueprint. Los valores más relevantes del blueprint para elementos escénicos son los siguientes:
Display Name
En esta sección podemos informar el nombre del objeto y su descripción en un conjunto amplio y variado de idiomas.
Cabe observar que si no se introduce ninguna descripción en un idioma determinado el vehículo no estará disponible en el editor si el juego se inicia para ese idioma, por lo que es recomendable introducir algún texto en todos ellos caso de querer la publicación internacional del mismo. Desconozco si este error se corrige mediante algún parche de los existentes, o será corregido en un futuro.
Mass
Masa del vehículo expresada en toneladas, sin tener presente la posible carga del mismo.
Datos de Unión entre vehículos
Estos valores permiten ajustar el espacio entre vagones cuando estos están acoplados.
Front Pivot X
Distancia en metros desde el centro del vagón hasta el extremo (plato) de los topes frontales.
Front Pivot Y
Altura en metros desde el nivel del carril hasta la posición de los topes frontales.
Back Pivot X
Distancia en metros desde el centro del vagón hasta el extremo (plato) de los topes traseros. Esta distancia se expresará en valor negativo.
Back Pivot Y
Altura en metros desde el nivel del carril hasta la posición de los topes traseros.
Datos del Collision Box
Determina las dimensiones y posición del cubo que define la zona sólida del vehículo (o Bounding Box). El Collision Box se ubica en la caja del vehículo, excluyendo topes y rodamiento. Ver figura anexa:Collision center x
Distancia en metros desde el centro del vagón hasta el centro del Collision Box en el eje longitudinal.
Collision center y
Distancia en metros desde el centro del vagón hasta el centro del Collision Box en altura. Para calcular este valor:
- Se toma la altura total del vehículo (h)
- Se resta el diámetro de las ruedas (r)
- El valor obtenido se divide por dos
- Al resultado se le suma la altura de las ruedas (r)
Collision center y = ((h - r) / 2) + r
Collision width
Anchura total del vehículo en metros
Collision height
Altura del Collision Box. Para calcular este valor:
- Se toma la altura total del vehículo (h)
- Se resta el diámetro de las ruedas (r)
Collision height y = (h - r)
Collision length
Longitud del vehículo sin considerar los topes. Los valores de front/rear pivot point si tienen en cuenta los topes.
Si la longitud del Collision Box incluye los topes, al aproximarse dos vagones para acoplarse estos colisionarán y no podrá producirse dicho acople.
Si la longitud de los topes fuese muy pequeña, y el Collision Box de dos vagones estuvieran por tanto muy próximos al estar acoplados, se debería reducir esta longitud para evitar que en las curvas cerradas las esquinas de los Collision Box colisionasen, provocando el descarrilamiento de los vehículos.
Bogey
Train brake assembly
Geometry ID
Aquí deberemos indicar la ruta, bajo Provider y Product donde se encuentra el archivo IGS de nuestro modelo que va a ser convertido a archivo accesible en el juego. Para no tener que escribir dicha ruta, con el riesgo de equivocarnos, podemos hacer clic con el botón derecho encima del archivo .IGS en el árbol de la izquierda (es el que tiene un icono con un cubo azul claro con dos triángulos naranjas, todo ello semejante a un envoltorio de caramelo), y seleccionar la opción Copy filename. Después pegaremos la ruta en el campo Geometry ID mediante Control + V.
En este caso: Scenery\Buildings\Torre_Enclav\Torre_Enclav.IGS
Shadow Type
Sólo hay dos valores posibles:
- Blobby, si queremos que el juego genere una sombra circular difusa bajo nuestro objeto.
- None, si no queremos la sombra anterior (p.e. porque el objeto ya posee sombras propias).
Detail level generation range
Este apartado incluye dos campos: Highest level 1 is highest, y Lowest level 10 is lowest. Ambos, en conjunción, indican los límites entre los cuales el juego generará un número de Detail level que se asociará al objeto al incorporarlo a una ruta, siendo Highest level 1 is highest el valor inferior y Lowest level 10 is lowest el valor superior (si, está bien indicado aunque pueda parecer que no).
Una vez asociado el nivel de detalle al elemento, cuando el usuario del juego seleccione su nivel de detalle (según sea su ordenador) verá únicamente aquellos objetos que superen dicho nivel. Es decir, en lenguaje llano, que si el objeto tiene por límites 10 y 10 siempre se le generará el valor 10 como nivel de detalle y siempre será visible, pues este valor siempre será igual o superior al nivel de detalle elegido por el jugador. Si por contra tiene por límites 1 y 5 se le generará un valor entre 1 y 5 como nivel de detalle y únicamente será visible cuando el usuario elija un valor de detalle superior: entre medio (5) y máximo (10).
Personalmente considero que los edificios que forman parte de las estructuras ferroviarias siempre han de ser visibles y les asigno los valores 10 y 10, mientras que a edificios de viviendas les suelo asignar los valores 1 y 10 para que la frecuencia de aparición varíe en virtud de lo que disponga en cada caso el jugador.
Creación del Bogie
Visualización en el RS
A continuación procederemos a exportar el blueprint del vagón mediante el botón Export situado en la parte superior del Blueprint Editor, observando que no se produzcan errores (no deberían producirse).Para ver el resultado de la exportación, iniciaremos el Rail Simulator y nos dirigiremos a editar una ruta, o en su defecto crearemos una para nuestras pruebas.
Una vez estemos en la edición de la ruta, en la ventana superior de Caja de herramientas seleccionar Herramientas de escenario. Luego en la ventana de Explorador de objetos seleccionar Material rodante, y en la lista de elementos deberá aparecer nuestro vagón. Una vez seleccionado, el vehículo lo podremos situar sobre una vía mediante el cursor.
En el caso de que no apareciese en la lista, deberemos asegurarnos, mediante el botón Filtro de conjunto de datos que nos desplegará la ventana del mismo nombre a la derecha, de que el Provider y el Product donde se encuadra nuestro objeto están seleccionados, con el fin de permitir su uso.
En este punto ya tenemos el vagón migrado a RS, y perfectamente operacional: lo podremos enganchar a una composición, mover en un tren por un recorrido, desenganchar en una estación, etc. Pero si deseamos explotar mejor las posibilidades que nos permite RS podemos continuar con los siguientes puntos descritos en este artículo. |
Creación de sombra
Sombra bajo el vagón
Sombra del propio vagón
Creación del Gancho
Para incorporar un gancho funcional a nuestro modelo deberemos primero tener un gancho definido y exportado correctamnte.
Obtención de un gancho funcional
La documentación que se incluye con las Developer Tools incluye el documento 4.12 How to Create Couplings donde se explica en amplitud la forma de crear un gancho, del tipo que sea, para nuestros vehículos. No obstante, en el presente artículo pretendemos dar una introducción a las diferentes posibilidades técnicas de Rail Simulator, y en este caso vamos a mostrar una forma sencilla de conseguir un gancho de husillo: el modelo inglés que se incluye en el juego.
En los directorios de ejemplo que las Developer Tools, que se pueden ver bajo el Provider Developer, en la ruta ...Rail Simulator\Source\Developer\Addon\RailVehicles\Couplings\3Link\Screw encontraremos los archivos necesarios para la generación del gancho, con un único problema: la textura 3link_screw.ace del gancho es de un color calabaza uniforme (como en toos los ejemplos incluidos). Esto último no es mucho problema, pues junto al archivo .ace también encontraremos el archivo 3link_screw.psd con las texturas originales. Bastará con abrir este archivo en Photoshop y gardarlo en formato .ace.
No obstante, incluimos el archivo .ace por si no se dispone de un editor capaz de abrir archivos .psd: 3link_screw.zip
Para tener el gancho bastará con copiar bajo nuestro Provider la ruta antes mostrada junto a todos los archivos, sustituir la textura 3link_screw.ace por la que indicamos, y abrir el blueprint del gacho (también está suministrado en el directorio señalado) y exportar el gancho.
Uso en el modelo del gancho funcional
No es necesario modificar el modelo en cuestion, porque los parámetros necesarios se indican exclusivamente a nivel del Blueprint del material.
Abriremos el Blueprint del vagón para completar la información referente al gancho y cumplimentaremos los siguientes valores: