Merge pull request #3107 from sbwalker/dev
add transparency support on image resizing
This commit is contained in:
		| @ -210,7 +210,7 @@ | ||||
|  | ||||
|     private string GetLogo(int fileid) | ||||
|     { | ||||
|         var url = ImageUrl(fileid, 100, 100, "", "", "ffffff", 0, false); | ||||
|         var url = ImageUrl(fileid, 100, 100); | ||||
|         url = (!string.IsNullOrEmpty(PageState.Alias.Path)) ? url.Substring(PageState.Alias.Path.Length + 1) : url; | ||||
|         return Constants.PackageRegistryUrl + url; | ||||
|     } | ||||
|  | ||||
| @ -212,7 +212,7 @@ | ||||
|  | ||||
|     private string GetLogo(int fileid) | ||||
|     { | ||||
|         var url = ImageUrl(fileid, 100, 100, "", "", "ffffff", 0, false); | ||||
|         var url = ImageUrl(fileid, 100, 100); | ||||
|         url = (!string.IsNullOrEmpty(PageState.Alias.Path)) ? url.Substring(PageState.Alias.Path.Length + 1) : url; | ||||
|         return Constants.PackageRegistryUrl + url; | ||||
|     } | ||||
|  | ||||
| @ -572,7 +572,7 @@ namespace Oqtane.Controllers | ||||
|                         // validation | ||||
|                         if (!Enum.TryParse(mode, true, out ResizeMode _)) mode = "crop"; | ||||
|                         if (!Enum.TryParse(position, true, out AnchorPositionMode _)) position = "center"; | ||||
|                         if (!Color.TryParseHex("#" + background, out _)) background = "000000"; | ||||
|                         if (!Color.TryParseHex("#" + background, out _)) background = "transparent"; | ||||
|                         if (!int.TryParse(rotate, out _)) rotate = "0"; | ||||
|                         rotate = (int.Parse(rotate) < 0 || int.Parse(rotate) > 360) ? "0" : rotate; | ||||
|                         if (!bool.TryParse(recreate, out _)) recreate = "false"; | ||||
| @ -644,10 +644,23 @@ namespace Oqtane.Controllers | ||||
|                                 Mode = resizemode, | ||||
|                                 Position = anchorpositionmode, | ||||
|                                 Size = new Size(width, height) | ||||
|                             }) | ||||
|                             .BackgroundColor(Color.ParseHex("#" + background))); | ||||
|                             })); | ||||
|  | ||||
|                         image.Save(imagepath, new PngEncoder()); | ||||
|                         if (background != "transparent") | ||||
|                         { | ||||
|                             image.Mutate(x => x | ||||
|                                 .BackgroundColor(Color.ParseHex("#" + background))); | ||||
|                         } | ||||
|  | ||||
|                         PngEncoder encoder = new PngEncoder | ||||
|                         { | ||||
|                             ColorType = PngColorType.RgbWithAlpha, | ||||
|                             TransparentColorMode = PngTransparentColorMode.Preserve, | ||||
|                             BitDepth = PngBitDepth.Bit8, | ||||
|                             CompressionLevel = PngCompressionLevel.BestSpeed | ||||
|                         }; | ||||
|  | ||||
|                         image.Save(imagepath, encoder); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| @ -133,7 +133,7 @@ namespace Oqtane.Shared | ||||
|             var url = (alias != null && !string.IsNullOrEmpty(alias.Path)) ? "/" + alias.Path : ""; | ||||
|             mode = string.IsNullOrEmpty(mode) ? "crop" : mode; | ||||
|             position = string.IsNullOrEmpty(position) ? "center" : position; | ||||
|             background = string.IsNullOrEmpty(background) ? "000000" : background; | ||||
|             background = string.IsNullOrEmpty(background) ? "transparent" : background; | ||||
|             return $"{alias?.BaseUrl}{url}{Constants.ImageUrl}{fileId}/{width}/{height}/{mode}/{position}/{background}/{rotate}/{recreate}"; | ||||
|         } | ||||
|  | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker