2

ubuntu 11.10でffmpegライブラリをコンパイルし、コンパイル済みファイルをAndroidに移植しました。
コンパイル後、libffmpeg.soを正常に取得しました。Androidに正常にロードされます。

私はubuntu 11.10 Eclipse Androidエミュレーターでそれをやっています。

ユーザーからのコマンドを受け入れて結果を表示するコマンドプロンプトとして機能する小さなテストアプリケーションを作成しました。(ffmpeg コマンドのテスト)

「ls」、「ls -l」などの単純なコマンドを実行すると、完全に機能します。しかし、コマンドとして「cd mnt」または「ffmpeg」と入力して実行しようとすると。Logcatで警告が表示されまし

08-26 16:44:52.553: W/System.err(5961): java.io.IOException: Error running exec(). Command: [ffmpeg] Working Directory: null Environment: null
08-26 16:44:52.573: W/System.err(5961):     at java.lang.ProcessManager.exec(ProcessManager.java:211)
08-26 16:44:52.573: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:168)
08-26 16:44:52.573: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:241)
08-26 16:44:52.583: W/System.err(5961):     at java.lang.Runtime.exec(Runtime.java:184)
08-26 16:44:52.593: W/System.err(5961):     at ch.ffmpeg.reversit.MainActivity.Execute(MainActivity.java:61)
08-26 16:44:52.593: W/System.err(5961):     at ch.ffmpeg.reversit.MainActivity$1.onClick(MainActivity.java:46)
08-26 16:44:52.593: W/System.err(5961):     at android.view.View.performClick(View.java:3480)
08-26 16:44:52.593: W/System.err(5961):     at android.view.View$PerformClick.run(View.java:13983)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Handler.handleCallback(Handler.java:605)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Handler.dispatchMessage(Handler.java:92)
08-26 16:44:52.603: W/System.err(5961):     at android.os.Looper.loop(Looper.java:137)
08-26 16:44:52.614: W/System.err(5961):     at android.app.ActivityThread.main(ActivityThread.java:4340)
08-26 16:44:52.624: W/System.err(5961):     at java.lang.reflect.Method.invokeNative(Native Method)
08-26 16:44:52.624: W/System.err(5961):     at java.lang.reflect.Method.invoke(Method.java:511)
08-26 16:44:52.634: W/System.err(5961):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
08-26 16:44:52.634: W/System.err(5961):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
08-26 16:44:52.644: W/System.err(5961):     at dalvik.system.NativeStart.main(Native Method)
08-26 16:44:52.644: W/System.err(5961): Caused by: java.io.IOException: Permission denied
08-26 16:44:52.674: W/System.err(5961):     at java.lang.ProcessManager.exec(Native Method)
08-26 16:44:52.674: W/System.err(5961):     at java.lang.ProcessManager.exec(ProcessManager.java:209)
08-26 16:44:52.684: W/System.err(5961):     ... 16 more

これが私のコードです:

imports;
public class MainActivity extends Activity {
    String com;
    Process process;
    EditText command;
    Button run;
    RelativeLayout main_layout;

    static {
     System.loadLibrary("ffmpeg");
    }

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

       //find view 
       command=(EditText)findViewById(R.id.command);
       run=(Button)findViewById(R.id.run);

