(mostly)Fix ResizeFill

pull/5556/head
Odd Stråbø 4 years ago
parent 383aa4e4d9
commit 13d0837b78

@ -521,6 +521,8 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] string? tag, [FromQuery] string? tag,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] ImageFormat? format, [FromQuery] ImageFormat? format,
@ -530,9 +532,7 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetItemById(itemId); var item = _libraryManager.GetItemById(itemId);
if (item == null) if (item == null)
@ -553,8 +553,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -607,6 +607,8 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] string? tag, [FromQuery] string? tag,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] ImageFormat? format, [FromQuery] ImageFormat? format,
@ -615,9 +617,7 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? unplayedCount, [FromQuery] int? unplayedCount,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetItemById(itemId); var item = _libraryManager.GetItemById(itemId);
if (item == null) if (item == null)
@ -638,8 +638,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -691,6 +691,8 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromRoute, Required] string tag, [FromRoute, Required] string tag,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromRoute, Required] ImageFormat format, [FromRoute, Required] ImageFormat format,
@ -700,9 +702,7 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromRoute, Required] int imageIndex, [FromRoute, Required] int imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetItemById(itemId); var item = _libraryManager.GetItemById(itemId);
if (item == null) if (item == null)
@ -723,8 +723,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -780,14 +780,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromRoute, Required] int imageIndex, [FromRoute, Required] int imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetArtist(name); var item = _libraryManager.GetArtist(name);
if (item == null) if (item == null)
@ -808,8 +808,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -865,14 +865,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetGenre(name); var item = _libraryManager.GetGenre(name);
if (item == null) if (item == null)
@ -893,8 +893,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -951,13 +951,13 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetGenre(name); var item = _libraryManager.GetGenre(name);
if (item == null) if (item == null)
@ -978,8 +978,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1035,14 +1035,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetMusicGenre(name); var item = _libraryManager.GetMusicGenre(name);
if (item == null) if (item == null)
@ -1063,8 +1063,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1121,13 +1121,13 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetMusicGenre(name); var item = _libraryManager.GetMusicGenre(name);
if (item == null) if (item == null)
@ -1148,8 +1148,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1205,14 +1205,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetPerson(name); var item = _libraryManager.GetPerson(name);
if (item == null) if (item == null)
@ -1233,8 +1233,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1291,13 +1291,13 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetPerson(name); var item = _libraryManager.GetPerson(name);
if (item == null) if (item == null)
@ -1318,8 +1318,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1375,14 +1375,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetStudio(name); var item = _libraryManager.GetStudio(name);
if (item == null) if (item == null)
@ -1403,8 +1403,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1461,13 +1461,13 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var item = _libraryManager.GetStudio(name); var item = _libraryManager.GetStudio(name);
if (item == null) if (item == null)
@ -1488,8 +1488,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1545,14 +1545,14 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer,
[FromQuery] int? imageIndex, [FromQuery] int? imageIndex)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var user = _userManager.GetUserById(userId); var user = _userManager.GetUserById(userId);
if (user?.ProfileImage == null) if (user?.ProfileImage == null)
@ -1590,8 +1590,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1649,13 +1649,13 @@ namespace Jellyfin.Api.Controllers
[FromQuery] int? width, [FromQuery] int? width,
[FromQuery] int? height, [FromQuery] int? height,
[FromQuery] int? quality, [FromQuery] int? quality,
[FromQuery] int? fillWidth,
[FromQuery] int? fillHeight,
[FromQuery] bool? cropWhitespace, [FromQuery] bool? cropWhitespace,
[FromQuery] bool? addPlayedIndicator, [FromQuery] bool? addPlayedIndicator,
[FromQuery] int? blur, [FromQuery] int? blur,
[FromQuery] string? backgroundColor, [FromQuery] string? backgroundColor,
[FromQuery] string? foregroundLayer, [FromQuery] string? foregroundLayer)
[FromQuery] int? fillHeight,
[FromQuery] int? fillWidth)
{ {
var user = _userManager.GetUserById(userId); var user = _userManager.GetUserById(userId);
if (user?.ProfileImage == null) if (user?.ProfileImage == null)
@ -1693,8 +1693,8 @@ namespace Jellyfin.Api.Controllers
width, width,
height, height,
quality, quality,
fillHeight,
fillWidth, fillWidth,
fillHeight,
cropWhitespace, cropWhitespace,
addPlayedIndicator, addPlayedIndicator,
blur, blur,
@ -1779,8 +1779,8 @@ namespace Jellyfin.Api.Controllers
int? width, int? width,
int? height, int? height,
int? quality, int? quality,
int? fillHeight,
int? fillWidth, int? fillWidth,
int? fillHeight,
bool? cropWhitespace, // TODO: Remove bool? cropWhitespace, // TODO: Remove
bool? addPlayedIndicator, bool? addPlayedIndicator,
int? blur, int? blur,
@ -1844,11 +1844,13 @@ namespace Jellyfin.Api.Controllers
item, item,
itemId, itemId,
imageIndex, imageIndex,
width,
height, height,
maxHeight,
maxWidth, maxWidth,
maxHeight,
fillWidth,
fillHeight,
quality, quality,
width,
addPlayedIndicator, addPlayedIndicator,
percentPlayed, percentPlayed,
unplayedCount, unplayedCount,
@ -1859,9 +1861,7 @@ namespace Jellyfin.Api.Controllers
outputFormats, outputFormats,
cacheDuration, cacheDuration,
responseHeaders, responseHeaders,
isHeadRequest, isHeadRequest).ConfigureAwait(false);
fillHeight,
fillWidth).ConfigureAwait(false);
} }
private ImageFormat[] GetOutputFormats(ImageFormat? format) private ImageFormat[] GetOutputFormats(ImageFormat? format)
@ -1944,11 +1944,13 @@ namespace Jellyfin.Api.Controllers
BaseItem? item, BaseItem? item,
Guid itemId, Guid itemId,
int? index, int? index,
int? width,
int? height, int? height,
int? maxHeight,
int? maxWidth, int? maxWidth,
int? maxHeight,
int? fillWidth,
int? fillHeight,
int? quality, int? quality,
int? width,
bool? addPlayedIndicator, bool? addPlayedIndicator,
double? percentPlayed, double? percentPlayed,
int? unplayedCount, int? unplayedCount,
@ -1959,9 +1961,7 @@ namespace Jellyfin.Api.Controllers
IReadOnlyCollection<ImageFormat> supportedFormats, IReadOnlyCollection<ImageFormat> supportedFormats,
TimeSpan? cacheDuration, TimeSpan? cacheDuration,
IDictionary<string, string> headers, IDictionary<string, string> headers,
bool isHeadRequest, bool isHeadRequest)
int? fillHeight,
int? fillWidth)
{ {
if (!imageInfo.IsLocalFile && item != null) if (!imageInfo.IsLocalFile && item != null)
{ {

@ -97,6 +97,16 @@ namespace MediaBrowser.Controller.Drawing
return false; return false;
} }
if (FillWidth.HasValue && sizeValue.Width > FillWidth.Value)
{
return false;
}
if (FillHeight.HasValue && sizeValue.Height > FillHeight.Value)
{
return false;
}
return true; return true;
} }

