У меня есть RecyclerView
, и я хотел бы передать данные в конструктор «ViewHolder
s» RecyclerView.Adapter
s в onCreateViewHolder(ViewGroup parent, int viewType)
.Android - передача данных в ViewHolder конструктор в onCreateViewHolder (..)
То, что я хотел бы сделать, - передать параметр (сам элемент данных) в конструктор ViewHolder, чтобы я не получал его каждый раз, когда элемент был нажат.
Однако, когда я пытаюсь получить позицию в onCreateViewHolder (ViewGroup родителя, внутр ViewType), я не получаю абсолютное положение строки, viewType которая всегда возвращает 0.
Я не хочу использовать RecyclerView .onItemTouchListener().
теперь я понимаю, что я могу использовать
@Override
public int getItemViewType(int position) {
return super.getItemViewType(position);
}
, которые могут возвращать уникальные позиции для каждого элемента в списке. Но тогда мне пришлось бы писать (длинные) лестницы для переключения, чтобы обрабатывать каждый элемент в структуре данных, который является утомительным.
Могу ли я использовать onCreateViewHolder (...) так, чтобы целочисленный параметр возвращал абсолютные позиции (чтобы я мог использовать позицию для передачи данных конструктору ViewHolder) без необходимости обрабатывать каждый элемент отдельно в блоке переключателя?
Вот мой адаптер:
public class Adapter extends RecyclerView.Adapter<Adapter.DataViewHolder> {
ArrayList<String> mContinentList;
ClickListener mListener;
public interface ClickListener{
void onContinentClicked(String continent);
}
public class DataViewHolder extends RecyclerView.ViewHolder{
TextView mDataItemTextView;
String mContinent;
public DataViewHolder(View itemView,String continent) {
super(itemView);
mDataItemTextView = (TextView) itemView.findViewById(R.id.data_text_view);
mContinent = continent;
Log.v("continent",mContinent);
mDataItemTextView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mListener.onContinentClicked(mContinent);
}
});
}
}
public Adapter(Context context, ArrayList<String> continentList){
this.mContinentList = continentList;
this.mListener = (ClickListener) context;
}
@Override
public DataViewHolder onCreateViewHolder(ViewGroup parent, int position) {
Log.v("position", Integer.toString(position));
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.data_item_view, parent, false);
return new DataViewHolder(view,mContinentList.get(position));
}
@Override
public void onBindViewHolder(DataViewHolder holder, int position) {
holder.mDataItemTextView.setText(mContinentList.get(position));
}
@Override
public int getItemCount() {
return mContinentList.size();
}
}
и вот моя активность:
public class MainActivity extends AppCompatActivity implements Adapter.ClickListener{
RecyclerView mRecyclerView;
Adapter mAdapter;
ArrayList<String> mDataList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initData();
mRecyclerView = (RecyclerView)findViewById(R.id.recycler_view);
mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
mAdapter = new Adapter(this,mDataList);
mRecyclerView.setAdapter(mAdapter);
}
private void initData(){
mDataList = new ArrayList<>();
mDataList.add("Africa");
mDataList.add("Antartica");
mDataList.add("Asia");
mDataList.add("Australia");
mDataList.add("Europe");
mDataList.add("North America");
mDataList.add("South America");
}
@Override
public void onContinentClicked(String continent) {
Log.v("continent",continent);
}
}
А вот мои журналы:
07-14 15:53:59.271 2987-2987/com.android.test V/position: 0
07-14 15:53:59.309 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.312 2987-2987/com.android.test V/position: 0
07-14 15:53:59.312 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.315 2987-2987/com.android.test V/position: 0
07-14 15:53:59.316 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.316 2987-2987/com.android.test V/position: 0
07-14 15:53:59.316 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.316 2987-2987/com.android.test V/position: 0
07-14 15:53:59.316 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.317 2987-2987/com.android.test V/position: 0
07-14 15:53:59.317 2987-2987/com.android.test V/continent: Africa
07-14 15:53:59.317 2987-2987/com.android.test V/position: 0
07-14 15:53:59.317 2987-2987/com.android.test V/continent: Africa
Спасибо за это, что, если мне нужно, чтобы добавить верхние и нижние колонтитулы вокруг моего списка и ViewHolder каждый для заголовка, нижнего колонтитула и элемент данных? – user1841702
В этом случае вы можете использовать переключатель в onCreateViewHolder, чтобы проверить, равна ли позиция 0 или вашемуData.size() -1. Затем раздуйте основание заголовка на корпусе. Это означает, что ваш первый и последний элемент будет представлять верхний и нижний колонтитулы соответственно –