我构建了一个自定义ArrayAdapter来填充Spinner。
public class CountryAdapter extends ArrayAdapter<CountryItem> {
public CountryAdapter(@NonNull Context context, ArrayList<CountryItem> countryList) {
super(context, 0, countryList);
}
@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
return initView(position, convertView, parent);
}
@Override
public View getDropDownView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
return initView(position, convertView, parent);
}
private View initView(int position, View convertView, ViewGroup parent) {
if (convertView == null) {
convertView = LayoutInflater.from(getContext()).inflate(
R.layout.country_spinner_row, parent, false);
}
ImageView imageViewFlag = convertView.findViewById(R.id.image_view_flag);
TextView textViewName = convertView.findViewById(R.id.text_view_name);
CountryItem currentItem = getItem(position);
imageViewFlag.setImageResource(currentItem.getFlagImage());
textViewName.setText(currentItem.getCountryName());
return convertView;
}
}
setImageResource
和setText
方法向我显示了一个NullPointer警告,但考虑到我在这里传递一个ArrayList,这是否可以忽略?在我看来,这也应该返回给定位置的项目。
答案 0 :(得分:3)
问题在于:
CountryItem currentItem = getItem(position);
getItem()
可以返回null值。以下是该方法的源代码,您会注意到它已使用@Nullable
进行注释。
@Override
public @Nullable T getItem(int position) {
return mObjects.get(position);
}
这意味着当您调用此方法时,您需要处理null条件。我知道在正常操作中你永远不会得到null,你可以忽略这个警告。但正确的方法是进行无效检查。
final CountryItem currentItem = getItem(position);
if (currentItem != null) {
imageViewFlag.setImageResource(currentItem.getFlagImage());
textViewName.setText(currentItem.getCountryName());
}