#android
#Android
Вопрос:
Я пытаюсь передать данные из моего адаптера recycler в действие. В настоящее время я пытаюсь использовать намерение более подробная информация приведена ниже
Адаптер
public class BlogRecyclerAdapter extends RecyclerView.Adapter<BlogRecyclerAdapter.ViewHolder> {
public List<BlogPost> blog_list;
private FirebaseFirestore firebaseFirestore;
private FirebaseDatabase firebaseDatabase;
private DatabaseReference mUserDatabase;
private FirebaseUser mCurrentUser;
private Context mContext;
public BlogRecyclerAdapter(Context context, List<BlogPost> blog_list) {
mContext = context;
this.blog_list = blog_list;
}
@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.blog_list_item, parent, false);
firebaseFirestore = FirebaseFirestore.getInstance();
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull final ViewHolder holder, int position) {
String desc_data = blog_list.get(position).getDesc();
holder.setDescText(desc_data);
String user_name = blog_list.get(position).getUser_id();
holder.setBlogUserName(user_name);
String image_url = blog_list.get(position).getImage_url();
holder.setBlogImage(image_url);
final String message_doc = blog_list.get(position).getMessage_doc();
/*
long millisecond = blog_list.get(position).getTimestamp().getTime();
String dateString = DateFormat.format("MM/dd/yyyy", new Date(millisecond)).toString();
holder.setTime(dateString);
*/
// String user_data = blog_list.get(position).getUser_id();
// holder.setUserData(user_data);
holder.parentLayout.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int pos = holder.getAdapterPosition();
//THIS IS WHAT NEEDS TO GET PASSED
String id = blog_list.get(pos).getPost_id();
/*
//IMPORTANT
Intent messageDocIntent = new Intent(mContext, BlogRecyclerAdapter.class);
messageDocIntent.putExtra("EXTRA_SESSION_ID", message_doc);
mContext.startActivity(messageDocIntent);
*/
Toast.makeText(mContext, message_doc, Toast.LENGTH_LONG).show();
// Toast.makeText(mContext, "test " id, Toast.LENGTH_LONG).show();
Intent intent = new Intent(mContext, Confirmation_Activity.class);
mContext.startActivity(intent);
}
});
}
@Override
public int getItemCount() {
return blog_list.size();
}
public class ViewHolder extends RecyclerView.ViewHolder {
public Context mContext;
ConstraintLayout parentLayout;
private View mView;
private TextView descView;
private ImageView blogPostView;
private TextView blogDate;
private TextView blogUserName;
private CircleImageView blogUserImage;
private StorageReference mImageStorage;
private TextView userName;
@SuppressLint("ResourceType")
public ViewHolder(View itemView) {
super(itemView);
mView = itemView;
parentLayout = itemView.findViewById(R.id.Main_Blog_Post);
}
public void setDescText(String descText) {
descView = mView.findViewById(R.id.blog_desc);
descView.setText(descText);
}
public void setUserData(String downloadUrl, String name) {
mImageStorage = FirebaseStorage.getInstance().getReference();
mCurrentUser = FirebaseAuth.getInstance().getCurrentUser();
final String current_uid = mCurrentUser.getUid();
mUserDatabase = FirebaseDatabase.getInstance().getReference().child("Users").child(current_uid);
mUserDatabase.keepSynced(true);
mUserDatabase.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
String name = Objects.requireNonNull(dataSnapshot.child("name").getValue()).toString();
StorageReference filepath = mImageStorage.child("profile_images").child(current_uid (".jpeg"));
Log.d("heere", "S");
// This gets the download url async
filepath.getDownloadUrl().addOnSuccessListener(new OnSuccessListener<Uri>() {
@Override
public void onSuccess(Uri uri) {
//The download url
final String downloadUrl =
uri.toString();
Log.d("tag", downloadUrl);
if (!downloadUrl.equals("default")) {
// Glide.with(getApplicationContext()).load(downloadUrl).into(mDisplayImage);
Glide.with(itemView.getContext()).load(downloadUrl).into(blogUserImage);
}
}
}).addOnFailureListener(new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
// Toast.makeText(getApplicationContext(), "Something went wrong", Toast.LENGTH_SHORT).show();
}
});
//Toast.makeText(getApplicationContext(), image, Toast.LENGTH_SHORT).show();
Log.d("value", dataSnapshot.getValue().toString());
Log.d("key", dataSnapshot.getKey());
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
public void setTime(String date) {
blogDate = mView.findViewById(R.id.blog_date);
blogDate.setText(date);
}
public void setBlogImage(final String downloadUri) {
blogPostView = mView.findViewById(R.id.blog_image);
Glide.with(itemView.getContext()).load(downloadUri).into(blogPostView);
}
public void setBlogUserName(String userName) {
blogUserName = mView.findViewById(R.id.blog_user_name);
blogUserName.setText(userName);
}
}
}
Если бы вы могли указать мне правильное направление, как действовать дальше, я был бы признателен
Текущая проблема
Адаптер
@Override
public void onBindViewHolder(@NonNull final ViewHolder holder, int position) {
String desc_data = blog_list.get(position).getDesc();
holder.setDescText(desc_data);
String user_name = blog_list.get(position).getUser_id();
holder.setBlogUserName(user_name);
String image_url = blog_list.get(position).getImage_url();
holder.setBlogImage(image_url);
final String message_doc = blog_list.get(position).getMessage_doc();
holder.parentLayout.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
int pos = holder.getAdapterPosition();
Toast.makeText(mContext, message_doc, Toast.LENGTH_LONG).show();
Intent intent = new Intent(mContext, Confirmation_Activity.class);
intent.putExtra("Message_ID", blog_list.get(pos).getMessage_doc());
mContext.startActivity(intent);
}
});
}
Активность, получающая его
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.chat_activity);
mFirebaseDatabase = FirebaseDatabase.getInstance();
mMessagedatabaseReference =
mFirebaseDatabase.getReference().child(messageID());
....
public String messageID(){
String id = getIntent().getStringExtra("Message_ID");
return id;
}
Если я отлаживаю приложение в адаптере, activity Message_Id равно значению из firebase, но когда я запускаю новое действие, приложение вылетает с
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.android.debateapp/com.example.android.debateapp.ChatActivity}: java.lang.NullPointerException: Can't pass null for argument 'pathString' in child()
с ошибкой, указывающей на mMessagedatabaseReference
Комментарии:
1. зачем нужен интерфейс или широковещательная передача для отправки данных на адаптер, у вас есть конструктор в адаптере
Ответ №1:
в соответствии с вашим кодом, на который вы хотите отправить идентификатор Confirmation_Activity.class затем вы можете отправить один пакет с вашим намерением следующим образом:-
из вашего адаптера :-
Intent intent = new Intent(mContext, Confirmation_Activity.class);
intent.putExtra("id", blog_list.get(position).getPost_id())
mContext.startActivity(intent);
в вашем Confirmation_Activity.class:-
String id = getIntent().getStringExtras("id");
Комментарии:
1. оцените ответ, если он вам поможет
2. привет, спасибо за ответ, я реализовал его так, как вы объяснили выше, но у меня возникли проблемы проверьте новый код выше
Ответ №2:
Оказывается, я пытался передать идентификатор firestore в режиме реального времени