RecyclerViewの使用(1)
4079 ワード
RecyclerViewはsupport-v 7を導入する必要があります.
RecyclerViewの基本使用
RecyclerViewアダプタのアダプタは、次のコードでRecyclerView.Adapterを継承する必要があります.
LinearLayoutManagerリニアレイアウトでスライド方向を設定
GridLayoutManagerグリッドレイアウトでは列数を設定する必要があります
StaggerdGridLayoutManagerの滝のレイアウト方向と列数を設定
滝の流れのレイアウトはitemの高さを変えて適当なonBindView Holderに加える必要があります
itemにクリックと長押しイベントを追加するには、まずコールバックインタフェースを新規作成します.
次にitemにクリックイベントを追加し、最後にカスタムコールバックイベントを適用します.
compile 'com.android.support:recyclerview-v7:25.0.1'
RecyclerViewの基本使用
//
LinearLayoutManager layoutManager = new LinearLayoutManager(this);
//
layoutManager.setOrientation(LinearLayoutManager.VERTICAL);
// RecyclerView
recyclerView.setLayoutManager(layoutManager);
//
adapter = new MyAdapter(mDatas);
recyclerView.setAdapter(adapter);
RecyclerViewアダプタのアダプタは、次のコードでRecyclerView.Adapterを継承する必要があります.
private static class MyAdapter extends RecyclerView.Adapter {
List data;
//
public MyAdapter(List data) {
this.data = data;
}
private OnItemClickLitener mOnItemClickLitener;
// View
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item, parent, false);
ViewHolder viewHolder = new ViewHolder(view);
return viewHolder;
}
//
@Override
public void onBindViewHolder(final ViewHolder holder, int position) {
holder.textView.setText(data.get(position));
}
//
@Override
public int getItemCount() {
return data.size();
}
//
class ViewHolder extends RecyclerView.ViewHolder {
private TextView textView;
public ViewHolder(View itemView) {
super(itemView);
textView = (TextView) itemView.findViewById(R.id.tc_item);
}
}
// item
public void removeData(int position) {
data.remove(position);
notifyItemRemoved(position);
}
}
LinearLayoutManagerリニアレイアウトでスライド方向を設定
setOrientation(LinearLayoutManager.VERTICAL);//
setOrientation(LinearLayoutManager.HORIZONTAL);//
GridLayoutManagerグリッドレイアウトでは列数を設定する必要があります
GridLayoutManager gridLayoutManager = new GridLayoutManager(this,4);
StaggerdGridLayoutManagerの滝のレイアウト方向と列数を設定
StaggeredGridLayoutManager gridLayoutManager = new StaggeredGridLayoutManager(4,StaggeredGridLayoutManager.HORIZONTAL);
滝の流れのレイアウトはitemの高さを変えて適当なonBindView Holderに加える必要があります
ViewGroup.LayoutParams params = holder.itemView.getLayoutParams();// item LayoutParams
params.height = (int) (200 + Math.random() * 400);// itemView
holder.itemView.setLayoutParams(params);// params itemView
itemにクリックと長押しイベントを追加するには、まずコールバックインタフェースを新規作成します.
//
public void setOnItemClickLitener(OnItemClickLitener mOnItemClickLitener) {
this.mOnItemClickLitener = mOnItemClickLitener;
}
//
public interface OnItemClickLitener {
void onItemClick(View view, int position);
void onItemLongClick(View view, int position);
}
次にitemにクリックイベントを追加し、最後にカスタムコールバックイベントを適用します.
if (mOnItemClickLitener != null) {
holder.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int pos = holder.getLayoutPosition();
mOnItemClickLitener.onItemClick(holder.itemView, pos);//
}
});
holder.itemView.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View view) {
int pos = holder.getLayoutPosition();
mOnItemClickLitener.onItemLongClick(holder.itemView, pos);//
return false;
}
});
}