gpt4 book ai didi

java - 使用 RecyclerView 动态绑定(bind)简单待办事项列表中的列表项

转载 作者:行者123 更新时间:2023-12-01 22:33:37 25 4
gpt4 key购买 nike

我正在尝试编写一个简单的待办事项列表,它将使用 RecyclerView 列表显示添加的项目。我的应用程序正常启动,但它没有向负责显示项目的 RecyclerView 对象添加任何内容。

我的猜测是,它需要某种动态或异步绑定(bind),以确保动态添加到列表中,但我坚持实现它。我尝试向我自己的适配器添加自定义 addremove 方法,但它仍然无法动态加载。

这是我的代码:

RecyclerViewAdapter.java

package com.example.kandydatpl;, adapter for list items

import android.content.Context;
import android.support.annotation.NonNull;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.CheckBox;
import android.widget.RelativeLayout;
import android.widget.TextView;

import java.util.ArrayList;

public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.ViewHolder>{

private static final String TAG = "RecyclerViewAdapter";
private ArrayList<String> listItemTexts = new ArrayList<>();
private Context context;

public RecyclerViewAdapter(ArrayList<String> listItemTexts, Context context) {
this.listItemTexts = listItemTexts;
this.context = context;
}

public void add(String content){
listItemTexts.add(content);
}

public void remove(int position){

listItemTexts.remove(position);
}

@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.layout_listitem, viewGroup, false);
ViewHolder holder = new ViewHolder(view);
return holder;
}

@Override
public void onBindViewHolder(@NonNull ViewHolder viewHolder, final int i) {
Log.d(TAG, "onBindViewHolder: called");

viewHolder.listItem.setText(listItemTexts.get(i));
viewHolder.parentLayout.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.d(TAG, "onClick: onClick: clicked on: " + listItemTexts.get(i));
}
});
}

@Override
public int getItemCount() {
return listItemTexts.size();
}

public class ViewHolder extends RecyclerView.ViewHolder{

TextView listItem;
CheckBox listItemCheckbox;
RelativeLayout parentLayout;

public ViewHolder(@NonNull View itemView) {
super(itemView);
listItem = itemView.findViewById(R.id.itemText);
listItemCheckbox = itemView.findViewById(R.id.itemCheckBox);
parentLayout = itemView.findViewById(R.id.parent_layout);
}
}
}

TaskListActivity.java,实现列表的 Activity

package com.example.kandydatpl;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

import java.io.File;
import java.util.ArrayList;

public class TaskListActivity extends AppCompatActivity implements View.OnClickListener, AdapterView.OnItemClickListener {

private EditText itemET;
private Button btn;
// private ListView itemsList;
// private ArrayList<String> items;
// private ArrayAdapter<String> adapter;

private ArrayList<String> mNames = new ArrayList<>();
RecyclerView recyclerView;
RecyclerViewAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_task_list);
recyclerView = findViewById(R.id.taskList);
recyclerView.setAdapter(adapter);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
adapter = new RecyclerViewAdapter(mNames, this);

itemET = findViewById(R.id.editText);
btn = findViewById(R.id.addBtn);
// itemsList = findViewById(R.id.list);
//
mNames = FileHelper.readData(this);
//
// adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, items);
// itemsList.setAdapter(adapter);
//
btn.setOnClickListener(this);
// itemsList.setOnItemClickListener(this);
}

@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.addBtn:
String itemEntered = itemET.getText().toString();
adapter.add(itemEntered);
itemET.setText("");
FileHelper.writeData(mNames, this);
Toast.makeText(this, "Item Added!", Toast.LENGTH_SHORT).show();
break;
}
}

@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
mNames.remove(position);
adapter.notifyDataSetChanged();
Toast.makeText(this, "Delete", Toast.LENGTH_SHORT).show();
}
}

activity_task_list.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">

<EditText
android:id="@+id/editText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10"
android:inputType="textPersonName"
android:text="Name" />

<Button
android:id="@+id/addBtn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Add" />

<android.support.v7.widget.RecyclerView
android:id="@+id/taskList"
android:scrollbars="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"/>

<ListView
android:id="@+id/list"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>

layout_listitem.xml,要显示的item的布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="wrap_content"
android:padding="20dp"
android:id="@+id/parent_layout">

<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/itemCheckBox"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Placeholder"
android:layout_toRightOf="@+id/itemCheckBox"
android:id="@+id/itemText"
/>

</RelativeLayout>

我已经调试了这段代码,幸运的是“添加”按钮有响应,并且用户输入的字符串被添加到适配器 ArrayList 中,但似乎没有在 Activity 屏幕上从中检索它。

最佳答案

简短而幼稚的解决方案(如果列表很大,将使应用程序变慢):在你的add()remove() RecyclerView.Adapter中的方法,最后调用这个函数: notifyDataSetChanged

更长、更优雅的解决方案:使用DiffUtil

为什么你会看到你所看到的?
这是因为只有Adapter看到的是您正在实现的更改,而不是 RecyclerView本身。为了RecyclerView要知道适配器状态(即数据)已更新,我们使用 notifyDataSetChangedDiffUtil回调。

关于java - 使用 RecyclerView 动态绑定(bind)简单待办事项列表中的列表项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58538621/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com