NullPointerException в TextView.checkForRelayout(), в то время как setText()

Я пытаюсь реализовать шаблон ViewHolder для улучшения производительности при рисовании на холсте над картой. Мне нужно создать несколько меток для моих маркеров. Этот метод вызывается во время обработки данных в draw()

// now we create label view and convert it into bitmap
private Bitmap createLabelBitmap(GisLaborHistoryObject object, HistoryPoint point) {
    // create view from xml
    if (vh == null) {
        vh = new ViewHolder();
        vh.view = inflater.inflate(R.layout.map_gis_history_label, null, false);
        vh.tv = (TextView) vh.view.findViewById(R.id.gislabeltext);
    }

    // set label content
    if (vh.tv != null) {
        if (!mSingleLaborHistory) {
            String name = "";
            name = object.getDisplayName();
            if (name == null || "".equals(name))
                name = object.getPersonId();
            if (name == null || "".equals(name))
                name = object.getLaborCode();
            if (name == null)
                name = "";

            vh.tv.setText(name);
        } else
            vh.tv.setText(point.getChangeDate());
    } 
    // measure resulting view
    vh.view.measure(spec, spec);
    vh.view.layout(0, 0, vh.view.getMeasuredWidth(), vh.view.getMeasuredHeight());
    Bitmap b = Bitmap.createBitmap(vh.view.getWidth(), vh.view.getHeight(), Bitmap.Config.ARGB_8888);
    canvasToDraw.setBitmap(b);
    canvasToDraw.translate(-vh.view.getScrollX(), -vh.view.getScrollY());
    vh.view.draw(canvasToDraw);
    return b;
}

spec

spec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);

результат Logcat:

 04-29 17:12:34.057: E/AndroidRuntime(389): java.lang.NullPointerException
 04-29 17:12:34.057: E/AndroidRuntime(389):     at android.widget.TextView.checkForRelayout(TextView.java:5497)
 04-29 17:12:34.057: E/AndroidRuntime(389):     at android.widget.TextView.setText(TextView.java:2730)
 04-29 17:12:34.057: E/AndroidRuntime(389):     at android.widget.TextView.setText(TextView.java:2598)
 04-29 17:12:34.057: E/AndroidRuntime(389):     at android.widget.TextView.setText(TextView.java:2573)
 04-29 17:12:34.057: E/AndroidRuntime(389):     at com.xxx.android.proj.ui.map.overlays.LaborsMarkerOverlay.createLabelBitmap(LaborsMarkerOverlay.java:164)

XML-макет, который я использую

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/gislabeltext"
style="@style/labelStyle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="2dp"
android:paddingRight="2dp" />

что может быть причиной этой ошибки?

Ответ 1

Изучив android исходный код в строке 5497, я заметил, что есть чек с использованием mLayoutParams. Я посмотрел случай в режиме отладки, и это действительно было null! Я добавляю строку, которая явно задает эти параметры. Теперь все работает нормально.

vh.tv = (TextView) vh.view.findViewById(R.id.gislabeltext);
vh.tv.setLayoutParams(new ViewGroup.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));

Моя ошибка заключалась в том, что я должен был явно установить LayoutParams при раздувании с помощью ViewGroup root = null; Все работает нормально, пока я не попытаюсь многократно использовать TextView.

Ответ 2

вам нужно вызвать метод vh.tv.setText в вашем потоке ui. Поэтому убедитесь, что вы это делаете.