Files
flowframes/Flowframes/Media/GetFrameCountCached.cs

101 lines
3.1 KiB
C#
Raw Permalink Normal View History

2021-08-23 16:50:18 +02:00
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Linq;
2021-08-23 16:50:18 +02:00
using System.Threading.Tasks;
using Flowframes.Data;
using Flowframes.IO;
namespace Flowframes.Media
{
class GetFrameCountCached
{
private static Dictionary<QueryInfo, int> cache = new Dictionary<QueryInfo, int>();
2021-08-23 16:50:18 +02:00
public static async Task<int> GetFrameCountAsync(MediaFile mf, int retryCount = 3)
{
return await GetFrameCountAsync(mf.SourcePath, retryCount);
}
public static async Task<int> GetFrameCountAsync(string path, int retryCount = 3)
2021-08-23 16:50:18 +02:00
{
Logger.Log($"Getting frame count ({path})", true);
long filesize = IoUtils.GetPathSize(path);
2021-09-14 18:18:41 +02:00
QueryInfo hash = new QueryInfo(path, filesize);
2021-08-23 16:50:18 +02:00
if (filesize > 0 && CacheContains(hash))
{
Logger.Log($"Cache contains this hash, using cached value.", true);
return GetFromCache(hash);
}
else
{
Logger.Log($"Hash not cached, reading frame count.", true);
}
int frameCount;
if (IoUtils.IsPathDirectory(path))
{
frameCount = IoUtils.GetAmountOfFiles(path, false); // Count frames based on image file amount
}
2021-08-23 16:50:18 +02:00
else
{
if (path.IsConcatFile())
{
var lines = IoUtils.ReadFileLines(path);
var filtered = lines.Where(l => l.StartsWith("file '"));
frameCount = filtered.Count(); // Count frames from concat file
}
else
frameCount = await FfmpegCommands.GetFrameCountAsync(path); // Count frames from video stream
}
2021-08-23 16:50:18 +02:00
if (frameCount > 0)
{
Logger.Log($"Adding hash with value {frameCount} to cache.", true);
cache.Add(hash, frameCount);
}
else
{
if (retryCount > 0)
{
Logger.Log($"Got {frameCount} frames, retrying ({retryCount} left)", true);
Clear();
frameCount = await GetFrameCountAsync(path, retryCount - 1);
}
else
{
Logger.Log($"Failed to get frames and out of retries ({frameCount} frames for {path})", true);
}
}
2021-08-23 16:50:18 +02:00
return frameCount;
}
2021-09-14 18:18:41 +02:00
private static bool CacheContains(QueryInfo hash)
2021-08-23 16:50:18 +02:00
{
2021-09-14 18:18:41 +02:00
foreach (KeyValuePair<QueryInfo, int> entry in cache)
2021-08-23 16:50:18 +02:00
if (entry.Key.path == hash.path && entry.Key.filesize == hash.filesize)
return true;
return false;
}
2021-09-14 18:18:41 +02:00
private static int GetFromCache(QueryInfo hash)
2021-08-23 16:50:18 +02:00
{
2021-09-14 18:18:41 +02:00
foreach (KeyValuePair<QueryInfo, int> entry in cache)
2021-08-23 16:50:18 +02:00
if (entry.Key.path == hash.path && entry.Key.filesize == hash.filesize)
return entry.Value;
return 0;
}
public static void Clear()
{
cache.Clear();
}
2021-08-23 16:50:18 +02:00
}
}