Hola a todos ^^
Vereís. Me he dado cuenta de que ha causa de que el manual de LuaDev está desactualizado, hay funciones en LuaDev recientemente implementadas que se desconocen. Por ello, haré un listado de las funciones de LuaDev que ya conozco y que no aparecen en el manual. A ver si me podeís indicar cuales faltan y así por lo menos tener una referencia para las funciones de LuaDev que no aparecen en el manual pero que aún así también podremos utilizar con el Eboot de LUADev más moderno. Te dejo también el manual de LUADev más reciente. Tienes al final del post todos los archivos para descarga directa desde el servidor privado de Scenebeta ;)
Por si acaso lo prefieres te dejo aquí las descargas desde mi cuenta de Ubuntu One (también son de descarga directa):
model.load( "ruta" ) --carga un archivo .obj con su respectivo mtl (texturas y colores) model.position( x, y, z ) --coordenadas x, y, z model.rotation( x, y, z ) --ángulo de rotación x, y, z en radianes (math.rad para convertir de grados a radianes) model.blit() --blitea el modelo en pantalla (no necesita ningún parametro)
Notas:
Transparencia: Para usar modelos 3D transparentes hay que crear primero el modelo 3D con partes transparentes. Luego exportarlo desde Sketchup y añadir este código: Modelo:alpha().
Cargar un modelo: Al cargar un modelo este debe estar dentro de una carpeta, de lo contrario crashea.
Las funciones position, rotation y blit necesitan que especifiquemos el modelo sobre el que queremos trabajar. Su uso es parecido al de las funciones para imágenes, a saber:
--Cargar modelo: modelo = model.load( "carpeta/modelo.obj" ) --Para usarlo: modelo:position( x, y, z ) modelo:rotation( x, y, z ) modelo:blit()
El origen está en el centro de la pantalla de la PSP. Los sentidos positivos de cada eje son: X hacia la derecha, Y hacia arriba y Z hacia atrás (hacia fuera de la pantalla de la PSP).
Las rotaciones son respecto al eje de coordenadas original del objeto (cuando lo creamos MUCHO cuidado con esto).
files.encrypt( archivo, contraseña ) --encripta un archivo files.decrypt( archivo, contraseña ) --desencripta un archivo
Notas:
Contraseña: Si no se especifica la contraseña, el archivo se encriptará con la contraseña interna de LUADev. Un archivo encriptado con la contraseña interna de LUADev no se puede desencriptar. Un archivo encriptado con una contraseña personalizada no se puede usar directamente en LUADev (se debe desencriptar antes de usarlo).
world.lightenabled( N, ENABLED ) -- enciende apaga luz. N = 1-4. ENABLED = true / false. (4 luces) world.lightambient( N, COLOR ) -- color de la componente "ambiental" de la luz numero N. world.lightdiffuse( N, COLOR ) -- color de la componente "difusa" de la luz numero N. world.lightspecular( N, COLOR ) -- color de la componente "specular" de la luz numero N. world.lightype( N, TIPO ) -- Cambiar tipo de luz numero N. Tipos: 1, direccional. 2, punto de luz. 3, foco. world.lightcomponent( N, COMPONENTES ) -- Cambiar componentes de luz. 1, amb + dif. 2, dif + spec. 3, desconocida. world.lightspotlight( N, EXPONENTE, CORTE) -- Solo focos. Cambia potencia y angulo de corte del foco. world.lightdirection( 4, X, Y, Z ) --Direccion de la luz N. (Sólo direccional o foco). (Vector UNITARIO) world.lightposition( N, X, Y, Z ) --Posicion de la luz N. world.ambient( COLOR ) -- Cambia el color ambiental. world.specular( COLOR ) -- Cambia el color specular. world.viewat( TAB1, TAB2, TAB3 ) -- Cambia la posicion de la cámara. world.perspective( fovy, ratio, near, far ) -- 3D Modo perspectiva (por defecto). world.ortho( left, right, bottom, top ) -- 3D modo ortogonal. world.fog( cerca, lejos, color ) -- Niebla. world.update() -- actualiza cambios en las luces / otros cambios en el modul
Notas:
Vector UNITARIO quiere decir que: raiz( X^2+Y^2+Z^2 ) == 1.
TAB1 = { x, y, z } (posicion de la camara)
TAB2 = { x, y, z } (punto al que miramos)
TAB3 = { x, y, z } (donde está el techo, (rotacion de la camara)). ( Normalmente { 0, 1, 0 } )
Cuando salga cerca / lejos quiere decir unidades. Por ejemplo en la
niebla, cerca y lejos es donde se empieza a ver niebla, y donde no se vé
un pimiento. (y el color de la niebla claro ). Con lejos = 0, niebla
off.
Para todos los comandos, SIN argumentos (excepto los que tengan
numero de luz, que en estos, sólo se pasará el argumento N ), devolverán
el valor actual. O sease: world.fog(); devolverá 3 valores.
world.lighttype(1) devolverá el tipo de luz de la luz numero 1.
world.ambient() devolverá el color de ambiente actual.
Para jugar con el 3D hay que tener las matemáticas algo claritas...
por ejemplo, normalizar un vector... (X,Y,Z). (hacerlo unitario)
( 34.21, 224.23, 12.45 ) seria... elevamos al cuadrado... (
1170.3241, 50279.0929, 155.0025 ) ... sumando ... 51604,4195 ... raiz
cuadrada... 227,16606150567474237336239880841, dividiendo cada
componente por separado por este valor... daria:
( 0.15, 0.98, 0.05 ) <- ahora ya es un vector normalizado, apunta hacia el mismo sitio, pero tiene módulo = 1.
math.vector.polar( x, y ) math.poly.testxy() math.poly.testlist() math.round( número_decimal ) -- Devuelve una aproximación de un número decimal, con lo que math.round(1.2) devolvería 1 y math.round(2.8) devolvería 3. tonumber( string ) --convierte un dato del tipo string al tipo number
zip.extract( directorio_del_zip, directorio_a_extraer, int_recursivo )
wlan.connected() --devuelve true o false según si estamos conectados a una red o no wlan.getconfigs() --devuelve una tabla con las conexiones configuradas. la tabla contiene los campos name y ssid para cada red wlan.init() --devuelve 1 si se realizó correctamente la conexión y otro valor si falló --[[ * Se puede llamar sin argumentos, en tal caso aparece el diálogo de selección de redes del XMB, bloqueando la ejecución del programa hasta que la conexión se realice (o surja un error xD). * Se puede llamar con un número como argumento, en tal caso se conectaría a la red especificada (1 para la 1ra conexión, 2 para la 2da y así) sin bloquear el ciclo del programa (digamos que es el modo avanzado de conexión). * Por último, se puede llamar con dos argumentos (ambos números). El 1er argumento indica la red a la que se va conectar y el 2do indica una espera máxima en segundos antes de que deje de intentar conectarse (en el XMB cuando se acaba el tiempo dice "Tiempo de espera agotado", sería algo parecido). Este modo muestra el diálogo de conexión del XMB, pero se conecta automáticamente a la red especificada (bloquea la ejecución del script) ]]-- wlan.ip() --devuelve la IP que nos asignaron wlan.mac() --devuelve nuestra direción MAC física de la PSP wlan.scan() --devuelve una tabla con las conexiones activas. --[[ ssid: ssid la conexión dtim: ?? bssid: bssid de la conexión rate: Información de la conexión bsstype: Tipo de conexión rssi: intensidad de la conexión info: información de la conexión channel: canal por el que emite atim: ?? localtime: ?? timestamp: ?? beacon: ?? ]]-- wlan.status() --según el estado de la red devuelbe un número --[[ 0 desconectado 1 escaneando 2 conectando 3 obteniendo IP 4 conectado 5 autorizando 6 intercambiando clave ]]-- wlan.statustext() --lo mismo que wlan.status() pero en vez de devolber números devuelbe los strings de arriba wlan.strength() --de 0 a 100 el nivel de la señal
tostring( cualquier_parametro ) --convierte un dato de cualquier tipo al tipo string
socket socket.connect(servidor, puerto par, puerto local) -- Crea un nuevo objeto Socket con protocolo TCP/IP. Si no se especifica el puerto local, abre un puerto aleatoriamente. socket socket.udp(servidor, puerto par, puerto local) -- Crea un nuevo objeto Socket con protocolo UDP. Si no se especifica el puerto local, abre un puerto aleatoriamente. nil socket.free(socket) -- Cierra y elimina el objeto Socket. boolean socket.isconnected(socket) -- Comprueba que el socket esta conectado. number socket.localport(socket) -- Devuelve el puerto local. number socket.peerport(socket) -- Devuelve el puerto par. number socket.packetslost(socket) -- Devuelve el número de paquetes perdidos. string socket.recv(socket, bytes) -- Lee los datos recibidos desde el socket. El numero de bytes es opcional number socket.send(socket, string) -- Envía un string mediante la conexión socket. Devuelve el numero de bytes enviados
os.sleep( segundos ) os.luadevsplash() --muestra el splash de LUADev os.luasplash() --muestra el splash de LUA
image.chipload() --sería un load de la imagen interna del logo de chipmunks image.gearload() --idem de arriba, rueda que usa la sphash de LUADev image.logoload() idem arriba logo de LUADev image.luaload() --logo de LUA logoload:zblit( x, y, z, angX, angY, angZ ) --blit en 3D (experimental, falla bastante)
chipmunk body mass new position cursor grab move new release init moment box circle polygon segment shape elasticity friction getbody newcircle newpoly newsegment space addbody addshape addstaticshape damping free gravity idlespeedthreshold iterations new pointqueryfirst pointqueryfirst_body resizeactivehash resizestatichash sleeptimethreshold staticbody step wiredraw debugmode debugprint debugset dump error fx add alpha color default none rgba sub gcinfo getfenv getfullmodulefunction getmetatable iif image chipload fastblit fxadd fxsub fxtint gearload logoload luaload zblit include ipairs lightstation load loadfile loadstring math bbox clamp inrect int poly rotate testlist testxy round vector cartesian magnitude polar model alpha buffer lshf mat stat module newproxy next debug debug getfenv gethook getinfo getlocal getmetatable getregistry getupvalue setfenv sethook setlocal setmetatable setupvalue traceback particles blit count enabled free init intensity limit new rand start stop socket connect free isconnected localport packetslost peerport recv send udp table foreach foreachi getn setn sort umd present video free info load wlan connected getconfigs init ip mac scan status statustext strength term world ambient envmapcolor envmapfx fog lightambient lightattenuation lightcomponent lightdiffuse lightdirection lightenabled lightposition lights lightspecular lightspotlight lighttype lookat ortho perspective shademodel specular update
Ok
Esta solo para windows, a ver si la sacan para linux o tendré que salir del OS
Comercial es el que debe de
Comercial es el que debe de tener licencia, no?
Exacto, si la quieres utiliza
Exacto, si la quieres utiliza esta que a mi me ha funcionado ( te dejo el Link ): http://www.taringa.net/posts/info/9159046/serial-de-google-s...
Completa: files.encrypt("arch
Completa:
Notas:
no es que
no es que estoy en desacuerdo con este post, pero no es que el manual este desactualizado, si no, que las funciones no estan, por que a Deviante le da weba x'D na bromas. Pueden ser por varias razones y uno es evitar muchas preguntas, aunque Deviante siempre las conteste ;)
"Las cosas brillantes siempre salen de repente, como la geometría de una flor"
Para que sirve el modulo
Para que sirve el modulo world?
Son focos para los modelos
Son focos para los modelos 3d.
zip.extract(directorio del
zip.extract(directorio del zip , directorio a extraer, int recursivo)
wlan.init()
wlan.term()
socket.recv()
socket.send()
socket.free()
socket.udp(url, puerto)
existe
wlan.send(Socket,Buffer)?
es socket.send
es socket.send
jojojojojoj
jejejejejej
DCatch en modo multijugador
Jjejejeje
Gracias.
Si sabes crear un servidor y
Si sabes crear un servidor y luego lo programas en PHP...
WTF?
Si yo lo digo de PSP a PSP
No online
Eso es adhoc.. deviante lo
Eso es adhoc.. deviante lo implementará junto con el os.browser
Ok
Digamos que yo tengo un router, y tengo un puerto socket, con determinado numero, yo podria enviar datos al router y recibirlos en otra psp, socket.recv()?
supongo que si
supongo que si
ok
ok
¿ Aun no se sabe nada de la
¿ Aun no se sabe nada de la función del navegador ?
que yo sepa no :(
que yo sepa no :(
El problema es que no se los
El problema es que no se los parámetros:
Módulo world:
Módulo math:
las del módulo world sirven
las del módulo world sirven para las luces en los juegos 3D no?
Exacto.
Exacto.