CommonSelectorLogic for ActorSelectorLogic and TileSelectionLogic

This commit is contained in:
rob-v
2018-12-31 13:56:20 +01:00
committed by Paul Chote
parent 63f76fc277
commit f18d874524
4 changed files with 126 additions and 96 deletions

View File

@@ -694,6 +694,7 @@
<Compile Include="Widgets\Logic\Lobby\SpawnSelectorTooltipLogic.cs" /> <Compile Include="Widgets\Logic\Lobby\SpawnSelectorTooltipLogic.cs" />
<Compile Include="Widgets\Logic\MainMenuLogic.cs" /> <Compile Include="Widgets\Logic\MainMenuLogic.cs" />
<Compile Include="Widgets\Logic\Editor\ActorSelectorLogic.cs" /> <Compile Include="Widgets\Logic\Editor\ActorSelectorLogic.cs" />
<Compile Include="Widgets\Logic\Editor\CommonSelectorLogic.cs" />
<Compile Include="Widgets\Logic\Editor\LayerSelectorLogic.cs" /> <Compile Include="Widgets\Logic\Editor\LayerSelectorLogic.cs" />
<Compile Include="Widgets\Logic\Editor\MapEditorLogic.cs" /> <Compile Include="Widgets\Logic\Editor\MapEditorLogic.cs" />
<Compile Include="Widgets\Logic\Editor\MapEditorTabsLogic.cs" /> <Compile Include="Widgets\Logic\Editor\MapEditorTabsLogic.cs" />

View File

