RecyclerView не отображает элементы, хранящиеся в базе данных SQLite - PullRequest
0 голосов
/ 13 мая 2018

У меня небольшая проблема с RecyclerView в моем приложении.Я постараюсь сделать его кратким и простым.

До этого момента мое приложение не показывало ошибок при сборке и не зависало.Однако после добавления некоторых данных в мою базу данных RecyclerView остается пустым.Я знаю, что база данных SQLite запущена и может быть заполнена.

Я подозреваю, что причиной может быть объединение строк в ViewHolder, что в соответствии с тем, что я прочитал (проверьте ссылки внизу), должно быть выполненоиспользование строк ресурсов с заполнителями, например

viewHolder.recordDescriptionTxtV.setText("Description" + records.getDescription());

должно быть заменено на

String description = getString(R.string.setDescriptionTxt, records.getDescription());
viewHolder.recordDescriptionTxtV.setText(description);

, где string.xml включает <string name="setDescriptionTxt">Description: %s</string>.

Однако, вызов getString() выдает ошибку, потому что, по-видимому, этот метод неизвестен.Было бы замечательно, если бы кто-то хотел помочь мне или, по крайней мере, указать мне правильное направление.

Вот класс RecordsAdapter.java:

import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import java.util.List;

class RecordsAdapter extends RecyclerView.Adapter<RecordsAdapter.ViewHolder> {
    private List<Records> mRecordsList;
    private Context mContext;
    private RecyclerView mRecyclerView;

    public class ViewHolder extends RecyclerView.ViewHolder {
    public TextView recordDescriptionTxtV;
    public TextView recordLocationTxtV;
    public TextView recordDayTxtV;
    public TextView recordMonthTxtV;
    public TextView recordYearTxtV;
    public TextView recordStartTxtV;
    public TextView recordFinishTxtV;
    public TextView recordCommentTxtV;

    public View layout;

    public ViewHolder(View view) {
        super(view);
        layout = view;
        recordDescriptionTxtV = (TextView) view.findViewById(R.id.description);
        recordLocationTxtV = (TextView) view.findViewById(R.id.location);
        recordDayTxtV = (TextView) view.findViewById(R.id.day);
        recordMonthTxtV = (TextView) view.findViewById(R.id.month);
        recordYearTxtV = (TextView) view.findViewById(R.id.year);
        recordStartTxtV = (TextView) view.findViewById(R.id.start);
        recordFinishTxtV = (TextView) view.findViewById(R.id.finish);
        recordCommentTxtV = (TextView) view.findViewById(R.id.comments);
    }
    }

    public void add(int position, Records records) {
    mRecordsList.add(position, records);
    notifyItemInserted(position);
    }
    public void remove(int position) {
    mRecordsList.remove(position);
    notifyItemRemoved(position);
    }

    public RecordsAdapter(List<Records> myDataset, Context context, RecyclerView recyclerView) {
    mRecordsList = myDataset;
    mContext = context;
    mRecyclerView = recyclerView;
    }

    @Override
    public RecordsAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    LayoutInflater inflater = LayoutInflater.from(parent.getContext());
    View view = inflater.inflate(R.layout.sin_row, parent, false);
    ViewHolder viewHolder = new ViewHolder(view);
    return viewHolder;
    }

    @Override
    public void onBindViewHolder(ViewHolder viewHolder, final int position) {
    final Records records = mRecordsList.get(position);

    viewHolder.recordDescriptionTxtV.setText("Description" + records.getDescription());
    viewHolder.recordLocationTxtV.setText("Location: " + records.getLocation());
    viewHolder.recordDayTxtV.setText("Day: " + records.getDay());
    viewHolder.recordMonthTxtV.setText("Month: " + records.getMonth());
    viewHolder.recordYearTxtV.setText("Year: " + records.getYear());
    viewHolder.recordStartTxtV.setText("Started at: " + records.getStart());
    viewHolder.recordFinishTxtV.setText("Finished at: " + records.getFinish());
    viewHolder.recordCommentTxtV.setText("Comments: " + records.getComments());

    viewHolder.layout.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            AlertDialog.Builder builder = new AlertDialog.Builder(mContext);
            builder.setTitle("Choose option");
            builder.setMessage("Update or delete user?");

            builder.setPositiveButton("Update", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    goToUpdateActivity(records.getId());
                }
            });

            builder.setNeutralButton("Delete", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                  RecordsDBHelper dbHelper = new RecordsDBHelper(mContext);
                  dbHelper.deleteRecordsRecords(records.getId(), mContext);
                  mRecordsList.remove(position);
                  mRecyclerView.removeViewAt(position);
                  notifyItemRemoved(position);
                  notifyItemRangeChanged(position, mRecordsList.size());
                  notifyDataSetChanged();
                }
            });

            builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    dialog.dismiss();
                }
            });

            builder.create().show();
        }

    });
    }

    private void goToUpdateActivity(long recordID) {
    Intent goToUpdate = new Intent(mContext, UpdateRecordActivity.class);
    goToUpdate.putExtra("USER_ID", recordID);
    mContext.startActivity(goToUpdate);
    }

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

Ссылки:

  1. https://developer.android.com/guide/topics/resources/string-resource#FormattingAndStyling
  2. https://developer.android.com/reference/android/content/Context#summary
  3. Android: Как получить строку из ресурсов, используя ее имя?
  4. Android TextView: «Не объединять текст, отображаемый с помощью setText»

Обновление: Вот мой logcat, отображающий ошибку:

05-13 12:31:39.797 15831-15831/com.example.benignfella.projectworkinghours E/dalvikvm: Could not find class 'android.graphics.drawable.RippleDrawable', referenced from method android.support.v7.widget.AppCompatImageHelper.hasOverlappingRendering

1 Ответ

0 голосов
/ 13 мая 2018

Here Решение:

Использовать ссылку на контекст (mContext) при доступе к данным из strings.xml в классе адаптера.

class RecordsAdapter extends RecyclerView.Adapter<RecordsAdapter.ViewHolder> {
private List<Records> mRecordsList;
private Context mContext;

                 //...

String descriptionTxt = mContext.getString(R.string.setDescriptionTxt);
String description = descriptionTxt + records.getDescription();
viewHolder.recordDescriptionTxtV.setText(description);

                 //...
}

Я думаю, что это может быть проблемой

<string name="setDescriptionTxt">Description: %s</string>

Решение:

<string name="setDescriptionTxt">Description</string>

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