我的应用程序允许用户按下按钮,打开相机,他们可以拍照,它将显示在图像视图中。如果用户在相机打开时按下或取消,我会关闭此强制 - 无法将结果ResultInfo {who = null,request = 1888,result = 0,data = null}发送到活动...所以我猜测结果= 0是我需要插入什么才能使此停止力关闭?
以下是我的代码。我知道我忘记了什么,但却无法弄清楚! (不可否认,我大约需要2周的时间学习android开发)。谢谢你的帮助!
private static final int CAMERA_REQUEST = 1888;
private ImageView imageView;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
this.imageView = (ImageView)this.findViewById(R.id.photostrippic1);
ImageView photoButton = (ImageView) this.findViewById(R.id.photostrippic1);
photoButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Intent cameraIntent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
startActivityForResult(cameraIntent, CAMERA_REQUEST);
}
});
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == CAMERA_REQUEST) {
Bitmap photo = (Bitmap) data.getExtras().get("data");
imageView.setImageBitmap(photo);
}
我想我会在那里需要一个“其他”,但我不知道这样做。
下面的是logcat
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1888, result=0, data=null} to activity {photo.booth.app/photo.booth.app.PhotoboothActivity}: java.lang.NullPointerException
at android.app.ActivityThread.deliverResults(ActivityThread.java:2934)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:2986)
at android.app.ActivityThread.access$2000(ActivityThread.java:132)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1068)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:150)
at android.app.ActivityThread.main(ActivityThread.java:4293)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:507)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:607)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at photo.booth.app.PhotoboothActivity.onActivityResult(PhotoboothActivity.java:76)
at android.app.Activity.dispatchActivityResult(Activity.java:4108)
at android.app.ActivityThread.deliverResults(ActivityThread.java:2930)
... 11 more
答案 0 :(得分:51)
添加第一个条件应该有效:
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if(resultCode != RESULT_CANCELED){
if (requestCode == CAMERA_REQUEST) {
Bitmap photo = (Bitmap) data.getExtras().get("data");
imageView.setImageBitmap(photo);
}
}
}
答案 1 :(得分:13)
对于Kotlin用户不要忘记添加?在data: Intent?
喜欢
public override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {}
答案 2 :(得分:11)
如果用户取消请求,数据将以NULL
的形式返回。当您致电nullPointerException
时,该主题将抛出data.getExtras().get("data");
。我想你只需要添加一个条件来检查返回的数据是否为空。
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == CAMERA_REQUEST) {
if (data != null)
{
Bitmap photo = (Bitmap) data.getExtras().get("data");
imageView.setImageBitmap(photo);
}
}
答案 3 :(得分:6)
我建议使用它:
检索父亲Intent
。
Intent intentParent = getIntent();
直接传达讯息。
setResult(RESULT_OK, intentParent);
这可以防止丢失其活动,从而产生空数据错误。
答案 4 :(得分:6)
对于Kotlin用户
如果用户取消了交易或出现任何问题,您只需要在onActivityResult
中添加带有Intent的?,因为数据可以是null
。因此,我们需要在nullable
onActivityResult
只需将SampleActivity的onActivityResult
签名替换为以下内容:
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?)
答案 5 :(得分:4)
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == CAMERE_REQUEST && resultCode == RESULT_OK && data != null)
{
Bitmap photo = (Bitmap) data.getExtras().get("data");
imageView.setImageBitmap(photo);
}
}
您可以检查resultCode是否等于RESULT_OK,只有在拍摄并选择了图片并且一切正常时才会出现这种情况。这里的if子句应检查每个条件。
答案 6 :(得分:1)
这是我的案例
startActivityForResult(intent, PICK_IMAGE_REQUEST);
我定义了两个具有相同值的请求代码PICK_IMAGE_REQUEST
和SCAN_BARCODE_REQUEST
,例如。
static final int BARCODE_SCAN_REQUEST = 1;
static final int PICK_IMAGE_REQUEST = 1;
这也可能导致问题
答案 7 :(得分:1)
我有这个错误消息显示给我,因为我在主线程上使用网络,新版本的Android有一个"严格"防止这种情况的政策。为了解决它,只需将任何网络连接调用抛入AsyncTask。
示例:
AsyncTask<CognitoCachingCredentialsProvider, Integer, Void> task = new AsyncTask<CognitoCachingCredentialsProvider, Integer, Void>() {
@Override
protected Void doInBackground(CognitoCachingCredentialsProvider... params) {
AWSSessionCredentials creds = credentialsProvider.getCredentials();
String id = credentialsProvider.getCachedIdentityId();
credentialsProvider.refresh();
Log.d("wooohoo", String.format("id=%s, token=%s", id, creds.getSessionToken()));
return null;
}
};
task.execute(credentialsProvider);
答案 8 :(得分:0)
我也遇到过这个问题,我通过添加两个条件解决了这个问题:
resultCode != null
另一个是:
resultCode != RESULT_CANCELED
答案 9 :(得分:0)
我的问题出现在被调用的活动中,当它试图通过&#34;完成时返回到上一个活动。&#34;我错误地设置了意图。以下代码是Kotlin。
我这样做:
intent.putExtra("foo", "bar")
finish()
当我应该这样做时:
val result = Intent()
result.putExtra("foo", "bar")
setResult(Activity.RESULT_OK, result)
finish()
答案 10 :(得分:0)
当我尝试传递可序列化的模型对象时,我遇到了这个问题。在该模型内部,另一个模型是变量,但不能序列化。这就是为什么我面临这个问题。确保模型中的所有模型都可序列化。
答案 11 :(得分:-1)
AsyncTask<CognitoCachingCredentialsProvider, Integer, Void> task = new
AsyncTask<CognitoCachingCredentialsProvider, Integer, Void>() {
@Override
protected Void doInBackground(CognitoCachingCredentialsProvider... params) {
AWSSessionCredentials creds = credentialsProvider.getCredentials();
String id = credentialsProvider.getCachedIdentityId();
credentialsProvider.refresh();
Log.d("wooohoo", String.format("id=%s, token=%s", id, creds.getSessionToken()));
return null;
}
};
task.execute(credentialsProvider);