Использовать другой макет для текста и изображения в программе повторного просмотра из базы данных Firebase? - PullRequest
0 голосов
/ 10 октября 2018

Я хочу использовать другой макет для данных, который содержит только текст и текст + изображение в Recyclerview.

Я создал два макета, layout_post для текстовых данных и layout_post_with_image для текста + данных изображений.

до сих пор мой код работает над тем, чтобы показать два разных макета в RecycleView, но проблема в том, что он показывает только layout_post_with_image в первых данных, layout_post во вторых данных и в третьих и на его show layout_post_with_image,какие бы данные я ни указывал, макет показывает тот же шаблон.так что кто-нибудь может мне помочь?

здесь видоискатель

import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.widget.ImageView;
import android.widget.TextView;
import com.example.myapp.R;
import java.awt.font.TextAttribute;

public class PostViewHolder extends RecyclerView.ViewHolder {
public TextView textPost;
public TextView textTime;
public ImageView postImage;

public PostViewHolder(View itemView){
    super(itemView);
    textPost = (TextView) itemView.findViewById(R.id.post_description);
    textTime = (TextView) itemView.findViewById(R.id.post_time);
    postImage = (ImageView) itemView.findViewById(R.id.post_image);
 }
}

здесь модель

package com.example.myapp.model;

public class Posts {
public String time, post, uid, image;

public Posts() {
}
public Posts(String time, String post, String uid, String image) {
    this.time = time;
    this.post = post;
    this.uid = uid;
    this.image = image;
}
public String getTime() {
    return time;
}
public void setTime(String time) {
    this.time = time;
}
public String getPost() {
    return post;
}
public void setPost(String post) {
    this.post = post;
}
public String getUid() {
    return uid;
}
public void setUid(String uid) {
    this.uid = uid;
}
public String getImage() {
    return image;
}
public void setImage(String image) {
    this.image = image;
}
}

и здесь домашний фрагмент

    postListView = (RecyclerView)rootView.findViewById(R.id.all_user_post_list);
    LinearLayoutManager linearLayoutManager = new LinearLayoutManager(getActivity());
    linearLayoutManager.setReverseLayout(true);
    linearLayoutManager.setStackFromEnd(true);
    postListView.setHasFixedSize(true);
    postListView.setLayoutManager(linearLayoutManager);
    firebaseRecyclerOptions = new FirebaseRecyclerOptions.Builder<Posts>()
            .setQuery(PostsRef, Posts.class)
            .build();
    firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Posts, PostViewHolder>(firebaseRecyclerOptions) {
        private final static int TEXT_ONLY = 1;
        private final static int TEXT_WITH_IMAGE= 0;


        public int getItemViewType(int position){
            switch (position){
                case 1:
                    return TEXT_ONLY;
                default:
                    return TEXT_WITH_IMAGE;
            }
        }

        @Override
        protected void onBindViewHolder(@NonNull PostViewHolder holder, int position, @NonNull Posts model) {
            if(holder.postImage !=null){
                holder.textTime.setText(model.getTime());
                holder.textPost.setText(model.getPost());
                Picasso.get().load(model.getImage()).into(holder.postImage);
            }else{
                holder.textTime.setText(model.getTime());
                holder.textPost.setText(model.getPost());
            }

        }

        @NonNull
        @Override
        public PostViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
          int layoutRes = 0;
            switch (viewType) {
                case TEXT_ONLY:
                    layoutRes = R.layout.layout_posts;
                    break;
                case TEXT_WITH_IMAGE:
                    layoutRes = R.layout.layout_posts_with_image;
                    break;
            }
            View view = LayoutInflater.from(parent.getContext()).inflate(layoutRes, parent, false);
            return new PostViewHolder(view);
        }
    };

    firebaseRecyclerAdapter.startListening();
    postListView.setAdapter(firebaseRecyclerAdapter);
    return rootView;

ОБНОВЛЕНИЕ: я думаю, что вместо двух разных макетов проще использовать один макет и настроить видимость для каждого элемента, который вы хотите изменить.

Ответы [ 2 ]

0 голосов
/ 10 октября 2018

Это довольно распространенный вопрос.Вам придется переопределить getItemViewType (что вы уже сделали), а затем вернуть другого держателя.

Я показал свой способ реализации этого в ответе здесь

Если у вас есть какие-либо вопросы, просто задайте Happy coding

0 голосов
/ 10 октября 2018

Я думаю, вам следует вызвать getItemViewType в onBindViewHolder, чтобы избежать проверки image == null и выполнить проверку внутри метода getItemViewType.

...