Mam RecycleView z adapterem, który pokazuje listę serwerów i użytkownik musi wybrać jeden serwer.notifyItemChanged() sprawiają, że RecyclerView przewijać i przejść do UP
gdy zgłoszę notifyItemChanged (previousPosition) wewnątrz metody onClick(), aby stary serwer odznaczone i nowy serwer wybrany, to zrobić listę RecycleView skokiem się dokładnie w środku listy.
i ten problem zdarzyć tylko po kliknięciu na jednym z ostatnich 2 lub 3 serwerów wewnątrz listy RecycleView
Oto kod mojego RecyclerView.Adapter:
public class ServerAdapter extends RecyclerView.Adapter<ServerAdapter.ServerViewHolder> {
private List<Server> listServers = new ArrayList<>();
private int[] icons = new int[]{R.drawable.server1,R.drawable.server2,R.drawable.server3,R.drawable.server4,R.drawable.server5,R.drawable.server6,R.drawable.offline};
private int selected = 0;
private int previousSelected = 0;
public ServerAdapter(List<Server> listServers){
this.listServers = listServers;
}
@Override
public ServerViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.server_relative_layout,parent,false);
return new ServerViewHolder(view);
}
@Override
public void onBindViewHolder(final ServerViewHolder holder, final int position) {
if(position == selected){
holder.getBackground().setSelected(true);
}else{
holder.getBackground().setSelected(false);
}
holder.getBackground().setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(position != selected){
previousSelected = selected;
selected = position;
holder.getBackground().setSelected(true);
notifyItemChanged(previousSelected);
}
}
});
holder.getImageServer().setImageResource(icons[position%6]);
holder.getTextNameServer().setText(listServers.get(position).getName());
holder.getTextConnected().setText(listServers.get(position).getUrl());
}
@Override
public int getItemCount() {
return listServers.size();
}
public class ServerViewHolder extends RecyclerView.ViewHolder{
private ImageView imageServer;
private TextView textNameServer;
private TextView textConnected;
private View background;
public ServerViewHolder(View itemView) {
super(itemView);
imageServer = (ImageView)itemView.findViewById(R.id.imageServer);
textNameServer = (TextView)itemView.findViewById(R.id.textNameServer);
textConnected = (TextView)itemView.findViewById(R.id.textConnected);
background = itemView;
}
public ImageView getImageServer() {
return imageServer;
}
public TextView getTextConnected() {
return textConnected;
}
public TextView getTextNameServer() {
return textNameServer;
}
public View getBackground() {
return background;
}
}
}
wszelkie rozwiązania do rozwiązania ten problem ? dzięki.
Problemem stało, kiedy dokładnie określić wysokość układu i nie pozwól, aby wrap_content
<android.support.v7.widget.RecyclerView
android:layout_width="wrap_content"
android:layout_height="400dp"
android:id="@+id/serverRecyclerView"
android:layout_margin="10dp"
/>
lub kiedy kładę go poniżej coś dla expample tak:
<android.support.v7.widget.RecyclerView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/serverRecyclerView"
android:layout_margin="10dp"
android:layout_below="@+id/image"/>
mój kod dokładnie jest:
<android.support.v7.widget.RecyclerView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/serverRecyclerView"
android:layout_margin="10dp"
android:layout_alignTop="@+id/imageBall"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:layout_toRightOf="@+id/camera"
android:layout_toEndOf="@+id/camera"/>
dlaczego notifyItemChanged (previousSelected); ??? –
ponieważ chcę, aby ten poprzedni widok został zaznaczony jako niezaznaczony, , jeśli nie wszystkie serwery będą pokazywane jako wybrane , ponieważ kiedy zadzwonię notifyItemChanged do tej starej pozycji zadzwoni onBindViewHolder i sprawdzi czy ta sytuacja jest taka sama jak numer przechowywane w liczbą całkowitą o jeśli (pozycja == wybrane) { holder.getBackground() setSelected (prawda.); } else { właściciel.getBackground(). SetSelected (false); } –
@OulhafianeZakariaa szybkie uwaga -> grawis wokół kodowych, nazw metoda poprawia czytelność (jak to '' -> 'this') –