ビデオを録画して保存する必要がありますがstart()
、メディアレコーダーのメソッドでエラーが発生します:失敗しました - 19 (このエラーは何ですか? ドキュメントにはコメントがありません:( ) 私はこのエラーで2番目に戦っています今日、私は複数のコードを試しました (Google チュートリアル、Intel サンプル、...) Web のいたるところで見つけましたが、どれも機能しませんでした。問題の原因を見つけるのを手伝ってください。私も始めています。私の携帯電話(SE live、wt19i)がビデオを録画できるかどうか疑問に思っています(ただし、デフォルトのカメラアプリは正常に動作します)本当に、お願いします、何を試し/チェック/修正すればよいか誰か知っていますか?
記録用のコードは次のとおりです。
public boolean record()
{
// if already recording, return
if( recording ) return false;
// We are recording
recording = true;
// log start of the method
System.out.println("CameraPreview::record() - Method start");
// Have tried to stop preview before record - didnt help
//mCamera.stopPreview();
mCamera.unlock();
mRecorder = new MediaRecorder();
// have tried this listener to get some extra info (doesnt work)
mRecorder.setOnErrorListener(new MediaRecorder.OnErrorListener() {
public void onError(MediaRecorder mr, int what, int extra) {
System.out.println("MediaRecorder::onError listener:"+what+" - "+extra);
}
});
mRecorder.setCamera(mCamera);
// Set media recorder properties
mRecorder.setAudioSource(MediaRecorder.AudioSource.CAMCORDER);
mRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
mRecorder.setProfile( CamcorderProfile.get( CamcorderProfile.QUALITY_LOW ) );
// have tried to set format without profile - didnt help
//mRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4);
//mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
//mRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.MPEG_4_SP);
mRecorder.setOutputFile("/sdcard/MVR_video.3gp");
mRecorder.setPreviewDisplay(mHolder.getSurface());
// Prepare media recorder
try {
mRecorder.prepare();
} catch (Exception e) {
Log.d("MyVideoRecord", "Error preparing media recorder: " + e.getMessage());
System.out.println("CameraPreview::record() - prepare() thrown an exception");
stopRecord();
return false;
}
// Have tried to wait until prepare is done - didnt help
try {Thread.sleep(1000); } catch( Exception e){}
try {
mRecorder.start();
} catch (Exception e) {
Log.d("MyVideoRecord", "Error starting media recorder: " + e.getMessage());
System.out.println("CameraPreview::record() - start() thrown an exception");
System.out.println("Exception: "+e.getMessage());
e.printStackTrace();
stopRecord();
return false;
}
System.out.println("CameraPreview::record() - Method returning TRUE");
return true;
}
マニフェスト ファイルに、カメラ、メモリ カード、およびオーディオの許可要求があります。minSdkVersionを 10 に、ターゲットを 15 に設定しました
LogCatはこちら
I/System.out(3990): CameraPreview::record() - Method start
I/MediaRecorderJNI(3990): prepare: surface=0x1f8e10 (identity=171)
E/MediaRecorder(3990): start failed: -19
D/MyVideoRecord(3990): Error starting media recorder: start failed.
I/System.out(3990): CameraPreview::record() - start() thrown an exception
I/System.out(3990): Exception: start failed.
W/System.err(3990): java.lang.RuntimeException: start failed.
W/System.err(3990): at android.media.MediaRecorder.start(Native Method)
W/System.err(3990): at com.example.myvideorecord.CameraPreview.record(CameraPreview.java:142)
W/System.err(3990): at com.example.myvideorecord.MainActivity.onOptionsItemSelected(MainActivity.java:101)
W/System.err(3990): at android.app.Activity.onMenuItemSelected(Activity.java:2502)
W/System.err(3990): at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:969)
W/System.err(3990): at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735)
W/System.err(3990): at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149)
W/System.err(3990): at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874)
W/System.err(3990): at com.android.internal.view.menu.IconMenuView.invokeItem(IconMenuView.java:468)
W/System.err(3990): at com.android.internal.view.menu.IconMenuItemView.performClick(IconMenuItemView.java:126)
W/System.err(3990): at android.view.View$PerformClick.run(View.java:14263)
W/System.err(3990): at android.os.Handler.handleCallback(Handler.java:605)
W/System.err(3990): at android.os.Handler.dispatchMessage(Handler.java:92)
W/System.err(3990): at android.os.Looper.loop(Looper.java:137)
W/System.err(3990): at android.app.ActivityThread.main(ActivityThread.java:4441)
W/System.err(3990): at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err(3990): at java.lang.reflect.Method.invoke(Method.java:511)
W/System.err(3990): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
W/System.err(3990): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
W/System.err(3990): at dalvik.system.NativeStart.main(Native Method)
編集:
マニフェスト ファイルを追加しています。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.myvideorecord"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="10"
android:targetSdkVersion="15" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
android:debuggable="true" >
<activity
android:name=".MainActivity"
android:label="@string/title_activity_main"
android:screenOrientation="landscape" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".CameraPreview"
android:screenOrientation="landscape"
></activity>
</application>
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
<uses-feature android:name="android.hardware.camera" />
</manifest>
EDIT2
私はこのアプリを私のいとこの暴徒(SE、しかし別のモデル)で実行しようとしましたが、問題なく動作しました。私の携帯電話には Android のアップデートがないので、元の「Sony PC コンパニオン」ソフトウェアを使用して「修復」しようとしています。「ハック」せずにAndroidバージョンをダウングレードすることはできないと思うので、それがうまくいくことを願っています
EDIT3
モバイルのファームウェアをアップグレードしたり、ダウングレードしたりしようとしました。何も変わっていません。カスタマー サポートまたは XDA フォーラムに書き込み、同じ電話を持っている人に実行してもらうことを検討しています。