Added drag direction mouse interaction for set the approach direction for airstrike and parabombs
This commit is contained in:
1
AUTHORS
1
AUTHORS
@@ -139,6 +139,7 @@ Also thanks to:
|
|||||||
* Teemu Nieminen (Temeez)
|
* Teemu Nieminen (Temeez)
|
||||||
* Tim Mylemans (gecko)
|
* Tim Mylemans (gecko)
|
||||||
* Tirili
|
* Tirili
|
||||||
|
* Tomas Einarsson (Mesacer)
|
||||||
* Tristan Keating (Kilkakon)
|
* Tristan Keating (Kilkakon)
|
||||||
* Tristan Mühlbacher (MicroBit)
|
* Tristan Mühlbacher (MicroBit)
|
||||||
* UnknownProgrammer
|
* UnknownProgrammer
|
||||||
|
|||||||
@@ -125,6 +125,8 @@ namespace OpenRA.Graphics
|
|||||||
|
|
||||||
public void Render(Renderer renderer) { }
|
public void Render(Renderer renderer) { }
|
||||||
|
|
||||||
|
public int Frame { get { return frame; } }
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
foreach (var cursors in hardwareCursors)
|
foreach (var cursors in hardwareCursors)
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ namespace OpenRA.Graphics
|
|||||||
void Render(Renderer renderer);
|
void Render(Renderer renderer);
|
||||||
void SetCursor(string cursor);
|
void SetCursor(string cursor);
|
||||||
void Tick();
|
void Tick();
|
||||||
|
int Frame { get; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public sealed class SoftwareCursor : ICursor
|
public sealed class SoftwareCursor : ICursor
|
||||||
@@ -77,7 +78,7 @@ namespace OpenRA.Graphics
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
var cursorSequence = cursorProvider.GetCursorSequence(cursorName);
|
var cursorSequence = cursorProvider.GetCursorSequence(cursorName);
|
||||||
var cursorSprite = sprites[cursorName][((int)cursorFrame % cursorSequence.Length)];
|
var cursorSprite = sprites[cursorName][Frame];
|
||||||
var cursorSize = CursorProvider.CursorViewportZoomed ? 2.0f * cursorSprite.Size : cursorSprite.Size;
|
var cursorSize = CursorProvider.CursorViewportZoomed ? 2.0f * cursorSprite.Size : cursorSprite.Size;
|
||||||
|
|
||||||
var cursorOffset = CursorProvider.CursorViewportZoomed ?
|
var cursorOffset = CursorProvider.CursorViewportZoomed ?
|
||||||
@@ -91,6 +92,15 @@ namespace OpenRA.Graphics
|
|||||||
cursorSize);
|
cursorSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int Frame
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
var cursorSequence = cursorProvider.GetCursorSequence(cursorName);
|
||||||
|
return (int)cursorFrame % cursorSequence.Length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
{
|
{
|
||||||
palette.Dispose();
|
palette.Dispose();
|
||||||
|
|||||||
@@ -331,6 +331,7 @@
|
|||||||
<Compile Include="Traits\Conditions\GrantExternalConditionToCrusher.cs" />
|
<Compile Include="Traits\Conditions\GrantExternalConditionToCrusher.cs" />
|
||||||
<Compile Include="Traits\Conditions\GrantRandomCondition.cs" />
|
<Compile Include="Traits\Conditions\GrantRandomCondition.cs" />
|
||||||
<Compile Include="Traits\Contrail.cs" />
|
<Compile Include="Traits\Contrail.cs" />
|
||||||
|
<Compile Include="Traits\SupportPowers\SelectDirectionalTarget.cs" />
|
||||||
<Compile Include="Traits\TemporaryOwnerManager.cs" />
|
<Compile Include="Traits\TemporaryOwnerManager.cs" />
|
||||||
<Compile Include="Traits\TooltipDescription.cs" />
|
<Compile Include="Traits\TooltipDescription.cs" />
|
||||||
<Compile Include="Traits\Health.cs" />
|
<Compile Include="Traits\Health.cs" />
|
||||||
|
|||||||
@@ -36,6 +36,12 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
[Desc("Amount of time to keep the camera alive after the aircraft have finished attacking")]
|
[Desc("Amount of time to keep the camera alive after the aircraft have finished attacking")]
|
||||||
public readonly int CameraRemoveDelay = 25;
|
public readonly int CameraRemoveDelay = 25;
|
||||||
|
|
||||||
|
[Desc("Placeholder cursor animation for the target cursor when the real cursor is invisible.")]
|
||||||
|
public readonly string TargetPlaceholderCursorAnimation = null;
|
||||||
|
|
||||||
|
[Desc("Animation used to render the direction arrows.")]
|
||||||
|
public readonly string DirectionArrowAnimation = null;
|
||||||
|
|
||||||
[Desc("Weapon range offset to apply during the beacon clock calculation")]
|
[Desc("Weapon range offset to apply during the beacon clock calculation")]
|
||||||
public readonly WDist BeaconDistanceOffset = WDist.FromCells(6);
|
public readonly WDist BeaconDistanceOffset = WDist.FromCells(6);
|
||||||
|
|
||||||
@@ -52,11 +58,19 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
this.info = info;
|
this.info = info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void SelectTarget(Actor self, string order, SupportPowerManager manager)
|
||||||
|
{
|
||||||
|
Game.Sound.PlayToPlayer(SoundType.UI, manager.Self.Owner, Info.SelectTargetSound);
|
||||||
|
Game.Sound.PlayNotification(self.World.Map.Rules, self.Owner, "Speech",
|
||||||
|
Info.SelectTargetSpeechNotification, self.Owner.Faction.InternalName);
|
||||||
|
|
||||||
|
self.World.OrderGenerator = new SelectDirectionalTarget(self.World, order, manager, Info.Cursor, info.TargetPlaceholderCursorAnimation, info.DirectionArrowAnimation);
|
||||||
|
}
|
||||||
|
|
||||||
public override void Activate(Actor self, Order order, SupportPowerManager manager)
|
public override void Activate(Actor self, Order order, SupportPowerManager manager)
|
||||||
{
|
{
|
||||||
base.Activate(self, order, manager);
|
base.Activate(self, order, manager);
|
||||||
|
SendAirstrike(self, order.Target.CenterPosition, order.ExtraData == uint.MaxValue, (int)order.ExtraData);
|
||||||
SendAirstrike(self, order.Target.CenterPosition);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SendAirstrike(Actor self, WPos target, bool randomize = true, int attackFacing = 0)
|
public void SendAirstrike(Actor self, WPos target, bool randomize = true, int attackFacing = 0)
|
||||||
|
|||||||
@@ -50,6 +50,12 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
[Desc("Amount of time (in ticks) to keep the camera alive while the passengers drop.")]
|
[Desc("Amount of time (in ticks) to keep the camera alive while the passengers drop.")]
|
||||||
public readonly int CameraRemoveDelay = 85;
|
public readonly int CameraRemoveDelay = 85;
|
||||||
|
|
||||||
|
[Desc("Placeholder cursor animation for the target cursor when the real cursor is invisible.")]
|
||||||
|
public readonly string TargetPlaceholderCursorAnimation = null;
|
||||||
|
|
||||||
|
[Desc("Animation used to render the direction arrows.")]
|
||||||
|
public readonly string DirectionArrowAnimation = null;
|
||||||
|
|
||||||
[Desc("Weapon range offset to apply during the beacon clock calculation.")]
|
[Desc("Weapon range offset to apply during the beacon clock calculation.")]
|
||||||
public readonly WDist BeaconDistanceOffset = WDist.FromCells(4);
|
public readonly WDist BeaconDistanceOffset = WDist.FromCells(4);
|
||||||
|
|
||||||
@@ -66,11 +72,20 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
this.info = info;
|
this.info = info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override void SelectTarget(Actor self, string order, SupportPowerManager manager)
|
||||||
|
{
|
||||||
|
Game.Sound.PlayToPlayer(SoundType.UI, manager.Self.Owner, Info.SelectTargetSound);
|
||||||
|
Game.Sound.PlayNotification(self.World.Map.Rules, self.Owner, "Speech",
|
||||||
|
Info.SelectTargetSpeechNotification, self.Owner.Faction.InternalName);
|
||||||
|
|
||||||
|
self.World.OrderGenerator = new SelectDirectionalTarget(self.World, order, manager, Info.Cursor, info.TargetPlaceholderCursorAnimation, info.DirectionArrowAnimation);
|
||||||
|
}
|
||||||
|
|
||||||
public override void Activate(Actor self, Order order, SupportPowerManager manager)
|
public override void Activate(Actor self, Order order, SupportPowerManager manager)
|
||||||
{
|
{
|
||||||
base.Activate(self, order, manager);
|
base.Activate(self, order, manager);
|
||||||
|
|
||||||
SendParatroopers(self, order.Target.CenterPosition);
|
SendParatroopers(self, order.Target.CenterPosition, order.ExtraData == uint.MaxValue, (int)order.ExtraData);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Actor[] SendParatroopers(Actor self, WPos target, bool randomize = true, int dropFacing = 0)
|
public Actor[] SendParatroopers(Actor self, WPos target, bool randomize = true, int dropFacing = 0)
|
||||||
|
|||||||
@@ -0,0 +1,186 @@
|
|||||||
|
#region Copyright & License Information
|
||||||
|
/*
|
||||||
|
* Copyright 2007-2019 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 System.Linq;
|
||||||
|
using OpenRA.Graphics;
|
||||||
|
using OpenRA.Traits;
|
||||||
|
|
||||||
|
namespace OpenRA.Mods.Common.Traits
|
||||||
|
{
|
||||||
|
public class SelectDirectionalTarget : IOrderGenerator
|
||||||
|
{
|
||||||
|
readonly string order;
|
||||||
|
readonly SupportPowerManager manager;
|
||||||
|
readonly string cursor;
|
||||||
|
readonly Animation targetCursor;
|
||||||
|
|
||||||
|
readonly string[] arrows = { "arrow-t", "arrow-tl", "arrow-l", "arrow-bl", "arrow-b", "arrow-br", "arrow-r", "arrow-tr" };
|
||||||
|
readonly Arrow[] directionArrows;
|
||||||
|
|
||||||
|
CPos targetCell;
|
||||||
|
int2 location;
|
||||||
|
int2 dragLocation;
|
||||||
|
bool beginDrag;
|
||||||
|
bool dragStarted;
|
||||||
|
Arrow currentArrow;
|
||||||
|
|
||||||
|
public SelectDirectionalTarget(World world, string order, SupportPowerManager manager, string cursor, string targetPlaceholderCursorAnimation,
|
||||||
|
string directionArrowAnimation)
|
||||||
|
{
|
||||||
|
this.order = order;
|
||||||
|
this.manager = manager;
|
||||||
|
this.cursor = cursor;
|
||||||
|
|
||||||
|
targetCursor = new Animation(world, targetPlaceholderCursorAnimation);
|
||||||
|
targetCursor.PlayRepeating("cursor");
|
||||||
|
|
||||||
|
for (var i = 0; i < Game.Cursor.Frame; i++)
|
||||||
|
targetCursor.Tick();
|
||||||
|
|
||||||
|
directionArrows = LoadArrows(directionArrowAnimation, world, arrows.Length);
|
||||||
|
}
|
||||||
|
|
||||||
|
IEnumerable<Order> IOrderGenerator.Order(World world, CPos cell, int2 worldPixel, MouseInput mi)
|
||||||
|
{
|
||||||
|
if (mi.Button == MouseButton.Right)
|
||||||
|
{
|
||||||
|
world.CancelInputMode();
|
||||||
|
yield break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mi.Button == MouseButton.Left && mi.Event == MouseInputEvent.Down)
|
||||||
|
{
|
||||||
|
if (!beginDrag)
|
||||||
|
{
|
||||||
|
targetCell = cell;
|
||||||
|
location = mi.Location;
|
||||||
|
beginDrag = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
yield break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mi.Event == MouseInputEvent.Move)
|
||||||
|
{
|
||||||
|
if (beginDrag)
|
||||||
|
{
|
||||||
|
dragLocation = mi.Location;
|
||||||
|
var angle = AngleBetween(location, dragLocation);
|
||||||
|
currentArrow = GetArrow(angle);
|
||||||
|
dragStarted = true;
|
||||||
|
|
||||||
|
yield break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mi.Button == MouseButton.Left && mi.Event == MouseInputEvent.Up)
|
||||||
|
{
|
||||||
|
yield return new Order(order, manager.Self, Target.FromCell(manager.Self.World, targetCell), false)
|
||||||
|
{
|
||||||
|
SuppressVisualFeedback = true,
|
||||||
|
ExtraData = IsOutsideDragZone ? (uint)currentArrow.Direction.Facing : uint.MaxValue
|
||||||
|
};
|
||||||
|
|
||||||
|
world.CancelInputMode();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void IOrderGenerator.Tick(World world)
|
||||||
|
{
|
||||||
|
targetCursor.Tick();
|
||||||
|
|
||||||
|
// Cancel the OG if we can't use the power
|
||||||
|
if (!manager.Powers.ContainsKey(order))
|
||||||
|
world.CancelInputMode();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool IsOutsideDragZone
|
||||||
|
{
|
||||||
|
get { return dragStarted && (dragLocation - location).Length > 20; }
|
||||||
|
}
|
||||||
|
|
||||||
|
IEnumerable<IRenderable> IOrderGenerator.Render(WorldRenderer wr, World world) { yield break; }
|
||||||
|
|
||||||
|
IEnumerable<IRenderable> IOrderGenerator.RenderAboveShroud(WorldRenderer wr, World world)
|
||||||
|
{
|
||||||
|
if (!beginDrag)
|
||||||
|
return Enumerable.Empty<IRenderable>();
|
||||||
|
|
||||||
|
var palette = wr.Palette("chrome");
|
||||||
|
var worldPx = wr.Viewport.ViewToWorldPx(location);
|
||||||
|
var worldPos = wr.ProjectedPosition(worldPx);
|
||||||
|
var renderables = new List<IRenderable>(targetCursor.Render(worldPos, WVec.Zero, -511, palette, 1 / wr.Viewport.Zoom));
|
||||||
|
|
||||||
|
if (IsOutsideDragZone)
|
||||||
|
renderables.Add(new SpriteRenderable(currentArrow.Sprite, worldPos, WVec.Zero, -511, palette, 1 / wr.Viewport.Zoom, true));
|
||||||
|
|
||||||
|
return renderables;
|
||||||
|
}
|
||||||
|
|
||||||
|
string IOrderGenerator.GetCursor(World world, CPos cell, int2 worldPixel, MouseInput mi) { return beginDrag ? "invisible" : cursor; }
|
||||||
|
|
||||||
|
// Starting at (0, -1) and rotating in CCW
|
||||||
|
static double AngleBetween(int2 p1, int2 p2)
|
||||||
|
{
|
||||||
|
var radian = Math.Atan2(p2.Y - p1.Y, p2.X - p1.X);
|
||||||
|
var d = radian * (180 / Math.PI);
|
||||||
|
if (d < 0.0)
|
||||||
|
d += 360.0;
|
||||||
|
var angle = 270.0 - d;
|
||||||
|
if (angle < 0)
|
||||||
|
angle += 360.0;
|
||||||
|
|
||||||
|
return angle;
|
||||||
|
}
|
||||||
|
|
||||||
|
Arrow GetArrow(double degree)
|
||||||
|
{
|
||||||
|
var arrow = directionArrows.FirstOrDefault(d => d.EndAngle >= degree);
|
||||||
|
return arrow ?? directionArrows[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
Arrow[] LoadArrows(string cursorAnimation, World world, int noOfDividingPoints)
|
||||||
|
{
|
||||||
|
var points = new Arrow[noOfDividingPoints];
|
||||||
|
var partAngle = 360 / noOfDividingPoints;
|
||||||
|
var i1 = partAngle / 2d;
|
||||||
|
|
||||||
|
for (var i = 0; i < noOfDividingPoints; i++)
|
||||||
|
{
|
||||||
|
var sprite = world.Map.Rules.Sequences.GetSequence(cursorAnimation, arrows[i]).GetSprite(0);
|
||||||
|
|
||||||
|
var angle = i * partAngle;
|
||||||
|
var direction = WAngle.FromDegrees(angle);
|
||||||
|
var endAngle = angle + i1;
|
||||||
|
|
||||||
|
points[i] = new Arrow(sprite, endAngle, direction);
|
||||||
|
}
|
||||||
|
|
||||||
|
return points;
|
||||||
|
}
|
||||||
|
|
||||||
|
class Arrow
|
||||||
|
{
|
||||||
|
public Sprite Sprite { get; private set; }
|
||||||
|
public double EndAngle { get; private set; }
|
||||||
|
public WAngle Direction { get; private set; }
|
||||||
|
|
||||||
|
public Arrow(Sprite sprite, double endAngle, WAngle direction)
|
||||||
|
{
|
||||||
|
Sprite = sprite;
|
||||||
|
EndAngle = endAngle;
|
||||||
|
Direction = direction;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -136,6 +136,8 @@ Cursors:
|
|||||||
sell-vehicle:
|
sell-vehicle:
|
||||||
Start: 154
|
Start: 154
|
||||||
Length: 24
|
Length: 24
|
||||||
|
invisible:
|
||||||
|
Start: 28
|
||||||
mouse3.shp: cursor
|
mouse3.shp: cursor
|
||||||
default:
|
default:
|
||||||
Start: 0
|
Start: 0
|
||||||
|
|||||||
@@ -628,6 +628,8 @@ HQ:
|
|||||||
ArrowSequence: arrow
|
ArrowSequence: arrow
|
||||||
ClockSequence: clock
|
ClockSequence: clock
|
||||||
CircleSequence: circles
|
CircleSequence: circles
|
||||||
|
TargetPlaceholderCursorAnimation: airstriketarget
|
||||||
|
DirectionArrowAnimation: airstrikedirection
|
||||||
SupportPowerChargeBar:
|
SupportPowerChargeBar:
|
||||||
Power:
|
Power:
|
||||||
Amount: -50
|
Amount: -50
|
||||||
|
|||||||
@@ -436,3 +436,47 @@ smokland:
|
|||||||
Length: 32
|
Length: 32
|
||||||
Tick: 120
|
Tick: 120
|
||||||
ZOffset: 1023
|
ZOffset: 1023
|
||||||
|
|
||||||
|
airstriketarget:
|
||||||
|
cursor: mouse2
|
||||||
|
Start: 88
|
||||||
|
Length: 8
|
||||||
|
Tick: 80
|
||||||
|
|
||||||
|
airstrikedirection:
|
||||||
|
arrow-t: mouse2
|
||||||
|
Start: 1
|
||||||
|
Y: -12
|
||||||
|
Offset: 0, -15, 0
|
||||||
|
arrow-tr: mouse2
|
||||||
|
Start: 2
|
||||||
|
X: 14
|
||||||
|
Y: -12
|
||||||
|
Offset: 7, -7, 0
|
||||||
|
arrow-r: mouse2
|
||||||
|
Start: 3
|
||||||
|
X: 14
|
||||||
|
Offset: 12, 0, 0
|
||||||
|
arrow-br: mouse2
|
||||||
|
Start: 4
|
||||||
|
X: 14
|
||||||
|
Y: 11
|
||||||
|
Offset: 7, 7, 0
|
||||||
|
arrow-b: mouse2
|
||||||
|
Start: 5
|
||||||
|
Y: 11
|
||||||
|
Offset: 0, 15, 0
|
||||||
|
arrow-bl: mouse2
|
||||||
|
Start: 6
|
||||||
|
X: -15
|
||||||
|
Y: 11
|
||||||
|
Offset: -7, 7, 0
|
||||||
|
arrow-l: mouse2
|
||||||
|
Start: 7
|
||||||
|
X: -15
|
||||||
|
Offset: -12, 0, 0
|
||||||
|
arrow-tl: mouse2
|
||||||
|
Start: 8
|
||||||
|
X: -15
|
||||||
|
Y: -12
|
||||||
|
Offset: -7, -7, 0
|
||||||
|
|||||||
@@ -8,14 +8,6 @@ Container@PLAYER_WIDGETS:
|
|||||||
X: 10
|
X: 10
|
||||||
Y: 10
|
Y: 10
|
||||||
Children:
|
Children:
|
||||||
SupportPowers@SUPPORT_PALETTE:
|
|
||||||
IconSize: 62, 46
|
|
||||||
IconSpriteOffset: -1, -1
|
|
||||||
TooltipContainer: TOOLTIP_CONTAINER
|
|
||||||
ReadyText: READY
|
|
||||||
HoldText: ON HOLD
|
|
||||||
HotkeyPrefix: SupportPower
|
|
||||||
HotkeyCount: 6
|
|
||||||
Container@PALETTE_FOREGROUND:
|
Container@PALETTE_FOREGROUND:
|
||||||
Children:
|
Children:
|
||||||
Image@ICON_TEMPLATE:
|
Image@ICON_TEMPLATE:
|
||||||
@@ -24,9 +16,18 @@ Container@PLAYER_WIDGETS:
|
|||||||
Y: 0 - 2
|
Y: 0 - 2
|
||||||
Width: 62
|
Width: 62
|
||||||
Height: 46
|
Height: 46
|
||||||
|
ClickThrough: false
|
||||||
IgnoreMouseOver: true
|
IgnoreMouseOver: true
|
||||||
ImageCollection: sidebar
|
ImageCollection: sidebar
|
||||||
ImageName: background-supportoverlay
|
ImageName: background-supportoverlay
|
||||||
|
SupportPowers@SUPPORT_PALETTE:
|
||||||
|
IconSize: 62, 46
|
||||||
|
IconSpriteOffset: -1, -1
|
||||||
|
TooltipContainer: TOOLTIP_CONTAINER
|
||||||
|
ReadyText: READY
|
||||||
|
HoldText: ON HOLD
|
||||||
|
HotkeyPrefix: SupportPower
|
||||||
|
HotkeyCount: 6
|
||||||
SupportPowerTimer@SUPPORT_POWER_TIMER:
|
SupportPowerTimer@SUPPORT_POWER_TIMER:
|
||||||
X: 80
|
X: 80
|
||||||
Y: 10
|
Y: 10
|
||||||
|
|||||||
@@ -200,6 +200,8 @@ Cursors:
|
|||||||
sell2:
|
sell2:
|
||||||
Start: 148
|
Start: 148
|
||||||
Length: 12
|
Length: 12
|
||||||
|
invisible:
|
||||||
|
Start: 34
|
||||||
nopower.shp: cursor
|
nopower.shp: cursor
|
||||||
powerdown-blocked:
|
powerdown-blocked:
|
||||||
Start: 0
|
Start: 0
|
||||||
|
|||||||
@@ -1461,6 +1461,8 @@ AFLD:
|
|||||||
ArrowSequence: arrow
|
ArrowSequence: arrow
|
||||||
ClockSequence: clock
|
ClockSequence: clock
|
||||||
CircleSequence: circles
|
CircleSequence: circles
|
||||||
|
TargetPlaceholderCursorAnimation: paratarget
|
||||||
|
DirectionArrowAnimation: paradirection
|
||||||
ParatroopersPower@paratroopers:
|
ParatroopersPower@paratroopers:
|
||||||
OrderName: SovietParatroopers
|
OrderName: SovietParatroopers
|
||||||
Prerequisites: aircraft.soviet
|
Prerequisites: aircraft.soviet
|
||||||
@@ -1479,6 +1481,8 @@ AFLD:
|
|||||||
ArrowSequence: arrow
|
ArrowSequence: arrow
|
||||||
ClockSequence: clock
|
ClockSequence: clock
|
||||||
CircleSequence: circles
|
CircleSequence: circles
|
||||||
|
TargetPlaceholderCursorAnimation: paratarget
|
||||||
|
DirectionArrowAnimation: paradirection
|
||||||
AirstrikePower@parabombs:
|
AirstrikePower@parabombs:
|
||||||
OrderName: UkraineParabombs
|
OrderName: UkraineParabombs
|
||||||
Prerequisites: aircraft.ukraine
|
Prerequisites: aircraft.ukraine
|
||||||
@@ -1498,6 +1502,8 @@ AFLD:
|
|||||||
ArrowSequence: arrow
|
ArrowSequence: arrow
|
||||||
ClockSequence: clock
|
ClockSequence: clock
|
||||||
CircleSequence: circles
|
CircleSequence: circles
|
||||||
|
TargetPlaceholderCursorAnimation: paratarget
|
||||||
|
DirectionArrowAnimation: paradirection
|
||||||
ProductionBar:
|
ProductionBar:
|
||||||
ProductionType: Aircraft
|
ProductionType: Aircraft
|
||||||
SupportPowerChargeBar:
|
SupportPowerChargeBar:
|
||||||
|
|||||||
@@ -627,3 +627,47 @@ ctflag:
|
|||||||
bib: mbGAP
|
bib: mbGAP
|
||||||
Length: *
|
Length: *
|
||||||
UseTilesetExtension: true
|
UseTilesetExtension: true
|
||||||
|
|
||||||
|
paratarget:
|
||||||
|
cursor: mouse
|
||||||
|
Start: 82
|
||||||
|
Length: 8
|
||||||
|
Tick: 80
|
||||||
|
|
||||||
|
paradirection:
|
||||||
|
arrow-t: mouse
|
||||||
|
Start: 1
|
||||||
|
Y: -7
|
||||||
|
Offset: 0, -19, 0
|
||||||
|
arrow-tr: mouse
|
||||||
|
Start: 2
|
||||||
|
X: 6
|
||||||
|
Y: -5
|
||||||
|
Offset: 15, -15, 0
|
||||||
|
arrow-r: mouse
|
||||||
|
Start: 3
|
||||||
|
X: 7
|
||||||
|
Offset: 19, 0, 0
|
||||||
|
arrow-br: mouse
|
||||||
|
Start: 4
|
||||||
|
X: 6
|
||||||
|
Y: 5
|
||||||
|
Offset: 15, 15, 0
|
||||||
|
arrow-b: mouse
|
||||||
|
Start: 5
|
||||||
|
Y: 7
|
||||||
|
Offset: 0, 19, 0
|
||||||
|
arrow-bl: mouse
|
||||||
|
Start: 6
|
||||||
|
X: -6
|
||||||
|
Y: 5
|
||||||
|
Offset: -15, 15, 0
|
||||||
|
arrow-l: mouse
|
||||||
|
Start: 7
|
||||||
|
X: -8
|
||||||
|
Offset: -19, 0, 0
|
||||||
|
arrow-tl: mouse
|
||||||
|
Start: 8
|
||||||
|
X: -6
|
||||||
|
y: 5
|
||||||
|
Offset: -15, -15, 0
|
||||||
|
|||||||
Reference in New Issue
Block a user