Пользовательский метод getView() не вызывается
Вот код фрагмента, в котором я устанавливаю пользовательский адаптер в список.
Нет ошибок, но ListView
пуст. Я реализовал getCount()
, который возвращает правильное количество элементов в моем ArrayList. Я не вижу ("Inside", "GetView")
в logcat
Фрагмент
public class ServiceCarListFragment extends Fragment {
private String url;
private ArrayList<CarDetail> carDetailList = new ArrayList<CarDetail>();
private CarListAdapter adapter;
private ListView mList;
@Override
public void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
url = getActivity().getIntent().getStringExtra("url");
new DownloadCarDetail().execute(url);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// TODO Auto-generated method stub
View v = inflater.inflate(R.layout.fragment_service_car_list, container, false);
mList = (ListView) v.findViewById(R.id.list);
mList.setAdapter(adapter);
for (CarDetail car : carDetailList) {
// START LOADING IMAGES FOR EACH STUDENT
car.loadImage(adapter);
}
return v;
}
class DownloadCarDetail extends AsyncTask<String, String, ArrayList<CarDetail>> {
@Override
protected ArrayList<CarDetail> doInBackground(String... params) {
// TODO Auto-generated method stub
ArrayList<CarDetail> carDetailList = JsonParser.parseJson(params[0]);
return carDetailList;
}
@Override
protected void onPostExecute(ArrayList<CarDetail> carDetailList) {
// TODO Auto-generated method stub
ServiceCarListFragment.this.carDetailList = carDetailList;
Log.d("dccs", String.valueOf(ServiceCarListFragment.this.carDetailList.size()));
adapter = new CarListAdapter(getActivity(), ServiceCarListFragment.this.carDetailList);
Log.d("dccs", String.valueOf((adapter.getCount())));
}
}
}
CustomAdapter
public class CarListAdapter extends BaseAdapter {
private ArrayList<CarDetail> items = new ArrayList<CarDetail>();
private Context context;
public CarListAdapter(Context context, ArrayList<CarDetail> items) {
this.context = context;
this.items = items;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return items.size();
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return items.get(position);
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
Log.d("Inside", "GetView");
LayoutInflater mInflater = (LayoutInflater) context.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
ViewHolder holder = null;
CarDetail car = items.get(position);
if (convertView == null) {
convertView = mInflater.inflate(R.layout.car_list_row, null);
holder = new ViewHolder();
holder.tvCarName = (TextView) convertView.findViewById(R.id.tvCarName);
holder.tvDailyPriceValue = (TextView) convertView.findViewById(R.id.tvWeeklyPriceValue);
holder.tvWeeklyPriceValue = (TextView) convertView.findViewById(R.id.tvWeeklyPriceValue);
holder.imgCar = (ImageView) convertView.findViewById(R.id.imgCar);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.tvCarName.setText(car.getCarName());
if (car.getImage() != null) {
holder.imgCar.setImageBitmap(car.getImage());
} else {
// MY DEFAULT IMAGE
holder.imgCar.setImageResource(R.drawable.ic_action_call);
}
return convertView;
}
static class ViewHolder {
TextView tvCarName;
TextView tvDailyPriceValue;
TextView tvWeeklyPriceValue;
ImageView imgCar;
}
}
Ответы
Ответ 1
Единственными причинами getView
не называются:
-
getCount
возвращает 0.
- вы забыли называть
setAdapter
на ListView
.
- Если видимость
ListView
(или ее видимость контейнера) GONE
. Спасибо @TaynãBonaldo за ценный вклад.
-
ListView
не привязан к макету видового экрана. То есть mListView = new ListView(...)
используется без myLayout.addView(mListView)
.
В onPostExcute
, после создания нового экземпляра CarListAdapter
, я предлагаю вам обновить новый экземпляр до вашего ListView
. Действительно, вам нужно снова позвонить
mList.setAdapter(adapter);
Изменить: setAdapter
должен всегда вызываться в потоке ui, чтобы избежать неожиданного поведения
Edit2:
То же самое относится к RecyclerView
. Убедитесь, что
-
getItemCount
возвращает значение grater чем 0
(обычно размер набора данных)
- оба
setLayoutManager
и setAdapter
должны быть вызваны на UI Thread
- Видимость виджета должна быть установлена на
VISIBLE
Ответ 2
вы должны убедиться, что в списке есть элементы, которые могут иметь ошибку при добавлении элементов в ваш список.
Чтобы проверить, используйте метод:
adapter.getCount();
Ответ 3
У меня возникла аналогичная проблема. Чтобы решить эту проблему, выполните простую работу:
В вашем onCreateView вам придется подождать до создания представления. Измените свои строки следующим образом:
mList = (ListView)v.findViewById(R.id.list);
mList.setAdapter(adapter);
ИЗМЕНИТЬ ВЫШЕ ДВУХ ЛИНИЙ В:
mList = (ListView)v.findViewById(R.id.list);
mList.post(new Runnable() {
public void run() {
mList.setAdapter(adapter);
}
});
Надеюсь, что это поможет другим, столкнувшимся с подобной проблемой.
Ответ 4
В конструкторе отсутствует суперкласс. См. Мой пример ниже:
public AppDataAdapter(Activity a, int textViewResourceId, ArrayList<AppData> entries) {
super(a, textViewResourceId, entries);
this.entries = entries;
this.activity = a;
}
Ответ 5
Что вы делали, это
В адаптере
public CarListAdapter(Context context , ArrayList<CarDetail> items) {
this.context = context;
this.items = items;
}
в вашем фрагменте
adapter = new CarListAdapter(getActivity(),ServiceCarListFragment.this.carDetailList);
Надеюсь, вы будете использовать FragmentActivity
Вам нужно позвонить
adapter = new CarListAdapter(YOUR_ACTIVITY_CONTEXT, carDetailList);
где YOUR_ACTIVITY_CONTEXT
будет вашим FragmentActivity