MoveViewport takes a float to allow for smoother panning. Added more scripting to shellmap
This commit is contained in:
committed by
Chris Forbes
parent
fc72066ed2
commit
ff7daf8727
2
OpenRA.Game/Game.cs
Normal file → Executable file
2
OpenRA.Game/Game.cs
Normal file → Executable file
@@ -43,7 +43,7 @@ namespace OpenRA
|
|||||||
public static Renderer Renderer;
|
public static Renderer Renderer;
|
||||||
public static bool HasInputFocus = false;
|
public static bool HasInputFocus = false;
|
||||||
|
|
||||||
public static void MoveViewport(int2 loc)
|
public static void MoveViewport(float2 loc)
|
||||||
{
|
{
|
||||||
viewport.Center(loc);
|
viewport.Center(loc);
|
||||||
}
|
}
|
||||||
|
|||||||
2
OpenRA.Game/Graphics/Viewport.cs
Normal file → Executable file
2
OpenRA.Game/Graphics/Viewport.cs
Normal file → Executable file
@@ -123,7 +123,7 @@ namespace OpenRA.Graphics
|
|||||||
return ViewToWorld(mi.Location);
|
return ViewToWorld(mi.Location);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Center(int2 loc)
|
public void Center(float2 loc)
|
||||||
{
|
{
|
||||||
scrollPosition = this.NormalizeScrollPosition(Game.CellSize*loc - .5f * new float2(Width, Height));
|
scrollPosition = this.NormalizeScrollPosition(Game.CellSize*loc - .5f * new float2(Width, Height));
|
||||||
}
|
}
|
||||||
|
|||||||
46
OpenRA.Mods.RA/DefaultShellmapScript.cs
Normal file → Executable file
46
OpenRA.Mods.RA/DefaultShellmapScript.cs
Normal file → Executable file
@@ -11,6 +11,7 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
|
using System;
|
||||||
|
|
||||||
namespace OpenRA.Mods.RA
|
namespace OpenRA.Mods.RA
|
||||||
{
|
{
|
||||||
@@ -18,29 +19,48 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
class DefaultShellmapScript: IWorldLoaded, ITick
|
class DefaultShellmapScript: IWorldLoaded, ITick
|
||||||
{
|
{
|
||||||
Dictionary<string, Actor> Actors;
|
Dictionary<string, Actor> Actors;
|
||||||
|
private static int2 ViewportOrigin;
|
||||||
|
|
||||||
public void WorldLoaded(World w)
|
public void WorldLoaded(World w)
|
||||||
{
|
{
|
||||||
Game.MoveViewport((.5f * (w.Map.TopLeft + w.Map.BottomRight).ToFloat2()).ToInt2());
|
int2 loc = (.5f * (w.Map.TopLeft + w.Map.BottomRight).ToFloat2()).ToInt2();
|
||||||
|
Game.MoveViewport(loc);
|
||||||
|
|
||||||
|
ViewportOrigin = loc;
|
||||||
|
|
||||||
Actors = w.WorldActor.Trait<SpawnMapActors>().Actors;
|
Actors = w.WorldActor.Trait<SpawnMapActors>().Actors;
|
||||||
Sound.SoundVolumeModifier = 0f;
|
Sound.SoundVolumeModifier = 0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ticks = 0;
|
int ticks = 0;
|
||||||
public void Tick(Actor self)
|
float speed = 4f;
|
||||||
{
|
public void Tick(Actor self)
|
||||||
|
{
|
||||||
|
var loc = new float2(
|
||||||
|
(float)(System.Math.Sin((ticks + 45) % (360f * speed) * (Math.PI / 180) * 1f / speed) * 15f + ViewportOrigin.X),
|
||||||
|
(float)(System.Math.Cos((ticks + 45) % (360f * speed) * (Math.PI / 180) * 1f / speed) * 10f + ViewportOrigin.Y));
|
||||||
|
|
||||||
|
Game.MoveViewport(loc);
|
||||||
|
|
||||||
if (ticks == 250)
|
if (ticks == 250)
|
||||||
{
|
{
|
||||||
Actors["pdox"].Trait<Chronosphere>().Teleport(Actors["ca1"], new int2(90, 70));
|
Actors["pdox"].Trait<Chronosphere>().Teleport(Actors["ca1"], new int2(90, 70));
|
||||||
Actors["pdox"].Trait<Chronosphere>().Teleport(Actors["ca2"], new int2(92, 71));
|
Actors["pdox"].Trait<Chronosphere>().Teleport(Actors["ca2"], new int2(92, 71));
|
||||||
|
}
|
||||||
|
if (ticks == 100)
|
||||||
|
Actors["mslo1"].Trait<NukeSilo>().Attack(new int2(98, 52));
|
||||||
|
if (ticks == 140)
|
||||||
|
Actors["mslo2"].Trait<NukeSilo>().Attack(new int2(95, 54));
|
||||||
|
if (ticks == 180)
|
||||||
|
Actors["mslo3"].Trait<NukeSilo>().Attack(new int2(95, 49));
|
||||||
|
|
||||||
|
if (ticks == 430)
|
||||||
|
{
|
||||||
|
Actors["mig1"].Trait<AttackPlane>().AttackTarget(Actors["mig1"], Actors["greeceweap"], true);
|
||||||
|
Actors["mig2"].Trait<AttackPlane>().AttackTarget(Actors["mig2"], Actors["greeceweap"], true);
|
||||||
|
Actors["mig3"].Trait<AttackPlane>().AttackTarget(Actors["mig3"], Actors["greeceweap"], true);
|
||||||
}
|
}
|
||||||
if (ticks == 100)
|
|
||||||
Actors["mslo1"].Trait<NukeSilo>().Attack(new int2(96,53));
|
|
||||||
if (ticks == 110)
|
|
||||||
Actors["mslo2"].Trait<NukeSilo>().Attack(new int2(92,53));
|
|
||||||
if (ticks == 120)
|
|
||||||
Actors["mslo3"].Trait<NukeSilo>().Attack(new int2(94,50));
|
|
||||||
|
|
||||||
ticks++;
|
ticks++;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
5065fbcb8e5b1b6cea2a003c64f9b48fcaa33e06
|
f1e5ed95dccfa5ba9c61f1263adffe17635ec069
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -77,4 +77,4 @@ Movies:
|
|||||||
mods/ra/movies2.yaml
|
mods/ra/movies2.yaml
|
||||||
|
|
||||||
LoadScreen: RALoadScreen
|
LoadScreen: RALoadScreen
|
||||||
ShellmapUid:5065fbcb8e5b1b6cea2a003c64f9b48fcaa33e06
|
ShellmapUid:f1e5ed95dccfa5ba9c61f1263adffe17635ec069
|
||||||
|
|||||||
Reference in New Issue
Block a user