CommonSelectorLogic for ActorSelectorLogic and TileSelectionLogic
This commit is contained in:
@@ -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" />
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user