在我的應用程序中,有一個照片按鈕在那裏。當我點擊相機模式下打開的按鈕應用程序時,捕捉照片後它將返回佈局並顯示捕捉照片在此佈局上。但是當應用程序處於相機模式時,當按下返回按鈕時,應用程序停止工作它顯示:Android:當相機模式打開時返回按鈕不起作用
應用 「APPNAME」(XXX)已意外停止[強制關閉]
在logcat的它顯示以下錯誤:
了java.lang.RuntimeException :失敗傳遞結果ResultInf o {who = null,request = 1888,result = 0,data = null} to activity {com.XXX.android.XXX/com.XXX.android.XXX.FirstActivity}:java.lang.NullPointerException
但是在這裏,我希望我的應用程序返回到佈局。 在我的應用我寫下面的代碼: main.xml中創建一個ImageView的,一個EditView中,一張照片按鈕和一個保存按鈕:
<ImageView
android:id="@+id/test_image"
android:src="@drawable/aas"
android:layout_width="180dp"
android:layout_height="150dp"
android:layout_below="@id/edit2"
android:layout_toRightOf="@id/main_view_id_text7"
android:layout_alignParentRight="true"
android:layout_marginTop="5dp"
android:layout_marginLeft="2dp" />
<EditText
android:id="@+id/edit2"
android:layout_width="fill_parent"
android:layout_height="30dp"
android:layout_below="@id/edit1"
android:layout_centerHorizontal="true"
android:layout_marginTop="9dp"
android:layout_marginRight="4dp"
android:layout_marginLeft="2dp"
android:layout_toRightOf="@id/button1"
android:layout_alignParentRight="false"
android:background="@color/light_yellow"
android:textColor="@color/darkblue"
android:inputType="text"
android:hint="Photo Name" />
<Button
android:id="@+id/button1"
android:layout_width="70dp"
android:layout_height="36dp"
android:layout_below="@id/main_view_id_text4"
android:layout_marginTop="11dp"
android:onClick="addPhoto"
android:text="@string/photo"
/>
<Button
android:id="@+id/button2"
android:layout_width="150dp"
android:layout_height="40dp"
android:layout_below="@id/test_image"
android:layout_alignParentLeft="true"
android:layout_marginTop="2dp"
android:onClick="savePhoto"
android:text="@string/save" />
現在,在活動課碼相機應用:
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
editTextPhoto = (EditText) findViewById(R.id.edit2);
buttonPhoto = (Button) findViewById(R.id.button1);
imageView = (ImageView) findViewById(R.id.test_image);
buttonPhoto.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
addPhoto();
}
});
protected void addPhoto() {
Intent cameraIntent = new Intent(
android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
startActivityForResult(cameraIntent, CAMERA_REQUEST);
editTextPhoto.setText(new Date().toString() + ".jpg");
}
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == CAMERA_REQUEST) {
Bitmap photo = (Bitmap) data.getExtras().get("data");
imageView.setImageBitmap(photo);
}
}
protected void savePhoto() {
// code to save captured photo on provided location
}
我也想在EditText(或TextView)上顯示圖像名稱,圖像名稱由攝像機捕獲。通過此代碼拍攝的照片存儲在手機的圖庫/照片文件夾中。還有一件事是我想再次點擊照片按鈕時,先前拍攝的照片將從該文件夾中刪除,並且只有當我點擊保存按鈕時,拍攝的照片纔會保存。
還有一件事也請註明返回按鈕將如何處理,所以我在應用程序的其他部分使用。在我的應用程序中收集一些數據。假設客戶輸入一些數據,並在中間他/她按回車鍵,然後一個警報框會出現「你當前的數據將失去你想要的[是] [否]」按下「否」後,應用程序將停止。
問題的一覽表中我面對的:當相機模式是開放
- 返回按鈕不起作用。
- 請注意返回按鈕將如何處理,因此我在應用程序的其他部分使用此項
- 檢索由相機捕獲的照片的名稱。
- 保存只有照片,我點擊保存按鈕等拍攝的照片將不保存在任何其他地方。
類似的問題,其先前在本網站詢問,他們所做的事情:他們捕捉這個代碼的照片,保存在畫廊和展示照片由ImageView的佈局,但他們不顯示照片上的佈局的名稱。
此消息出現在logcat的時候按回車鍵或手機的返回鍵,而應用程序是在攝像模式下:
01-23 10:47:25.839: E/AndroidRuntime(11266): FATAL EXCEPTION: main
01-23 10:47:25.839: E/AndroidRuntime(11266): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1888, result=0, data=null} to activity {com.pixel.android.locationentry/com.pixel.android.locationentry.FirstActivity}: java.lang.NullPointerException
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread.deliverResults(ActivityThread.java:2536)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread.handleSendResult(ActivityThread.java:2578)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread.access$2000(ActivityThread.java:117)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:965)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.os.Handler.dispatchMessage(Handler.java:99)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.os.Looper.loop(Looper.java:130)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread.main(ActivityThread.java:3687)
01-23 10:47:25.839: E/AndroidRuntime(11266): at java.lang.reflect.Method.invokeNative(Native Method)
01-23 10:47:25.839: E/AndroidRuntime(11266): at java.lang.reflect.Method.invoke(Method.java:507)
01-23 10:47:25.839: E/AndroidRuntime(11266): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
01-23 10:47:25.839: E/AndroidRuntime(11266): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
01-23 10:47:25.839: E/AndroidRuntime(11266): at dalvik.system.NativeStart.main(Native Method)
01-23 10:47:25.839: E/AndroidRuntime(11266): Caused by: java.lang.NullPointerException
01-23 10:47:25.839: E/AndroidRuntime(11266): at com.pixel.android.locationentry.FirstActivity.onActivityResult(FirstActivity.java:420)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.Activity.dispatchActivityResult(Activity.java:3908)
01-23 10:47:25.839: E/AndroidRuntime(11266): at android.app.ActivityThread.deliverResults(ActivityThread.java:2532)
01-23 10:47:25.839: E/AndroidRuntime(11266): ... 11 more
您需要發佈ACTUAL logcat,但沒有足夠的信息來診斷此問題。 – JoxTraex
嗨JoxTraex,上面我提到完整的LogCat錯誤信息。 –
你的測試設備是什麼? – Jin35