Populate the list from yaml; Define ra-allies movies; Additional polish.

This commit is contained in:
Paul Chote
2010-08-12 19:31:29 +12:00
parent 0f953226a6
commit 11aed465a8
7 changed files with 97 additions and 32 deletions

View File

@@ -257,7 +257,7 @@ namespace OpenRA.FileFormats
} }
} }
int cachedFrame; int cachedFrame = -1;
public int[,] FrameData { get public int[,] FrameData { get
{ {
if (cachedFrame != currentFrame) if (cachedFrame != currentFrame)

View File

@@ -56,7 +56,7 @@ namespace OpenRA.FileFormats
public readonly string[] public readonly string[]
Folders, Packages, Rules, Folders, Packages, Rules,
Sequences, Chrome, Assemblies, ChromeLayout, Sequences, Chrome, Assemblies, ChromeLayout,
Weapons, Voices, Music, TileSets; Weapons, Voices, Music, Movies, TileSets;
public readonly string ShellmapUid; public readonly string ShellmapUid;
@@ -76,6 +76,7 @@ namespace OpenRA.FileFormats
Weapons = YamlList(yaml, "Weapons"); Weapons = YamlList(yaml, "Weapons");
Voices = YamlList(yaml, "Voices"); Voices = YamlList(yaml, "Voices");
Music = YamlList(yaml, "Music"); Music = YamlList(yaml, "Music");
Movies = YamlList(yaml, "Movies");
TileSets = YamlList(yaml, "TileSets"); TileSets = YamlList(yaml, "TileSets");
ShellmapUid = yaml["ShellmapUid"].Value; ShellmapUid = yaml["ShellmapUid"].Value;

View File

@@ -24,6 +24,7 @@ namespace OpenRA
public static Dictionary<string, WeaponInfo> Weapons; public static Dictionary<string, WeaponInfo> Weapons;
public static Dictionary<string, VoiceInfo> Voices; public static Dictionary<string, VoiceInfo> Voices;
public static Dictionary<string, MusicInfo> Music; public static Dictionary<string, MusicInfo> Music;
public static Dictionary<string, string> Movies;
public static Dictionary<string, TileSet> TileSets; public static Dictionary<string, TileSet> TileSets;
public static void LoadRules(Manifest m, Map map) public static void LoadRules(Manifest m, Map map)
@@ -32,6 +33,7 @@ namespace OpenRA
Weapons = LoadYamlRules(m.Weapons, map.Weapons, (k, _) => new WeaponInfo(k.Key.ToLowerInvariant(), k.Value)); Weapons = LoadYamlRules(m.Weapons, map.Weapons, (k, _) => new WeaponInfo(k.Key.ToLowerInvariant(), k.Value));
Voices = LoadYamlRules(m.Voices, map.Voices, (k, _) => new VoiceInfo(k.Value)); Voices = LoadYamlRules(m.Voices, map.Voices, (k, _) => new VoiceInfo(k.Value));
Music = LoadYamlRules(m.Music, map.Music, (k, _) => new MusicInfo(k.Value)); Music = LoadYamlRules(m.Music, map.Music, (k, _) => new MusicInfo(k.Value));
Movies = LoadYamlRules(m.Movies, new Dictionary<string,MiniYaml>(), (k, v) => k.Value.Value);
TileSets = new Dictionary<string, TileSet>(); TileSets = new Dictionary<string, TileSet>();
foreach (var file in m.TileSets) foreach (var file in m.TileSets)

View File

@@ -16,17 +16,13 @@ namespace OpenRA.Widgets.Delegates
{ {
public class VideoPlayerDelegate : IWidgetDelegate public class VideoPlayerDelegate : IWidgetDelegate
{ {
string Selected = null; string Selected;
public VideoPlayerDelegate() public VideoPlayerDelegate()
{ {
var bg = Widget.RootWidget.GetWidget("VIDEOPLAYER_MENU"); var bg = Widget.RootWidget.GetWidget("VIDEOPLAYER_MENU");
var player = bg.GetWidget<VqaPlayerWidget>("VIDEOPLAYER"); var player = bg.GetWidget<VqaPlayerWidget>("VIDEOPLAYER");
bg.GetWidget("BUTTON_PLAY").OnMouseUp = mi => bg.GetWidget("BUTTON_PLAY").OnMouseUp = mi =>
{ {
if (Selected == null)
return true;
player.Load(Selected);
player.Play(); player.Play();
return true; return true;
}; };
@@ -53,14 +49,11 @@ namespace OpenRA.Widgets.Delegates
var itemTemplate = vl.GetWidget<LabelWidget>("VIDEO_TEMPLATE"); var itemTemplate = vl.GetWidget<LabelWidget>("VIDEO_TEMPLATE");
int offset = itemTemplate.Bounds.Y; int offset = itemTemplate.Bounds.Y;
// Todo: pull into per-mod yaml / Manifest Selected = Rules.Movies.Keys.FirstOrDefault();
var tempVideos = new Dictionary<string,string>(); if (Selected != null)
tempVideos.Add("obel.vqa", "Obelisk ZZZZAAAAAP"); player.Load(Selected);
tempVideos.Add("ally1.vqa", "Allies briefing #1");
tempVideos.Add("ally10.vqa", "Allies briefing #10");
Selected = tempVideos.Keys.FirstOrDefault(); foreach (var kv in Rules.Movies)
foreach (var kv in tempVideos)
{ {
var video = kv.Key; var video = kv.Key;
var title = kv.Value; var title = kv.Value;
@@ -73,10 +66,8 @@ namespace OpenRA.Widgets.Delegates
template.GetBackground = () => ((video == Selected) ? "dialog2" : null); template.GetBackground = () => ((video == Selected) ? "dialog2" : null);
template.OnMouseDown = mi => template.OnMouseDown = mi =>
{ {
if (Selected == video)
return true;
player.Stop();
Selected = video; Selected = video;
player.Load(video);
return true; return true;
}; };
template.Parent = vl; template.Parent = vl;

View File

@@ -28,6 +28,12 @@ namespace OpenRA.Widgets
if (filename == cachedVideo) if (filename == cachedVideo)
return; return;
if (playing)
{
playing = false;
Sound.StopVideoSoundtrack();
}
cachedVideo = filename; cachedVideo = filename;
video = new VqaReader(FileSystem.Open(filename)); video = new VqaReader(FileSystem.Open(filename));
invLength = video.Framerate*1f/video.Frames; invLength = video.Framerate*1f/video.Frames;
@@ -35,7 +41,8 @@ namespace OpenRA.Widgets
var size = Math.Max(video.Width, video.Height); var size = Math.Max(video.Width, video.Height);
var textureSize = OpenRA.Graphics.Util.NextPowerOf2(size); var textureSize = OpenRA.Graphics.Util.NextPowerOf2(size);
videoSprite = new Sprite(new Sheet(new Size(textureSize,textureSize)), new Rectangle( 0, 0, video.Width, video.Height ), TextureChannel.Alpha); videoSprite = new Sprite(new Sheet(new Size(textureSize,textureSize)), new Rectangle( 0, 0, video.Width, video.Height ), TextureChannel.Alpha);
videoSprite.sheet.Texture.SetData(video.FrameData);
var scale = Math.Min(RenderBounds.Width / video.Width, RenderBounds.Height / video.Height); var scale = Math.Min(RenderBounds.Width / video.Width, RenderBounds.Height / video.Height);
videoOrigin = new float2(RenderBounds.X + (RenderBounds.Width - scale*video.Width)/2, RenderBounds.Y + (RenderBounds.Height - scale*video.Height)/2); videoOrigin = new float2(RenderBounds.X + (RenderBounds.Width - scale*video.Width)/2, RenderBounds.Y + (RenderBounds.Height - scale*video.Height)/2);
videoSize = new float2(video.Width * scale, video.Height * scale); videoSize = new float2(video.Width * scale, video.Height * scale);
@@ -45,38 +52,47 @@ namespace OpenRA.Widgets
Stopwatch sw = new Stopwatch(); Stopwatch sw = new Stopwatch();
public override void DrawInner(World world) public override void DrawInner(World world)
{ {
if (!playing) if (video == null)
return; return;
var nextFrame = (int)float2.Lerp(0, video.Frames, (float)(sw.ElapsedTime()*invLength));
if (nextFrame > video.Frames)
{
Stop();
return;
}
while (nextFrame > video.CurrentFrame) if (playing)
{ {
video.AdvanceFrame(); var nextFrame = (int)float2.Lerp(0, video.Frames, (float)(sw.ElapsedTime()*invLength));
if (nextFrame == video.CurrentFrame) if (nextFrame > video.Frames)
videoSprite.sheet.Texture.SetData(video.FrameData); {
Stop();
return;
}
while (nextFrame > video.CurrentFrame)
{
video.AdvanceFrame();
if (nextFrame == video.CurrentFrame)
videoSprite.sheet.Texture.SetData(video.FrameData);
}
} }
Game.Renderer.RgbaSpriteRenderer.DrawSprite(videoSprite, videoOrigin, "chrome", videoSize); Game.Renderer.RgbaSpriteRenderer.DrawSprite(videoSprite, videoOrigin, "chrome", videoSize);
} }
public void Play() public void Play()
{ {
if (playing || video == null)
return;
playing = true; playing = true;
video.Reset();
videoSprite.sheet.Texture.SetData(video.FrameData);
sw.Reset(); sw.Reset();
Sound.PlayVideoSoundtrack(video.AudioData); Sound.PlayVideoSoundtrack(video.AudioData);
} }
public void Stop() public void Stop()
{ {
if (!playing || video == null)
return;
playing = false; playing = false;
Sound.StopVideoSoundtrack(); Sound.StopVideoSoundtrack();
video.Reset();
videoSprite.sheet.Texture.SetData(video.FrameData);
} }
} }
} }

View File

@@ -20,6 +20,7 @@ Packages:
snow.mix snow.mix
interior.mix interior.mix
scores.mix scores.mix
~movies1.mix
Rules: Rules:
mods/ra/defaults.yaml mods/ra/defaults.yaml
@@ -61,4 +62,7 @@ TileSets:
Music: Music:
mods/ra/music.yaml mods/ra/music.yaml
Movies:
mods/ra/movies1.yaml
ShellmapUid:f78ab8d4d40ac3c263d1e404e5bf8233dce1f1a7 ShellmapUid:f78ab8d4d40ac3c263d1e404e5bf8233dce1f1a7

51
mods/ra/movies1.yaml Normal file
View File

@@ -0,0 +1,51 @@
aagun.vqa: a.a. gun shooting yak
aftrmath.vqa: iron curtain destroyed
ally1.vqa: get einstien
ally2.vqa: clear the way for the convoy
ally4.vqa: close the mountain pass
ally5.vqa: rescue tanya
ally6.vqa: find the iron curtain
ally8.vqa: protect the tech centre
ally9.vqa: rescue kosygin
ally10.vqa: stop nukes
ally10b.vqa: deactivate launch terminals
ally11.vqa: clear the river
ally12.vqa: infiltrate tech centers
ally14.vqa: final assult on moscow
allyend.vqa: stalin is dead
allymorf.vqa: allied logo
apcescpe.vqa: apc running away
assess.vqa: allied found iron curtain
battle.vqa: destroyed vechicles
binoc.vqa: guy viewing tanks through binoculars
bmap.vqa: dagger falls on map of europe & europe turns red
brdgtilt.vqa: a bridge
cronfail.vqa: chronosphere test failed
crontest.vqa: chronosphere test ok
destroyr.vqa: allied destroyers
dud.vqa: dud missile in london
elevator.vqa: inside soviet elevator
flare.vqa: flare man
frozen.vqa: frozen soldier
grvestne.vqa: tanya adams r.i.p.
landing.vqa: helicopter landing outside soviet base
masasslt.vqa: assault on moscow
mcv.vqa: mcv drives up
mcv_land.vqa: helicopter lands near mcv
montpass.vqa: truck drives over sign
oildrum.vqa: artillery blows up barrels
overrun.vqa: soldiers nearly run over
prolog.vqa: einstien eliminating hitler
redintro.vqa: red alert intro sequence
shipsink.vqa: ship sinking
shorbom1.vqa: ships attacking base
shorbom2.vqa: ships attacking base again
shorbomb.vqa: ships attacking another base
snowbomb.vqa: base being blown up in the snow
soviet1.vqa: kill the civillians
sovtstar.vqa: soviets logo
spy.vqa: spy infiltrating building
tanya1.vqa: tanya being interrogated
tanya2.vqa: tanya has been rescued
toofar.vqa: bridge being blown up
trinity.vqa: paris being nuked