@@ -19,7 +19,7 @@ using OpenRA.Widgets;
namespace OpenRA.Mods.Common.Widgets.Logic namespace OpenRA.Mods.Common.Widgets.Logic
{ {
public class ActorSelectorLogic : ChromeLogic public class ActorSelectorLogic : CommonSelectorLogic
{ {
class ActorSelectorActor class ActorSelectorActor
{ {
@@ -37,30 +37,21 @@ namespace OpenRA.Mods.Common.Widgets.Logic
} }
} }
readonly EditorViewportControllerWidget editor;
readonly DropDownButtonWidget ownersDropDown; readonly DropDownButtonWidget ownersDropDown;
readonly ScrollPanelWidget panel; readonly ScrollPanelWidget panel;
readonly ScrollItemWidget itemTemplate; readonly ScrollItemWidget itemTemplate;
readonly Ruleset mapRules; readonly Ruleset mapRules;
readonly World world;
readonly WorldRenderer worldRenderer;
readonly string[] allCategories;
readonly HashSet<string> selectedCategories = new HashSet<string>();
readonly List<string> filteredCategories = new List<string>();
readonly ActorSelectorActor[] allActors; readonly ActorSelectorActor[] allActors;
PlayerReference selectedOwner; PlayerReference selectedOwner;
string searchFilter;
[ObjectCreator.UseCtor] [ObjectCreator.UseCtor]
public ActorSelectorLogic(Widget widget, World world, WorldRenderer worldRenderer) public ActorSelectorLogic(Widget widget, World world, WorldRenderer worldRenderer)
: base(widget, world, worldRenderer)
{ {
mapRules = world.Map.Rules; mapRules = world.Map.Rules;
this.world = world;
this.worldRenderer = worldRenderer;
editor = widget.Parent.Get<EditorViewportControllerWidget>("MAP_EDITOR");
ownersDropDown = widget.Get<DropDownButtonWidget>("OWNERS_DROPDOWN"); ownersDropDown = widget.Get<DropDownButtonWidget>("OWNERS_DROPDOWN");
panel = widget.Get<ScrollPanelWidget>("ACTORTEMPLATE_LIST"); panel = widget.Get<ScrollPanelWidget>("ACTORTEMPLATE_LIST");
@@ -130,7 +121,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
var tooltipText = (tooltip == null ? "Type: " : tooltip.Name + "\nType: ") + a.Name; var tooltipText = (tooltip == null ? "Type: " : tooltip.Name + "\nType: ") + a.Name;
allActorsTemp.Add(new ActorSelectorActor(a, editorData.Categories, searchTerms.ToArray(), tooltipText)); allActorsTemp.Add(new ActorSelectorActor(a, editorData.Categories, searchTerms.ToArray(), tooltipText));
} }
allActors = allActorsTemp.ToArray(); allActors = allActorsTemp.ToArray();
@@ -141,27 +132,27 @@ namespace OpenRA.Mods.Common.Widgets.Logic
foreach (var c in allCategories) foreach (var c in allCategories)
{ {
selectedCategories.Add(c); SelectedCategories.Add(c);
filteredCategories.Add(c); FilteredCategories.Add(c);
} }
var searchTextField = widget.Get<TextFieldWidget>("SEARCH_TEXTFIELD"); var searchTextField = widget.Get<TextFieldWidget>("SEARCH_TEXTFIELD");
searchTextField.OnTextEdited = () => searchTextField.OnTextEdited = () =>
{ {
searchFilter = searchTextField.Text.Trim(); searchFilter = searchTextField.Text.Trim();
filteredCategories.Clear(); FilteredCategories.Clear();
if (!string.IsNullOrEmpty(searchFilter)) if (!string.IsNullOrEmpty(searchFilter))
filteredCategories.AddRange( FilteredCategories.AddRange(
allActors.Where(t => t.SearchTerms.Any( allActors.Where(t => t.SearchTerms.Any(
s => s.IndexOf(searchFilter, StringComparison.OrdinalIgnoreCase) >= 0)) s => s.IndexOf(searchFilter, StringComparison.OrdinalIgnoreCase) >= 0))
.SelectMany(t => t.Categories) .SelectMany(t => t.Categories)
.Distinct() .Distinct()
.OrderBy(x => x)); .OrderBy(x => x));
else else
filteredCategories.AddRange(allCategories); FilteredCategories.AddRange(allCategories);
InitializeActorPreviews(); InitializePreviews();
}; };
searchTextField.OnEscKey = () => searchTextField.OnEscKey = () =>
@@ -174,16 +165,16 @@ namespace OpenRA.Mods.Common.Widgets.Logic
var actorCategorySelector = widget.Get<DropDownButtonWidget>("CATEGORIES_DROPDOWN"); var actorCategorySelector = widget.Get<DropDownButtonWidget>("CATEGORIES_DROPDOWN");
actorCategorySelector.GetText = () => actorCategorySelector.GetText = () =>
{ {
if (selectedCategories.Count == 0) if (SelectedCategories.Count == 0)
return "None"; return "None";
if (!string.IsNullOrEmpty(searchFilter)) if (!string.IsNullOrEmpty(searchFilter))
return "Search Results"; return "Search Results";
if (selectedCategories.Count == 1) if (SelectedCategories.Count == 1)
return selectedCategories.First(); return SelectedCategories.First();
if (selectedCategories.Count == allCategories.Length) if (SelectedCategories.Count == allCategories.Length)
return "All"; return "All";
return "Multiple"; return "Multiple";
@@ -195,10 +186,10 @@ namespace OpenRA.Mods.Common.Widgets.Logic
searchTextField.YieldKeyboardFocus(); searchTextField.YieldKeyboardFocus();
actorCategorySelector.RemovePanel(); actorCategorySelector.RemovePanel();
actorCategorySelector.AttachPanel(CreateCategoriesPanel()); actorCategorySelector.AttachPanel(CreateCategoriesPanel(panel));
}; };
InitializeActorPreviews(); InitializePreviews();
} }
void SelectOwner(PlayerReference option) void SelectOwner(PlayerReference option)
@@ -206,67 +197,18 @@ namespace OpenRA.Mods.Common.Widgets.Logic
selectedOwner = option; selectedOwner = option;
ownersDropDown.Text = option.Name; ownersDropDown.Text = option.Name;
ownersDropDown.TextColor = option.Color.RGB; ownersDropDown.TextColor = option.Color.RGB;
InitializeActorPreviews(); InitializePreviews();
} }
Widget CreateCategoriesPanel() protected override void InitializePreviews()
{
var categoriesPanel = Ui.LoadWidget("ACTOR_CATEGORY_FILTER_PANEL", null, new WidgetArgs());
var categoryTemplate = categoriesPanel.Get<CheckboxWidget>("CATEGORY_TEMPLATE");
var selectButtons = categoriesPanel.Get<ContainerWidget>("SELECT_CATEGORIES_BUTTONS");
categoriesPanel.AddChild(selectButtons);
var selectAll = selectButtons.Get<ButtonWidget>("SELECT_ALL");
selectAll.OnClick = () =>
{
selectedCategories.Clear();
foreach (var c in allCategories)
selectedCategories.Add(c);
InitializeActorPreviews();
};
var selectNone = selectButtons.Get<ButtonWidget>("SELECT_NONE");
selectNone.OnClick = () =>
{
selectedCategories.Clear();
InitializeActorPreviews();
};
var categoryHeight = 5 + selectButtons.Bounds.Height;
foreach (var cat in filteredCategories)
{
var category = (CheckboxWidget)categoryTemplate.Clone();
category.GetText = () => cat;
category.IsChecked = () => selectedCategories.Contains(cat);
category.IsVisible = () => true;
category.OnClick = () =>
{
if (!selectedCategories.Remove(cat))
selectedCategories.Add(cat);
InitializeActorPreviews();
};
categoriesPanel.AddChild(category);
categoryHeight += categoryTemplate.Bounds.Height;
}
categoriesPanel.Bounds.Height = Math.Min(categoryHeight, panel.Bounds.Height);
return categoriesPanel;
}
void InitializeActorPreviews()
{ {
panel.RemoveChildren(); panel.RemoveChildren();
if (!selectedCategories.Any()) if (!SelectedCategories.Any())
return; return;
foreach (var a in allActors) foreach (var a in allActors)
{ {
if (!selectedCategories.Overlaps(a.Categories)) if (!SelectedCategories.Overlaps(a.Categories))
continue; continue;
if (!string.IsNullOrEmpty(searchFilter) && !a.SearchTerms.Any(s => s.IndexOf(searchFilter, StringComparison.OrdinalIgnoreCase) >= 0)) if (!string.IsNullOrEmpty(searchFilter) && !a.SearchTerms.Any(s => s.IndexOf(searchFilter, StringComparison.OrdinalIgnoreCase) >= 0))
@@ -283,8 +225,8 @@ namespace OpenRA.Mods.Common.Widgets.Logic
try try
{ {
var item = ScrollItemWidget.Setup(itemTemplate, var item = ScrollItemWidget.Setup(itemTemplate,
() => { var brush = editor.CurrentBrush as EditorActorBrush; return brush != null && brush.Actor == actor; }, () => { var brush = Editor.CurrentBrush as EditorActorBrush; return brush != null && brush.Actor == actor; },
() => editor.SetBrush(new EditorActorBrush(editor, actor, selectedOwner, worldRenderer))); () => Editor.SetBrush(new EditorActorBrush(Editor, actor, selectedOwner, WorldRenderer)));
var preview = item.Get<ActorPreviewWidget>("ACTOR_PREVIEW"); var preview = item.Get<ActorPreviewWidget>("ACTOR_PREVIEW");
preview.SetPreview(actor, td); preview.SetPreview(actor, td);
@@ -309,7 +251,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
catch catch
{ {
Log.Write("debug", "Map editor ignoring actor {0}, because of missing sprites for tileset {1}.", Log.Write("debug", "Map editor ignoring actor {0}, because of missing sprites for tileset {1}.",
actor.Name, world.Map.Rules.TileSet.Id); actor.Name, World.Map.Rules.TileSet.Id);
continue; continue;
} }
} }

View File

@@ -0,0 +1,91 @@
#region Copyright & License Information
/*
* Copyright 2007-2017 The OpenRA Developers (see AUTHORS)
* This file is part of OpenRA, which is free software. It is made
* available to you under the terms of the GNU General Public License
* as published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version. For more
* information, see COPYING.
*/
#endregion
using System;
using System.Collections.Generic;
using OpenRA.Graphics;
using OpenRA.Widgets;
namespace OpenRA.Mods.Common.Widgets.Logic
{
public abstract class CommonSelectorLogic : ChromeLogic
{
protected readonly Widget Widget;
protected readonly World World;
protected readonly WorldRenderer WorldRenderer;
protected readonly EditorViewportControllerWidget Editor;
protected readonly HashSet<string> SelectedCategories = new HashSet<string>();
protected readonly List<string> FilteredCategories = new List<string>();
protected string[] allCategories;
protected string searchFilter;
public CommonSelectorLogic(Widget widget, World world, WorldRenderer worldRenderer)
{
this.Widget = widget;
this.World = world;
this.WorldRenderer = worldRenderer;
Editor = widget.Parent.Get<EditorViewportControllerWidget>("MAP_EDITOR");
}
protected Widget CreateCategoriesPanel(ScrollPanelWidget panel)
{
var categoriesPanel = Ui.LoadWidget("ACTOR_CATEGORY_FILTER_PANEL", null, new WidgetArgs());
var categoryTemplate = categoriesPanel.Get<CheckboxWidget>("CATEGORY_TEMPLATE");
var selectButtons = categoriesPanel.Get<ContainerWidget>("SELECT_CATEGORIES_BUTTONS");
categoriesPanel.AddChild(selectButtons);
var selectAll = selectButtons.Get<ButtonWidget>("SELECT_ALL");
selectAll.OnClick = () =>
{
SelectedCategories.Clear();
foreach (var c in allCategories)
SelectedCategories.Add(c);
InitializePreviews();
};
var selectNone = selectButtons.Get<ButtonWidget>("SELECT_NONE");
selectNone.OnClick = () =>
{
SelectedCategories.Clear();
InitializePreviews();
};
var categoryHeight = 5 + selectButtons.Bounds.Height;
foreach (var cat in FilteredCategories)
{
var category = (CheckboxWidget)categoryTemplate.Clone();
category.GetText = () => cat;
category.IsChecked = () => SelectedCategories.Contains(cat);
category.IsVisible = () => true;
category.OnClick = () =>
{
if (!SelectedCategories.Remove(cat))
SelectedCategories.Add(cat);
InitializePreviews();
};
categoriesPanel.AddChild(category);
categoryHeight += categoryTemplate.Bounds.Height;
}
categoriesPanel.Bounds.Height = Math.Min(categoryHeight, panel.Bounds.Height);
return categoriesPanel;
}
protected abstract void InitializePreviews();
}
}

View File

@@ -16,7 +16,7 @@ using OpenRA.Widgets;
namespace OpenRA.Mods.Common.Widgets.Logic namespace OpenRA.Mods.Common.Widgets.Logic
{ {
public class TileSelectorLogic : ChromeLogic public class TileSelectorLogic : CommonSelectorLogic
{ {
class TileSelectorTemplate class TileSelectorTemplate
{ {
@@ -35,23 +35,19 @@ namespace OpenRA.Mods.Common.Widgets.Logic
} }
readonly TileSet tileset; readonly TileSet tileset;
readonly WorldRenderer worldRenderer;
readonly EditorViewportControllerWidget editor;
readonly ScrollPanelWidget panel; readonly ScrollPanelWidget panel;
readonly ScrollItemWidget itemTemplate; readonly ScrollItemWidget itemTemplate;
readonly TileSelectorTemplate[] allTemplates; readonly TileSelectorTemplate[] allTemplates;
string selectedCategory; string selectedCategory;
string userSelectedCategory; string userSelectedCategory;
string searchFilter;
[ObjectCreator.UseCtor] [ObjectCreator.UseCtor]
public TileSelectorLogic(Widget widget, WorldRenderer worldRenderer) public TileSelectorLogic(Widget widget, World world, WorldRenderer worldRenderer) :
base(widget, world, worldRenderer)
{ {
tileset = worldRenderer.World.Map.Rules.TileSet; tileset = world.Map.Rules.TileSet;
this.worldRenderer = worldRenderer;
editor = widget.Parent.Get<EditorViewportControllerWidget>("MAP_EDITOR");
panel = widget.Get<ScrollPanelWidget>("TILETEMPLATE_LIST"); panel = widget.Get<ScrollPanelWidget>("TILETEMPLATE_LIST");
itemTemplate = panel.Get<ScrollItemWidget>("TILEPREVIEW_TEMPLATE"); itemTemplate = panel.Get<ScrollItemWidget>("TILEPREVIEW_TEMPLATE");
panel.Layout = new GridLayout(panel); panel.Layout = new GridLayout(panel);
@@ -69,7 +65,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
searchFilter = searchTextField.Text.Trim(); searchFilter = searchTextField.Text.Trim();
selectedCategory = string.IsNullOrEmpty(searchFilter) ? userSelectedCategory : null; selectedCategory = string.IsNullOrEmpty(searchFilter) ? userSelectedCategory : null;
InitializeTilePreview(); InitializePreviews();
}; };
searchTextField.OnEscKey = () => searchTextField.OnEscKey = () =>
@@ -88,7 +84,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
if (option != null) if (option != null)
userSelectedCategory = option; userSelectedCategory = option;
InitializeTilePreview(); InitializePreviews();
}); });
var title = categoryTitle(option); var title = categoryTitle(option);
@@ -120,7 +116,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
actorCategorySelector.GetText = () => categoryTitle(selectedCategory); actorCategorySelector.GetText = () => categoryTitle(selectedCategory);
selectedCategory = userSelectedCategory = orderedCategories.First(); selectedCategory = userSelectedCategory = orderedCategories.First();
InitializeTilePreview(); InitializePreviews();
} }
int CategoryOrder(string category) int CategoryOrder(string category)
@@ -129,7 +125,7 @@ namespace OpenRA.Mods.Common.Widgets.Logic
return i >= 0 ? i : int.MaxValue; return i >= 0 ? i : int.MaxValue;
} }
void InitializeTilePreview() protected override void InitializePreviews()
{ {
panel.RemoveChildren(); panel.RemoveChildren();
@@ -143,13 +139,13 @@ namespace OpenRA.Mods.Common.Widgets.Logic
var tileId = t.Template.Id; var tileId = t.Template.Id;
var item = ScrollItemWidget.Setup(itemTemplate, var item = ScrollItemWidget.Setup(itemTemplate,
() => { var brush = editor.CurrentBrush as EditorTileBrush; return brush != null && brush.Template == tileId; }, () => { var brush = Editor.CurrentBrush as EditorTileBrush; return brush != null && brush.Template == tileId; },
() => editor.SetBrush(new EditorTileBrush(editor, tileId, worldRenderer))); () => Editor.SetBrush(new EditorTileBrush(Editor, tileId, WorldRenderer)));
var preview = item.Get<TerrainTemplatePreviewWidget>("TILE_PREVIEW"); var preview = item.Get<TerrainTemplatePreviewWidget>("TILE_PREVIEW");
var template = tileset.Templates[tileId]; var template = tileset.Templates[tileId];
var grid = worldRenderer.World.Map.Grid; var grid = WorldRenderer.World.Map.Grid;
var bounds = worldRenderer.Theater.TemplateBounds(template, grid.TileSize, grid.Type); var bounds = WorldRenderer.Theater.TemplateBounds(template, grid.TileSize, grid.Type);
// Scale templates to fit within the panel // Scale templates to fit within the panel
var scale = 1f; var scale = 1f;