Removed Rectangle from LocationContainer
mapped-ids-then-whole-percentages-to-location-container save-extracted-face save-extracted-java-script-object-notation
This commit is contained in:
@ -4,7 +4,6 @@ using System.Text.Json.Serialization;
|
||||
namespace View_by_Distance.Shared.Models;
|
||||
|
||||
public record ExifDirectory(AviDirectory[] AviDirectories,
|
||||
object? Encoding,
|
||||
ExifDirectoryBase[] ExifBaseDirectories,
|
||||
FileMetadataDirectory[] FileMetadataDirectories,
|
||||
FilePath FilePath,
|
||||
@ -28,25 +27,6 @@ public record ExifDirectory(AviDirectory[] AviDirectories,
|
||||
return result;
|
||||
}
|
||||
|
||||
public static ExifDirectory Get(object encoding, ExifDirectory e) =>
|
||||
new(e.AviDirectories,
|
||||
encoding,
|
||||
e.ExifBaseDirectories,
|
||||
e.FileMetadataDirectories,
|
||||
e.FilePath,
|
||||
e.GifHeaderDirectories,
|
||||
e.GpsDirectories,
|
||||
e.Height,
|
||||
e.JpegDirectories,
|
||||
e.MakernoteDirectories,
|
||||
e.PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
e.PhotoshopDirectories,
|
||||
e.PngDirectories,
|
||||
e.QuickTimeMovieHeaderDirectories,
|
||||
e.QuickTimeTrackHeaderDirectories,
|
||||
e.WebPDirectories,
|
||||
e.Width);
|
||||
|
||||
}
|
||||
|
||||
[JsonSourceGenerationOptions(WriteIndented = true, DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull)]
|
||||
|
@ -1,4 +1,5 @@
|
||||
using System.Drawing;
|
||||
using System.Text.Json;
|
||||
using System.Text.Json.Serialization;
|
||||
|
||||
namespace View_by_Distance.Shared.Models;
|
||||
|
||||
@ -10,22 +11,35 @@ public record LocationContainer(DateOnly? CreationDateOnly,
|
||||
int? LengthPermyriad,
|
||||
FilePath? LengthSource,
|
||||
PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName? PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
RectangleF? Rectangle,
|
||||
int? WholePercentages)
|
||||
{
|
||||
|
||||
public static LocationContainer Get(LocationContainer locationContainer, object? encoding, bool keepExifDirectory)
|
||||
public string GetWithoutEncoding()
|
||||
{
|
||||
string result;
|
||||
WithoutEncoding withoutEncoding = new(CreationDateOnly: CreationDateOnly,
|
||||
ExifDirectory: ExifDirectory,
|
||||
FaceFile: FaceFile,
|
||||
FilePath: FilePath,
|
||||
LengthPermyriad: LengthPermyriad,
|
||||
LengthSource: LengthSource,
|
||||
PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName: PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
WholePercentages: WholePercentages);
|
||||
result = JsonSerializer.Serialize(withoutEncoding, WithoutEncodingSourceGenerationContext.Default.WithoutEncoding);
|
||||
return result;
|
||||
}
|
||||
|
||||
public static LocationContainer Get(LocationContainer locationContainer, object? encoding)
|
||||
{
|
||||
LocationContainer result;
|
||||
result = new(CreationDateOnly: locationContainer.CreationDateOnly,
|
||||
ExifDirectory: keepExifDirectory ? locationContainer.ExifDirectory : null,
|
||||
ExifDirectory: locationContainer.ExifDirectory,
|
||||
Encoding: encoding,
|
||||
FaceFile: locationContainer.FaceFile,
|
||||
FilePath: locationContainer.FilePath,
|
||||
LengthPermyriad: locationContainer.LengthPermyriad,
|
||||
LengthSource: locationContainer.LengthSource,
|
||||
PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName: locationContainer.PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
Rectangle: locationContainer.Rectangle,
|
||||
WholePercentages: locationContainer.WholePercentages);
|
||||
return result;
|
||||
}
|
||||
@ -41,9 +55,23 @@ public record LocationContainer(DateOnly? CreationDateOnly,
|
||||
LengthPermyriad: lengthPermyriad,
|
||||
LengthSource: source.FilePath,
|
||||
PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName: locationContainer.PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
Rectangle: locationContainer.Rectangle,
|
||||
WholePercentages: locationContainer.WholePercentages);
|
||||
return result;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
internal record WithoutEncoding(DateOnly? CreationDateOnly,
|
||||
ExifDirectory? ExifDirectory,
|
||||
FaceFile? FaceFile,
|
||||
FilePath FilePath,
|
||||
int? LengthPermyriad,
|
||||
FilePath? LengthSource,
|
||||
PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName? PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName,
|
||||
int? WholePercentages);
|
||||
|
||||
[JsonSourceGenerationOptions(WriteIndented = true, DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull)]
|
||||
[JsonSerializable(typeof(WithoutEncoding))]
|
||||
internal partial class WithoutEncodingSourceGenerationContext : JsonSerializerContext
|
||||
{
|
||||
}
|
@ -5,11 +5,6 @@ namespace View_by_Distance.Shared.Models.Stateless;
|
||||
public interface ILocation
|
||||
{
|
||||
|
||||
RectangleF? TestStatic_GetPercentagesRectangle(DistanceSettings distanceSettings, int wholePercentages) =>
|
||||
GetPercentagesRectangle(distanceSettings, wholePercentages);
|
||||
static RectangleF? GetPercentagesRectangle(DistanceSettings distanceSettings, int wholePercentages) =>
|
||||
Location.GetPercentagesRectangle(distanceSettings, wholePercentages);
|
||||
|
||||
Models.Location TestStatic_GetTrimBound(double detectionConfidence, Rectangle rectangle, int width, int height, int facesCount) =>
|
||||
TrimBound(detectionConfidence, rectangle, width, height, facesCount);
|
||||
static Models.Location TrimBound(double detectionConfidence, Rectangle rectangle, int width, int height, int facesCount) =>
|
||||
|
@ -1,6 +1,4 @@
|
||||
using System.Drawing;
|
||||
|
||||
namespace View_by_Distance.Shared.Models.Stateless;
|
||||
namespace View_by_Distance.Shared.Models.Stateless;
|
||||
|
||||
internal abstract class Location
|
||||
{
|
||||
@ -47,32 +45,4 @@ internal abstract class Location
|
||||
return result;
|
||||
}
|
||||
|
||||
internal static RectangleF? GetPercentagesRectangle(DistanceSettings distanceSettings, int wholePercentages)
|
||||
{
|
||||
RectangleF? result;
|
||||
string wp = wholePercentages.ToString();
|
||||
int length = (distanceSettings.LocationDigits - 1) / 4;
|
||||
string[] segments =
|
||||
[
|
||||
wp[..1],
|
||||
wp.Substring(1, length),
|
||||
wp.Substring(3, length),
|
||||
wp.Substring(5, length),
|
||||
wp.Substring(7, length)
|
||||
];
|
||||
if (string.Join(string.Empty, segments) != wp)
|
||||
result = null;
|
||||
else
|
||||
{
|
||||
if (!int.TryParse(segments[1], out int xWholePercent) || !int.TryParse(segments[2], out int yWholePercent) || !int.TryParse(segments[3], out int wWholePercent) || !int.TryParse(segments[4], out int hWholePercent))
|
||||
result = null;
|
||||
else
|
||||
{
|
||||
float factor = 100;
|
||||
result = new(xWholePercent / factor, yWholePercent / factor, wWholePercent / factor, hWholePercent / factor);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user