jellyfin/MediaBrowser.Model/Drawing/DrawingUtils.cs

147 lines
5.1 KiB
C#
Raw Normal View History

namespace MediaBrowser.Model.Drawing
2013-02-20 18:33:05 -07:00
{
/// <summary>
/// Class DrawingUtils
/// </summary>
public static class DrawingUtils
{
/// <summary>
/// Resizes a set of dimensions
/// </summary>
/// <param name="currentWidth">Width of the current.</param>
/// <param name="currentHeight">Height of the current.</param>
/// <param name="scaleFactor">The scale factor.</param>
/// <returns>ImageSize.</returns>
public static ImageSize Scale(double currentWidth, double currentHeight, double scaleFactor)
{
2014-05-08 13:09:53 -07:00
return Scale(new ImageSize
{
Width = currentWidth,
Height = currentHeight
}, scaleFactor);
2013-02-20 18:33:05 -07:00
}
/// <summary>
/// Resizes a set of dimensions
/// </summary>
/// <param name="size">The size.</param>
/// <param name="scaleFactor">The scale factor.</param>
/// <returns>ImageSize.</returns>
public static ImageSize Scale(ImageSize size, double scaleFactor)
{
double newWidth = size.Width * scaleFactor;
2013-02-20 18:33:05 -07:00
2014-05-08 13:09:53 -07:00
return Resize(size.Width, size.Height, newWidth, null, null, null);
2013-02-20 18:33:05 -07:00
}
/// <summary>
/// Resizes a set of dimensions
/// </summary>
/// <param name="currentWidth">Width of the current.</param>
/// <param name="currentHeight">Height of the current.</param>
/// <param name="width">The width.</param>
/// <param name="height">The height.</param>
/// <param name="maxWidth">A max fixed width, if desired</param>
/// <param name="maxHeight">A max fixed height, if desired</param>
/// <returns>ImageSize.</returns>
2014-05-08 13:09:53 -07:00
public static ImageSize Resize(double currentWidth,
double currentHeight,
double? width,
double? height,
double? maxWidth,
double? maxHeight)
2013-02-20 18:33:05 -07:00
{
2014-05-08 13:09:53 -07:00
return Resize(new ImageSize
{
Width = currentWidth,
Height = currentHeight
}, width, height, maxWidth, maxHeight);
2013-02-20 18:33:05 -07:00
}
/// <summary>
/// Resizes a set of dimensions
/// </summary>
/// <param name="size">The original size object</param>
/// <param name="width">A new fixed width, if desired</param>
/// <param name="height">A new fixed height, if desired</param>
/// <param name="maxWidth">A max fixed width, if desired</param>
/// <param name="maxHeight">A max fixed height, if desired</param>
/// <returns>A new size object</returns>
2014-05-08 13:09:53 -07:00
public static ImageSize Resize(ImageSize size,
double? width,
double? height,
double? maxWidth,
double? maxHeight)
2013-02-20 18:33:05 -07:00
{
double newWidth = size.Width;
double newHeight = size.Height;
if (width.HasValue && height.HasValue)
{
newWidth = width.Value;
newHeight = height.Value;
}
else if (height.HasValue)
{
newWidth = GetNewWidth(newHeight, newWidth, height.Value);
newHeight = height.Value;
}
else if (width.HasValue)
{
newHeight = GetNewHeight(newHeight, newWidth, width.Value);
newWidth = width.Value;
}
2014-05-08 13:09:53 -07:00
if (maxHeight.HasValue && maxHeight.Value < newHeight)
2013-02-20 18:33:05 -07:00
{
newWidth = GetNewWidth(newHeight, newWidth, maxHeight.Value);
newHeight = maxHeight.Value;
}
2014-05-08 13:09:53 -07:00
if (maxWidth.HasValue && maxWidth.Value < newWidth)
2013-02-20 18:33:05 -07:00
{
newHeight = GetNewHeight(newHeight, newWidth, maxWidth.Value);
newWidth = maxWidth.Value;
}
return new ImageSize { Width = newWidth, Height = newHeight };
}
/// <summary>
/// Gets the new width.
/// </summary>
/// <param name="currentHeight">Height of the current.</param>
/// <param name="currentWidth">Width of the current.</param>
/// <param name="newHeight">The new height.</param>
/// <returns>System.Double.</returns>
private static double GetNewWidth(double currentHeight, double currentWidth, double newHeight)
{
double scaleFactor = newHeight;
2013-02-20 18:33:05 -07:00
scaleFactor /= currentHeight;
scaleFactor *= currentWidth;
return scaleFactor;
}
/// <summary>
/// Gets the new height.
/// </summary>
/// <param name="currentHeight">Height of the current.</param>
/// <param name="currentWidth">Width of the current.</param>
/// <param name="newWidth">The new width.</param>
/// <returns>System.Double.</returns>
private static double GetNewHeight(double currentHeight, double currentWidth, double newWidth)
{
double scaleFactor = newWidth;
2013-02-20 18:33:05 -07:00
scaleFactor /= currentWidth;
scaleFactor *= currentHeight;
return scaleFactor;
}
}
}