ImageView.setBitmapImage выдает исключение нулевого указателя

Я использую диалоговое окно для отображения меню выбора для пользователя, а на экране диалогового окна я использую ImageView. Я использую BitmapFactory.decodeFile() с путем к файлу изображения, которое будет использоваться с SD-карты пользователя, и у меня определенно установлены все разрешения. Я проверил в отладчике, а также с помощью операторов журнала, чтобы убедиться, что путь к файлу и растровое изображение имеют какую-то ценность, а не нуль. По какой-то причине, когда он использует возвращенное изображение, он генерирует исключение нулевого указателя. Вот небольшой фрагмент кода для просмотра изображений в диалоговом окне.

                        dialog2 = new Dialog(MyView.this);

                        LayoutInflater li =      (LayoutInflater) MyView.this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                        View w = li.inflate(R.layout.userpreference, null, false);

                            dialog2.setContentView(w);

                            dialog2.setTitle("MY PREFERENCES");

    ////////////////////////////////////////////////////////////////////
                            profileImage = new ImageView(MyView.this);
                            profileImage = (ImageView) dialog2.findViewById(R.id.profileImage);
                            BitmapFactory.Options opts = new BitmapFactory.Options();
                            opts.inSampleSize = 16;
                            profileImage.setImageBitmap(BitmapFactory.decodeFile(curr_profimg,opts));

Я заметил, что мне не нужен layoutinflater, но я подумал, что это может быть как-то связано с ошибкой. Вот строки из logcat

11-06 03:31:15.488: E/AndroidRuntime(11889): FATAL EXCEPTION: main
11-06 03:31:15.488: E/AndroidRuntime(11889): java.lang.NullPointerException
11-06 03:31:15.488: E/AndroidRuntime(11889):    at graf.main.MyView$6$9.onClick(MyView.java:567)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.view.View.performClick(View.java:2485)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.view.View$PerformClick.run(View.java:9089)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.os.Handler.handleCallback(Handler.java:587)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.os.Handler.dispatchMessage(Handler.java:92)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.os.Looper.loop(Looper.java:130)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at android.app.ActivityThread.main(ActivityThread.java:3806)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at java.lang.reflect.Method.invokeNative(Native Method)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at java.lang.reflect.Method.invoke(Method.java:507)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
11-06 03:31:15.488: E/AndroidRuntime(11889):    at dalvik.system.NativeStart.main(Native Method)

Как всегда, любой вклад по этому вопросу будет принят с благодарностью


person James andresakis    schedule 06.11.2011    source источник
comment
dialog2.findViewById , замените это на w.findViewById   -  person Yashwanth Kumar    schedule 06.11.2011
comment
@YashwanthKumar спасибо за помощь, но я уже понял, что это было, лол..... пора спать :)   -  person James andresakis    schedule 06.11.2011


Ответы (1)


Я только что понял, что у меня проблема с моим собственным соглашением об именах, лол..... У меня было два ресурса с именем profileImage....один с большой буквы и один со строчной буквой i.....много кофе и недостаточно сон .... еще одна причина вспомнить, что вы узнали в школе о соглашениях об именах в нескольких классах, лол

person James andresakis    schedule 06.11.2011