【发布时间】:2016-01-21 12:21:42
【问题描述】:
我的应用程序中有一个功能,我可以打开照片库并选择要在 ImageView 中显示的图像。奇怪的是,在我的三星 Galaxy S5 上,代码运行良好,但当我在华硕 Zenphone 或摩托罗拉 Moto X 上尝试时,代码就无法运行,应用程序崩溃。
所有设备都具有相同的 Android 版本 (5.0)
这是我的代码示例:
打算打开照片库:
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.setType("image/*");
startActivityForResult(intent, IMG_SDCARD);
活动结果:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
File file = null;
if(data != null && requestCode == IMG_SDCARD && resultCode == getActivity().RESULT_OK){
Uri img = data.getData();
String[] cols = { MediaStore.Images.Media.DATA };
Cursor cursor = getActivity().getContentResolver().query(img, cols, null, null, null);
cursor.moveToFirst();
int indexCol = cursor.getColumnIndex(cols[0]);
String imgString = cursor.getString(indexCol);
cursor.close();
file = new File(imgString);
if(file != null){
wd.getImage().setResizedBitmap(file, 1200, 700);
wd.getImage().setMimeFromImgPath(file.getPath());
}
}
if(wd.getImage().getBitmap() != null){
imageView.setImageBitmap(wd.getImage().getBitmap());
}
}
你们见过这样的吗?
在不同设备之间从照片库中获取图像可能会有所不同吗?
编辑
这是日志错误:
01-21 10:34:01.066 30243-30243/com.inthecheesefactory.lab.designlibrary E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.inthecheesefactory.lab.designlibrary, PID: 30243
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=65539, result=-1, data=Intent { dat=content://com.android.providers.media.documents/document/image:4904 flg=0x1 }} to activity {com.inthecheesefactory.lab.designlibrary/br.com.amais.viumeupet.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'char[] java.lang.String.toCharArray()' on a null object reference
at android.app.ActivityThread.deliverResults(ActivityThread.java:3559)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:3602)
at android.app.ActivityThread.access$1300(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1334)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5289)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'char[] java.lang.String.toCharArray()' on a null object reference
at java.io.File.fixSlashes(File.java:179)
at java.io.File.<init>(File.java:128)
at br.com.amais.viumeupet.Fragment1.onActivityResult(Fragment1.java:285)
at android.support.v4.app.FragmentActivity.onActivityResult(FragmentActivity.java:153)
at br.com.amais.viumeupet.MainActivity.onActivityResult(MainActivity.java:231)
at android.app.Activity.dispatchActivityResult(Activity.java:6220)
at android.app.ActivityThread.deliverResults(ActivityThread.java:3555)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:3602)
at android.app.ActivityThread.access$1300(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1334)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5289)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
【问题讨论】:
-
你有错误日志吗?
-
我会得到错误日志,然后尝试那个解决方案@SuhasB
标签: android image android-sdcard mobile-devices