Використання ImageShalp. Web з ядром ASP. NET (Українська (Ukrainian))

Використання ImageShalp. Web з ядром ASP. NET

Comments

NOTE: Apart from English (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.

Friday, 13 September 2024

//

Less than a minute

Вступ

Розширення зображеньComment є потужною бібліотекою для обробки зображень, яка надає вам змогу маніпулювати зображеннями у декілька способів. ImageShalz. Web - це розширення можливостей роботи з зображеннями у програмах з ядром ImageShalp, які надають додаткові можливості для роботи з зображеннями у програмі ASP. NET. У цьому підручнику ми дослідимо, як скористатися пунктом меню ImageSap. Web для зміни розмірів, обрізання і форматування зображень у цій програмі.

Встановлення imageShalp. Web

Щоб розпочати роботу з ImageSharp. Web, вам слід встановити такі пакунки NuGet:

dotnet add package SixLabors.ImageSharp
dotnet add package SixLabors.ImageSharp.Web

Налаштування imageShalp. WebComment

У нашому файлі Program.cs ми встановили ImageSap. Web. У нашому випадку ми маємо на увазі і зберігаємо наші зображення в теці, що називається "зображення" в нашому проекті. Потім ми створили програмне забезпечення ImageSap.Web для використання цієї теки як джерела наших зображень.

ImageShalp. Web також використовує теку " cache " для зберігання оброблених файлів (це запобігає відшкодуванню файлів кожного разу).

services.AddImageSharp().Configure<PhysicalFileSystemCacheOptions>(options => options.CacheFolder = "cache");

Ці теки відносяться до кореневої теки wwwroot, отже у нас є така структура:

Структура тек

ImageShalp. Web має декілька параметрів, за допомогою яких ви можете зберегти ваші файли і кешування (див. тут, щоб дізнатися більше: https: // docs. 6labors.com/articles/imagesapal. web/ imageprofiders. html? tabs=tabid- 1% 2Ctabid- 1a)

Наприклад, щоб зберігати ваші зображення у контейнері Azure (корисно для масштабування), вам слід скористатися постачальником Azure за допомогою параметрів AzureBlobCache:

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>()

Використання imageSape. Web

Тепер, коли ми маємо це, це дуже просто використовувати в нашій заяві. Наприклад, якщо ми хочемо обслужити збільшене зображення, ми можемо використовувати або інше зображення Інструмент довідки міток або напряму вказати адресу URL.

Допомога мітками:

<img
    src="sixlabors.imagesharp.web.png"
    imagesharp-width="300"
    imagesharp-height="200"
    imagesharp-rmode="ResizeMode.Pad"
    imagesharp-rcolor="Color.LimeGreen" />

Зауважте, що за допомогою цього пункту ми змінюємо розміри зображення, встановлюємо ширину і висоту, а також встановлюємо значення Змінити розмір і змінити колір зображення.

У цій програмі ми йдемо простішим шляхом і просто використовуємо параметри querystring. Для розмітки ми використовуємо суфікс, за допомогою якого ми можемо вказати розмір і формат зображення.

    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;
            }
               
    }

Це надає нам можливість вказати їх у таких постах, як

![image](/image.jpg?format=webp&quality=50)

Звідки прийде це зображення? wwwroot/articleimages/image.jpg і його розміри у 50% якості у форматі webp.

Або ж ми можемо використовувати зображення у такому вигляді, у якому його буде змінено і відформатовано, як вказано у рядку діалогу.

Панель

Зауважте cache що я вже використовував вище має бути придатний для запису в цій заяві. Если ты используешь Докера, тебе нужно убедиться, что это так. Див. мій попередній допис як мені це вдається за допомогою накресленого об'єму.

Висновки

Як ви вже бачили, ImageSapute. Web дає нам чудову можливість змінювати і форматувати зображення в наших ключових програмах ASP.NET. Легко налагодити і використовувати та створювати гнучкість у тому, як можна маніпулювати зображеннями в наших програмах.

logo

©2024 Scott Galloway