Динамическое связывание элементов списка в простом списке дел с помощью RecyclerView - PullRequest
0 голосов
/ 24 октября 2019

Я пытаюсь написать простой список дел, который будет отображать добавленные элементы, используя список RecyclerView. Мое приложение запускается правильно, но оно ничего не добавляет к объекту RecyclerView, отвечающему за отображение элементов.

Я предполагаю, что для этого требуется какая-то динамическая или асинхронная привязка, которая будет гарантировать на летудополнение к списку, но я застрял в его реализации. Я пытался добавить пользовательские методы add и remove к своему адаптеру, но он не загружается динамически.

Вот мой код:

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, действие, в котором реализован список

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, макет для отображаемого элемента

<?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, но кажется, что она не извлекается из него на экране активности.

1 Ответ

0 голосов
/ 24 октября 2019

Краткое и простое решение (замедлит приложение, если список большой): в ваших add() и remove() методах в RecyclerView.Adapter, в конце вызовите эту функцию: notifyDataSetChanged

Более длинное и элегантное решение: используйте DiffUtil

И почему вы видите то, что видите?
Это потому, что видит только Adapterизменения, которые вы внедряете, а не сам RecyclerView. Чтобы RecyclerView знал, что состояние адаптера (то есть данные) было обновлено, мы используем обратный вызов notifyDataSetChanged или DiffUtil.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...