下载图像并显示它
应用程序的主要目的是下载和显示图像,但是当我尝试启动应用程序时它崩溃。下载图像并显示它
这是我的代码。
private DownloadImageTask task;
protected void onCreate(Bundle savedInstanceState) {
task = new DownloadImageTask();
task.onPostExecute(task.doInBackground("http://parkcinema.az/uploads/structures/movies/images/xickok_poster1_resized.jpg"));
}
private class DownloadImageTask extends AsyncTask <String, Void, Bitmap> {
protected Bitmap doInBackground(String... urls) {
String urldisplay = urls[0];
Bitmap mIcon11 = null;
try {
InputStream in = new java.net.URL(urldisplay).openStream();
mIcon11 = BitmapFactory.decodeStream(in);
} catch (Exception e) {
Log.e("Error", e.getMessage());
e.printStackTrace();
}
return mIcon11;
}
protected void onPostExecute(Bitmap result) {
ImageView img = (ImageView) findViewById(R.id.imageView1);
img.setImageBitmap(result);
}
}
这里是logcat的:
02-24 11:04:56.814: E/Trace(957): error opening trace file: No such file or directory (2)
02-24 11:04:57.384: D/AndroidRuntime(957): Shutting down VM
02-24 11:04:57.384: W/dalvikvm(957): threadid=1: thread exiting with uncaught exception (group=0x40a13300)
02-24 11:04:57.404: E/AndroidRuntime(957): FATAL EXCEPTION: main
02-24 11:04:57.404: E/AndroidRuntime(957): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.bakumovies/com.example.bakumovies.MainActivity}: java.lang.NullPointerException: println needs a message
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2059)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread.access$600(ActivityThread.java:130)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.os.Handler.dispatchMessage(Handler.java:99)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.os.Looper.loop(Looper.java:137)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread.main(ActivityThread.java:4745)
02-24 11:04:57.404: E/AndroidRuntime(957): at java.lang.reflect.Method.invokeNative(Native Method)
02-24 11:04:57.404: E/AndroidRuntime(957): at java.lang.reflect.Method.invoke(Method.java:511)
02-24 11:04:57.404: E/AndroidRuntime(957): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
02-24 11:04:57.404: E/AndroidRuntime(957): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
02-24 11:04:57.404: E/AndroidRuntime(957): at dalvik.system.NativeStart.main(Native Method)
02-24 11:04:57.404: E/AndroidRuntime(957): Caused by: java.lang.NullPointerException: println needs a message
02-24 11:04:57.404: E/AndroidRuntime(957): at android.util.Log.println_native(Native Method)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.util.Log.e(Log.java:231)
02-24 11:04:57.404: E/AndroidRuntime(957): at com.example.bakumovies.MainActivity$DownloadImageTask.doInBackground(MainActivity.java:49)
02-24 11:04:57.404: E/AndroidRuntime(957): at com.example.bakumovies.MainActivity.onCreate(MainActivity.java:27)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.Activity.performCreate(Activity.java:5008)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
02-24 11:04:57.404: E/AndroidRuntime(957): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
02-24 11:04:57.404: E/AndroidRuntime(957): ... 11 more
这里是.XML
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="144dp" />
</RelativeLayout>
我不明白为什么它崩溃。图像下载在新线程中启动,imageview对象被创建。我完全同意这一点。 任何帮助将不胜感激。
原因NPE(空指针异常)
Log.e( “错误”,e.getMessage()); //e.getMessage()是NULL,所以它给NPE。
protected void onCreate(Bundle savedInstanceState)
task = new DownloadImageTask().execute("http://parkcinema.az/uploads/structures/movies/images/xickok_poster1_resized.jpg");
}
protected Bitmap doInBackground(String... urls) {
String urldisplay = urls[0];
Bitmap mIcon11 = null;
try {
mIcon11 = BitmapFactory.decodeStream(new URL(urldisplay).openConnection().getInputStream());
}
catch (Exception e) {
e.printStackTrace();
}
return mIcon11;
}
添加此权限在AndroidManifest.xml中,因为你在做互联网操作。
<uses-permission android:name="android.permission.INTERNET" />
我不明白你的代码将如何纠正错误:( – 2013-02-24 11:30:09
我已经注释掉了这行代码,试图启动应用程序。它没有崩溃,但图像没有出现:/ – 2013-02-24 11:42:42
@Math Daimon尝试我上面的代码.. – 2013-02-24 11:46:42
我怀疑它会帮助,但你不(可能不应该)手工调用doInBackground的AsyncTask方法。 Android会自己做这件事。事实上,您的AsyncTask的整个逻辑有点关闭。 onPostExecute在doInBackground完成时被调用。
实际上,尝试将task.onPostexecute(...)更改为task.execute(...),只传递您的url字符串。这应该有帮助! :) – LokiSinclair 2013-02-24 11:47:47
我试过这个,没有帮助:( task.execute(“http://parkcinema.az/uploads/structures/movies/images/xickok_poster1_resized.jpg”); – 2013-02-24 12:00:52
你真的**读过**错误吗?它说:'NullPointerException:println需要一个消息',这似乎是你的'Log.e'语句的一个问题。请参阅[Bug-Report](http://code.google.com/p/android/issues/detail?id=9211) – 2013-02-24 11:21:39
@Math Daimon尝试我的解决方案,如果您有任何问题,请告诉我。 – 2013-02-24 12:04:41
这帮了很多! – 2016-04-10 18:36:04