2

У меня есть RecyclerView, и я хотел бы передать данные в конструктор «ViewHolderRecyclerView.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 

ответ

0

Вы не должны писать длительные если вы хотите другое представление для каждого элемента. getItemViewType передано абсолютное положение точно так же, как onBindViewHolder, поэтому просто верните позицию, полученную вами от getItemViewHolder, и используйте ее непосредственно в onCreateViewHolder. I.e viewType будет содержать реальную позицию.

Кстати извините за структуру ответа, я отвечаю с браузера телефона;)

+0

Спасибо за это, что, если мне нужно, чтобы добавить верхние и нижние колонтитулы вокруг моего списка и ViewHolder каждый для заголовка, нижнего колонтитула и элемент данных? – user1841702

+0

В этом случае вы можете использовать переключатель в onCreateViewHolder, чтобы проверить, равна ли позиция 0 или вашемуData.size() -1. Затем раздуйте основание заголовка на корпусе. Это означает, что ваш первый и последний элемент будет представлять верхний и нижний колонтитулы соответственно –

 Смежные вопросы

  • Нет связанных вопросов^_^