NOTE: Apart from
(and even then it's questionable, I'm Scottish). These are machine translated in languages I don't read. If they're terrible please contact me.
You can see how this translation was done in this article.
Tuesday, 13 August 2024
//3 minute read
ImageSharp is een krachtige beeldverwerkingsbibliotheek waarmee u afbeeldingen op verschillende manieren kunt manipuleren. ImageSharp.Web is een uitbreiding van ImageSharp die extra functionaliteit biedt voor het werken met afbeeldingen in ASP.NET Core toepassingen. In deze tutorial zullen we onderzoeken hoe we ImageSharp kunnen gebruiken.Web om afbeeldingen in deze toepassing te wijzigen, bij te snijden en te formatteren.
Om te beginnen met ImageSharp.Web, moet u de volgende NuGet pakketten installeren:
dotnet add package SixLabors.ImageSharp
dotnet add package SixLabors.ImageSharp.Web
In ons programma.cs bestand hebben we vervolgens ImageSharp.Web ingesteld. In ons geval verwijzen we naar en slaan we onze afbeeldingen op in een map genaamd "beelden" in de wwwroot van ons project. Vervolgens zetten we de ImageSharp.Web middleware op om deze map te gebruiken als bron van onze afbeeldingen.
ImageSharp.Web gebruikt ook een 'cache' map om verwerkte bestanden op te slaan (dit voorkomt dat bestanden elke keer worden gereporbeerd).
services.AddImageSharp().Configure<PhysicalFileSystemCacheOptions>(options => options.CacheFolder = "cache");
Deze mappen zijn relatief aan de wwwroot dus we hebben de volgende structuur:
ImageSharp.Web heeft meerdere opties voor waar u uw bestanden en caching opslaat (zie hier voor alle details: https://docs.sislabors.com/articles/imagesharp.web/imageproviders.html?tabs=tabid-1%2Ctabid-1a)
Bijvoorbeeld om uw afbeeldingen op te slaan in een Azure blob container (handig om te schalen) zou u de Azure Provider gebruiken met AzureBlobCacheOptions:
dotnet add SixLabors.ImageSharp.Web.Providers.Azure
// Configure and register the containers.
// Alteratively use `appsettings.json` to represent the class and bind those settings.
.Configure<AzureBlobStorageImageProviderOptions>(options =>
{
// The "BlobContainers" collection allows registration of multiple containers.
options.BlobContainers.Add(new AzureBlobContainerClientOptions
{
ConnectionString = {AZURE_CONNECTION_STRING},
ContainerName = {AZURE_CONTAINER_NAME}
});
})
.AddProvider<AzureBlobStorageImageProvider>()
Nu we dit hebben opgezet is het heel eenvoudig om het in onze toepassing te gebruiken. Als we bijvoorbeeld een verkleinde afbeelding willen serveren, kunnen we beide gebruiken de TagHelper of de URL direct specificeren.
TagHelper:
<img
src="sixlabors.imagesharp.web.png"
imagesharp-width="300"
imagesharp-height="200"
imagesharp-rmode="ResizeMode.Pad"
imagesharp-rcolor="Color.LimeGreen" />
Merk op dat we hiermee de grootte van de afbeelding wijzigen, de breedte en hoogte instellen, en ook de grootte wijzigen en de afbeelding herkleuren.
In deze app gaan we de eenvoudigere manier en gewoon gebruik maken van querystring parameters. Voor het markdown gebruiken we een extensie waarmee we de grootte en het formaat van de afbeelding kunnen specificeren.
public void ChangeImgPath(MarkdownDocument document)
{
foreach (var link in document.Descendants<LinkInline>())
if (link.IsImage)
{
if(link.Url.StartsWith("http")) continue;
if (!link.Url.Contains("?"))
{
link.Url += "?format=webp&quality=50";
}
link.Url = "/articleimages/" + link.Url;
}
}
Dit geeft ons de bruikbaarheid van ofwel het specificeren van deze in de berichten zoals
![image](/image.jpg?format=webp&quality=50)
Waar deze afbeelding vandaan komt wwwroot/articleimages/image.jpg
en worden verkleind tot 50% kwaliteit en in webp formaat.
Of we kunnen gewoon het beeld gebruiken zoals het is en het zal worden aangepast en geformatteerd zoals gespecificeerd in de querystring.
Let op de cache
forlder die ik hierboven heb gebruikt moet beschrijfbaar zijn door de toepassing. Als je Docker gebruikt, moet je er zeker van zijn dat dit het geval is.
Zie mijn eerdere post voor hoe ik dit beheer met behulp van een in kaart gebracht volume.
Zoals u hebt gezien ImageSharp.Web geeft ons een geweldige mogelijkheid om afbeeldingen te wijzigen en te formatteren in onze ASP.NET Core applicaties. Het is eenvoudig op te zetten en te gebruiken en biedt veel flexibiliteit in hoe we beelden kunnen manipuleren in onze toepassingen.