我想了解RecylerView.adapter
的设计是什么。 onCreateViewHolder
方法接受视图类型作为参数。
onCreateViewHolder(ViewGroup parent, int viewType)
当RecyclerView需要新的RecyclerView.ViewHolder时调用 给定类型来表示项目。
此视图类型映射在getItemViewType
中getItemViewType(int position)
为了查看的目的,返回项目的视图类型 回收
最后绑定ViewHolder时调用bindViewHolder
onBindViewHolder(VH holder, int position)
由RecyclerView调用以在指定位置显示数据。
为什么在onBindViewHolder中定位一个参数?我的理解是发送到onCreateViewHolder的viewType允许开发人员根据视图类型创建适当的ViewHolder。如果是这种情况,onBindViewHolder中的位置是多余的,不必要的。
我是否正在考虑正确使用RecyclerView.adapter类?它让我质疑我的理解是将position参数传递给onBindViewHolder,它似乎在使用尖叫,但是在我当前的实现中确实没有需要,因为我的ViewHolders已经使用映射的视图类型创建了从位置。
答案 0 :(得分:2)
为什么在onBindViewHolder中定位一个参数?
因此,您知道要绑定到ViewHolder
的数据。 RecyclerView
旨在显示一组数据; a ViewHolder
将该集合中的一个项目绑定到其视图。
如果是这种情况,onBindViewHolder中的位置是多余的,没有必要。
仅当您始终将RecyclerView
与零件或单件商品模型数据集合使用时,在这种情况下您不应使用RecyclerView
。
我的ViewHolders已经使用从位置
映射的视图类型创建
视图类型用于截然不同的结构视图,例如标题和详细信息。视图类型与位置无关,这就是位置未传递到onCreateViewHolder()
。
因此,例如,假设您要显示来自lorem ipsum列表的25个拉丁单词的垂直滚动列表。默认情况下,有一种视图类型(即,您不会覆盖getItemViewType()
),并将该单词绑定到TextView
中列表行的onBindViewHolder()
(或其他)。
如果您在25字列表RecyclerView
的实现中使用了25种视图类型,那么很可能您做错了。可能含糊不清的唯一情况是每行的结构是否非常不同(第一行是TextView
,第二行是ImageButton
,第三行是ImageView
加a Switch
等。)
例如,这是一个托管RecyclerView
以显示25个字词列表的活动:
/***
Copyright (c) 2008-2015 CommonsWare, LLC
Licensed under the Apache License, Version 2.0 (the "License"); you may not
use this file except in compliance with the License. You may obtain a copy
of the License at http://www.apache.org/licenses/LICENSE-2.0. Unless required
by applicable law or agreed to in writing, software distributed under the
License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS
OF ANY KIND, either express or implied. See the License for the specific
language governing permissions and limitations under the License.
From _The Busy Coder's Guide to Android Development_
https://commonsware.com/Android
*/
package com.commonsware.android.recyclerview.simplelist;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;
public class MainActivity extends RecyclerViewActivity {
private static final String[] items={"lorem", "ipsum", "dolor",
"sit", "amet",
"consectetuer", "adipiscing", "elit", "morbi", "vel",
"ligula", "vitae", "arcu", "aliquet", "mollis",
"etiam", "vel", "erat", "placerat", "ante",
"porttitor", "sodales", "pellentesque", "augue", "purus"};
@Override
public void onCreate(Bundle icicle) {
super.onCreate(icicle);
setLayoutManager(new LinearLayoutManager(this));
setAdapter(new IconicAdapter());
}
class IconicAdapter extends RecyclerView.Adapter<RowHolder> {
@Override
public RowHolder onCreateViewHolder(ViewGroup parent, int viewType) {
return(new RowHolder(getLayoutInflater()
.inflate(R.layout.row, parent, false)));
}
@Override
public void onBindViewHolder(RowHolder holder, int position) {
holder.bindModel(items[position]);
}
@Override
public int getItemCount() {
return(items.length);
}
}
static class RowHolder extends RecyclerView.ViewHolder {
TextView label=null;
TextView size=null;
ImageView icon=null;
String template=null;
RowHolder(View row) {
super(row);
label=(TextView)row.findViewById(R.id.label);
size=(TextView)row.findViewById(R.id.size);
icon=(ImageView)row.findViewById(R.id.icon);
template=size.getContext().getString(R.string.size_template);
}
void bindModel(String item) {
label.setText(item);
size.setText(String.format(template, item.length()));
if (item.length()>4) {
icon.setImageResource(R.drawable.delete);
}
else {
icon.setImageResource(R.drawable.ok);
}
}
}
}
这扩展了a simple RecyclerViewActivity
我作为ListActivity
的对应部分拼凑在一起,但大多数逻辑都在Adapter
和ViewHolder
。如果需要,您还可以整体查看the full project和~20 RecyclerView
sample projects。