android – UpdateAppWidget Null Pointer Exception

前端之家收集整理的这篇文章主要介绍了android – UpdateAppWidget Null Pointer Exception前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下是更新appwidget的静态方法
  1. public static void updateAppWidget(Context context,int id,WALL_POST_DETAILS post){
  2. try{
  3. System.out.println("In updateAppWidget==>"+id);
  4. AppWidgetManager mngr=AppWidgetManager.getInstance(context);
  5.  
  6. String diff=diff(post.created_time.trim());
  7.  
  8. RemoteViews views=new RemoteViews(context.getPackageName(),R.layout.widget_layout);
  9. PendingIntent pending=PendingIntent.getActivity(context,new Intent(context,ShareDialogActivity.class),0);
  10. views.setOnClickPendingIntent(R.id.TextView01,pending);
  11. views.setOnClickPendingIntent(R.id.Button03,pending);
  12.  
  13. views.setTextViewText(R.id.actor_name,post.actor_name);
  14. views.setTextViewText(R.id.actor_message,post.message);
  15. views.setImageViewBitmap(R.id.actor_photo,post.image);
  16. views.setTextViewText(R.id.created_time,diff);
  17. if(post.no_of_comments>0){
  18. views.setViewVisibility(R.id.comments_image,View.VISIBLE);
  19. views.setViewVisibility(R.id.comment_word,View.VISIBLE);
  20. views.setTextViewText(R.id.no_of_comments,String.valueOf(post.no_of_comments));
  21. views.setViewVisibility(R.id.no_of_comments,View.VISIBLE);
  22. System.out.println("No. of Comments==>"+post.no_of_comments);
  23. }else{
  24. views.setViewVisibility(R.id.comments_image,View.INVISIBLE);
  25. views.setViewVisibility(R.id.comment_word,View.INVISIBLE);
  26. views.setTextViewText(R.id.no_of_comments,String.valueOf(""));
  27. views.setViewVisibility(R.id.no_of_comments,View.INVISIBLE);
  28. }
  29.  
  30. if(post.no_of_likes>0){
  31. views.setViewVisibility(R.id.likes_image,View.VISIBLE);
  32. views.setViewVisibility(R.id.likes_word,View.VISIBLE);
  33. views.setTextViewText(R.id.no_of_likes,String.valueOf(post.no_of_likes));
  34. views.setViewVisibility(R.id.no_of_likes,View.VISIBLE);
  35. }else{
  36. views.setViewVisibility(R.id.likes_image,View.INVISIBLE);
  37. views.setViewVisibility(R.id.likes_word,View.INVISIBLE);
  38. views.setTextViewText(R.id.no_of_likes,String.valueOf(""));
  39. views.setViewVisibility(R.id.no_of_likes,View.INVISIBLE);
  40. }
  41.  
  42. Intent intent_next=new Intent(context,GetPostService.class);
  43. Bundle b_next=new Bundle();
  44. b_next.putInt(MyWidgetProvider.APP_WIDGET_ID,id);
  45. b_next.putInt(MyWidgetProvider.REQUEST_CODE,MyWidgetProvider.NEXT_FB_POST);
  46. intent_next.putExtras(b_next);
  47. PendingIntent nextPostService=PendingIntent.getService(context,MyWidgetProvider.NEXT_FB_POST,intent_next,PendingIntent.FLAG_UPDATE_CURRENT);
  48. views.setOnClickPendingIntent(R.id.next_button,nextPostService);
  49.  
  50. Intent intent_prev=new Intent(context,GetPostService.class);
  51. Bundle b_prev=new Bundle();
  52. b_prev.putInt(MyWidgetProvider.APP_WIDGET_ID,id);
  53. b_prev.putInt(MyWidgetProvider.REQUEST_CODE,MyWidgetProvider.PREV_FB_POST);
  54. intent_prev.putExtras(b_prev);
  55. PendingIntent prevPostService=PendingIntent.getService(context,MyWidgetProvider.PREV_FB_POST,intent_prev,PendingIntent.FLAG_UPDATE_CURRENT);
  56. views.setOnClickPendingIntent(R.id.prev_button,prevPostService);
  57.  
  58. Intent intent_comment=new Intent(context,FBShowCommentsActivity.class);
  59. Bundle b_comment=new Bundle();
  60. b_comment.putInt(MyWidgetProvider.APP_WIDGET_ID,id);
  61. b_comment.putInt(MyWidgetProvider.REQUEST_CODE,MyWidgetProvider.SHOW_COMMENTS);
  62. b_comment.putString(MyWidgetProvider.POST_ID,SessionStore.restoreCurrentPostId(context));
  63. intent_comment.putExtras(b_comment);
  64. PendingIntent fbActionActivity=PendingIntent.getActivity(context,MyWidgetProvider.SHOW_COMMENTS,intent_comment,PendingIntent.FLAG_UPDATE_CURRENT);
  65. views.setOnClickPendingIntent(R.id.comment_word,fbActionActivity);
  66. views.setOnClickPendingIntent(R.id.comments_image,fbActionActivity);
  67. views.setOnClickPendingIntent(R.id.no_of_comments,fbActionActivity);
  68.  
  69. Intent intent_likes=new Intent(context,ShowLikeDialogActivity.class);
  70. Bundle b_likes=new Bundle();
  71. b_likes.putInt(MyWidgetProvider.APP_WIDGET_ID,id);
  72. b_likes.putInt(MyWidgetProvider.REQUEST_CODE,MyWidgetProvider.SHOW_LIKES);
  73. b_likes.putString(MyWidgetProvider.POST_ID,SessionStore.restoreCurrentPostId(context));
  74. intent_likes.putExtras(b_likes);
  75. PendingIntent fbLikesActivity=PendingIntent.getActivity(context,MyWidgetProvider.SHOW_LIKES,intent_likes,PendingIntent.FLAG_UPDATE_CURRENT);
  76. views.setOnClickPendingIntent(R.id.likes_word,fbLikesActivity);
  77. views.setOnClickPendingIntent(R.id.likes_image,fbLikesActivity);
  78. views.setOnClickPendingIntent(R.id.no_of_likes,fbLikesActivity);
  79.  
  80. mngr.updateAppWidget(id,views);
  81.  
  82. }catch(Exception e){
  83. e.printStackTrace();
  84. System.out.println("Exception==>"+e.getMessage());
  85. }
  86. }

