我有一个带有包含几个EditText和图像视图的listview的活动。
当用户注册时,其存储在firebase中的数据(名称,电话,个人资料图片等)。
我希望位于列表视图行中的imageview显示每个用户的个人资料图像。
我有图像下载Uri,并且我使用picaso将配置文件图像设置为图像视图。
问题是:配置文件图像仅显示在listview的最后一行中。
这是我将配置文件图像设置为ImageView的方式:
public void getProfileImage() {
mDatabase.child("Users").addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for (DataSnapshot ds : dataSnapshot.getChildren()) {
User user = ds.getValue(User.class);
if (!user.getUserImage().equals("default"))
Picasso.with(getContext()).load(user.getUserImage()).into(profileImage);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
希望有人能找出问题所在。
谢谢。
编辑:
这是列表视图适配器:
public class mainScreenAdapter extends ArrayAdapter<TrempData> {
private TextView name ,timestamp ,uid, from,to,date,time,myextra ;
private ImageButton phoneBtn;
private ImageView timeline, profileImage;
private int layoutResource;
private FirebaseAuth firebaseAuth;
private DatabaseReference mDatabase;
public mainScreenAdapter(Context context, int layoutResource, ArrayList<TrempData> list) {
super(context, layoutResource, list);
this.layoutResource = layoutResource;
firebaseAuth = FirebaseAuth.getInstance();
mDatabase = FirebaseDatabase.getInstance().getReference();
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
final LayoutInflater Inflater = LayoutInflater.from(getContext());
view = Inflater.inflate(layoutResource, null);
}
final TrempData data = getItem(position);
//data.setPos(position);
//int[] androidColors = getContext().getResources().getIntArray(R.array.androidcolors);
//int randomAndroidColor = androidColors[new Random().nextInt(androidColors.length)];
if (data != null) {
name = (TextView) view.findViewById(R.id.myname);
phoneBtn = (ImageButton) view.findViewById(R.id.myphone);
//myphonestr = (TextView)view.findViewById(R.id.myphonestr);
timestamp = (TextView) view.findViewById(R.id.mytimestamp);
uid = (TextView) view.findViewById(R.id.myuid);
timeline = (ImageView)view.findViewById(R.id.timeline);
profileImage = (ImageView)view.findViewById(R.id.mycar);
date = (TextView) view.findViewById(R.id.mydate);
time = (TextView) view.findViewById(R.id.mytime);
from = (TextView) view.findViewById(R.id.myfrom);
to = (TextView) view.findViewById(R.id.myto);
myextra = (TextView) view.findViewById(R.id.myextra);
name.setText(data.get_name());
//name.setTextColor(randomAndroidColor);
//myphonestr.setText(data.get_phone());
timestamp.setText(data.get_timestamp());
uid.setText(data.get_uid());
date.setText(data.get_date());
time.setText(data.get_time());
to.setText(data.get_to());
from.setText(data.get_from());
uid.setText(data.get_uid());
myextra.setText(data.get_extras());
phoneBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent i = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + data.get_phone()));
getContext().startActivity(i);
}
});
if(firebaseAuth.getCurrentUser().getUid().equals(uid.getText())){
phoneBtn.setVisibility(View.GONE);
//car.setColorFilter(Color.rgb(255,164,30));
}
else{
phoneBtn.setVisibility(View.VISIBLE);
//car.setColorFilter(Color.rgb(176,176,176));
}
}
getProfileImage();
return view;
}
public void getProfileImage() {
mDatabase.child("Users").addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for (DataSnapshot ds : dataSnapshot.getChildren()) {
User user = ds.getValue(User.class);
if (!user.getUserImage().equals("default"))
Picasso.with(getContext()).load(user.getUserImage()).into(profileImage);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
}
}
更新:
我做了@Danilo de Oliveira建议我做的事情,它可以工作,但是现在我遇到了新问题。尽管在firebase中每个用户的下载图像Uri不同,但每一行的个人资料图像都相同
最佳答案
问题是您每次运行getView()时都要调用getProfileImage()。这是实际发生的情况:
对于第1行:
遍历所有dataSnapshot.getChildren()
将图像加载到profileImage
对于第2行:
遍历所有dataSnapshot.getChildren()
将图像加载到profileImage
对于第3行:
遍历所有dataSnapshot.getChildren()
将图像加载到profileImage
...
因此,您总是将N张照片加载到profileImage中,最后每行显示最后一张图像。
这应该是流程:
1. Load all your data from firebase.
2. Store them in an ArrayList<User> mUsers
3. listView.setAdapter(yourAdapter)
4. In getView()
4a. Get your user by mUsers.get(position)
4b. Get your imageview by view.findViewById(...)
4c. Load your image here.
这应该工作。
另外,我认为您应该检查列表视图和列表适配器的工作方式。