Android開発:RecyclerViewの使用(一)
6678 ワード
“ ”
記事を表示する
app/buildを開きます.gradleファイル、dependencies閉パッケージに次の内容を追加します.
compile 'com.android.support:recyclerview-v7:24.2.1'
追加が終わったら、Sync Nowをクリックして同期してください.次にactivity_を変更しますmain.xmlのコードは、次のようになります.
新規Fruitクラスとfruit_item.xml、コードは以下の通りです.
public class Fruit {
private String name;
private int imageId;
public Fruit(String name, int imageId) {
this.name = name;
this.imageId = imageId;
}
public String getName() {
return name;
}
public int getImageId() {
return imageId;
}
}
Fruitクラスには2つのフィールドしかなく、nameは果物の名前を表し、imageIdは果物対応画像のリソースidを表す.
次に、layoutディレクトリの下にfruit_を新規作成するカスタムレイアウトを指定する必要があります.item.xml、コードは以下の通りです.
次に、RecyclerViewにアダプタを用意し、Fruit Adapterクラスを新規作成し、このアダプタをRecyclerViewから継承する必要があります.Adapterは、汎用型をFruit Adapterとして指定する.ViewHolder.ここで、ViewHolderは、以下に示すように、Fruit Adapterで定義した内部クラスです.
public class FruitAdapter extends RecyclerView.Adapter {
private List mFruitList;
static class ViewHolder extends RecyclerView.ViewHolder {
ImageView fruitImage;
TextView fruitName;
public ViewHolder(View view) {
super(view);
fruitImage = (ImageView) view.findViewById(R.id.fruit_image);
fruitName = (TextView) view.findViewById(R.id.fruit_name);
}
}
public FruitAdapter(List fruitList) {
mFruitList = fruitList;
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.fruit_item, parent, false);
ViewHolder holder = new ViewHolder(view);
return holder;
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
Fruit fruit = mFruitList.get(position);
holder.fruitImage.setImageResource(fruit.getImageId());
holder.fruitName.setText(fruit.getName());
}
@Override
public int getItemCount() {
return mFruitList.size();
}
}
ここではまず内部クラスViewHolderを定義し、ViewHolderはRecyclerViewから継承する.ViewHolder.次に、ViewHolderのコンストラクション関数にViewパラメータが入力されます.このパラメータは通常、RecyclerViewサブアイテムの最外層レイアウトです.findViewById()メソッドを使用して、レイアウト内のImageViewおよびTextViewのインスタンスを取得できます.
次に、Fruit Adapterにも構造関数があります.この方法は、表示するデータソースを転送し、グローバル変数mFruitListに値を付与するために使用されます.私たちの後続の操作は、このデータソースに基づいて行われます.
引き続き下を見ると、Fruit AdapterはRecyclerViewから継承されているためです.Adapterの場合は、onCreateView Holder()、onBindView Holder()、getItemCount()の3つのメソッドを書き換える必要があります.onCreateViewHolder()メソッドは、ViewHolderインスタンスを作成するために使用されます.このメソッドではfruit_itemレイアウトをロードし、ViewHolderインスタンスを作成し、ロードしたレイアウトをコンストラクション関数に転送し、最後にViewHolderインスタンスを返します.onBindViewHolder()メソッドは、RecyclerViewサブアイテムのデータを付与するために使用され、各サブアイテムが画面内にスクロールされたときに実行されます.ここではpositionパラメータで現在のアイテムのFruitインスタンスを得てから、ViewHolderのImageViewとTextViewにデータを設定します.getItemCount()メソッドは非常に簡単で、RecyclerViewに全部で何個のサブアイテムがあるかを教えて、データソースの長さを直接返すだけでいいです.
アダプタの準備ができたら、次のようにRecyclerViewを使用してMainActivityのコードを変更できます.
public class MainActivity extends AppCompatActivity {
private List fruitList = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initFruits(); //
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
LinearLayoutManager layoutManager = new LinearLayoutManager(this);
recyclerView.setLayoutManager(layoutManager);
FruitAdapter adapter = new FruitAdapter(fruitList);
recyclerView.setAdapter(adapter);
}
private void initFruits() {
for (int i = 0; i < 2; i++) {
Fruit apple = new Fruit("Apple", R.drawable.apple_pic);
fruitList.add(apple);
Fruit banana = new Fruit("Banana", R.drawable.banana_pic);
fruitList.add(banana);
Fruit orange = new Fruit("Orange", R.drawable.orange_pic);
fruitList.add(orange);
Fruit watermelon = new Fruit("Watermelon", R.drawable.watermelon_pic);
fruitList.add(watermelon);
Fruit pear = new Fruit("Pear", R.drawable.pear_pic);
fruitList.add(pear);
Fruit grape = new Fruit("Grape", R.drawable.grape_pic);
fruitList.add(grape);
Fruit pineapple = new Fruit("Pineapple", R.drawable.pineapple_pic);
fruitList.add(pineapple);
Fruit strawberry = new Fruit("Strawberry", R.drawable.strawberry_pic);
fruitList.add(strawberry);
Fruit cherry = new Fruit("Cherry", R.drawable.cherry_pic);
fruitList.add(cherry);
Fruit mango = new Fruit("Mango", R.drawable.mango_pic);
fruitList.add(mango);
}
}
}
ここでは、すべての果物データを初期化するために同じinitFruits()メソッドが使用されていることがわかります.次にonCreate()メソッドでRecyclerViewのインスタンスを取得し、LinearLayoutManagerオブジェクトを作成してRecyclerViewに設定します.LayoutManagerは、RecyclerViewのレイアウト方法を指定するために使用されます.ここで使用するLinearLayoutManagerはリニアレイアウトの意味で、ListViewと同様の効果を実現できます.次に、Fruit Adapterのインスタンスを作成し、フルーツデータをFruit Adapterのコンストラクション関数に転送し、最後にRecyclerViewのsetAdapter()メソッドを呼び出してアダプタ設定を完了し、RecyclerViewとデータとの関連付けが完了します.
この文章は郭霖の作者が書いた「第1行コード」の本の中の章から転載された.ここで転載声明をします.