RecyclerView не отображает ни одного элемента при загрузке - PullRequest
0 голосов
/ 17 сентября 2018

Я получаю данные JSON и анализирую их с помощью Retrofit. Я хочу отобразить его в RecyclerView, но не могу отобразить его. Где я делаю это неправильно? Здесь MainActivity, Model и ListFlowerAdapter приведены

public class MainActivity extends AppCompatActivity {

    private ListFlowerAdapter mListFlowerAdapter;
    private RecyclerView mRecyclerView;
    private RetrofitClient mRetrofitClient;
    LinearLayoutManager linearLayoutManager;

    //private List<FlowerModel> myFlowers;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        configViews();

        mRetrofitClient = new RetrofitClient();
        Call<List<FlowerModel>> listCall = mRetrofitClient.getFlowerService().getAllFlowers();
        listCall.enqueue(new Callback<List<FlowerModel>>() {
            @Override
            public void onResponse(Call<List<FlowerModel>> call, Response<List<FlowerModel>> response) {
                if (response.isSuccessful()) {
                    List<FlowerModel> flowerList = response.body();

                    for (int i = 0; i < flowerList.size(); i++) {
                        FlowerModel flowerModel = flowerList.get(i);
                        mListFlowerAdapter.addFlower(flowerModel);
                    }
                } else {
                    int sc = response.code();
                    switch (sc) {
                    }
                }
            }

            @Override
            public void onFailure(Call<List<FlowerModel>> call, Throwable t) {
            }
        });
    }

    private void configViews() {
        mRecyclerView = findViewById(R.id.recycler_view);
        mRecyclerView.setHasFixedSize(true);

        mRecyclerView.setRecycledViewPool(new RecyclerView.RecycledViewPool());

        linearLayoutManager = new LinearLayoutManager(this);
        linearLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);
        mRecyclerView.setLayoutManager(linearLayoutManager);

        mListFlowerAdapter = new ListFlowerAdapter();
        mRecyclerView.setAdapter(mListFlowerAdapter);

        //mRecyclerView.setLayoutManager(new LinearLayoutManager(getApplicationContext(),LinearLayoutManager.VERTICAL,false));
        //mListFlowerAdapter = new ListFlowerAdapter();
        // mRecyclerView.setAdapter(mListFlowerAdapter);
    }
}

Класс ListFlowerAdapter

public class ListFlowerAdapter extends RecyclerView.Adapter<ListFlowerAdapter.MyViewHolder> {

    private static final String TAG = ListFlowerAdapter.class.getSimpleName();
    private Context context;
    private List<FlowerModel> myFlowers;

    public ListFlowerAdapter() {
        myFlowers = new ArrayList<>();
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {

        View row = LayoutInflater.from(parent.getContext()).inflate(R.layout.row_item, null, false);
        return new MyViewHolder(row);
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        FlowerModel currFlower = myFlowers.get(position);
        holder.mName.setText(currFlower.getName());
        holder.mPrice.setText(Double.toString(currFlower.getPrice()));
        Picasso.with(holder.itemView.getContext()).load("http://services.hanselandpetal.com/photos/" + currFlower.getPhoto()).into(holder.mPhoto);
    }

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

    public void addFlower(FlowerModel flowerModel) {
        myFlowers.add(flowerModel);
        notifyDataSetChanged();
    }

    public class MyViewHolder extends RecyclerView.ViewHolder {

        private ImageView mPhoto;
        private TextView mName, mPrice;

        public MyViewHolder(View itemView) {
            super(itemView);
            mPhoto = itemView.findViewById(R.id.flower_photo);
            mName = itemView.findViewById(R.id.flower_name);
            mPrice = itemView.findViewById(R.id.flower_price);
        }
    }
}

FlowerModel класс

 public class FlowerModel implements Serializable {
    @Expose
    private String category;
    @Expose
    private String price;

    @Expose
    private String instructions;

    @Expose
    private String photo;

    @Expose
    private String name;

    @Expose
    private int productId;

