Android ArrayAdapter не возвращается?

Я создал следующий адаптер:

package org.virtualbet.gui.util;

import java.util.List;


import org.virtualbet.R;
import org.virtualbet.model.Tip;


import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;

public class TipListAdapter extends ArrayAdapter<Tip> {
    private final Context context;
    private List<Tip> values;

    public TipListAdapter(Context context, int textViewResourceId, List<Tip> objects) {
        super(context, textViewResourceId, objects);
        //super(context, R.layout.rowlayout, values);
        this.context = context;
        this.values = objects;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        try {
            View v = convertView;
            if (v == null) {
                LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                v = inflater.inflate(R.layout.row_tip, null);
            }
            Tip tip = values.get(position);
            if (tip!=null) {
                ((TextView)v.findViewById(R.id.textviewtipid)).setText((CharSequence)tip.getTipNumber());
                ((TextView)v.findViewById(R.id.textviewtiprepresentation)).setText((CharSequence)tip.getTipRepresentation());
                ((TextView)v.findViewById(R.id.textviewtipresult)).setText((CharSequence)tip.getDetails());
                ((TextView)v.findViewById(R.id.textviewtipid)).setText((CharSequence)tip.getTipOptions());
                return v;
            }
            return null;
        } catch (Throwable t) {
            Log.e("A", t.toString());
            return null;
        }
    }


}

ListView xml выглядит так:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content">
    <TextView android:text="TextView" 
    android:id="@+id/textviewtipid" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content"
    >
    </TextView>
    <TextView android:text="TextView" 
    android:id="@+id/textviewtiprepresentation" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content">
    </TextView>
     <TextView android:text="TextView" 
    android:id="@+id/textviewtipresult" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content">
    </TextView>
    <TextView android:text="TextView" 
    android:id="@+id/textviewtipplayed" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content">
    </TextView>

</LinearLayout>

Метод getView вызывается... все текстовые представления меняют свои значения... и после последнего изменения (независимо от того, какой это) программа переходит в часть catch???

Зачем? У кого-нибудь были такие проблемы? Я где-то читал, что это проблема проекта (затмения)....

Ах да, место, где я меняю модель:

package org.virtualbet.gui;

import java.util.ArrayList;
import java.util.List;

import org.virtualbet.R;
import org.virtualbet.bll.TipBLL;
import org.virtualbet.gui.util.TipListAdapter;
import org.virtualbet.model.Ticket;
import org.virtualbet.model.Tip;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;

public class FollowTicket extends Activity {

    private static final String TAG = "FollowTicket";

    private TipBLL bll;
    private TipListAdapter tipListAdapter;
    private ListView lv;
    private List<Tip> tips;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.follow_ticket);

        bll = new TipBLL();
        tips = new ArrayList<Tip>();
        tipListAdapter = new TipListAdapter(this.getApplicationContext(), R.layout.row_tip, tips);
        lv = ((ListView)findViewById(R.id.listViewTips));
        lv.setAdapter(tipListAdapter);
        ((Button)findViewById(R.id.buttonSearchForTicket)).setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                searchTicket(((EditText)findViewById(R.id.editTextSerialNumber)).getText().toString());
            }
        });
    }

    private void searchTicket (String serialNumber) {
        Log.i(TAG, "Searching ticket " + serialNumber);
        Ticket ticket = bll.getTicket(serialNumber);
        if (ticket != null){
            Log.i(TAG, "Found it!");
            tips.clear();
            for (Tip tip : ticket.getTips()) {
                Log.i(TAG, "Adding tip " + tip.getTipNumber());
                tips.add(tip);
            }
            tipListAdapter.notifyDataSetChanged();
        } else {
            Log.i(TAG, "Didn't find it!");
        }
    }

}

2 ответа

Решение

ПОЧИНИЛ ЭТО! Действительно глупая ошибка. В моем макете, где я держал список для заполнения, я имел

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="fill_parent" <-------------ERROR!!!!!!
    android:background="#880000"
    android:orientation="horizontal" >

............. некоторые элементы

</LinearLayout>
<ListView
    android:id="@android:id/list"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >
</ListView>

Где ОШИБКА!!! указывает, что это должно быть wrap_content, потому что этот макет выталкивает ListView из области видимости, и он не знает, что существует ListView (во время выполнения, пока компилятор кодирования не будет жаловаться)...... действительно глупо!!!

Спасибо за помощь в любом случае....

Может быть, вы захотите снова взглянуть на эту часть в своем коде:

        if (tip!=null) {
            ((TextView)v.findViewById(R.id.textviewtipid)).setText((CharSequence)tip.getTipNumber());
            ((TextView)v.findViewById(R.id.textviewtiprepresentation)).setText((CharSequence)tip.getTipRepresentation());
            ((TextView)v.findViewById(R.id.textviewtipresult)).setText((CharSequence)tip.getDetails());
            ((TextView)v.findViewById(R.id.textviewtipid)).setText((CharSequence)tip.getTipOptions());
            return v;
        }

Я думаю, что вы пытаетесь R.id.textviewtipid два раза.

        if (tip!=null) {
            ((TextView)v.findViewById(R.id.textviewtipid)).setText((CharSequence)tip.getTipNumber());
            ((TextView)v.findViewById(R.id.textviewtiprepresentation)).setText((CharSequence)tip.getTipRepresentation());
            ((TextView)v.findViewById(R.id.textviewtipresult)).setText((CharSequence)tip.getDetails());
            ((TextView)v.findViewById(R.id.textviewipplayed)).setText((CharSequence)tip.getTipOptions());
            return v;
        }

Это может быть причиной

Другие вопросы по тегам