RecyclerView не обновляется после добавления данных

Я перехожу с ListView на RecyclerView, но после ввода некоторых данных в SQLite мой список не обновляется с помощью notifyDataSetChanged(); поэтому мне всегда приходится вызывать метод setAdapter();

Я упростил свой код, чтобы опубликовать его здесь. может ли кто-нибудь помочь мне исправить notifyDataSetChanged(); работать в моем коде, пожалуйста?

Рециклервиевадаптер

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);
} }

person F4bioo    schedule 09.02.2016    source источник
comment
В вашем коде я не вижу notifyDataSetChanged. Куда ты это звонишь? Кстати, в вашем адаптере я вижу, что вы создаете копию списка ввода с помощью this.model = new ArrayList<>(model), и у вас нет метода addItem для явного обновления такого списка. Может быть, вы не сообщили об этом в общем коде?   -  person thetonrifles    schedule 09.02.2016
comment
метод сохранения находится в Repository insert (Model model). Я удалил его и добавил ecyclerView.setAdapter (recyclerViewAdapter); в onActivityResult, и это мой вопрос, как я могу реализовать notifyDataSetChanged (); без необходимости перестраивать с setAdapter()?   -  person F4bioo    schedule 09.02.2016
comment
Я имею в виду, что в вашем репозитории вы храните данные. Затем вам также необходимо обновить свой список‹Модель›, и этот список должен быть разделен между Activity и Adapter. В конструкторе адаптера используйте this.model = model, а в onActivityResult сделайте listModel .clear();, затем listModel.addAll(repository.consDataBase(context)), затем recyclerViewAdapter.notifyDataSetChanged().   -  person thetonrifles    schedule 09.02.2016
comment
спасибо, теперь все работает, большое спасибо :) ... Пожалуйста, отредактируйте свой ответ, это поможет вам получить баллы   -  person F4bioo    schedule 09.02.2016
comment
Рад, что смог помочь :) ... Я отправил ответ :)   -  person thetonrifles    schedule 09.02.2016
comment
Вы также можете проголосовать, если считаете это разумным :)   -  person thetonrifles    schedule 09.02.2016
comment
после изменения в конструкторе адаптера: this.model = new ArrayList <> (model); на this.model = model; мой поиск не работает, есть идеи? ссылка для поиска   -  person F4bioo    schedule 11.02.2016
comment
Если вы имеете в виду, что список не фильтруется, возможно, проблема в том, что вы должны сохранить две коллекции: исходную со всеми элементами и отфильтрованную для сохранения только результатов фильтрации. Отфильтрованный список должен быть в начале копией исходного списка и должен быть передан в конструктор адаптера. Затем метод фильтра должен обновить список фильтров, проверив элементы в исходном списке. Надеюсь, это поможет.   -  person thetonrifles    schedule 11.02.2016
comment
может быть, если это не трудно сделать, вы можете показать мне его? извините, я еще новичок. еще раз спасибо.   -  person F4bioo    schedule 11.02.2016
comment
Мне нужно время, но я могу попытаться поделиться с вами кодом.   -  person thetonrifles    schedule 11.02.2016
comment
эй, @thetonrifles, спасибо, в этом нет необходимости, я это исправил. см. ниже :) ссылка   -  person F4bioo    schedule 11.02.2016


Ответы (3)


Чтобы ваш код работал, вам нужно изменить реализацию конструктора адаптера следующим образом:

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();
    }
}
person thetonrifles    schedule 09.02.2016
comment
если я не создам отдельный класс для получения и настройки, как обновить представление ресайклера, братан stackoverflow.com/questions/63661586/ - person Kingg; 31.08.2020

теперь это работает

RecyclerViewAdapter

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);
    }

    ...

    public void notify(List<Model> list) {
        if (model != null) {
        model.clear();
        model.addAll(list);

        } else {
            model = list;
        }
        notifyDataSetChanged();
    }
}

Затем в onActivityResult

@Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if (requestCode == 4) {
    listModel = repository.consDataBase(this);
        recyclerViewAdapter.notify(listModel);
    }
}

благодарю вас :)

person F4bioo    schedule 11.02.2016

Проще говоря: RecyclerViewAdapter.notyfyDataSetChanged();

person Akhtar Shaikh    schedule 30.05.2019