Mam problem ze zmianą tła widoku w widoku listy.Zmień tło listy - dziwne zachowanie
Co potrzebne:
zmienić obraz tła wiersza onClick()
Co właściwie się dzieje:
Tło zostanie zmieniony (wybrane) po naciśnięciu na przykład pierwszy wpis. Ale po przewinięciu w dół zaznaczono także 8 pozycję. Przewiń do góry, pierwszy nie jest już wybrany. Drugi wpis jest teraz wybrany. dalej przewijanie i nadal skacze ...
co mam dong w Kodeksie:
mam kanały i onClick() przełączam atrybut kanału logiczną wybraną a potem zmienić tło. Robię tylko tylko onClick(), dlatego nie rozumiem, dlaczego dzieje się tak również w innych wpisach. Jedno zawiadomienia I to: Wydaje się, że tylko „rysunek” -part ponieważ rzecz, która się wybrany „przez niego samego siebie” ma nadal wybraną wartość na fałszywy
myślę, że wydaje się mieć coś zrobić z ponownym wykorzystaniem poglądów w niestandardowych ListAdapters getView (...)
Kodeks onClick() w ListActivity:
@Override
protected ViewHolder createHolder(View v) {
// createHolder will be called only as long, as the ListView is not
// filled
TextView title = (TextView) v
.findViewById(R.id.tv_title_channel_list_adapter);
TextView content = (TextView) v
.findViewById(R.id.tv_content_channel_list_adapter);
ImageView icon = (ImageView) v
.findViewById(R.id.icon_channel_list_adapter);
if (title == null || content == null || icon == null) {
Log.e("ERROR on findViewById",
"Couldn't find Title, Content or Icon");
}
ViewHolder mvh = new MyViewHolder(title, content, icon);
// We make the views become clickable
// so, it is not necessary to use the android:clickable attribute in
// XML
v.setOnClickListener(new ChannelListAdapter.OnClickListener(mvh) {
public void onClick(View v, ViewHolder viewHolder) {
// we toggle the enabled state and also switch the the
// background
MyViewHolder mvh = (MyViewHolder) viewHolder;
Channel ch = (Channel) mvh.data;
ch.setSelected(!ch.getSelected()); // toggle
if (ch.getSelected()) {
v.setBackgroundResource(R.drawable.row_blue_selected);
} else {
v.setBackgroundResource(R.drawable.row_blue);
}
// TESTING
Log.d("onClick() Channel", "onClick() Channel: "
+ ch.getTitle() + " selected: " + ch.getSelected());
}
});
return mvh;
}
Kodeksu z getView (...):
@Override
public View getView(int position, View view, ViewGroup parent) {
ViewHolder holder;
// When view is not null, we can reuse it directly, there is no need
// to reinflate it.
// We only inflate a new View when the view supplied by ListView is
// null.
if (view == null) {
view = mInflater.inflate(mViewId, null);
// call own implementation
holder = createHolder(view);
// TEST
// we set the holder as tag
view.setTag(holder);
} else {
// get holder back...much faster than inflate
holder = (ViewHolder) view.getTag();
}
// we must update the object's reference
holder.data = getItem(position);
// <EDIT SOLUTION>
if(getItem(position).get_id() == channelList.get(position).get_id()){
if(getItem(position).getSelected())
{
view.setBackgroundResource(R.drawable.row_blue_selected);
}
else{
view.setBackgroundResource(R.drawable.row_blue);
}
}
// </EDIT SOLUTION>
// call the own implementation
bindHolder(holder);
return view;
}
naprawdę doceni każdy pomysł jak rozwiązać ten problem! :)
Jeśli potrzebujesz więcej informacji, proszę mi powiedzieć.
Z góry dziękuję!
Czy mam rację, że być może jest to tylko dlatego, że brakowało mi tej części: if (pozycja == selectedListItem) { holder.backgrouundView.setBackgroundResource (R.drawable.and_gray_bg_listing_selected); } else { właściciel.backgrouundView.setBackgroundResource (R.drawable.and_gray_bg_listing); } ? Jestem w pracy, więc nie mogę tego wypróbować ... ale zrobię to tak szybko, jak będę w domu. Dziękuję bardzo długo :) – Beasly
Tak, wystarczy wykonać to sprawdzenie w metodzie getView. Reszta będzie automatycznie wykonywana – Javanator
Za pomocą tej metody możemy bardzo płynnie rysować listy i kontrolować kolejne zdarzenia. wprowadziłem nawet animowaną funkcję usuwania iPhone TableView .. czerwony przycisk usuwania i inne rzeczy – Javanator