    public String getCategory() {
        return category;
    }

    public void setCategory(String category) {
        this.category = category;
    }

    public double getPrice() {
        return price;
    }

    public void setPrice(String price) {
        this.price = price;
    }

    public String getInstructions() {
        return instructions;
    }

    public void setInstructions(String instructions) {
        this.instructions = instructions;
    }

    public String getPhoto() {
        return photo;
    }

    public void setPhoto(String photo) {
        this.photo = photo;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getProductId() {
        return productId;
    }

    public void setProductId(int productId) {
        this.productId = productId;
    }
}

XML

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

        <ImageView
            android:id="@+id/flower_photo"
            android:layout_width="150dp"
            android:layout_height="150dp"
            android:background="@mipmap/ic_launcher"

            android:scaleType="centerCrop" />

        <LinearLayout
            android:orientation="vertical"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

            <TextView
                android:id="@+id/flower_name"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textAppearance="@style/Base.TextAppearance.AppCompat.Large"
                android:text="Large Text" />

            <TextView
                android:id="@+id/flower_price"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textAppearance="@style/Base.TextAppearance.AppCompat.Medium"
                android:text="Medium Text" />
        </LinearLayout>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:padding="16dp"
tools:context=".MainActivity">

<Button
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="Stop Downloading" />

<android.support.v7.widget.RecyclerView
    android:id="@+id/recycler_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:scrollbars="none"
    android:visibility="visible" />

Не могли бы вы помочь мне с этой проблемой, пожалуйста? Большое спасибо.

Ответы [ 3 ]

0 голосов
/ 17 сентября 2018

Попробуйте удалить эту строку:

mRecyclerView.setHasFixedSize(true);

И добавьте это в файл XML:

android:fillViewport="true"

Без этой строки начальная высота содержимого вашего RecyclerView равна 0 (пустой список)и с фиксированным размером он не может расти, хотя вы добавляете элементы в адаптер.

0 голосов
/ 17 сентября 2018

Передайте контекст активности в адаптер и используйте этот контекст для заполнения элемента в представлении списка.

 private Context mContext;     

 public ListFlowerAdapter(Context context) {
        myFlowers = new ArrayList<>();
        this.mContext = context;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {

        View row = LayoutInflater.from(mContext).inflate(R.layout.row_item, parent, false);
        return new MyViewHolder(row);
    }

Из действия отправьте контекст действия для инициализации адаптера следующим образом

 mListFlowerAdapter = new ListFlowerAdapter(this);

И для добавления нового элемента

public void addFlowers(List<FlowerModel> flowerModels) {
    for (int i = 0; i < flowerModels.size(); i++) {
            FlowerModel flowerModel = flowerModels.get(i);
            myFlowers.add(flowerModel);
         }
    notifyDataSetChanged();  
}

И для успешного ответа просто отправьте список для обновления адаптера

List<FlowerModel> flowerList = response.body();
mListFlowerAdapter.addFlowers(flowerList);

Надеюсь, это поможет.

0 голосов
/ 17 сентября 2018

Не уведомлять ваш адаптер рекурсивно,

Ваш код:

for (int i = 0; i < flowerList.size(); i++) {
                    FlowerModel flowerModel = flowerList.get(i);
                    mListFlowerAdapter.addFlower(flowerModel); // Called from here
                }

Код от адаптера

public void addFlower(FlowerModel flowerModel) {
    myFlowers.add(flowerModel);
    notifyDataSetChanged(); // Notifying everytime
}

Вместо этого вы должны добавить все данные в адаптер и уведомить только один раз: (Обновленный код)

for (int i = 0; i < flowerList.size(); i++) {
                    FlowerModel flowerModel = flowerList.get(i);
                    mListFlowerAdapter.addFlower(flowerModel);
                }
mListFlowerAdapter.notifyDataSetChanged(); // Notify like this

Код от адаптера

public void addFlower(FlowerModel flowerModel) {
    myFlowers.add(flowerModel);
    //notifyDataSetChanged(); Remove from here
}
...