我正在从ListView迁移到RecyclerView,但是在SQLite中输入一些数据之后,我的列表没有使用notifyDataSetChanged()更新;所以我总是必须调用setAdapter()方法;
回收器ViewAdapter
public class RecyclerViewAdapter extends RecyclerView.Adapter<ViewHolder> {
private List<Model> model;
private Context context;
public RecyclerViewAdapter(Context context, List<Model> model) {
this.context = context;
this.model = new ArrayList<>(model);
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.custom_layout, parent, false);
return new ViewHolder(context, view, model);
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
final Model model = model.get(position);
holder.bind(model);
}
@Override
public int getItemCount() {
return model.size();
} }
观赏者
public class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener {
private List<Model> model = new ArrayList<>();
private Context context;
private TextView textViewGroup;
private TextView textViewName;
public ViewHolder(Context context, View itemView, List<Model> model) {
super(itemView);
this.model = model;
this.context = context;
itemView.setOnClickListener(this);
textViewGroup = (TextView) itemView.findViewById(R.id.textViewGroup);
textViewName = (TextView) itemView.findViewById(R.id.textViewName);
}
public void bind(Model model) {
textViewGroup.setText(model.getGroup());
textViewName.setText(model.getName());
}
}
@Override
public void onClick(View view) {
Model model = this.model.get(getAdapterPosition());
Intent intent = new Intent(this.context, ShowGroup.class);
intent.putExtra("DATA", model);
intent.putExtra("POSITION", getAdapterPosition());
((Activity) this.context).startActivityForResult(intent, 7);
Log.i(">>", "_IDHOLDER: " + model.getId());
Log.i(">>", "_POSITION: " + getAdapterPosition());
Log.i(">>", ".");
} }
模型
public class Model implements Serializable {
public static final String TABLE = "GROUP_NAME";
public static final String ID = "_ID";
public static final String GROUP = "GROUP";
public static final String NAME = "NAME";
private long id;
private String group;
private String name;
public Model() {
setId(0);
}
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getGroup() {
return group;
}
public void setGroup(String group) {
this.group = group;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} }
public class Repository {
private SQLiteDatabase db;
public Repository(SQLiteDatabase db) {
this.db = db;
}
private ContentValues fillModelValues(Model model) {
ContentValues values = new ContentValues();
values.put(Model.GROUP, model.getGroup());
values.put(Model.NAME, model.getName());
return values;
}
public void insert(Model model) {
ContentValues values = fillModelValues(model);
db.insertOrThrow(Model.TABLE, null, values);
}
public List<Model> consDataBase(Context context) {
List<Model> listModel = new ArrayList<>();
Cursor cursor = db.query(Model.TABLE, null, null, null, null, null, null);
if (cursor.getCount() > 0) {
cursor.moveToFirst();
do {
Model model = new Model();
model.setId(cursor.getLong(cursor.getColumnIndex(Model.ID)));
model.setGroup(cursor.getString(cursor.getColumnIndex(Model.GROUP)));
model.setName(cursor.getString(cursor.getColumnIndex(Model.NAME)));
listModel.add(model);
} while (cursor.moveToNext());
}
cursor.close();
return listModel;
} }
public class MainActivity extends AppCompatActivity {
private List<Model> listModel;
private LinearLayoutManager layoutManager;
private RecyclerView recyclerView;
private RecyclerViewAdapter recyclerViewAdapter;
private FloatingActionButton fab;
private DataBase dataBase;
private SQLiteDatabase db;
private Repository repository;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
layoutManager = new LinearLayoutManager(this);
recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
recyclerView.setLayoutManager(layoutManager);
fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
startActivityForResult(new Intent(MainActivity.this, AddGroup.class), 4);
}
});
try {
dataBase = new DataBase(this);
db = dataBase.getWritableDatabase();
repository = new Repository(db);
listModel = repository.consDataBase(context);
recyclerViewAdapter = new RecyclerViewAdapter(context, listModel);
recyclerView.setAdapter(recyclerViewAdapter);
recyclerView.setHasFixedSize(true);
} catch (SQLException e) {
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if (db != null) {
db.close();
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == 4) {
listModel = repository.consDataBase(context);
recyclerViewAdapter = new RecyclerViewAdapter(context, listModel);
recyclerView.setAdapter(recyclerViewAdapter);
}
} }
public class AddGroup extends AppCompatActivity {
private EditText editTextGroup;
private EditText editTextName;
private DataBase dataBase;
private SQLiteDatabase db;
private Repository repository;
private Model model;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add_group);
editTextGroup = (EditText) findViewById(R.id.editTextGroup);
editTextName = (EditText) findViewById(R.id.editTextName);
try {
dataBase = new DataBase(this);
db = dataBase.getWritableDatabase();
repository = new Repository(db);
model = new Model();
} catch (SQLException e) {
}
}
private void saveModel() {
try {
model.setGroup(editTextGroup.getText().toString().trim());
model.setName(editTextName.getText().toString().trim());
if (model.getId() == 0) {
repository.insert(model);
}
} catch (Exception e) {
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if (db != null) {
db.close();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.menu_add_group, menu);
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
if (item.getItemId() == R.id.action_save) {
saveModel();
}
return super.onOptionsItemSelected(item);
} }
为了使代码正常工作,您需要更改适配器构造函数实现,如下所示:
public RecyclerViewAdapter(Context context, List<Model> model) {
this.context = context;
this.model = model;
}
然后在OnActivityResult
中执行以下操作:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == 4) {
listModel.clear();
listModel.addAll(repository.consDataBase(context));
recyclerViewAdapter.notifyDataSetChanged();
}
}
RecycerView只显示创建时ArrayList(适配器的数据)中的项。我所有添加更多行的尝试似乎都奏效了,但列表仍然是初始数据。它不是重复的,因为我尝试了谷歌上找到的所有建议。我已经做了什么: Adapter.NotifyDataSetChanged(); Adapter.NotifyItemChanged(5); recyleList.invalidate(); recyclelist.s
如题;相关代码如下,网络请求是异步操作(回调不是在主线程中),请问各位大佬该如何解决? 初始化 recyclerview 代码: 更新数据的代码如下: 适配器代码如下
我的TableView没有更新,我需要一个监听器吗?(m是我的模型) 在一个新的阶段,我在我的模型列表中添加了一些Mitarbeiter 但是另一个阶段的TableView没有更新新数据。最后,观察列表不是指向模型中的ArrayList吗?
我试图解决一个问题,但没有成功。每当数据库(数据库室)中特定模型的记录发生变化时,我想更新我的回收器视图。我使用ViewModel来处理模型数据,记录列表存储在LiveData中。 数据库 模型 刀 视图模型 碎片 现在,我的问题是为什么观察者只被调用一次(在片段的开始),然后没有被再次调用?我如何让观察者不断地倾听数据库中的变化(插入,更新,删除),以便我的回收器视图可以立即更新?非常感谢任何建
本文向大家介绍Android RecyclerView添加上拉加载更多功能,包括了Android RecyclerView添加上拉加载更多功能的使用技巧和注意事项,需要的朋友参考一下 上一篇文章已经介绍了如何为RecyclerView添加FootView,在此基础上,要添加分页加载的功能其实已经很简单了。 上一篇文章地址:为RecyclerView添加FootView和HeadView 效果:(源
我在片段的底部有一个水平图像滑块。片段的顶部显示了一些细节。一旦用户点击底部的图像,想法是从图像滑块中删除该图像,并在片段中显示其信息。现在,信息显示出来,但图像不会从中删除。下面是我在最外层布局的中编码的内容。我试过了所有我能找到的相关答案,但都没有奏效。它们都在代码里。请让我知道我做错了什么或者错过了什么。 适配器的完整代码 }