Clean up map previews. Fixes #5665.

This commit is contained in:
Paul Chote
2014-06-21 14:09:13 +12:00
parent 444380b3cf
commit 5760e665d3
10 changed files with 64 additions and 36 deletions

View File

@@ -50,6 +50,7 @@ Also thanks to:
* Lesueur Benjamin (Valkirie) * Lesueur Benjamin (Valkirie)
* Maarten Meuris (Nyerguds) * Maarten Meuris (Nyerguds)
* Mark Olson (markolson) * Mark Olson (markolson)
* Matija Hustic (matija-hustic)
* Matthew Gatland (mgatland) * Matthew Gatland (mgatland)
* Matthew Uzzell (MUzzell) * Matthew Uzzell (MUzzell)
* Max621 * Max621

View File

@@ -26,9 +26,6 @@ namespace OpenRA.Widgets
public readonly string Country; public readonly string Country;
public readonly int SpawnPoint; public readonly int SpawnPoint;
public SpawnOccupant()
{
}
public SpawnOccupant(Session.Client client) public SpawnOccupant(Session.Client client)
{ {
Color = client.Color; Color = client.Color;
@@ -38,6 +35,7 @@ namespace OpenRA.Widgets
Country = client.Country; Country = client.Country;
SpawnPoint = client.SpawnPoint; SpawnPoint = client.SpawnPoint;
} }
public SpawnOccupant(GameInformation.Player player) public SpawnOccupant(GameInformation.Player player)
{ {
Color = player.Color; Color = player.Color;
@@ -51,34 +49,58 @@ namespace OpenRA.Widgets
public class MapPreviewWidget : Widget public class MapPreviewWidget : Widget
{ {
public Func<MapPreview> Preview = () => null; public readonly bool IgnoreMouseInput = false;
public Func<Dictionary<CPos, SpawnOccupant>> SpawnOccupants = () => new Dictionary<CPos, SpawnOccupant>(); public readonly bool ShowSpawnPoints = true;
public Action<MouseInput> OnMouseDown = _ => {};
public bool IgnoreMouseInput = false;
public bool ShowSpawnPoints = true;
public readonly string TooltipContainer; public readonly string TooltipContainer;
public readonly string TooltipTemplate = "SPAWN_TOOLTIP"; public readonly string TooltipTemplate = "SPAWN_TOOLTIP";
Lazy<TooltipContainerWidget> tooltipContainer; readonly Lazy<TooltipContainerWidget> tooltipContainer;
readonly Sprite spawnClaimed, spawnUnclaimed;
readonly SpriteFont spawnFont;
readonly Color spawnColor, spawnContrastColor;
readonly int2 spawnLabelOffset;
public Func<MapPreview> Preview = () => null;
public Func<Dictionary<CPos, SpawnOccupant>> SpawnOccupants = () => new Dictionary<CPos, SpawnOccupant>();
public Action<MouseInput> OnMouseDown = _ => { };
public int TooltipSpawnIndex = -1; public int TooltipSpawnIndex = -1;
Rectangle MapRect; Rectangle mapRect;
float PreviewScale = 0; float previewScale = 0;
Sprite minimap;
public MapPreviewWidget() public MapPreviewWidget()
{ {
tooltipContainer = Exts.Lazy(() => Ui.Root.Get<TooltipContainerWidget>(TooltipContainer)); tooltipContainer = Exts.Lazy(() => Ui.Root.Get<TooltipContainerWidget>(TooltipContainer));
spawnClaimed = ChromeProvider.GetImage("lobby-bits", "spawn-claimed");
spawnUnclaimed = ChromeProvider.GetImage("lobby-bits", "spawn-unclaimed");
spawnFont = Game.Renderer.Fonts[ChromeMetrics.Get<string>("SpawnFont")];
spawnColor = ChromeMetrics.Get<Color>("SpawnColor");
spawnContrastColor = ChromeMetrics.Get<Color>("SpawnContrastColor");
spawnLabelOffset = ChromeMetrics.Get<int2>("SpawnLabelOffset");
} }
protected MapPreviewWidget(MapPreviewWidget other) protected MapPreviewWidget(MapPreviewWidget other)
: base(other) : base(other)
{ {
Preview = other.Preview; Preview = other.Preview;
SpawnOccupants = other.SpawnOccupants;
IgnoreMouseInput = other.IgnoreMouseInput;
ShowSpawnPoints = other.ShowSpawnPoints; ShowSpawnPoints = other.ShowSpawnPoints;
TooltipTemplate = other.TooltipTemplate; TooltipTemplate = other.TooltipTemplate;
TooltipContainer = other.TooltipContainer; TooltipContainer = other.TooltipContainer;
SpawnOccupants = other.SpawnOccupants;
tooltipContainer = Exts.Lazy(() => Ui.Root.Get<TooltipContainerWidget>(TooltipContainer)); tooltipContainer = Exts.Lazy(() => Ui.Root.Get<TooltipContainerWidget>(TooltipContainer));
spawnClaimed = ChromeProvider.GetImage("lobby-bits", "spawn-claimed");
spawnUnclaimed = ChromeProvider.GetImage("lobby-bits", "spawn-unclaimed");
spawnFont = Game.Renderer.Fonts[ChromeMetrics.Get<string>("SpawnFont")];
spawnColor = ChromeMetrics.Get<Color>("SpawnColor");
spawnContrastColor = ChromeMetrics.Get<Color>("SpawnContrastColor");
spawnLabelOffset = ChromeMetrics.Get<int2>("SpawnLabelOffset");
} }
public override Widget Clone() { return new MapPreviewWidget(this); } public override Widget Clone() { return new MapPreviewWidget(this); }
@@ -110,10 +132,11 @@ namespace OpenRA.Widgets
public int2 ConvertToPreview(CPos point) public int2 ConvertToPreview(CPos point)
{ {
var preview = Preview(); var preview = Preview();
return new int2(MapRect.X + (int)(PreviewScale*(point.X - preview.Bounds.Left)) , MapRect.Y + (int)(PreviewScale*(point.Y - preview.Bounds.Top))); var dx = (int)(previewScale * (point.X - preview.Bounds.Left));
var dy = (int)(previewScale * (point.Y - preview.Bounds.Top));
return new int2(mapRect.X + dx, mapRect.Y + dy);
} }
Sprite minimap;
public override void Draw() public override void Draw()
{ {
var preview = Preview(); var preview = Preview();
@@ -127,14 +150,14 @@ namespace OpenRA.Widgets
return; return;
// Update map rect // Update map rect
PreviewScale = Math.Min(RenderBounds.Width / minimap.size.X, RenderBounds.Height / minimap.size.Y); previewScale = Math.Min(RenderBounds.Width / minimap.size.X, RenderBounds.Height / minimap.size.Y);
var w = (int)(PreviewScale * minimap.size.X); var w = (int)(previewScale * minimap.size.X);
var h = (int)(PreviewScale * minimap.size.Y); var h = (int)(previewScale * minimap.size.Y);
var x = RenderBounds.X + (RenderBounds.Width - w) / 2; var x = RenderBounds.X + (RenderBounds.Width - w) / 2;
var y = RenderBounds.Y + (RenderBounds.Height - h) / 2; var y = RenderBounds.Y + (RenderBounds.Height - h) / 2;
MapRect = new Rectangle(x, y, w, h); mapRect = new Rectangle(x, y, w, h);
Game.Renderer.RgbaSpriteRenderer.DrawSprite(minimap, new float2(MapRect.Location), new float2(MapRect.Size)); Game.Renderer.RgbaSpriteRenderer.DrawSprite(minimap, new float2(mapRect.Location), new float2(mapRect.Size));
TooltipSpawnIndex = -1; TooltipSpawnIndex = -1;
if (ShowSpawnPoints) if (ShowSpawnPoints)
@@ -146,20 +169,19 @@ namespace OpenRA.Widgets
{ {
var owned = colors.ContainsKey(p); var owned = colors.ContainsKey(p);
var pos = ConvertToPreview(p); var pos = ConvertToPreview(p);
var sprite = ChromeProvider.GetImage("lobby-bits", owned ? "spawn-claimed" : "spawn-unclaimed"); var sprite = owned ? spawnClaimed : spawnUnclaimed;
var offset = new int2(sprite.bounds.Width, sprite.bounds.Height) / 2; var offset = new int2(sprite.bounds.Width, sprite.bounds.Height) / 2;
if (owned) if (owned)
WidgetUtils.FillEllipseWithColor(new Rectangle(pos.X - offset.X + 1, pos.Y - offset.Y + 1, sprite.bounds.Width - 2, sprite.bounds.Height - 2), colors[p]); WidgetUtils.FillEllipseWithColor(new Rectangle(pos.X - offset.X + 1, pos.Y - offset.Y + 1, sprite.bounds.Width - 2, sprite.bounds.Height - 2), colors[p]);
Game.Renderer.RgbaSpriteRenderer.DrawSprite(sprite, pos - offset); Game.Renderer.RgbaSpriteRenderer.DrawSprite(sprite, pos - offset);
var fonts = Game.Renderer.Fonts[ChromeMetrics.Get<string>("SpawnFont")];
var number = Convert.ToChar('A' + spawnPoints.IndexOf(p)).ToString(); var number = Convert.ToChar('A' + spawnPoints.IndexOf(p)).ToString();
offset = fonts.Measure(number) / 2; var textOffset = spawnFont.Measure(number) / 2 + spawnLabelOffset;
offset.Y += 1; // Does not center well vertically for some reason
fonts.DrawTextWithContrast(number, pos - offset, ChromeMetrics.Get<Color>("SpawnColor"), ChromeMetrics.Get<Color>("SpawnContrastColor"), 1);
if (((pos - Viewport.LastMousePos).ToFloat2() * offset.ToFloat2()).LengthSquared < 1) spawnFont.DrawTextWithContrast(number, pos - textOffset, spawnColor, spawnContrastColor, 1);
if (((pos - Viewport.LastMousePos).ToFloat2() / offset.ToFloat2()).LengthSquared <= 1)
TooltipSpawnIndex = spawnPoints.IndexOf(p) + 1; TooltipSpawnIndex = spawnPoints.IndexOf(p) + 1;
} }
} }

View File

@@ -92,16 +92,14 @@ namespace OpenRA.Mods.RA.Widgets.Logic
{ {
Func<int, ScrollItemWidget, ScrollItemWidget> setupItem = (ii, itemTemplate) => Func<int, ScrollItemWidget, ScrollItemWidget> setupItem = (ii, itemTemplate) =>
{ {
var spawnPoint = spawnPoints.ToList()[ii];
var item = ScrollItemWidget.Setup(itemTemplate, var item = ScrollItemWidget.Setup(itemTemplate,
() => client.SpawnPoint == spawnPoint, () => client.SpawnPoint == ii,
() => SetSpawnPoint(orderManager, client, spawnPoint)); () => SetSpawnPoint(orderManager, client, ii));
item.Get<LabelWidget>("LABEL").GetText = () => spawnPoint == 0 ? "-" : Convert.ToChar('A' - 1 + spawnPoint).ToString(); item.Get<LabelWidget>("LABEL").GetText = () => ii == 0 ? "-" : Convert.ToChar('A' - 1 + ii).ToString();
return item; return item;
}; };
var options = Exts.MakeArray(spawnPoints.Count(), i => i).ToList(); dropdown.ShowDropDown("SPAWN_DROPDOWN_TEMPLATE", 150, spawnPoints, setupItem);
dropdown.ShowDropDown("SPAWN_DROPDOWN_TEMPLATE", 150, options, setupItem);
} }
public static void ShowRaceDropDown(DropDownButtonWidget dropdown, Session.Client client, public static void ShowRaceDropDown(DropDownButtonWidget dropdown, Session.Client client,
@@ -171,9 +169,10 @@ namespace OpenRA.Mods.RA.Widgets.Logic
if (!orderManager.LocalClient.IsObserver && orderManager.LocalClient.State == Session.ClientState.Ready) if (!orderManager.LocalClient.IsObserver && orderManager.LocalClient.State == Session.ClientState.Ready)
return; return;
var spawnSize = new float2(ChromeProvider.GetImage("lobby-bits", "spawn-unclaimed").bounds.Size);
var selectedSpawn = preview.SpawnPoints var selectedSpawn = preview.SpawnPoints
.Select((sp, i) => Pair.New(mapPreview.ConvertToPreview(sp), i)) .Select((sp, i) => Pair.New(mapPreview.ConvertToPreview(sp), i))
.Where(a => ((a.First - mi.Location).ToFloat2() / new float2(ChromeProvider.GetImage("lobby-bits", "spawn-unclaimed").bounds.Width / 2, ChromeProvider.GetImage("lobby-bits", "spawn-unclaimed").bounds.Height / 2)).LengthSquared <= 1) .Where(a => ((a.First - mi.Location).ToFloat2() / spawnSize * 2).LengthSquared <= 1)
.Select(a => a.Second + 1) .Select(a => a.Second + 1)
.FirstOrDefault(); .FirstOrDefault();

View File

@@ -107,8 +107,6 @@ namespace OpenRA.Mods.RA.Widgets.Logic
titleLabel.GetText = () => preview.Title; titleLabel.GetText = () => preview.Title;
var previewWidget = item.Get<MapPreviewWidget>("PREVIEW"); var previewWidget = item.Get<MapPreviewWidget>("PREVIEW");
previewWidget.IgnoreMouseOver = true;
previewWidget.IgnoreMouseInput = true;
previewWidget.Preview = () => preview; previewWidget.Preview = () => preview;
var detailsWidget = item.GetOrNull<LabelWidget>("DETAILS"); var detailsWidget = item.GetOrNull<LabelWidget>("DETAILS");

View File

@@ -48,6 +48,8 @@ Container@MAPCHOOSER_PANEL:
Y: 4 Y: 4
Width: 173 Width: 173
Height: 173 Height: 173
IgnoreMouseOver: true
IgnoreMouseInput: true
Label@TITLE: Label@TITLE:
X: 2 X: 2
Y: PARENT_BOTTOM-48 Y: PARENT_BOTTOM-48

View File

@@ -23,3 +23,4 @@ Metrics:
SpawnFont: TinyBold SpawnFont: TinyBold
SpawnColor: 255,255,255 SpawnColor: 255,255,255
SpawnContrastColor: 0,0,0 SpawnContrastColor: 0,0,0
SpawnLabelOffset: 0,1

View File

@@ -23,3 +23,4 @@ Metrics:
SpawnFont: TinyBold SpawnFont: TinyBold
SpawnColor: 255,255,255 SpawnColor: 255,255,255
SpawnContrastColor: 0,0,0 SpawnContrastColor: 0,0,0
SpawnLabelOffset: 0,1

View File

@@ -31,6 +31,8 @@ Background@MAPCHOOSER_PANEL:
Y: 4 Y: 4
Width: 184 Width: 184
Height: 184 Height: 184
IgnoreMouseOver: true
IgnoreMouseInput: true
Label@TITLE: Label@TITLE:
X: 2 X: 2
Y: PARENT_BOTTOM-48 Y: PARENT_BOTTOM-48

View File

@@ -23,3 +23,4 @@ Metrics:
SpawnFont: TinyBold SpawnFont: TinyBold
SpawnColor: 255,255,255 SpawnColor: 255,255,255
SpawnContrastColor: 0,0,0 SpawnContrastColor: 0,0,0
SpawnLabelOffset: 0,1

View File

@@ -23,3 +23,4 @@ Metrics:
SpawnFont: TinyBold SpawnFont: TinyBold
SpawnColor: 255,255,255 SpawnColor: 255,255,255
SpawnContrastColor: 0,0,0 SpawnContrastColor: 0,0,0
SpawnLabelOffset: 0,1