AppWidget已从GetPostService待处理服务成功更新.在安装后第一次启动Pending Activity时,我可以成功更新小部件.但是,如果我再次启动第二次,Activity正确启动,但AppWidget没有获得更新,它会抛出空指针异常.我正在从UI线程更新小部件(来自AsyncTask的onPostExecute()方法).

W/System.err( 522): at android.widget.RemoteViews$ReflectionAction.writeToPa rcel(RemoteViews.java:400) W/System.err( 522): at android.widget.RemoteViews.writeToParcel(RemoteViews. java:1012) W/System.err( 522): at com.android.internal.appwidget.IAppWidgetService$Stub $Proxy.updateAppWidgetIds(IAppWidgetService.java:374) W/System.err( 522): at android.appwidget.AppWidgetManager.updateAppWidget(Ap pWidgetManager.java:246) W/System.err( 522): at android.appwidget.AppWidgetManager.updateAppWidget(Ap pWidgetManager.java:265) W/System.err( 522): at com.mobisys.android.app_widget.MyWidgetProvider.updat eAppWidget(MyWidgetProvider.java:185) W/System.err( 522): at com.mobisys.android.app_widget.MyWidgetProvider.onRec eive(MyWidgetProvider.java:71) W/System.err( 522): at android.app.ActivityThread.handleReceiver(ActivityThr ead.java:1769) W/System.err( 522): at android.app.ActivityThread.access$2400(ActivityThread .java:117) W/System.err( 522): at android.app.ActivityThread$H.handleMessage(ActivityTh read.java:978) W/System.err( 522): at android.os.Handler.dispatchMessage(Handler.java:99) W/System.err( 522): at android.os.Looper.loop(Looper.java:123) W/System.err( 522): at android.app.ActivityThread.main(ActivityThread.java:3 647) W/System.err( 522): at java.lang.reflect.Method.invokeNative(Native Method) W/System.err( 522): at java.lang.reflect.Method.invoke(Method.java:507) W/System.err( 522): at com.android.internal.os.ZygoteInit$MethodAndArgsCalle r.run(ZygoteInit.java:839) W/System.err( 522): at com.android.internal.os.ZygoteInit.main(ZygoteInit.ja va:597)
W/System.err( 522): at dalvik.system.NativeStart.main(Native Method)

我从Pending Activity中按以下方式调用updateAppWidget静态方法

  1. MyWidgetProvider.updateAppWidget(context,mAppWidgetId,post); //context is pending Activity's instance

可能是什么问题?

提前致谢.

解决方法

我有完全相同的问题和堆栈跟踪.原因是我在setImageViewBitmap中传递了一个null Bitmap.
答案可能为时已晚,但我认为你应该仔细检查这一行:
  1. views.setImageViewBitmap(R.id.actor_photo,post.image);

如果我正确post.image将为null – 您应该删除此行或提供非空位图.

问候

猜你在找的Android相关文章