Show player and spawn details in the replay browser.

This commit is contained in:
Paul Chote
2014-03-23 11:57:50 +13:00
parent 272e872357
commit 55ad12d9a3
5 changed files with 213 additions and 107 deletions

View File

@@ -31,7 +31,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
var preview = available.Get<MapPreviewWidget>("MAP_PREVIEW"); var preview = available.Get<MapPreviewWidget>("MAP_PREVIEW");
preview.Preview = () => lobby.Map; preview.Preview = () => lobby.Map;
preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi); preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi);
preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager, lobby.Map); preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager.LobbyInfo, lobby.Map);
var title = available.GetOrNull<LabelWidget>("MAP_TITLE"); var title = available.GetOrNull<LabelWidget>("MAP_TITLE");
if (title != null) if (title != null)
@@ -54,7 +54,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
var preview = download.Get<MapPreviewWidget>("MAP_PREVIEW"); var preview = download.Get<MapPreviewWidget>("MAP_PREVIEW");
preview.Preview = () => lobby.Map; preview.Preview = () => lobby.Map;
preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi); preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi);
preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager, lobby.Map); preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager.LobbyInfo, lobby.Map);
var title = download.GetOrNull<LabelWidget>("MAP_TITLE"); var title = download.GetOrNull<LabelWidget>("MAP_TITLE");
if (title != null) if (title != null)
@@ -81,7 +81,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
var preview = progress.Get<MapPreviewWidget>("MAP_PREVIEW"); var preview = progress.Get<MapPreviewWidget>("MAP_PREVIEW");
preview.Preview = () => lobby.Map; preview.Preview = () => lobby.Map;
preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi); preview.OnMouseDown = mi => LobbyUtils.SelectSpawnPoint(orderManager, preview, lobby.Map, mi);
preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager, lobby.Map); preview.SpawnClients = () => LobbyUtils.GetSpawnClients(orderManager.LobbyInfo, lobby.Map);
var title = progress.GetOrNull<LabelWidget>("MAP_TITLE"); var title = progress.GetOrNull<LabelWidget>("MAP_TITLE");
if (title != null) if (title != null)

View File

@@ -130,10 +130,10 @@ namespace OpenRA.Mods.RA.Widgets.Logic
color.AttachPanel(colorChooser, onExit); color.AttachPanel(colorChooser, onExit);
} }
public static Dictionary<CPos, Session.Client> GetSpawnClients(OrderManager orderManager, MapPreview preview) public static Dictionary<CPos, Session.Client> GetSpawnClients(Session lobbyInfo, MapPreview preview)
{ {
var spawns = preview.SpawnPoints; var spawns = preview.SpawnPoints;
return orderManager.LobbyInfo.Clients return lobbyInfo.Clients
.Where(c => c.SpawnPoint != 0) .Where(c => c.SpawnPoint != 0)
.ToDictionary(c => spawns[c.SpawnPoint - 1], c => c); .ToDictionary(c => spawns[c.SpawnPoint - 1], c => c);
} }

View File