@ -58,7 +58,7 @@ namespace MediaBrowser.Model.Drawing
} }
/// <summary> /// <summary>
/// Resizes to fill box. /// Scale down to fill box.
/// Returns original size if both width and height are null or zero. /// Returns original size if both width and height are null or zero.
/// </summary> /// </summary>
/// <param name="size">The original size object.</param> /// <param name="size">The original size object.</param>
@ -71,9 +71,8 @@ namespace MediaBrowser.Model.Drawing
int? fillHeight) int? fillHeight)
{ {
// Return original size if input is invalid. // Return original size if input is invalid.
if ( if ((fillWidth == null || fillWidth == 0)
(fillWidth == null && fillHeight == null) && (fillHeight == null || fillHeight == 0))
|| (fillWidth == 0 || fillHeight == 0))
{ {
return size; return size;
} }
@ -89,9 +88,8 @@ namespace MediaBrowser.Model.Drawing
} }
double widthRatio = (double)size.Width / (double)fillWidth; double widthRatio = (double)size.Width / (double)fillWidth;
double heightRatio = (double)size.Height / (double)fillHeight!; double heightRatio = (double)size.Height / (double)fillHeight;
// min() double scaleRatio = Math.Min(widthRatio, heightRatio);
double scaleRatio = widthRatio > heightRatio ? heightRatio : widthRatio;
// Clamp to current size. // Clamp to current size.
if (scaleRatio < 1) if (scaleRatio < 1)

Loading…
Cancel
Save