unidades trabajo realiza que nulo neto mecanico horizontal hay fisica expresa ejemplos donde cuando cero android ffmpeg

android - realiza - Directorio de trabajo: nulo Entorno: nulo



trabajo nulo ejemplos (3)

Estoy intentando usar ffmpeg.so en Android. Estoy obteniendo Working Directory: null Environment: null error.

try { Process p = Runtime.getRuntime().exec("/data/data/com.example.foo/files/ffmpeg -f image2 -i " + Environment.getExternalStorageDirectory().getAbsolutePath() + "/img/b%d.jpg " + Environment.getExternalStorageDirectory().getAbsolutePath() + "/DCIM/Camera/a444.mp4"); } catch (IOException e) { e.printStackTrace(); }

REGISTRO DE ERRORES

04-09 01:50:45.683: I/Adreno-EGL(18393): <qeglDrvAPI_eglInitialize:320>: EGL 1.4 QUALCOMM Build: I0404c4692afb8623f95c43aeb6d5e13ed4b30ddbDate: 11/06/13 04-09 01:50:45.713: D/OpenGLRenderer(18393): Enabling debug mode 0 04-09 01:53:56.487: D/dalvikvm(18551): Trying to load lib /data/app-lib/com.example.sodeneme-1/libffmpeg.so 0x423d7d00 04-09 01:53:56.487: D/dalvikvm(18551): Added shared lib /data/app-lib/com.example.sodeneme-1/libffmpeg.so 0x423d7d00 04-09 01:53:56.487: D/dalvikvm(18551): No JNI_OnLoad found in /data/app-lib/com.example.sodeneme-1/libffmpeg.so 0x423d7d00, skipping init 04-09 01:53:56.537: W/System.err(18551): java.io.IOException: Error running exec(). Command: [/data/data/com.example.sodeneme/files/ffmpeg, -f, image2, -i, /storage/emulated/0/img/b%d.jpg, /storage/emulated/0/DCIM/Camera/a444.mp4] Working Directory: null Environment: null 04-09 01:53:56.537: W/System.err(18551): at java.lang.ProcessManager.exec(ProcessManager.java:211) 04-09 01:53:56.537: W/System.err(18551): at java.lang.Runtime.exec(Runtime.java:173) 04-09 01:53:56.537: W/System.err(18551): at java.lang.Runtime.exec(Runtime.java:246) 04-09 01:53:56.537: W/System.err(18551): at java.lang.Runtime.exec(Runtime.java:189) 04-09 01:53:56.537: W/System.err(18551): at com.example.sodeneme.MainActivity.onCreate(MainActivity.java:40) 04-09 01:53:56.537: W/System.err(18551): at android.app.Activity.performCreate(Activity.java:5231) 04-09 01:53:56.537: W/System.err(18551): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 04-09 01:53:56.537: W/System.err(18551): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159) 04-09 01:53:56.537: W/System.err(18551): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 04-09 01:53:56.537: W/System.err(18551): at android.app.ActivityThread.access$800(ActivityThread.java:135) 04-09 01:53:56.537: W/System.err(18551): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 04-09 01:53:56.537: W/System.err(18551): at android.os.Handler.dispatchMessage(Handler.java:102) 04-09 01:53:56.537: W/System.err(18551): at android.os.Looper.loop(Looper.java:136) 04-09 01:53:56.537: W/System.err(18551): at android.app.ActivityThread.main(ActivityThread.java:5017) 04-09 01:53:56.537: W/System.err(18551): at java.lang.reflect.Method.invokeNative(Native Method) 04-09 01:53:56.537: W/System.err(18551): at java.lang.reflect.Method.invoke(Method.java:515) 04-09 01:53:56.537: W/System.err(18551): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 04-09 01:53:56.537: W/System.err(18551): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 04-09 01:53:56.537: W/System.err(18551): at dalvik.system.NativeStart.main(Native Method) 04-09 01:53:56.547: W/System.err(18551): Caused by: java.io.IOException: No such file or directory 04-09 01:53:56.547: W/System.err(18551): at java.lang.ProcessManager.exec(Native Method) 04-09 01:53:56.547: W/System.err(18551): at java.lang.ProcessManager.exec(ProcessManager.java:209) 04-09 01:53:56.547: W/System.err(18551): ... 18 more 04-09 01:53:56.577: I/Adreno-EGL(18551): <qeglDrvAPI_eglInitialize:320>: EGL 1.4 QUALCOMM Build: I0404c4692afb8623f95c43aeb6d5e13ed4b30ddbDate: 11/06/13 04-09 01:53:56.607: D/OpenGLRenderer(18551): Enabling debug mode 0

Los permisos

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_INTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_INTERNAL_STORAGE" /> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />


Tal vez necesite agregar este permiso a su archivo AndroidManifest.xml :

android.permission.WRITE_EXTERNAL_STORAGE


Tuve este mismo problema de forma espontánea mientras trabajaba con el proyecto ffmpeg-android. Ya tenía todos los permisos establecidos que otros han mencionado, y no había tenido este problema en el pasado.

Regresé a una versión anterior, que funcionó bien, luego reconstruí la última versión y estuvo bien otra vez, por lo que la solución en mi caso fue un simple Limpiar y Reconstruir ...

¡Pruébalo si te sientes desesperado!


/data/data/com.example.foo/files/ffmpeg asegurarse de que el archivo /data/data/com.example.foo/files/ffmpeg tenga los permisos de archivo correctos.

Puede verificar el permiso de archivo con el siguiente comando:

String[] command = new String[]{"/system/bin/ls", "-l", "/data/data/com.example.foo/files/ffmpeg" }; Process process = Runtime.getRuntime().exec(command); BufferedReader reader = new BufferedReader( new InputStreamReader(process.getInputStream())); int read; String output = ""; String line; while ((line = reader.readLine()) != null) { output.concat(line + "/n"); Log.w("myApp", "[[output]]:" + line); } reader.close(); process.waitFor();

La salida sería algo como esto (dependiendo de los permisos reales, en este caso los permisos son 777):

[[output]]:-rwxrwxrwx u0_a67 u0_a67 254460 2015-03-02 17:12 ffmpeg

Puede establecer los permisos en 744, con el siguiente comando:

String[] command = new String[]{"/system/bin/chmod", "744", "/data/data/com.example.foo/files/ffmpeg" };

Si está ejecutando este comando desde una actividad externa (digamos desde un servicio), su permiso tendrá que ser 777 (no 744)