Force Single Image

This commit is contained in:
2022-08-30 12:49:05 -07:00
parent 7f717258d2
commit 21c549e4ce
9 changed files with 101 additions and 77 deletions

View File

@ -10,8 +10,8 @@ namespace View_by_Distance.Map.Models;
public class MapLogic
{
protected readonly List<long> _NotMappedTicks;
protected readonly List<double> _SkipCollection;
protected readonly List<long> _NotMappedPersonKeys;
protected readonly List<(int, string[])> _AllCollection;
protected readonly Dictionary<int, int[]> _KeyValuePairs;
protected readonly Dictionary<int, int[]> _IndicesFromNew;
@ -49,7 +49,7 @@ public class MapLogic
string fullPath;
List<double> skipCollection = new();
Dictionary<int, int[]>? keyValuePairs;
List<long> notMappedPersonKeys = new();
List<long> notMappedTicks = new();
List<KeyValuePair<int, int[]>>? collection;
string deterministicHashCodeContentDirectory;
Dictionary<int, int[]> indicesFromNew = new();
@ -72,7 +72,7 @@ public class MapLogic
if (!Directory.Exists(deterministicHashCodeRootDirectory))
_ = Directory.CreateDirectory(deterministicHashCodeRootDirectory);
deterministicHashCodeContentDirectory = Path.Combine(deterministicHashCodeRootDirectory, "()");
Stateless.ByDeterministicHashCode.SetByRef(_ResizeFilenameExtension, people, skipCollection, peopleKeyValuePairs, notMappedPersonKeys, deterministicHashCodeUnknownFaceKeyValuePairs, deterministicHashCodeKeyValuePairs, incorrectDeterministicHashCodeKeyValuePairs, deterministicHashCodeRootDirectory, deterministicHashCodeContentDirectory);
Stateless.ByDeterministicHashCode.SetByRef(_ResizeFilenameExtension, people, skipCollection, peopleKeyValuePairs, notMappedTicks, deterministicHashCodeUnknownFaceKeyValuePairs, deterministicHashCodeKeyValuePairs, incorrectDeterministicHashCodeKeyValuePairs, deterministicHashCodeRootDirectory, deterministicHashCodeContentDirectory);
if (!deterministicHashCodeUnknownFaceKeyValuePairs.Any())
sixCharacterNamedFaceInfo = new();
else
@ -119,7 +119,7 @@ public class MapLogic
_KeyValuePairs = keyValuePairs;
_IndicesFromNew = indicesFromNew;
_SkipCollection = skipCollection;
_NotMappedPersonKeys = notMappedPersonKeys;
_NotMappedTicks = notMappedTicks;
_PeopleKeyValuePairs = peopleKeyValuePairs;
_SixCharacterNamedFaceInfo = sixCharacterNamedFaceInfo;
_DeterministicHashCodeKeyValuePairs = deterministicHashCodeKeyValuePairs;
@ -158,16 +158,16 @@ public class MapLogic
return results;
}
public void SaveShortcuts(string[] juliePhares, string dFacesContentDirectory, List<Item> items)
public void SaveShortcuts(string[] juliePhares, string zPropertyHolderContentDirectory, List<Item> items)
{
string fileName;
string fullName;
string personKey;
DateTime? minimumDateTime;
DateTime minimumDateTime;
PersonBirthday personBirthday;
WindowsShortcut windowsShortcut;
(string DisplayDirectoryName, int? ApproximateYears, PersonBirthday[] _, long Ticks) person;
List<(Item, (long?, Face?, (string, string, string, string))[])> collections = GetCollection(items, dFacesContentDirectory);
List<(Item, (long?, Face?, (string, string, string, string))[])> collections = GetCollection(items, zPropertyHolderContentDirectory);
foreach ((Item item, (long? ticks, Face? _, (string, string, string, string))[] collection) in collections)
{
if (collection.Length != 1)
@ -179,8 +179,6 @@ public class MapLogic
if (item.Property?.Id is null || item.ImageFileHolder is null || item.ResizedFileHolder is null)
continue;
minimumDateTime = Shared.Models.Stateless.Methods.IProperty.GetMinimumDateTime(item.Property);
if (minimumDateTime is null)
continue;
if (!Directory.Exists(directory))
{
_ = Directory.CreateDirectory(directory);
@ -206,12 +204,12 @@ public class MapLogic
fileName = Path.Combine(directory, $"{item.Property.Id.Value}.lnk");
if (File.Exists(fileName))
continue;
windowsShortcut = new() { Path = item.ImageFileHolder.FullName };
windowsShortcut = new() { Path = item.ResizedFileHolder.FullName };
windowsShortcut.Save(fileName);
windowsShortcut.Dispose();
if (!File.Exists(fileName))
continue;
File.SetLastWriteTime(fileName, minimumDateTime.Value);
File.SetLastWriteTime(fileName, minimumDateTime);
}
}
}
@ -314,6 +312,7 @@ public class MapLogic
{
long ticks;
Mapping mapping;
bool forced = false;
int? approximateYears;
string displayDirectoryName;
PersonBirthday personBirthday;
@ -344,7 +343,7 @@ public class MapLogic
personBirthday = person.PersonBirthdays[0];
approximateYears = person.ApproximateYears;
displayDirectoryName = person.DisplayDirectoryName;
mapping = new(approximateYears, displayDirectoryName, face.Location.NormalizedPixelPercentage, personBirthday);
mapping = new(approximateYears, displayDirectoryName, forced, face.Location.NormalizedPixelPercentage, personBirthday);
item.Mapping.Add(mapping);
}
}
@ -362,7 +361,7 @@ public class MapLogic
personBirthday = person.PersonBirthdays[0];
approximateYears = person.ApproximateYears;
displayDirectoryName = person.DisplayDirectoryName;
mapping = new(approximateYears, displayDirectoryName, personBirthday);
mapping = new(approximateYears, displayDirectoryName, forced, personBirthday);
item.Mapping.Add(mapping);
}
}
@ -420,7 +419,7 @@ public class MapLogic
}
}
public void SaveNotMappedPersonKeys(string zPropertyHolderContentDirectory)
public void SaveNotMappedTicks(string zPropertyHolderContentDirectory)
{
string directory;
string personKey;
@ -428,7 +427,7 @@ public class MapLogic
PersonBirthday personBirthday;
List<SaveContainer> saveContainers = new();
const string facePopulatedKey = nameof(Closest);
foreach (long ticks in _NotMappedPersonKeys)
foreach (long ticks in _NotMappedTicks)
{
personBirthday = Shared.Models.Stateless.Methods.IPersonBirthday.GetPersonBirthday(ticks);
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(personBirthday);
@ -439,7 +438,7 @@ public class MapLogic
SaveContainers(saveContainers);
}
public List<(Item, (long?, Face?, (string, string, string, string))[])> GetCollection(List<Item> items, string dFacesContentDirectory)
public List<(Item, (long?, Face?, (string, string, string, string))[])> GetCollection(List<Item> items, string zPropertyHolderContentDirectory)
{
List<(Item, (long?, Face?, (string, string, string, string))[])> results = new();
int years;
@ -457,8 +456,8 @@ public class MapLogic
string isWrongYearFlag;
string shortcutFileName;
string subDirectoryName;
DateTime minimumDateTime;
List<int> indices = new();
DateTime? minimumDateTime;
List<Face> faceCollection;
PersonBirthday personBirthday;
PersonBirthday[] personBirthdays;
@ -482,39 +481,37 @@ public class MapLogic
{
faceCollection = new();
ticks = null;
directory = Path.Combine(dFacesContentDirectory, $"Unnamed{relativePath[2..]}");
directory = Path.Combine(zPropertyHolderContentDirectory, $"Unnamed{relativePath[2..]}");
}
else
{
faceCollection = item.Faces;
personBirthdays = _DeterministicHashCodeUnknownFaceKeyValuePairs[item.Property.Id.Value];
minimumDateTime = Shared.Models.Stateless.Methods.IProperty.GetMinimumDateTime(item.Property);
if (minimumDateTime is null)
continue;
(isWrongYear, _) = item.Property.IsWrongYear(item.ImageFileHolder.FullName, minimumDateTime.Value);
(isWrongYear, _) = item.Property.IsWrongYear(item.ImageFileHolder.FullName, minimumDateTime);
isWrongYearFlag = Shared.Models.Stateless.Methods.IItem.GetWrongYearFlag(isWrongYear);
subDirectoryName = $"{isWrongYearFlag}{minimumDateTime.Value:yyyy}";
subDirectoryName = $"{isWrongYearFlag}{minimumDateTime:yyyy}";
if (!faceCollection.Any())
{
ticks = null;
directory = Path.Combine(dFacesContentDirectory, $"None{relativePath[2..]}", subDirectoryName);
directory = Path.Combine(zPropertyHolderContentDirectory, $"None{relativePath[2..]}", subDirectoryName);
}
else if (personBirthdays.Length != 1)
{
ticks = null;
directory = Path.Combine(dFacesContentDirectory, $"Not Supported{relativePath[2..]}", subDirectoryName);
directory = Path.Combine(zPropertyHolderContentDirectory, $"Not Supported{relativePath[2..]}", subDirectoryName);
}
else if (faceCollection.Count != 1)
{
ticks = null;
directory = Path.Combine(dFacesContentDirectory, $"Many{relativePath[2..]}", subDirectoryName);
directory = Path.Combine(zPropertyHolderContentDirectory, $"Many{relativePath[2..]}", subDirectoryName);
}
else
{
indices.Add(zero);
personBirthday = personBirthdays[zero];
ticks = personBirthday.Value.Ticks;
timeSpan = Shared.Models.Stateless.Methods.IPersonBirthday.GetTimeSpan(minimumDateTime.Value, isWrongYear, personBirthday);
timeSpan = Shared.Models.Stateless.Methods.IPersonBirthday.GetTimeSpan(minimumDateTime, isWrongYear, personBirthday);
if (timeSpan.HasValue)
{
if (timeSpan.Value.Ticks < 0)
@ -527,11 +524,11 @@ public class MapLogic
}
face = faceCollection[zero];
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(personBirthday);
directory = Path.Combine(dFacesContentDirectory, "Shortcuts", personKey, subDirectoryName);
directory = Path.Combine(zPropertyHolderContentDirectory, "Shortcuts", personKey, subDirectoryName);
if (face.FaceEncoding is not null && face.Location?.NormalizedPixelPercentage is not null)
copyDirectory = Path.Combine(dFacesContentDirectory, "Images", personKey, subDirectoryName);
copyDirectory = Path.Combine(zPropertyHolderContentDirectory, "Images", personKey, subDirectoryName);
else
copyDirectory = Path.Combine(dFacesContentDirectory, "ImagesBut", personKey, subDirectoryName);
copyDirectory = Path.Combine(zPropertyHolderContentDirectory, "ImagesBut", personKey, subDirectoryName);
copyFileName = Path.Combine(copyDirectory, $"{item.Property.Id.Value}{item.ResizedFileHolder.ExtensionLowered}");
}
}
@ -550,27 +547,21 @@ public class MapLogic
public void AddToClosest(int maxDegreeOfParallelism, string argZero, Container[] containers)
{
long ticks;
string key;
string dateKey;
Closest closest;
string personKey;
const int zero = 0;
DateTime minimumDateTime;
Closest[] closestCollection;
PersonBirthday personBirthday;
double deterministicHashCodeKey;
DateTime dateTime = DateTime.Now;
Dictionary<string, int> keyValuePairs = new();
foreach (Container container in containers)
{
if (!_NotMappedPersonKeys.Any())
break;
if (!container.Items.Any())
continue;
if (!container.SourceDirectory.StartsWith(argZero))
continue;
ticks = _NotMappedPersonKeys[zero];
foreach (Item item in container.Items)
{
if (item.ImageFileHolder is null || item.Property is null)
@ -581,15 +572,14 @@ public class MapLogic
continue;
deterministicHashCodeKey = Shared.Models.Stateless.Methods.IMapping.GetDeterministicHashCodeKey(item, face);
if (_DeterministicHashCodeKeyValuePairs.ContainsKey(deterministicHashCodeKey))
continue;
personBirthday = Shared.Models.Stateless.Methods.IPersonBirthday.GetPersonBirthday(ticks);
continue;
minimumDateTime = Shared.Models.Stateless.Methods.IProperty.GetMinimumDateTime(item.Property);
closestCollection = Shared.Models.Stateless.Methods.IClosest.GetCollection(personBirthday, face, minimumDateTime, face.FaceDistances);
closestCollection = Shared.Models.Stateless.Methods.IClosest.GetCollection(face, minimumDateTime, face.FaceDistances);
face.FaceDistances.Clear();
for (int j = 0; j < closestCollection.Length; j++)
{
closest = closestCollection[j];
if (_IncorrectDeterministicHashCodeKeyValuePairs.ContainsKey(deterministicHashCodeKey) && _IncorrectDeterministicHashCodeKeyValuePairs[deterministicHashCodeKey].Contains(personBirthday))
if (_IncorrectDeterministicHashCodeKeyValuePairs.ContainsKey(deterministicHashCodeKey) && _IncorrectDeterministicHashCodeKeyValuePairs[deterministicHashCodeKey].Contains(closest.Mapping.PersonBirthday))
continue;
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(closest.Mapping.PersonBirthday);
dateKey = Stateless.MapLogic.GetDateKey(dateTime, closest.Mapping, closest.MinimumDateTime, closest.IsWrongYear);
@ -663,6 +653,8 @@ public class MapLogic
continue;
foreach (Closest closest in item.Closest)
{
if (closest.Mapping.Forced)
continue;
if (closest.NormalizedPixelPercentage != face.Location.NormalizedPixelPercentage.Value)
continue;
throw new Exception();
@ -728,6 +720,8 @@ public class MapLogic
continue;
foreach (Closest closest in item.Closest)
{
if (closest.Mapping.Forced)
continue;
if (closest.NormalizedPixelPercentage != face.Location.NormalizedPixelPercentage.Value)
continue;
throw new Exception();
@ -792,6 +786,7 @@ public class MapLogic
FileHolder faceFileHolder;
string facePartsDirectory;
SaveContainer saveContainer;
PersonBirthday personBirthday;
FileHolder facePartsFileHolder;
FileHolder hiddenFaceFileHolder;
double deterministicHashCodeKey;
@ -829,11 +824,28 @@ public class MapLogic
continue;
foreach (Mapping mapping in item.Mapping)
{
if (mapping.Forced)
continue;
if (mapping.NormalizedPixelPercentage is null || mapping.NormalizedPixelPercentage.Value != face.Location.NormalizedPixelPercentage.Value)
continue;
throw new Exception();
}
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(match.Mapping.PersonBirthday);
if (!match.AboveTolerance)
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(match.Mapping.PersonBirthday);
else
{
personKey = string.Empty;
foreach (long ticks in _NotMappedTicks)
{
if (ticks == match.Mapping.PersonBirthday.Value.Ticks)
continue;
personBirthday = Shared.Models.Stateless.Methods.IPersonBirthday.GetPersonBirthday(ticks);
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(personBirthday);
break;
}
if (string.IsNullOrEmpty(personKey))
personKey = Shared.Models.Stateless.Methods.IPersonBirthday.GetFormatted(match.Mapping.PersonBirthday);
}
dateKey = Stateless.MapLogic.GetDateKey(dateTime, match.Mapping, match.MinimumDateTime, match.IsWrongYear);
directory = Path.Combine(zPropertyHolderContentDirectory, facePopulatedKey, personKey, dateKey);
personDirectory = Path.Combine(directory, match.Mapping.DisplayDirectoryName[..1], "lnk");
@ -902,17 +914,22 @@ public class MapLogic
SaveContainers(saveContainers);
}
public void SetSingleImage(string[] ignoreRelativePaths, string argZero, Container[] containers)
public void ForceSingleImage(string[] ignoreRelativePaths, string argZero, Container[] containers)
{
Closest closest;
Mapping mapping;
bool? isWrongYear;
long? ticks = null;
const int zero = 0;
bool forced = true;
DateTime minimumDateTime;
bool aboveTolerance = false;
int? approximateYears = null;
PersonBirthday personBirthday;
const string displayDirectoryName = Property.Models.Stateless.IResult.AllInOne;
foreach (Container container in containers)
{
if (!_NotMappedPersonKeys.Any())
if (!_NotMappedTicks.Any())
break;
if (!container.Items.Any())
continue;
@ -922,15 +939,19 @@ public class MapLogic
continue;
foreach (Item item in container.Items)
{
if (item.ImageFileHolder is null || item.Property?.Id is null)
if (item.ImageFileHolder is null || item.Property?.Id is null || item.Mapping.Any())
continue;
foreach (Face face in item.Faces)
{
if (face.FaceEncoding is null || face.Location?.NormalizedPixelPercentage is null)
continue;
ticks = _NotMappedPersonKeys[zero];
ticks = _NotMappedTicks[zero];
minimumDateTime = Shared.Models.Stateless.Methods.IProperty.GetMinimumDateTime(item.Property);
(isWrongYear, _) = item.Property.IsWrongYear(item.ImageFileHolder.FullName, minimumDateTime);
personBirthday = Shared.Models.Stateless.Methods.IPersonBirthday.GetPersonBirthday(ticks.Value);
mapping = new(approximateYears, displayDirectoryName, face.Location.NormalizedPixelPercentage, personBirthday);
mapping = new(approximateYears, displayDirectoryName, forced, face.Location.NormalizedPixelPercentage, personBirthday);
closest = new(aboveTolerance, zero, face.Location.NormalizedPixelPercentage.Value, isWrongYear, mapping, zero, minimumDateTime, null);
item.Closest.Add(closest);
item.Mapping.Add(mapping);
if (ticks is not null)
break;