@@ -9,6 +9,8 @@
#endregion #endregion
using System; using System;
using System.Collections.Generic;
using System.Drawing;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using OpenRA.Network; using OpenRA.Network;
@@ -19,10 +21,13 @@ namespace OpenRA.Mods.RA.Widgets.Logic
public class ReplayBrowserLogic public class ReplayBrowserLogic
{ {
Widget panel; Widget panel;
ScrollPanelWidget playerList;
ScrollItemWidget playerTemplate, playerHeader;
MapPreview selectedMap = MapCache.UnknownMap; MapPreview selectedMap = MapCache.UnknownMap;
Dictionary<CPos, Session.Client> selectedSpawns;
string selectedFilename; string selectedFilename;
string selectedDuration; string selectedDuration;
string selectedPlayers;
bool selectedValid; bool selectedValid;
[ObjectCreator.UseCtor] [ObjectCreator.UseCtor]
@@ -30,6 +35,11 @@ namespace OpenRA.Mods.RA.Widgets.Logic
{ {
panel = widget; panel = widget;
playerList = panel.Get<ScrollPanelWidget>("PLAYER_LIST");
playerHeader = playerList.Get<ScrollItemWidget>("HEADER");
playerTemplate = playerList.Get<ScrollItemWidget>("TEMPLATE");
playerList.RemoveChildren();
panel.Get<ButtonWidget>("CANCEL_BUTTON").OnClick = () => { Ui.CloseWindow(); onExit(); }; panel.Get<ButtonWidget>("CANCEL_BUTTON").OnClick = () => { Ui.CloseWindow(); onExit(); };
var rl = panel.Get<ScrollPanelWidget>("REPLAY_LIST"); var rl = panel.Get<ScrollPanelWidget>("REPLAY_LIST");
@@ -52,11 +62,21 @@ namespace OpenRA.Mods.RA.Widgets.Logic
watch.IsDisabled = () => !selectedValid || selectedMap.Status != MapStatus.Available; watch.IsDisabled = () => !selectedValid || selectedMap.Status != MapStatus.Available;
watch.OnClick = () => { WatchReplay(); onStart(); }; watch.OnClick = () => { WatchReplay(); onStart(); };
panel.Get("REPLAY_INFO").IsVisible = () => selectedFilename != null;; panel.Get("REPLAY_INFO").IsVisible = () => selectedFilename != null;
var preview = panel.Get<MapPreviewWidget>("MAP_PREVIEW");
preview.SpawnClients = () => selectedSpawns;
preview.Preview = () => selectedMap;
var title = panel.GetOrNull<LabelWidget>("MAP_TITLE");
if (title != null)
title.GetText = () => selectedMap.Title;
var type = panel.GetOrNull<LabelWidget>("MAP_TYPE");
if (type != null)
type.GetText = () => selectedMap.Type;
panel.Get<LabelWidget>("DURATION").GetText = () => selectedDuration; panel.Get<LabelWidget>("DURATION").GetText = () => selectedDuration;
panel.Get<MapPreviewWidget>("MAP_PREVIEW").Preview = () => selectedMap;
panel.Get<LabelWidget>("MAP_TITLE").GetText = () => selectedMap.Title;
panel.Get<LabelWidget>("PLAYERS").GetText = () => selectedPlayers;
} }
void SelectReplay(string filename) void SelectReplay(string filename)
@@ -70,11 +90,53 @@ namespace OpenRA.Mods.RA.Widgets.Logic
{ {
selectedFilename = filename; selectedFilename = filename;
selectedMap = Game.modData.MapCache[conn.LobbyInfo.GlobalSettings.Map]; selectedMap = Game.modData.MapCache[conn.LobbyInfo.GlobalSettings.Map];
selectedSpawns = LobbyUtils.GetSpawnClients(conn.LobbyInfo, selectedMap);
selectedDuration = WidgetUtils.FormatTime(conn.TickCount * Game.NetTickScale); selectedDuration = WidgetUtils.FormatTime(conn.TickCount * Game.NetTickScale);
selectedPlayers = conn.LobbyInfo.Slots
.Count(s => conn.LobbyInfo.ClientInSlot(s.Key) != null)
.ToString();
selectedValid = conn.TickCount > 0; selectedValid = conn.TickCount > 0;
var clients = conn.LobbyInfo.Clients.Where(c => c.Slot != null)
.GroupBy(c => c.Team)
.OrderBy(g => g.Key);
var teams = new Dictionary<string, IEnumerable<Session.Client>>();
var noTeams = clients.Count() == 1;
foreach (var c in clients)
{
var label = noTeams ? "Players" : c.Key == 0 ? "No Team" : "Team {0}".F(c.Key);
teams.Add(label, c);
}
playerList.RemoveChildren();
foreach (var kv in teams)
{
var group = kv.Key;
if (group.Length > 0)
{
var header = ScrollItemWidget.Setup(playerHeader, () => true, () => {});
header.Get<LabelWidget>("LABEL").GetText = () => group;
playerList.AddChild(header);
}
foreach (var option in kv.Value)
{
var o = option;
var color = o.Color.RGB;
var item = ScrollItemWidget.Setup(playerTemplate, () => false, () => { });
var label = item.Get<LabelWidget>("LABEL");
label.GetText = () => o.Name;
label.GetColor = () => color;
var flag = item.Get<ImageWidget>("FLAG");
flag.GetImageCollection = () => "flags";
flag.GetImageName = () => o.Country;
playerList.AddChild(item);
}
}
} }
} }
catch (Exception e) catch (Exception e)

View File

