int create_bitmap_3d( int id_file, int id_graph )
Retorna:
El código del objeto 3D creado o (0) si no pudo crearlo.
Descripción:
Crea una imagen 3D con el gráfico que se le pasa como parámetro. Esta imagen sería conveniente que sea múltiplo de 2 en sus valores de ancho y alto (es decir tendría que valer 2, 4, 8, 16, 32, 64, ...). En el caso de no ser múltiplo de 2 se creará una imagen virtual a partir de esta que sea múltiplo de 2.
Se devuelve como valor de retorno el código del objeto 3D, que es un valor numérico que debe especificarse para utilizar el gráfico, en la variable object3d o, en general, en todas las funciones que requieran un código del objeto 3D entre sus parámetros.
Es posible crear tantos objetos 3D como sea necesario; cada vez que se cree uno la función devolverá el código que le corresponde.
Ejemplo de utilización de la función:
int objeto3d; PROCESS_INIT( objeto )(int tx) BEGIN_INIT x = tx; END_INIT BEGIN ctype = c_3d_object; object3d = objeto3d; size = 100; z = 100; y = -100; LOOP { angle3d.y += 5000; FRAME; } END MAIN_PROGRAM_CDIV PRIVATE int fichero; BEGIN_PROGRAM set_gfx(GFX_AUTODETECT_WINDOWED); set_depth(16); set_mode(m640x480); x = 0; y = -100; z = -1000; write(0,0, 0,0, "Pulse 'up' o 'down' para avanzar o retroceder"); write(0,0,10,0, "Pulse 'left' o 'right' gira la cámara izquierda o derecha"); write(0,0,20,0, "Pulse 'a' o 's' inclinar la cámara arriba o abajo"); write(0,0,30,0, "Pulse 'q' o 'w' girar la cámara horizontalmente"); fichero = load_fpg("../help.fpg"); objeto3d = create_bitmap_3d( fichero, 10 ); object3d = objeto3d; start_3d(0, fichero, 9, 10000, 10000, 0, this); new objeto(0); new objeto(-500); new objeto(500); m3d[0].distance.z = 500; // Nos movemos en el espacio 3D LOOP{ if( key(_a) ) angle3d.x += 1000; if( key(_s) ) angle3d.x -= 1000; if( key(_q) ) angle3d.z += 1000; if( key(_w) ) angle3d.z -= 1000; if( key(_left) ) angle3d.y += 5000; if( key(_right)) angle3d.y -= 5000; if( key(_up)) advance3d(5); if( key(_down)) advance3d(-5); if( key(_enter)) stop_3d(0); FRAME; } END_PROGRAM
En el ejemplo se crea una imagen 3d con gráfico pasado como parámetro con la función create_bitmap_3d() guardando el código del objeto 3d que retorna en la variable global objeto3d.
La función unload_object3d() permiten liberar la memoria del ordenador utilizada por el objeto 3D cuando ya no se va a utilizar más durante un tiempo, y para ello requieren también el código del objeto 3D, para saber qué objeto es el que se quiere destruir.
No es necesario descargar el objeto 3D de memoria antes de finalizar el programa, ya que el sistema lo hará de forma automática.
Ver: object3d - unload_object3d() - create_box_3d()