project_files/Android-build/SDL-android-project/src/org/hedgewars/hedgeroid/netplay/RoomListAdapter.java
changeset 7342 0e29eec2df5c
child 7349 12fdfd2038d4
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project_files/Android-build/SDL-android-project/src/org/hedgewars/hedgeroid/netplay/RoomListAdapter.java	Thu Jul 19 18:58:18 2012 +0200
@@ -0,0 +1,101 @@
+package org.hedgewars.hedgeroid.netplay;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+
+import org.hedgewars.hedgeroid.R;
+import org.hedgewars.hedgeroid.netplay.RoomList.Observer;
+
+import android.content.Context;
+import android.content.res.Resources;
+import android.text.Layout.Alignment;
+import android.text.SpannableStringBuilder;
+import android.text.Spanned;
+import android.text.style.AlignmentSpan;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.BaseAdapter;
+import android.widget.TextView;
+
+public class RoomListAdapter extends BaseAdapter implements Observer {
+	private List<Room> rooms = new ArrayList<Room>();
+	private Context context;
+	
+	public RoomListAdapter(Context context) {
+		this.context = context;
+	}
+	
+	public int getCount() {
+		return rooms.size();
+	}
+
+	public Object getItem(int position) {
+		return rooms.get(position);
+	}
+
+	public long getItemId(int position) {
+		return rooms.get(position).id;
+	}
+
+	public boolean hasStableIds() {
+		return true;
+	}
+
+	public void setList(Collection<Room> rooms) {
+		this.rooms = new ArrayList<Room>(rooms);
+		Collections.reverse(this.rooms); // We want to show the newest rooms first
+		notifyDataSetChanged();
+	}
+	
+	private static Spanned formatExtra(Resources res, Room room) {
+		String ownermsg = res.getString(R.string.roomlist_owner, room.owner);
+		String mapmsg = res.getString(R.string.roomlist_map, Room.formatMapName(res, room.map));
+		String schememsg = res.getString(R.string.roomlist_scheme, room.scheme);
+		String weaponsmsg = res.getString(R.string.roomlist_weapons,  room.weapons);
+		SpannableStringBuilder ssb = new SpannableStringBuilder();
+		ssb.append(ownermsg).append(" ").append(mapmsg).append("\n").append(schememsg).append(" ").append(weaponsmsg);
+		
+		int weaponOffset = ownermsg.length()+1+mapmsg.length()+1+schememsg.length()+1;
+		ssb.setSpan(new AlignmentSpan.Standard(Alignment.ALIGN_OPPOSITE), ownermsg.length(), ownermsg.length()+mapmsg.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
+		ssb.setSpan(new AlignmentSpan.Standard(Alignment.ALIGN_OPPOSITE), weaponOffset, weaponOffset+weaponsmsg.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
+		return ssb;
+	}
+	
+	public View getView(int position, View convertView, ViewGroup parent) {
+		View v = convertView;
+		TextView tv1;
+		if (v == null) {
+			LayoutInflater vi = LayoutInflater.from(context);
+			v = vi.inflate(android.R.layout.simple_list_item_2, null);
+			tv1 = (TextView)v.findViewById(android.R.id.text1);
+			tv1.setCompoundDrawablePadding(5);
+		} else {
+			tv1 = (TextView)v.findViewById(android.R.id.text1);
+		}
+		
+		Room room = rooms.get(position);
+		int iconRes = room.inProgress ? R.drawable.roomlist_ingame : R.drawable.roomlist_preparing;
+		TextView tv2 = (TextView)v.findViewById(android.R.id.text2);
+		tv1.setCompoundDrawablesWithIntrinsicBounds(iconRes, 0, 0, 0);
+		tv1.setText(room.name);
+		tv2.setText(formatExtra(context.getResources(), room));
+		return v;
+	}
+
+	public void itemAdded(Map<String, Room> map, String key, Room value) {
+		setList(map.values());
+	}
+
+	public void itemRemoved(Map<String, Room> map, String key, Room oldValue) {
+		setList(map.values());
+	}
+
+	public void itemReplaced(Map<String, Room> map, String key, Room oldValue,
+			Room newValue) {
+		setList(map.values());
+	}
+}
\ No newline at end of file