簡體   English   中英

如何在Android RecyclerView中顯示Firebase Firestore用戶?

[英]How to display Firebase Firestore users in Android RecyclerView?

我正在Cloud Firestore上工作。 我的Firestore數據庫文檔名稱為users ,我想在Android RecyclerView中顯示所有用戶,我的活動名稱為Alluser ,我正在使用此.XLM文件activity_alluser.xml

我對在FirebaseRecyclerAdapter內部傳遞參數感到困惑; 這是我的Java以及XML代碼。

public class Alluser extends AppCompatActivity
{
    private final static String TAG = Alluser.class.getSimpleName();
    private EditText mSearchField;
    private ImageButton mSearchBtn;
    private RecyclerView mUsersList;

    private FirebaseAuth mAuth;
    private FirebaseUser mCurrentUser;
    private DocumentReference mUser; 

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_alluser);

        mUsersList = (RecyclerView)findViewById(R.id.result_list);
        mSearchField = (EditText) findViewById(R.id.search_edittext);
        mUsersList.setHasFixedSize(true);
        mUsersList.setLayoutManager(new LinearLayoutManager(this));


        mAuth = FirebaseAuth.getInstance();
        //String current_user_id = mCurrentUser.getUid();
        String current_user_id = mAuth.getCurrentUser().getUid();
        mCurrentUser = FirebaseAuth.getInstance().getCurrentUser();


        mUser = FirebaseFirestore.getInstance().collection("users").document(current_user_id);

        mSearchBtn.setOnClickListener(new View.OnClickListener()
        {
            @Override
            public void onClick(View v)
            {
                firebaseUserSearch();
            }
        });
    }

    private void firebaseUserSearch()
    {
        FirebaseRecyclerAdapter<Users,UserviewHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Users, UserviewHolder>
                (Users.class,
                        R.layout.single_user_list_layout,
                        UserviewHolder.class,
                        //i am confused what to pass here)
        {
            @Override
            protected void onBindViewHolder(@NonNull UserviewHolder holder, int position, @NonNull Users model) {

            }

            @Override
            public UserviewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                return null;
            }
        };
        mUsersList.setAdapter(firebaseRecyclerAdapter);
    }

    public class UserviewHolder extends RecyclerView.ViewHolder
    {
        View mView;

        public UserviewHolder(View itemView)
        {
            super(itemView);
            mView = itemView;
        }
        public void setDetails(String username,String useremail,String userimage)
        {
            TextView user_name= (TextView)mView.findViewById(R.id.single_user_name);
            TextView user_email =(TextView)mView.findViewById(R.id.single_user_email);
            CircleImageView user_image = (CircleImageView)mView.findViewById(R.id.circleImageView);

            user_name.setText(username);
            user_email.setText(useremail);
        }
    }
}

XML代碼:

<android.support.constraint.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_margin="15dp"
        android:background="@drawable/fragment_background">


        <TextView
            android:id="@+id/textView3"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_alignParentStart="true"
            android:text="Search All User"
            android:paddingLeft="20sp"
            android:textColor="#000000"
            android:textSize="24sp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintHorizontal_bias="0.057"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.031" />

        <EditText
            android:id="@+id/search_edittext"
            android:layout_width="250dp"
            android:layout_height="50dp"
            android:background="@drawable/search_layout"
            android:ems="10"
            android:hint="Enter Email to Search..."
            android:inputType="textEmailAddress"
            android:paddingLeft="20dp"
            android:paddingRight="15dp"
            android:textColor="#999999"
            android:textSize="16sp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintHorizontal_bias="0.079"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.149" />

        <ImageButton
            android:id="@+id/search_button"
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:background="@drawable/search_icon"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintHorizontal_bias="0.98"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.149" />

        <android.support.v7.widget.RecyclerView
            android:layout_width="0dp"
            android:layout_height="0dp"
            android:id="@+id/result_list"
            android:layout_marginBottom="8dp"
            android:layout_marginEnd="7dp"
            android:layout_marginLeft="8dp"
            android:layout_marginRight="7dp"
            android:layout_marginStart="8dp"
            android:layout_marginTop="150dp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintHorizontal_bias="0.0"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintVertical_bias="0.625">

        </android.support.v7.widget.RecyclerView>

    </android.support.constraint.ConstraintLayout>

為了使FirebaseRecyclerAdapter正常工作,您需要將DatabaseReference作為最后一個參數傳遞,如官方文檔中所示

因此,您的代碼應如下所示:

FirebaseRecyclerAdapter<Users,UserviewHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Users, UserviewHolder>
            (Users.class,
             R.layout.single_user_list_layout,
             UserviewHolder.class,
             mUser)

Beeing一個抽象類,您還可以看一下FirebaseRecyclerAdapter類,以更清楚地了解應重寫的方法。

在談論Cloud Firestore ,我建議您使用FirestoreRecyclerAdapter而不是FirebaseRecyclerAdapter 要使用此適配器,您還需要一個FirestoreRecyclerOptions才能使其工作。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM