Search code examples
javaandroidnullpointerexceptionfatal-errorforceclose

FATAL EXCEPTION: main at BinderData.getView(BinderData.java:93)


I'm getting the error FATAL EXCEPTION: main at BinderData.getView(BinderData.java:93)

Line 93 in my source is: Drawable image = vi.getContext().getResources().getDrawable(imageResource);

I've attempted to set a break point at the line above it and step over it but when I do I get:

Source not found. Edit Source Lookup Path.


12-24 16:40:20.266: E/AndroidRuntime(8649): FATAL EXCEPTION: main
12-24 16:40:20.266: E/AndroidRuntime(8649): android.content.res.Resources$NotFoundException: Resource ID #0x0
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.content.res.Resources.getValue(Resources.java:1033)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.content.res.Resources.getDrawable(Resources.java:672)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at com.idg.voiscphone.BinderData.getView(BinderData.java:93)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.AbsListView.obtainView(AbsListView.java:2207)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.ListView.measureHeightOfChildren(ListView.java:1250)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.ListView.onMeasure(ListView.java:1162)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.View.measure(View.java:15604)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4918)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1411)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:698)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.LinearLayout.onMeasure(LinearLayout.java:588)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.View.measure(View.java:15604)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4918)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.View.measure(View.java:15604)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:850)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.LinearLayout.onMeasure(LinearLayout.java:588)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.View.measure(View.java:15604)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4918)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:310)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2191)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.View.measure(View.java:15604)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2165)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1249)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1443)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1139)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4879)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.Choreographer$CallbackRecord.run(Choreographer.java:776)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.Choreographer.doCallbacks(Choreographer.java:579)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.Choreographer.doFrame(Choreographer.java:548)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:762)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.os.Handler.handleCallback(Handler.java:725)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.os.Handler.dispatchMessage(Handler.java:92)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.os.Looper.loop(Looper.java:153)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at android.app.ActivityThread.main(ActivityThread.java:5297)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at java.lang.reflect.Method.invokeNative(Native Method)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at java.lang.reflect.Method.invoke(Method.java:511)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
12-24 16:40:20.266: E/AndroidRuntime(8649):     at dalvik.system.NativeStart.main(Native Method)

JAVA:

public class BinderData extends BaseAdapter {

    // XML node keys
    static final String KEY_TAG = "weatherdata"; // parent node
    static final String KEY_ID = "id";
    static final String KEY_CITY = "city";
    static final String KEY_TEMP_C = "tempc";
    static final String KEY_TEMP_F = "tempf";
    static final String KEY_CONDN = "condition";
    static final String KEY_SPEED = "windspeed";
    static final String KEY_ICON = "icon";

    LayoutInflater inflater;
    ImageView thumb_image;
    List<HashMap<String,String>> weatherDataCollection;
    ViewHolder holder;
    public BinderData() {
        // TODO Auto-generated constructor stub
    }

    public BinderData(Activity act, List<HashMap<String,String>> map) {

        this.weatherDataCollection = map;

        inflater = (LayoutInflater) act
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }


    public int getCount() {
        // TODO Auto-generated method stub
//      return idlist.size();
        return weatherDataCollection.size();
    }

    public Object getItem(int arg0) {
        // TODO Auto-generated method stub
        return null;
    }

    public long getItemId(int position) {
        // TODO Auto-generated method stub
        return 0;
    }

    public View getView(int position, View convertView, ViewGroup parent) {

        View vi=convertView;
        if(convertView==null){

          vi = inflater.inflate(R.layout.list_row, null);
          holder = new ViewHolder();

          holder.tvCity = (TextView)vi.findViewById(R.id.tvCity); // city name
          holder.tvWeather = (TextView)vi.findViewById(R.id.tvCondition); // city weather overview
          holder.tvTemperature =  (TextView)vi.findViewById(R.id.tvTemp); // city temperature
          holder.tvWeatherImage =(ImageView)vi.findViewById(R.id.list_image); // thumb image

          vi.setTag(holder);
        }
        else{

            holder = (ViewHolder)vi.getTag();
        }

          // Setting all values in listview

          holder.tvCity.setText(weatherDataCollection.get(position).get(KEY_CITY));
          holder.tvWeather.setText(weatherDataCollection.get(position).get(KEY_CONDN));
          holder.tvTemperature.setText(weatherDataCollection.get(position).get(KEY_TEMP_C));

          //Setting an image
          String uri = "drawable/"+ weatherDataCollection.get(position).get(KEY_ICON);
          int imageResource = vi.getContext().getApplicationContext().getResources().getIdentifier(uri, null, vi.getContext().getApplicationContext().getPackageName());
          Drawable image = vi.getContext().getResources().getDrawable(imageResource);
          holder.tvWeatherImage.setImageDrawable(image);

          return vi;
    }

    /*
     * 
     * */
    static class ViewHolder{

        TextView tvCity;
        TextView tvTemperature;
        TextView tvWeather;
        ImageView tvWeatherImage;
    }

}

Solution

  • Resources$NotFoundException - This exception is thrown by the resource APIs when a requested resource can not be found.

    Problem is here

    int imageResource = vi.getContext().getApplicationContext().getResources().getIdentifier(uri, null, vi.getContext().getApplicationContext().getPackageName());