Question

Below is the crash report I received from my app published for alpha testing. Can anyone throw some light on how I should read this? It says NullPointerException, but where? I have an expandable list view, is it because it is getting a null object to bind to a list item? This is the method that seems to be throwing the NPE:

@Override
public View getChildView(int parent, int child, boolean arg2,
        View convertView, ViewGroup container) {
    ViewHolder mHolder;
    CategoryEntity childEntity = childlist.get(parent).get(child);
    if (convertView == null) {
        LayoutInflater mInflater = (LayoutInflater) mContext
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        convertView = mInflater.inflate(R.layout.category_row, container,
                false);
        mHolder = new ViewHolder();
        mHolder.cateogoryname = (TextView) convertView
                .findViewById(R.id.textView);
        mHolder.imageView = (ImageView) convertView
                .findViewById(R.id.imageView1);
        convertView.setTag(mHolder);
    } else {
        mHolder = (ViewHolder) convertView.getTag();
    }
    if (childEntity != null) {
        String replace = childEntity.getSq_displayName().equals("") ? childEntity
                .getCatname() : childEntity.getSq_displayName().replace(
                "<br>", "");

        Spannable span = new SpannableString(replace);
        switch (childEntity.getSq_cat_id()) {
        case 1:
            mHolder.imageView.setImageResource(R.drawable.ic_food);
            break;
        case 2:
            mHolder.imageView.setImageResource(R.drawable.ic_home);
            break;
        case 3:
            mHolder.imageView.setImageResource(R.drawable.ic_apparels);

            mHolder.cateogoryname.setText(replace);
            break;
        case 4:
            mHolder.imageView.setImageResource(R.drawable.ic_beauty);

            break;
        case 5:
            mHolder.imageView.setImageResource(R.drawable.ic_electronics);
            break;
        case 6:
            mHolder.imageView.setImageResource(R.drawable.ic_mobile);

            break;

        }
        span.setSpan(new ForegroundColorSpan(Color.rgb(0, 161, 220)), 0, 1,
                Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
        span.setSpan(new android.text.style.StyleSpan(
                android.graphics.Typeface.BOLD), 0, 1,
                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
        span.setSpan(new AbsoluteSizeSpan(18, true), 0, 1,
                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
        mHolder.cateogoryname.setGravity(GravityCompat.START);

        mHolder.cateogoryname.setText(span);
    }

    return convertView;
}

This is the stack trace:

java.lang.NullPointerException
at com.application.app.entity.e.getChildView(Unknown Source)
at android.widget.ExpandableListConnector.getView(ExpandableListConnector.java:451)
at android.widget.AbsListView.obtainView(AbsListView.java:2271)
at android.widget.ListView.measureHeightOfChildren(ListView.java:1269)
at android.widget.ListView.onMeasure(ListView.java:1181)
at android.view.View.measure(View.java:15323)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4924)
at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1421)
at android.widget.LinearLayout.measureVertical(LinearLayout.java:698)
at android.widget.LinearLayout.onMeasure(LinearLayout.java:579)
at android.view.View.measure(View.java:15323)
at android.support.v4.widget.DrawerLayout.onMeasure(Unknown Source)
at android.view.View.measure(View.java:15323)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4924)
at android.widget.FrameLayout.onMeasure(FrameLayout.java:315)
at android.view.View.measure(View.java:15323)
at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4924)
at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1421)
Was it helpful?

Solution

The most relevant line here is com.application.app.entity.e.getChildView.

It's saying there is a java.lang.NullPointerException at this line. Maybe you are trying to access a view that is not yet initialized (i.e. it's null).

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top