Reputation: 2905
I have a custom adapter that displays the messages in conversation. Now I want to bold the textview if the message is not read and otherwise unbold it. However when I scroll the listview of that adapter, the TextViews do not keep the previous setup, they lose the bolded text or bold the read text. I have tried many solutions on SO, however nothing has worked so far.
I have put all the variables into a holder class:
private class Holder {
public TextView messageTo, messageContent, date;
public ImageView imgView;
public Typeface face, bold;
public int boldText, normalText;
public int readState;
}
and in getView I get the message item at the position and retrieve the readState from there (some redundant parts have been omitted)
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View convertView1 = convertView;
LayoutInflater vi = (LayoutInflater) ctx
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
Message message = getItem(position);
if (convertView1 == null) {
holder = new Holder();
convertView1 = vi.inflate(R.layout.list_view_main, parent,
false);
holder.messageTo = (TextView) convertView1
.findViewById(R.id.address);
holder.messageContent = (TextView) convertView1
.findViewById(R.id.previewMsg);
holder.date = (TextView) convertView1.findViewById(R.id.showDate);
holder.imgView = (ImageView) convertView1
.findViewById(R.id.quickBadge);
holder.face = Typeface.createFromAsset(ctx.getAssets(),
"fonts/helveticaneuelight.ttf");
holder.bold = Typeface.createFromAsset(ctx.getAssets(),
"fonts/helveticaneue.ttf");
holder.boldText = Typeface.BOLD;
holder.normalText = Typeface.NORMAL;
holder.readState = getItem(position).readState;
convertView1.setTag(holder);
} else {
holder = (Holder) convertView1.getTag();
}
if(holder.readState==0) {
holder.messageTo.setText(message.messageNumber);
holder.messageContent.setText(message.messageContent);
holder.date.setText(message.messageDate);
holder.messageTo.setTypeface(holder.bold, holder.boldText);
holder.messageContent.setTypeface(holder.face, holder.boldText);
holder.date.setTypeface(holder.face, holder.boldText);
} else {
holder.messageTo.setText(message.messageNumber);
holder.messageContent.setText(message.messageContent);
holder.date.setText(message.messageDate);
holder.messageTo.setTypeface(holder.bold, holder.normalText);
holder.messageContent.setTypeface(holder.face, holder.normalText);
holder.date.setTypeface(holder.face, holder.normalText);
}
return convertView1;
}
But it does not work. Anyone has a solution for this?
Upvotes: 1
Views: 233
Reputation: 12733
you can follow Raghunandan's answer but below answer also helps you:
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View convertView1 = convertView;
LayoutInflater vi = (LayoutInflater) ctx
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
Message message = getItem(position);
final Holder holder;
if (convertView1 == null) {
holder = new Holder();
convertView1 = vi.inflate(R.layout.list_view_main, parent,
false);
holder.messageTo = (TextView) convertView1
.findViewById(R.id.address);
holder.messageContent = (TextView) convertView1
.findViewById(R.id.previewMsg);
holder.date = (TextView) convertView1.findViewById(R.id.showDate);
holder.imgView = (ImageView) convertView1
.findViewById(R.id.quickBadge);
holder.face = Typeface.createFromAsset(ctx.getAssets(),
"fonts/helveticaneuelight.ttf");
holder.bold = Typeface.createFromAsset(ctx.getAssets(),
"fonts/helveticaneue.ttf");
holder.boldText = Typeface.BOLD;
holder.normalText = Typeface.NORMAL;
holder.readState = getItem(position).readState;
convertView1.setTag(holder);
} else {
holder = (Holder) convertView1.getTag();
}
if(holder.readState==0) {
holder.messageTo.setText(message.messageNumber);
holder.messageContent.setText(message.messageContent);
holder.date.setText(message.messageDate);
holder.messageTo.setTypeface(holder.bold, holder.boldText);
holder.messageContent.setTypeface(holder.face, holder.boldText);
holder.date.setTypeface(holder.face, holder.boldText);
} else {
holder.messageTo.setText(message.messageNumber);
holder.messageContent.setText(message.messageContent);
holder.date.setText(message.messageDate);
holder.messageTo.setTypeface(holder.bold, holder.normalText);
holder.messageContent.setTypeface(holder.face, holder.normalText);
holder.date.setTypeface(holder.face, holder.normalText);
}
return convertView1;
}
just create holder object inside getview()
method.
Upvotes: 1
Reputation: 133560
Try this
if(message.readState==0) {
// keep your other part of the code as it is
// set font
} else {
// keep your other code as it is
// set font
}
You can get rid of
holder.readState = getItem(position).readState;
To understand how it works
How ListView's recycling mechanism works
Upvotes: 1