@@ -1,9 +1,9 @@
Container@REPLAYBROWSER_PANEL: Container@REPLAYBROWSER_PANEL:
Logic:ReplayBrowserLogic Logic:ReplayBrowserLogic
X:(WINDOW_RIGHT - WIDTH)/2 X:(WINDOW_RIGHT - WIDTH)/2
Y:(WINDOW_BOTTOM - 300)/2 Y:(WINDOW_BOTTOM - 500)/2
Width:520 Width:520
Height:335 Height:535
Children: Children:
Label@TITLE: Label@TITLE:
Width:520 Width:520
@@ -14,14 +14,14 @@ Container@REPLAYBROWSER_PANEL:
Text:Replay Viewer Text:Replay Viewer
Background@bg: Background@bg:
Width:520 Width:520
Height:300 Height:500
Background:panel-black Background:panel-black
Children: Children:
ScrollPanel@REPLAY_LIST: ScrollPanel@REPLAY_LIST:
X:15 X:15
Y:15 Y:15
Width:286 Width:282
Height:270 Height:PARENT_BOTTOM-30
Children: Children:
ScrollItem@REPLAY_TEMPLATE: ScrollItem@REPLAY_TEMPLATE:
Width:PARENT_RIGHT-27 Width:PARENT_RIGHT-27
@@ -46,58 +46,81 @@ Container@REPLAYBROWSER_PANEL:
Y:1 Y:1
Width:192 Width:192
Height:192 Height:192
TooltipContainer:TOOLTIP_CONTAINER
Container@REPLAY_INFO: Container@REPLAY_INFO:
X:PARENT_RIGHT-WIDTH-15 X:PARENT_RIGHT-WIDTH-15
Y:219 Y:15
Width:194 Width:194
Height:56 Height:PARENT_BOTTOM - 15
Visible:false
Children: Children:
Label@MAP_TITLE_LABEL:
Align:Right
Width:70
Height:20
Text:Map:
Font:Bold
Label@MAP_TITLE: Label@MAP_TITLE:
X:75 Y:197
Width:70 Width:PARENT_RIGHT
Height:20 Height:25
Label@DURATION_LABEL:
Y:20
Align:Right
Width:70
Height:20
Text:Duration:
Font:Bold Font:Bold
Align:Center
Label@MAP_TYPE:
Y:212
Width:PARENT_RIGHT
Height:25
Font:TinyBold
Align:Center
Label@DURATION: Label@DURATION:
X:75 Y:225
Y:20 Width:PARENT_RIGHT
Width:70 Height:25
Height:20 Font:Tiny
Label@PLAYERS_LABEL: Align:Center
Y:40 ScrollPanel@PLAYER_LIST:
Align:Right Y:250
Width:70 Width:PARENT_RIGHT
Height:20 Height:PARENT_BOTTOM - 250 - 15
Text:Players: IgnoreChildMouseOver:true
Font:Bold Children:
Label@PLAYERS: ScrollItem@HEADER:
X:75 Width:PARENT_RIGHT-27
Y:40 Height:13
Width:70 X:2
Height:20 Y:0
Visible:false
Children:
Label@LABEL:
Font:TinyBold
Width:PARENT_RIGHT
Height:10
Align:Center
ScrollItem@TEMPLATE:
Width:PARENT_RIGHT-27
Height:25
X:2
Y:0
Visible:false
Children:
Image@FLAG:
X:4
Y:4
Width:32
Height:16
Label@LABEL:
X:40
Width:60
Height:25
Label@NOFLAG_LABEL:
X:5
Width:PARENT_RIGHT
Height:25
Button@CANCEL_BUTTON: Button@CANCEL_BUTTON:
Key:escape Key:escape
X:0 X:0
Y:299 Y:499
Width:140 Width:140
Height:35 Height:35
Text:Back Text:Back
Button@WATCH_BUTTON: Button@WATCH_BUTTON:
Key:return Key:return
X:380 X:380
Y:299 Y:499
Width:140 Width:140
Height:35 Height:35
Text:Watch Text:Watch
TooltipContainer@TOOLTIP_CONTAINER:

View File

