Merge pull request #721 from Bond-009/imagedimensions

Change image dimentions from double to int
This commit is contained in:
Andrew Rabert 2019-01-26 14:12:40 -05:00 committed by GitHub
commit e051ca6ff6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
21 changed files with 92 additions and 204 deletions

View File

@ -1088,8 +1088,8 @@ namespace Emby.Dlna.Didl
//{ //{
// var size = _imageProcessor.GetImageSize(imageInfo); // var size = _imageProcessor.GetImageSize(imageInfo);
// width = Convert.ToInt32(size.Width); // width = size.Width;
// height = Convert.ToInt32(size.Height); // height = size.Height;
//} //}
//catch //catch
//{ //{
@ -1162,8 +1162,7 @@ namespace Emby.Dlna.Didl
info.ImageTag, info.ImageTag,
format, format,
maxWidth.ToString(CultureInfo.InvariantCulture), maxWidth.ToString(CultureInfo.InvariantCulture),
maxHeight.ToString(CultureInfo.InvariantCulture) maxHeight.ToString(CultureInfo.InvariantCulture));
);
var width = info.Width; var width = info.Width;
var height = info.Height; var height = info.Height;
@ -1172,15 +1171,11 @@ namespace Emby.Dlna.Didl
if (width.HasValue && height.HasValue) if (width.HasValue && height.HasValue)
{ {
var newSize = DrawingUtils.Resize(new ImageSize var newSize = DrawingUtils.Resize(
{ new ImageDimensions(width.Value, height.Value), 0, 0, maxWidth, maxHeight);
Height = height.Value,
Width = width.Value
}, 0, 0, maxWidth, maxHeight); width = newSize.Width;
height = newSize.Height;
width = Convert.ToInt32(newSize.Width);
height = Convert.ToInt32(newSize.Height);
var normalizedFormat = format var normalizedFormat = format
.Replace("jpeg", "jpg", StringComparison.OrdinalIgnoreCase); .Replace("jpeg", "jpg", StringComparison.OrdinalIgnoreCase);

View File

@ -18,7 +18,6 @@ using MediaBrowser.Model.Extensions;
using MediaBrowser.Model.IO; using MediaBrowser.Model.IO;
using MediaBrowser.Model.Net; using MediaBrowser.Model.Net;
using Microsoft.Extensions.Logging; using Microsoft.Extensions.Logging;
using SkiaSharp;
namespace Emby.Drawing namespace Emby.Drawing
{ {
@ -66,7 +65,7 @@ namespace Emby.Drawing
_appPaths = appPaths; _appPaths = appPaths;
ImageEnhancers = Array.Empty<IImageEnhancer>(); ImageEnhancers = Array.Empty<IImageEnhancer>();
ImageHelper.ImageProcessor = this; ImageHelper.ImageProcessor = this;
} }
@ -168,10 +167,10 @@ namespace Emby.Drawing
string originalImagePath = originalImage.Path; string originalImagePath = originalImage.Path;
DateTime dateModified = originalImage.DateModified; DateTime dateModified = originalImage.DateModified;
ImageSize? originalImageSize = null; ImageDimensions? originalImageSize = null;
if (originalImage.Width > 0 && originalImage.Height > 0) if (originalImage.Width > 0 && originalImage.Height > 0)
{ {
originalImageSize = new ImageSize(originalImage.Width, originalImage.Height); originalImageSize = new ImageDimensions(originalImage.Width, originalImage.Height);
} }
if (!_imageEncoder.SupportsImageEncoding) if (!_imageEncoder.SupportsImageEncoding)
@ -231,7 +230,7 @@ namespace Emby.Drawing
return (originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified); return (originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified);
} }
ImageSize newSize = ImageHelper.GetNewImageSize(options, null); ImageDimensions newSize = ImageHelper.GetNewImageSize(options, null);
int quality = options.Quality; int quality = options.Quality;
ImageFormat outputFormat = GetOutputFormat(options.SupportedOutputFormats, requiresTransparency); ImageFormat outputFormat = GetOutputFormat(options.SupportedOutputFormats, requiresTransparency);
@ -334,7 +333,7 @@ namespace Emby.Drawing
/// <summary> /// <summary>
/// Gets the cache file path based on a set of parameters /// Gets the cache file path based on a set of parameters
/// </summary> /// </summary>
private string GetCacheFilePath(string originalPath, ImageSize outputSize, int quality, DateTime dateModified, ImageFormat format, bool addPlayedIndicator, double percentPlayed, int? unwatchedCount, int? blur, string backgroundColor, string foregroundLayer) private string GetCacheFilePath(string originalPath, ImageDimensions outputSize, int quality, DateTime dateModified, ImageFormat format, bool addPlayedIndicator, double percentPlayed, int? unwatchedCount, int? blur, string backgroundColor, string foregroundLayer)
{ {
var filename = originalPath var filename = originalPath
+ "width=" + outputSize.Width + "width=" + outputSize.Width
@ -378,26 +377,25 @@ namespace Emby.Drawing
return GetCachePath(ResizedImageCachePath, filename, "." + format.ToString().ToLower()); return GetCachePath(ResizedImageCachePath, filename, "." + format.ToString().ToLower());
} }
public ImageSize GetImageSize(BaseItem item, ItemImageInfo info) public ImageDimensions GetImageSize(BaseItem item, ItemImageInfo info)
=> GetImageSize(item, info, true); => GetImageSize(item, info, true);
public ImageSize GetImageSize(BaseItem item, ItemImageInfo info, bool updateItem) public ImageDimensions GetImageSize(BaseItem item, ItemImageInfo info, bool updateItem)
{ {
int width = info.Width; int width = info.Width;
int height = info.Height; int height = info.Height;
if (height > 0 && width > 0) if (height > 0 && width > 0)
{ {
return new ImageSize(width, height); return new ImageDimensions(width, height);
} }
string path = info.Path; string path = info.Path;
_logger.LogInformation("Getting image size for item {ItemType} {Path}", item.GetType().Name, path); _logger.LogInformation("Getting image size for item {ItemType} {Path}", item.GetType().Name, path);
var size = GetImageSize(path); ImageDimensions size = GetImageSize(path);
info.Width = size.Width;
info.Height = Convert.ToInt32(size.Height); info.Height = size.Height;
info.Width = Convert.ToInt32(size.Width);
if (updateItem) if (updateItem)
{ {
@ -410,20 +408,8 @@ namespace Emby.Drawing
/// <summary> /// <summary>
/// Gets the size of the image. /// Gets the size of the image.
/// </summary> /// </summary>
public ImageSize GetImageSize(string path) public ImageDimensions GetImageSize(string path)
{ => _imageEncoder.GetImageSize(path);
if (string.IsNullOrEmpty(path))
{
throw new ArgumentNullException(nameof(path));
}
using (var s = new SKFileStream(path))
using (var codec = SKCodec.Create(s))
{
var info = codec.Info;
return new ImageSize(info.Width, info.Height);
}
}
/// <summary> /// <summary>
/// Gets the image cache tag. /// Gets the image cache tag.

View File

@ -37,7 +37,7 @@ namespace Emby.Drawing
public bool SupportsImageEncoding => false; public bool SupportsImageEncoding => false;
public ImageSize GetImageSize(string path) public ImageDimensions GetImageSize(string path)
{ {
throw new NotImplementedException(); throw new NotImplementedException();
} }

View File

@ -8,7 +8,7 @@ namespace Emby.Drawing
{ {
private const int IndicatorHeight = 8; private const int IndicatorHeight = 8;
public static void Process(SKCanvas canvas, ImageSize imageSize, double percent) public static void Process(SKCanvas canvas, ImageDimensions imageSize, double percent)
{ {
using (var paint = new SKPaint()) using (var paint = new SKPaint())
{ {
@ -24,7 +24,7 @@ namespace Emby.Drawing
foregroundWidth /= 100; foregroundWidth /= 100;
paint.Color = SKColor.Parse("#FF52B54B"); paint.Color = SKColor.Parse("#FF52B54B");
canvas.DrawRect(SKRect.Create(0, (float)endY - IndicatorHeight, Convert.ToInt32(Math.Round(foregroundWidth)), (float)endY), paint); canvas.DrawRect(SKRect.Create(0, (float)endY - IndicatorHeight, Convert.ToInt32(foregroundWidth), (float)endY), paint);
} }
} }
} }

View File

@ -7,7 +7,7 @@ namespace Emby.Drawing
{ {
private const int OffsetFromTopRightCorner = 38; private const int OffsetFromTopRightCorner = 38;
public static void DrawPlayedIndicator(SKCanvas canvas, ImageSize imageSize) public static void DrawPlayedIndicator(SKCanvas canvas, ImageDimensions imageSize)
{ {
var x = imageSize.Width - OffsetFromTopRightCorner; var x = imageSize.Width - OffsetFromTopRightCorner;

View File

@ -168,18 +168,14 @@ namespace Emby.Drawing
} }
} }
public ImageSize GetImageSize(string path) public ImageDimensions GetImageSize(string path)
{ {
using (var s = new SKFileStream(path)) using (var s = new SKFileStream(path))
using (var codec = SKCodec.Create(s)) using (var codec = SKCodec.Create(s))
{ {
var info = codec.Info; var info = codec.Info;
return new ImageSize return new ImageDimensions(info.Width, info.Height);
{
Width = info.Width,
Height = info.Height
};
} }
} }
@ -513,7 +509,7 @@ namespace Emby.Drawing
//_logger.LogInformation("Color type {0}", bitmap.Info.ColorType); //_logger.LogInformation("Color type {0}", bitmap.Info.ColorType);
var originalImageSize = new ImageSize(bitmap.Width, bitmap.Height); var originalImageSize = new ImageDimensions(bitmap.Width, bitmap.Height);
if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize) && !autoOrient) if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize) && !autoOrient)
{ {
@ -523,8 +519,8 @@ namespace Emby.Drawing
var newImageSize = ImageHelper.GetNewImageSize(options, originalImageSize); var newImageSize = ImageHelper.GetNewImageSize(options, originalImageSize);
var width = Convert.ToInt32(Math.Round(newImageSize.Width)); var width = newImageSize.Width;
var height = Convert.ToInt32(Math.Round(newImageSize.Height)); var height = newImageSize.Height;
using (var resizedBitmap = new SKBitmap(width, height))//, bitmap.ColorType, bitmap.AlphaType)) using (var resizedBitmap = new SKBitmap(width, height))//, bitmap.ColorType, bitmap.AlphaType))
{ {
@ -626,7 +622,7 @@ namespace Emby.Drawing
{ {
try try
{ {
var currentImageSize = new ImageSize(imageWidth, imageHeight); var currentImageSize = new ImageDimensions(imageWidth, imageHeight);
if (options.AddPlayedIndicator) if (options.AddPlayedIndicator)
{ {

View File

@ -8,7 +8,7 @@ namespace Emby.Drawing
{ {
private const int OffsetFromTopRightCorner = 38; private const int OffsetFromTopRightCorner = 38;
public static void DrawUnplayedCountIndicator(SKCanvas canvas, ImageSize imageSize, int count) public static void DrawUnplayedCountIndicator(SKCanvas canvas, ImageDimensions imageSize, int count)
{ {
var x = imageSize.Width - OffsetFromTopRightCorner; var x = imageSize.Width - OffsetFromTopRightCorner;
var text = count.ToString(CultureInfo.InvariantCulture); var text = count.ToString(CultureInfo.InvariantCulture);

View File

@ -185,8 +185,8 @@ namespace Emby.Photos
if (size.Width > 0 && size.Height > 0) if (size.Width > 0 && size.Height > 0)
{ {
item.Width = Convert.ToInt32(size.Width); item.Width = size.Width;
item.Height = Convert.ToInt32(size.Height); item.Height = size.Height;
} }
} }
catch (ArgumentException) catch (ArgumentException)

View File

@ -1428,7 +1428,7 @@ namespace Emby.Server.Implementations.Dto
var supportedEnhancers = _imageProcessor.GetSupportedEnhancers(item, ImageType.Primary); var supportedEnhancers = _imageProcessor.GetSupportedEnhancers(item, ImageType.Primary);
ImageSize size; ImageDimensions size;
var defaultAspectRatio = item.GetDefaultPrimaryImageAspectRatio(); var defaultAspectRatio = item.GetDefaultPrimaryImageAspectRatio();
@ -1439,9 +1439,9 @@ namespace Emby.Server.Implementations.Dto
return defaultAspectRatio; return defaultAspectRatio;
} }
double dummyWidth = 200; int dummyWidth = 200;
double dummyHeight = dummyWidth / defaultAspectRatio; int dummyHeight = Convert.ToInt32(dummyWidth / defaultAspectRatio);
size = new ImageSize(dummyWidth, dummyHeight); size = new ImageDimensions(dummyWidth, dummyHeight);
} }
else else
{ {
@ -1481,7 +1481,7 @@ namespace Emby.Server.Implementations.Dto
var width = size.Width; var width = size.Width;
var height = size.Height; var height = size.Height;
if (width.Equals(0) || height.Equals(0)) if (width <= 0 || height <= 0)
{ {
return null; return null;
} }

View File

@ -328,10 +328,9 @@ namespace MediaBrowser.Api.Images
var fileInfo = _fileSystem.GetFileInfo(info.Path); var fileInfo = _fileSystem.GetFileInfo(info.Path);
length = fileInfo.Length; length = fileInfo.Length;
var size = _imageProcessor.GetImageSize(item, info, true); ImageDimensions size = _imageProcessor.GetImageSize(item, info, true);
width = size.Width;
width = Convert.ToInt32(size.Width); height = size.Height;
height = Convert.ToInt32(size.Height);
if (width <= 0 || height <= 0) if (width <= 0 || height <= 0)
{ {

View File

@ -44,6 +44,6 @@ namespace MediaBrowser.Controller.Drawing
/// <value><c>true</c> if [supports image encoding]; otherwise, <c>false</c>.</value> /// <value><c>true</c> if [supports image encoding]; otherwise, <c>false</c>.</value>
bool SupportsImageEncoding { get; } bool SupportsImageEncoding { get; }
ImageSize GetImageSize(string path); ImageDimensions GetImageSize(string path);
} }
} }

View File

@ -26,16 +26,16 @@ namespace MediaBrowser.Controller.Drawing
/// <value>The image enhancers.</value> /// <value>The image enhancers.</value>
IImageEnhancer[] ImageEnhancers { get; } IImageEnhancer[] ImageEnhancers { get; }
ImageSize GetImageSize(string path); ImageDimensions GetImageSize(string path);
/// <summary> /// <summary>
/// Gets the size of the image. /// Gets the size of the image.
/// </summary> /// </summary>
/// <param name="info">The information.</param> /// <param name="info">The information.</param>
/// <returns>ImageSize.</returns> /// <returns>ImageSize.</returns>
ImageSize GetImageSize(BaseItem item, ItemImageInfo info); ImageDimensions GetImageSize(BaseItem item, ItemImageInfo info);
ImageSize GetImageSize(BaseItem item, ItemImageInfo info, bool updateItem); ImageDimensions GetImageSize(BaseItem item, ItemImageInfo info, bool updateItem);
/// <summary> /// <summary>
/// Adds the parts. /// Adds the parts.

View File

@ -1,3 +1,4 @@
using System;
using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities;
using MediaBrowser.Model.Drawing; using MediaBrowser.Model.Drawing;
using MediaBrowser.Model.Entities; using MediaBrowser.Model.Entities;
@ -6,7 +7,7 @@ namespace MediaBrowser.Controller.Drawing
{ {
public static class ImageHelper public static class ImageHelper
{ {
public static ImageSize GetNewImageSize(ImageProcessingOptions options, ImageSize? originalImageSize) public static ImageDimensions GetNewImageSize(ImageProcessingOptions options, ImageDimensions? originalImageSize)
{ {
if (originalImageSize.HasValue) if (originalImageSize.HasValue)
{ {
@ -20,26 +21,26 @@ namespace MediaBrowser.Controller.Drawing
public static IImageProcessor ImageProcessor { get; set; } public static IImageProcessor ImageProcessor { get; set; }
private static ImageSize GetSizeEstimate(ImageProcessingOptions options) private static ImageDimensions GetSizeEstimate(ImageProcessingOptions options)
{ {
if (options.Width.HasValue && options.Height.HasValue) if (options.Width.HasValue && options.Height.HasValue)
{ {
return new ImageSize(options.Width.Value, options.Height.Value); return new ImageDimensions(options.Width.Value, options.Height.Value);
} }
var aspect = GetEstimatedAspectRatio(options.Image.Type, options.Item); double aspect = GetEstimatedAspectRatio(options.Image.Type, options.Item);
var width = options.Width ?? options.MaxWidth; int? width = options.Width ?? options.MaxWidth;
if (width.HasValue) if (width.HasValue)
{ {
var heightValue = width.Value / aspect; int heightValue = Convert.ToInt32((double)width.Value / aspect);
return new ImageSize(width.Value, heightValue); return new ImageDimensions(width.Value, heightValue);
} }
var height = options.Height ?? options.MaxHeight ?? 200; var height = options.Height ?? options.MaxHeight ?? 200;
var widthValue = aspect * height; int widthValue = Convert.ToInt32(aspect * height);
return new ImageSize(widthValue, height); return new ImageDimensions(widthValue, height);
} }
private static double GetEstimatedAspectRatio(ImageType type, BaseItem item) private static double GetEstimatedAspectRatio(ImageType type, BaseItem item)

View File

@ -57,7 +57,7 @@ namespace MediaBrowser.Controller.Drawing
!MaxHeight.HasValue; !MaxHeight.HasValue;
} }
public bool HasDefaultOptions(string originalImagePath, ImageSize? size) public bool HasDefaultOptions(string originalImagePath, ImageDimensions? size)
{ {
if (!size.HasValue) if (!size.HasValue)
{ {

View File

@ -2235,11 +2235,7 @@ namespace MediaBrowser.Controller.Entities
/// </exception> /// </exception>
/// <exception cref="ArgumentNullException">item</exception> /// <exception cref="ArgumentNullException">item</exception>
public string GetImagePath(ImageType imageType, int imageIndex) public string GetImagePath(ImageType imageType, int imageIndex)
{ => GetImageInfo(imageType, imageIndex)?.Path;
var info = GetImageInfo(imageType, imageIndex);
return info == null ? null : info.Path;
}
/// <summary> /// <summary>
/// Gets the image information. /// Gets the image information.

View File

@ -424,11 +424,9 @@ namespace MediaBrowser.Controller.MediaEncoding
if (state.VideoStream != null && state.VideoStream.Width.HasValue) if (state.VideoStream != null && state.VideoStream.Width.HasValue)
{ {
// This is hacky but not sure how to get the exact subtitle resolution // This is hacky but not sure how to get the exact subtitle resolution
double height = state.VideoStream.Width.Value; int height = Convert.ToInt32((double)state.VideoStream.Width.Value / 16.0 * 9.0);
height /= 16;
height *= 9;
arg += string.Format(" -canvas_size {0}:{1}", state.VideoStream.Width.Value.ToString(CultureInfo.InvariantCulture), Convert.ToInt32(height).ToString(CultureInfo.InvariantCulture)); arg += string.Format(" -canvas_size {0}:{1}", state.VideoStream.Width.Value.ToString(CultureInfo.InvariantCulture), height.ToString(CultureInfo.InvariantCulture));
} }
var subtitlePath = state.SubtitleStream.Path; var subtitlePath = state.SubtitleStream.Path;

View File

@ -319,7 +319,7 @@ namespace MediaBrowser.Controller.MediaEncoding
{ {
if (VideoStream != null && VideoStream.Width.HasValue && VideoStream.Height.HasValue) if (VideoStream != null && VideoStream.Width.HasValue && VideoStream.Height.HasValue)
{ {
var size = new ImageSize var size = new ImageDimensions
{ {
Width = VideoStream.Width.Value, Width = VideoStream.Width.Value,
Height = VideoStream.Height.Value Height = VideoStream.Height.Value
@ -331,7 +331,7 @@ namespace MediaBrowser.Controller.MediaEncoding
BaseRequest.MaxWidth ?? 0, BaseRequest.MaxWidth ?? 0,
BaseRequest.MaxHeight ?? 0); BaseRequest.MaxHeight ?? 0);
return Convert.ToInt32(newSize.Width); return newSize.Width;
} }
if (!IsVideoRequest) if (!IsVideoRequest)
@ -349,7 +349,7 @@ namespace MediaBrowser.Controller.MediaEncoding
{ {
if (VideoStream != null && VideoStream.Width.HasValue && VideoStream.Height.HasValue) if (VideoStream != null && VideoStream.Width.HasValue && VideoStream.Height.HasValue)
{ {
var size = new ImageSize var size = new ImageDimensions
{ {
Width = VideoStream.Width.Value, Width = VideoStream.Width.Value,
Height = VideoStream.Height.Value Height = VideoStream.Height.Value
@ -361,7 +361,7 @@ namespace MediaBrowser.Controller.MediaEncoding
BaseRequest.MaxWidth ?? 0, BaseRequest.MaxWidth ?? 0,
BaseRequest.MaxHeight ?? 0); BaseRequest.MaxHeight ?? 0);
return Convert.ToInt32(newSize.Height); return newSize.Height;
} }
if (!IsVideoRequest) if (!IsVideoRequest)

View File

@ -37,7 +37,7 @@ namespace MediaBrowser.Controller.Providers
/// <param name="imageIndex">Index of the image.</param> /// <param name="imageIndex">Index of the image.</param>
/// <param name="originalImageSize">Size of the original image.</param> /// <param name="originalImageSize">Size of the original image.</param>
/// <returns>ImageSize.</returns> /// <returns>ImageSize.</returns>
ImageSize GetEnhancedImageSize(BaseItem item, ImageType imageType, int imageIndex, ImageSize originalImageSize); ImageDimensions GetEnhancedImageSize(BaseItem item, ImageType imageType, int imageIndex, ImageDimensions originalImageSize);
EnhancedImageInfo GetEnhancedImageInfo(BaseItem item, string inputFile, ImageType imageType, int imageIndex); EnhancedImageInfo GetEnhancedImageInfo(BaseItem item, string inputFile, ImageType imageType, int imageIndex);

View File

@ -953,22 +953,11 @@ namespace MediaBrowser.Model.Dlna
if (videoStream != null && videoStream.Width.HasValue && videoStream.Height.HasValue) if (videoStream != null && videoStream.Width.HasValue && videoStream.Height.HasValue)
{ {
var size = new ImageSize ImageDimensions size = new ImageDimensions(videoStream.Width.Value, videoStream.Height.Value);
{
Width = videoStream.Width.Value,
Height = videoStream.Height.Value
};
double? maxWidth = MaxWidth.HasValue ? (double)MaxWidth.Value : (double?)null; size = DrawingUtils.Resize(size, 0, 0, MaxWidth ?? 0, MaxHeight ?? 0);
double? maxHeight = MaxHeight.HasValue ? (double)MaxHeight.Value : (double?)null;
var newSize = DrawingUtils.Resize(size, return size.Width;
0,
0,
maxWidth ?? 0,
maxHeight ?? 0);
return Convert.ToInt32(newSize.Width);
} }
return MaxWidth; return MaxWidth;
@ -983,22 +972,11 @@ namespace MediaBrowser.Model.Dlna
if (videoStream != null && videoStream.Width.HasValue && videoStream.Height.HasValue) if (videoStream != null && videoStream.Width.HasValue && videoStream.Height.HasValue)
{ {
var size = new ImageSize ImageDimensions size = new ImageDimensions(videoStream.Width.Value, videoStream.Height.Value);
{
Width = videoStream.Width.Value,
Height = videoStream.Height.Value
};
double? maxWidth = MaxWidth.HasValue ? (double)MaxWidth.Value : (double?)null; size = DrawingUtils.Resize(size, 0, 0, MaxWidth ?? 0, MaxHeight ?? 0);
double? maxHeight = MaxHeight.HasValue ? (double)MaxHeight.Value : (double?)null;
var newSize = DrawingUtils.Resize(size, return size.Height;
0,
0,
maxWidth ?? 0,
maxHeight ?? 0);
return Convert.ToInt32(newSize.Height);
} }
return MaxHeight; return MaxHeight;

View File

@ -1,3 +1,5 @@
using System;
namespace MediaBrowser.Model.Drawing namespace MediaBrowser.Model.Drawing
{ {
/// <summary> /// <summary>
@ -14,27 +16,25 @@ namespace MediaBrowser.Model.Drawing
/// <param name="maxWidth">A max fixed width, if desired</param> /// <param name="maxWidth">A max fixed width, if desired</param>
/// <param name="maxHeight">A max fixed height, if desired</param> /// <param name="maxHeight">A max fixed height, if desired</param>
/// <returns>A new size object</returns> /// <returns>A new size object</returns>
public static ImageSize Resize(ImageSize size, public static ImageDimensions Resize(ImageDimensions size,
double width, int width,
double height, int height,
double maxWidth, int maxWidth,
double maxHeight) int maxHeight)
{ {
double newWidth = size.Width; int newWidth = size.Width;
double newHeight = size.Height; int newHeight = size.Height;
if (width > 0 && height > 0) if (width > 0 && height > 0)
{ {
newWidth = width; newWidth = width;
newHeight = height; newHeight = height;
} }
else if (height > 0) else if (height > 0)
{ {
newWidth = GetNewWidth(newHeight, newWidth, height); newWidth = GetNewWidth(newHeight, newWidth, height);
newHeight = height; newHeight = height;
} }
else if (width > 0) else if (width > 0)
{ {
newHeight = GetNewHeight(newHeight, newWidth, width); newHeight = GetNewHeight(newHeight, newWidth, width);
@ -53,7 +53,7 @@ namespace MediaBrowser.Model.Drawing
newWidth = maxWidth; newWidth = maxWidth;
} }
return new ImageSize { Width = newWidth, Height = newHeight }; return new ImageDimensions(newWidth, newHeight);
} }
/// <summary> /// <summary>
@ -62,15 +62,9 @@ namespace MediaBrowser.Model.Drawing
/// <param name="currentHeight">Height of the current.</param> /// <param name="currentHeight">Height of the current.</param>
/// <param name="currentWidth">Width of the current.</param> /// <param name="currentWidth">Width of the current.</param>
/// <param name="newHeight">The new height.</param> /// <param name="newHeight">The new height.</param>
/// <returns>System.Double.</returns> /// <returns>the new width</returns>
private static double GetNewWidth(double currentHeight, double currentWidth, double newHeight) private static int GetNewWidth(int currentHeight, int currentWidth, int newHeight)
{ => Convert.ToInt32((double)newHeight / currentHeight * currentWidth);
double scaleFactor = newHeight;
scaleFactor /= currentHeight;
scaleFactor *= currentWidth;
return scaleFactor;
}
/// <summary> /// <summary>
/// Gets the new height. /// Gets the new height.
@ -79,13 +73,7 @@ namespace MediaBrowser.Model.Drawing
/// <param name="currentWidth">Width of the current.</param> /// <param name="currentWidth">Width of the current.</param>
/// <param name="newWidth">The new width.</param> /// <param name="newWidth">The new width.</param>
/// <returns>System.Double.</returns> /// <returns>System.Double.</returns>
private static double GetNewHeight(double currentHeight, double currentWidth, double newWidth) private static int GetNewHeight(int currentHeight, int currentWidth, int newWidth)
{ => Convert.ToInt32((double)newWidth / currentWidth * currentHeight);
double scaleFactor = newWidth;
scaleFactor /= currentWidth;
scaleFactor *= currentHeight;
return scaleFactor;
}
} }
} }

View File

@ -1,36 +1,23 @@
using System.Globalization;
namespace MediaBrowser.Model.Drawing namespace MediaBrowser.Model.Drawing
{ {
/// <summary> /// <summary>
/// Struct ImageSize /// Struct ImageSize
/// </summary> /// </summary>
public struct ImageSize public struct ImageDimensions
{ {
private double _height;
private double _width;
/// <summary> /// <summary>
/// Gets or sets the height. /// Gets or sets the height.
/// </summary> /// </summary>
/// <value>The height.</value> /// <value>The height.</value>
public double Height public int Height { get; set; }
{
get => _height;
set => _height = value;
}
/// <summary> /// <summary>
/// Gets or sets the width. /// Gets or sets the width.
/// </summary> /// </summary>
/// <value>The width.</value> /// <value>The width.</value>
public double Width public int Width { get; set; }
{
get => _width;
set => _width = value;
}
public bool Equals(ImageSize size) public bool Equals(ImageDimensions size)
{ {
return Width.Equals(size.Width) && Height.Equals(size.Height); return Width.Equals(size.Width) && Height.Equals(size.Height);
} }
@ -40,46 +27,10 @@ namespace MediaBrowser.Model.Drawing
return string.Format("{0}-{1}", Width, Height); return string.Format("{0}-{1}", Width, Height);
} }
public ImageSize(string value) public ImageDimensions(int width, int height)
{ {
_width = 0; Width = width;
Height = height;
_height = 0;
ParseValue(value);
}
public ImageSize(int width, int height)
{
_width = width;
_height = height;
}
public ImageSize(double width, double height)
{
_width = width;
_height = height;
}
private void ParseValue(string value)
{
if (!string.IsNullOrEmpty(value))
{
string[] parts = value.Split('-');
if (parts.Length == 2)
{
if (double.TryParse(parts[0], NumberStyles.Any, CultureInfo.InvariantCulture, out var val))
{
_width = val;
}
if (double.TryParse(parts[1], NumberStyles.Any, CultureInfo.InvariantCulture, out val))
{
_height = val;
}
}
}
} }
} }
} }