ウェブサイトからチュートリアルを入手して、RecyclerViewとCardViewを使用して基本的なアプリを作成しました。
アプリは正常に動作していて、混乱があります(ここにコード全体を表示しています)
混乱は、コードが段階的にどのように機能するかということです。ですから、私のコンセプトを明確にしてください。
私のアプリの基本構造:
row_data_layout
にバインドするrecycler_view
xmlファイルを作成しました。RecyclerView
ファイルのMainActivity
にデータをバインドします。row_data_layout.xml
ファイル:
<?xml version="1.0" encoding="utf-8"?>
<Android.support.v7.widget.CardView xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:id="@+id/CardView"
Android:paddingBottom="16dp"
Android:layout_marginBottom="16dp">
<LinearLayout
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:orientation="vertical">
<TextView
Android:id="@+id/txt_name"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:layout_gravity="center_horizontal"
Android:text="Large Text"
Android:textAppearance="?android:attr/textAppearanceLarge" />
</LinearLayout>
</Android.support.v7.widget.CardView>
データクラスファイル:
public class Data {
public String Name;
Data(String Name)
{
this.Name=Name;
}
}
Data_Adapterクラスファイル:
public class Data_Adapter extends RecyclerView.Adapter<Data_Adapter.View_holder> {
List<Data> list = Collections.emptyList();
Context context;
public Data_Adapter(List<Data> list, Context context) {
this.list = list;
this.context = context;
}
@Override
public Data_Adapter.View_holder onCreateViewHolder(ViewGroup parent, int viewType) {
View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.row_data_layout,parent,false);
View_holder holder=new View_holder(v);
return holder;
}
@Override
public void onBindViewHolder(Data_Adapter.View_holder holder, int position) {
holder.name.setText(list.get(position).Name);
}
@Override
public int getItemCount() {
return list.size();
}
@Override
public void onAttachedToRecyclerView(RecyclerView recyclerView) {
super.onAttachedToRecyclerView(recyclerView);
}
public class View_holder extends RecyclerView.ViewHolder{
CardView cv;
TextView name;
public View_holder(View itemView) {
super(itemView);
cv = (CardView) itemView.findViewById(R.id.CardView);
name = (TextView) itemView.findViewById(R.id.txt_name);
}
}
}
MainActivityファイル:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
List<Data> data = fill_data();
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
Data_Adapter adapter = new Data_Adapter(data,getApplicationContext());
recyclerView.setAdapter(adapter);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
}
public List<Data> fill_data()
{
List<Data> data = new ArrayList<>();
data.add(new Data("Bred Pit"));
data.add(new Data("Leonardo"));
return data;
}
}
RecyclerView.Adapterがどのように機能するかについての基本的な理解ができたら、 documentation をさらに深く掘り下げることは理にかなっています。
アダプターが行うことは、提供したデータを取り込むために、膨張したビューのプールを保持することです(これは、必要な数の 異なる タイプの ViewHolder にすることができます)。アダプターのプールに空のビューがない場合、新しいビューが作成されます。
ビューがRecyclerViewにアタッチされると、プールから削除され、デタッチされると(ビューを超えてある程度の距離までスクロール)、空のビューのプールに追加されます。これが重要な理由です。 ViewHoldersにデータを入力するときに、すべてをリセットします。
onCreateViewHolder() 関数は、新しい空のビュー(RecyclerView.ViewHolderによってラップされた)が作成され、プールに追加される場所です。
onBindViewHolder() 関数は、空のプールからビューを取得し、アダプターに提供したデータを使用してこのビューにデータを入力します。\
onViewRecycled() メソッドを使用して、メモリ使用量を削減するために、ImageViewのビットマップをnull(デタッチ時)に設定するなどの特定のアクションを実行できます。
私は通常 onAttachedToRecyclerView() をオーバーライドしませんが、アダプターがRecyclerViewに関連付けられているときに特定のことを行う必要がある場合は、ここで行います。