@@ -2,11 +2,10 @@ Background@REPLAYBROWSER_PANEL:
Logic:ReplayBrowserLogic Logic:ReplayBrowserLogic
X:(WINDOW_RIGHT - WIDTH)/2 X:(WINDOW_RIGHT - WIDTH)/2
Y:(WINDOW_BOTTOM - HEIGHT)/2 Y:(WINDOW_BOTTOM - HEIGHT)/2
Width:700 Width:530
Height:410 Height:535
Children: Children:
Label@REPLAYBROWSER_LABEL_TITLE: Label@REPLAYBROWSER_LABEL_TITLE:
X:0
Y:20 Y:20
Width:PARENT_RIGHT Width:PARENT_RIGHT
Height:25 Height:25
@@ -16,74 +15,95 @@ Background@REPLAYBROWSER_PANEL:
ScrollPanel@REPLAY_LIST: ScrollPanel@REPLAY_LIST:
X:20 X:20
Y:50 Y:50
Width:390 Width:282
Height:300 Height:430
Children: Children:
ScrollItem@REPLAY_TEMPLATE: ScrollItem@REPLAY_TEMPLATE:
Width:PARENT_RIGHT-27 Width:PARENT_RIGHT-27
Height:25 Height:25
X:2 X:2
Y:0
Visible:false Visible:false
Children: Children:
Label@TITLE: Label@TITLE:
X:10 X:10
Width:PARENT_RIGHT-20 Width:PARENT_RIGHT-20
Height:25 Height:25
Container@REPLAY_INFO: Background@MAP_BG:
X:0 X:PARENT_RIGHT-WIDTH-20
Y:0 Y:50
Width:PARENT_RIGHT Width:194
Height:PARENT_BOTTOM Height:194
Visible:false Background:dialog3
Children: Children:
MapPreview@MAP_PREVIEW: MapPreview@MAP_PREVIEW:
X:PARENT_RIGHT-241 X:1
Y:30 Y:1
Width:192 Width:192
Height:192 Height:192
Label@MAP_TITLE_LABEL: TooltipContainer:TOOLTIP_CONTAINER
X:PARENT_RIGHT - 200 - WIDTH Container@REPLAY_INFO:
Y:250 X:PARENT_RIGHT-WIDTH - 20
Align:Right Y:50
Width:70 Width:194
Height:20 Height:PARENT_BOTTOM - 15
Text:Map: Children:
Font:Bold
Label@MAP_TITLE: Label@MAP_TITLE:
X:PARENT_RIGHT - 195 Y:197
Y:250 Width:PARENT_RIGHT
Align:Left Height:25
Width:70
Height:20
Label@DURATION_LABEL:
X:PARENT_RIGHT - 200 - WIDTH
Y:270
Align:Right
Width:70
Height:20
Text:Duration:
Font:Bold Font:Bold
Align:Center
Label@MAP_TYPE:
Y:212
Width:PARENT_RIGHT
Height:25
Font:TinyBold
Align:Center
Label@DURATION: Label@DURATION:
X:PARENT_RIGHT - 195 Y:225
Y:270 Width:PARENT_RIGHT
Align:Left Height:25
Width:70 Font:Tiny
Height:20 Align:Center
Label@PLAYERS_LABEL: ScrollPanel@PLAYER_LIST:
X:PARENT_RIGHT - 200 - WIDTH Y:250
Y:290 Width:PARENT_RIGHT
Align:Right Height:PARENT_BOTTOM - 340
Width:70 IgnoreChildMouseOver:true
Height:20 Children:
Text:Players: ScrollItem@HEADER:
Font:Bold BaseName:scrollheader
Label@PLAYERS: Width:PARENT_RIGHT-27
X:PARENT_RIGHT - 195 Height:13
Y:290 X:2
Align:Left Y:0
Width:70 Visible:false
Height:20 Children:
Label@LABEL:
Font:TinyBold
Width:PARENT_RIGHT
Height:10
Align:Center
ScrollItem@TEMPLATE:
Width:PARENT_RIGHT-27
Height:25
X:2
Y:0
Visible:false
Children:
Image@FLAG:
X:4
Y:4
Width:32
Height:16
Label@LABEL:
X:40
Width:60
Height:25
Label@NOFLAG_LABEL:
X:5
Width:PARENT_RIGHT
Height:25
Button@WATCH_BUTTON: Button@WATCH_BUTTON:
X:PARENT_RIGHT - 140 - 130 X:PARENT_RIGHT - 140 - 130
Y:PARENT_BOTTOM - 45 Y:PARENT_BOTTOM - 45
@@ -100,3 +120,4 @@ Background@REPLAYBROWSER_PANEL:
Text:Cancel Text:Cancel
Font:Bold Font:Bold
Key:escape Key:escape
TooltipContainer@TOOLTIP_CONTAINER: