unhacking IChromeButton.
This commit is contained in:
@@ -38,6 +38,9 @@ namespace OpenRA
|
||||
public static World world;
|
||||
internal static Viewport viewport;
|
||||
public static Controller controller;
|
||||
public static Widget RootWidget {
|
||||
get { return Chrome.rootWidget; }
|
||||
}
|
||||
internal static Chrome chrome;
|
||||
internal static UserSettings Settings;
|
||||
|
||||
|
||||
@@ -229,6 +229,7 @@
|
||||
<Compile Include="Widgets\SliderWidget.cs" />
|
||||
<Compile Include="Widgets\TimerWidget.cs" />
|
||||
<Compile Include="Widgets\ShpImageWidget.cs" />
|
||||
<Compile Include="Widgets\OrderButtonWidget.cs" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\OpenRA.FileFormats\OpenRA.FileFormats.csproj">
|
||||
|
||||
@@ -150,16 +150,6 @@ namespace OpenRA.Traits
|
||||
void Cancel(Actor self);
|
||||
}
|
||||
|
||||
public interface IChromeButton
|
||||
{
|
||||
string Image { get; }
|
||||
bool Enabled { get; }
|
||||
bool Pressed { get; }
|
||||
void OnClick();
|
||||
string Description { get; }
|
||||
string LongDesc { get; }
|
||||
}
|
||||
|
||||
public interface IRenderOverlay { void Render(); }
|
||||
public interface INotifyIdle { void Idle(Actor self); }
|
||||
|
||||
|
||||
@@ -13,7 +13,7 @@ using System.Drawing;
|
||||
|
||||
namespace OpenRA.Widgets
|
||||
{
|
||||
class ButtonWidget : Widget
|
||||
public class ButtonWidget : Widget
|
||||
{
|
||||
public string Text = "";
|
||||
public bool Bold = false;
|
||||
|
||||
@@ -70,59 +70,6 @@ namespace OpenRA.Widgets
|
||||
x -= 14;
|
||||
}
|
||||
}
|
||||
|
||||
var origin = new int2(Game.viewport.Width - 200, 2);
|
||||
|
||||
foreach (var cb in world.WorldActor.traits.WithInterface<IChromeButton>())
|
||||
{
|
||||
var state = cb.Enabled ? cb.Pressed ? "pressed" : "normal" : "disabled";
|
||||
var image = ChromeProvider.GetImage(Game.chrome.renderer, cb.Image + "-button", state);
|
||||
|
||||
origin.X -= (int)image.size.X + chromeButtonGap;
|
||||
|
||||
var button = cb;
|
||||
var rect = new Rectangle(origin.X, origin.Y, (int)image.size.X, (int)image.size.Y);
|
||||
AddButton(rect, _ => { if (button.Enabled) button.OnClick(); });
|
||||
|
||||
if (rect.Contains(Game.chrome.lastMousePos.ToPoint()))
|
||||
{
|
||||
rect = rect.InflateBy(3, 3, 3, 3);
|
||||
var pos = new int2(rect.Left, rect.Top);
|
||||
var m = pos + new int2(rect.Width, rect.Height);
|
||||
var br = pos + new int2(rect.Width, rect.Height + 20);
|
||||
|
||||
var u = Game.chrome.renderer.RegularFont.Measure(cb.LongDesc.Replace("\\n", "\n"));
|
||||
|
||||
br.X -= u.X;
|
||||
br.Y += u.Y;
|
||||
br += new int2(-15, 25);
|
||||
|
||||
var border = WidgetUtils.GetBorderSizes("dialog4");
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", rect
|
||||
.InflateBy(0, 0, 0, border[1]),
|
||||
PanelSides.Top | PanelSides.Left | PanelSides.Right);
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", new Rectangle(br.X, m.Y, pos.X - br.X, br.Y - m.Y)
|
||||
.InflateBy(0, 0, border[3], 0),
|
||||
PanelSides.Top | PanelSides.Left | PanelSides.Bottom);
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", new Rectangle(pos.X, m.Y, m.X - pos.X, br.Y - m.Y)
|
||||
.InflateBy(border[2], border[0], 0, 0),
|
||||
PanelSides.Right | PanelSides.Bottom);
|
||||
|
||||
pos.X = br.X + 8;
|
||||
pos.Y = m.Y + 8;
|
||||
Game.chrome.renderer.BoldFont.DrawText(cb.Description, pos, Color.White);
|
||||
|
||||
pos += new int2(0, 20);
|
||||
Game.chrome.renderer.RegularFont.DrawText(cb.LongDesc.Replace("\\n", "\n"), pos, Color.White);
|
||||
}
|
||||
|
||||
Game.chrome.renderer.RgbaSpriteRenderer.DrawSprite(image, origin, "chrome");
|
||||
}
|
||||
|
||||
Game.chrome.renderer.RgbaSpriteRenderer.Flush();
|
||||
}
|
||||
|
||||
public override bool HandleInput(MouseInput mi)
|
||||
@@ -137,7 +84,6 @@ namespace OpenRA.Widgets
|
||||
action(mi);
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
66
OpenRA.Game/Widgets/OrderButtonWidget.cs
Normal file
66
OpenRA.Game/Widgets/OrderButtonWidget.cs
Normal file
@@ -0,0 +1,66 @@
|
||||
using System;
|
||||
using OpenRA.Graphics;
|
||||
using System.Drawing;
|
||||
namespace OpenRA.Widgets
|
||||
{
|
||||
public class OrderButtonWidget : ButtonWidget
|
||||
{
|
||||
public Func<bool> Enabled = () => true;
|
||||
public Func<bool> Pressed = () => false;
|
||||
|
||||
public string Image, Description, LongDesc = "";
|
||||
|
||||
public Func<string> GetImage, GetDescription, GetLongDesc;
|
||||
|
||||
public OrderButtonWidget()
|
||||
{
|
||||
GetImage = () => Enabled() ? Pressed() ? "pressed" : "normal" : "disabled";
|
||||
GetDescription = () => Description;
|
||||
GetLongDesc = () => LongDesc;
|
||||
}
|
||||
|
||||
public override void DrawInner (World world)
|
||||
{
|
||||
var image = ChromeProvider.GetImage(Game.chrome.renderer, Image + "-button", GetImage());
|
||||
var rect = new Rectangle(RenderBounds.X, RenderBounds.Y, (int)image.size.X, (int)image.size.Y);
|
||||
|
||||
if (rect.Contains(Game.chrome.lastMousePos.ToPoint()))
|
||||
{
|
||||
rect = rect.InflateBy(3, 3, 3, 3);
|
||||
var pos = new int2(rect.Left, rect.Top);
|
||||
var m = pos + new int2(rect.Width, rect.Height);
|
||||
var br = pos + new int2(rect.Width, rect.Height + 20);
|
||||
|
||||
var u = Game.chrome.renderer.RegularFont.Measure(GetLongDesc().Replace("\\n", "\n"));
|
||||
|
||||
br.X -= u.X;
|
||||
br.Y += u.Y;
|
||||
br += new int2(-15, 25);
|
||||
|
||||
var border = WidgetUtils.GetBorderSizes("dialog4");
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", rect
|
||||
.InflateBy(0, 0, 0, border[1]),
|
||||
PanelSides.Top | PanelSides.Left | PanelSides.Right);
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", new Rectangle(br.X, m.Y, pos.X - br.X, br.Y - m.Y)
|
||||
.InflateBy(0, 0, border[3], 0),
|
||||
PanelSides.Top | PanelSides.Left | PanelSides.Bottom);
|
||||
|
||||
WidgetUtils.DrawPanelPartial("dialog4", new Rectangle(pos.X, m.Y, m.X - pos.X, br.Y - m.Y)
|
||||
.InflateBy(border[2], border[0], 0, 0),
|
||||
PanelSides.Right | PanelSides.Bottom);
|
||||
|
||||
pos.X = br.X + 8;
|
||||
pos.Y = m.Y + 8;
|
||||
Game.chrome.renderer.BoldFont.DrawText(GetDescription(), pos, Color.White);
|
||||
|
||||
pos += new int2(0, 20);
|
||||
Game.chrome.renderer.RegularFont.DrawText(GetLongDesc().Replace("\\n", "\n"), pos, Color.White);
|
||||
}
|
||||
|
||||
Game.chrome.renderer.RgbaSpriteRenderer.DrawSprite(image, new int2(RenderBounds.X, RenderBounds.Y), "chrome");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user