web-dev-qa-db-fra.com

Répertoire de travail: null Environnement: null

J'essaie d'utiliser ffmpeg.so sur Android Je reçois le répertoire de travail: null Environnement: erreur nulle.

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();
}

JOURNAL DES ERREURS

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

PERMISSIONS

<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" />
18
Mert

Vous devez peut-être ajouter cette autorisation à votre fichier AndroidManifest.xml:

Android.permission.WRITE_EXTERNAL_STORAGE
2
ChuongPham

Vous devez vous assurer que le /data/data/com.example.foo/files/ffmpeg le fichier dispose des autorisations de fichier correctes.

Vous pouvez vérifier l'autorisation de fichier avec la commande suivante:

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 sortie serait quelque chose comme ça (selon les autorisations réelles, dans ce cas, les autorisations sont 777):

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

Vous pouvez définir les autorisations sur 744, avec la commande ci-dessous:

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

Si vous exécutez cette commande à partir d'une activité extérieure (à partir d'un service, disons), votre autorisation devra être 777 (pas 744)

2
Shashank Singla

J'ai eu ce même problème spontanément en travaillant avec le projet ffmpeg-Android. J'avais déjà toutes les autorisations définies par d'autres, et je n'avais pas eu ce problème dans le passé.

Je suis revenu à une ancienne version, qui fonctionnait bien, puis j'ai reconstruit la dernière version et tout allait bien à nouveau - donc la solution dans mon cas était simple Clean and Rebuild ..

Essayez-le si vous vous sentez désespéré!

0
Mete

Dans mon cas, vous devez ajouter "sh -c" comme dans l'exemple suivant:

sh -c shellcommand  

J'espère que cela aide.

David

0
us_david