        run.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                com=command.getText().toString();
                try {
                    Execute();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

            }
        }); 

    }

    public void Execute() throws IOException, InterruptedException{
        process=Runtime.getRuntime().exec(com);
        // process = pb.command(com).redirectErrorStream(true).start();

        if(process!=null)
        ShowOutput();
        else
        Toast.makeText(getBaseContext(),"Null Process",Toast.LENGTH_LONG).show();
    }

    public void ShowOutput() throws IOException, InterruptedException{
        String s,text="",errors="";
        BufferedReader stdInput = new BufferedReader(new 
                InputStreamReader(process.getInputStream()));

           BufferedReader stdError = new BufferedReader(new 
                InputStreamReader(process.getErrorStream()));


           TextView output=(TextView)findViewById(R.id.output);
           TextView error=(TextView)findViewById(R.id.error);

            while ((s = stdInput.readLine()) != null) {
                   text+=s.toString()+"\n";
                   System.out.println("Error: "+s);
               }

         output.setText(text);
         text="";
           // read any errors from the attempted command
           System.out.println("Here is the standard error of the command (if any):\n");
           while ((s = stdError.readLine()) != null) {
               text+=s.toString()+"\n";
               System.out.println("Error: "+s);
           }

           error.setText(text);

           error.setMovementMethod(new ScrollingMovementMethod());
           output.setMovementMethod(new ScrollingMovementMethod());

           stdInput.close();
           stdError.close();

           process.waitFor();
           process.getOutputStream().close();
           process.getInputStream().close();
           process.getErrorStream().close(); 
           process.destroy();


    }

}

私もprocess = pb.command(com).redirectErrorStream(true).start();実行しようとしました。同じエラーが表示されますが、今回の環境は [ANDROID_SOCKET_Zygot] bla bla bla ..


編集1: ubuntuでOpenjdkを使用しています

手伝ってください !!

4

3 に答える 3

2

[android] [ffmpeg] の議論とハウツーのかなり大きなボディがあります...

ルート化されていないデバイス (つまり、一般ユーザー向けのアプリ) で ffmpeg を呼び出す通常の方法は、NDK と C 言語の統合を使用することです。この場合、java では、CLI のものと、そのパラメーターのコレクションをラップする通常のメソッド呼び出しを行います。 JNI レイヤーは、ffmpeg 実行可能ファイルのインターフェースに配信します。

Android 呼び出しの例 step1.android は次のようになります...

             new FFMpegTask().execute(invoke_lib_path,"ffmpeg", "-y", 
                    "-i", Picture.getPath(), "-i", recordFilePath,
                    "-vcodec", "mpeg4", "-s", siz,
                    "-r", "15", "-b:v", "200k",
                    "-acodec", "copy", "-f", "3gp"
                    ,pathOut);

Step2.c

JNIEXPORT void JNICALL Java_com_..._naRun( JNIEnv *env, jobject obj, jobjectArray args) { int i = 0; int argc = 0; char **argv = NULL;

if (args != NULL) { argc = ( env)->GetArrayLength(env, args); argv = (char * ) malloc(sizeof(char *) * argc);

  for(i=0;i<argc;i++)         {           jstring str =

(jstring)(*env)->GetObjectArrayElement(env, args, i); argv[i] = (char *)(*env)->GetStringUTFChars(env, str, NULL); } } int j = 0; j = メイン (argc, argv); }

Java runtime.exec() タイプの CLI 呼び出しを使用しようとすることは、私がハックと呼ぶものであり、時間の大きな無駄になります。

NDK と .apk の通常のパッケージを使用することで、デプロイ デバイスのプロセッサ アーキテクチャなどと ffmpeg が構築されたプロセッサとの間の高度な信頼性と統合が保証されます。

roman10のイントロを読んでみてください

次に、Android用のffmpegを構築した多くの人々からのパンくずリストに頼ってみてください..つまり、google "android-ffmpeg"

ルート化されていて、実行可能ファイルをコンパイルした場合は、シェルを取得して adb CLI を使用することで、実行可能ファイルを呼び出すことができます。java を runtime.exec 呼び出しのラッパーとして使用するようなものではないことに注意してください。

adb プッシュ ffmpeg /data/local/ffmpeg/ffmpeg

./ffmpeg -コーデック

于 2012-08-26T16:48:45.223 に答える
1

AFAIK cd コマンドは使用できません。これは bash ディレクティブであり、実行可能な cd はありません。権限が原因でffmpegが機能していないと思います。adb シェルで chmod 777 ffmpeg を実行して、もう一度やり直してください。

于 2012-08-26T12:32:20.873 に答える