استخدام صورة Sharp. Web مع ASP.net مصدر (العربية (Arabic))

استخدام صورة Sharp. 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

//

3 minute read

أولاً

صورة هي مكتبة معالجة قوية للصور تسمح لك بالتلاعب بالصور بطرق مختلفة. صورة Sharp.Web هو امتداد لصورة Sharp يوفر وظيفة إضافية للعمل مع الصور في تطبيقات ASP.NET الأساسية. في هذا الدرس، سوف نستكشف كيفية استخدام صورة Sharp. Web لإعادة تحجيم، محصول، وتشكيل صور في هذا التطبيق.

[رابعاً -

صورة Sharp.Web

إلى بدء مع صورةWeb أنت إلى تثبيت التالي not get حزم:

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

صورة شارب. Web الإعداد

في ملف برنامجنا نحن بعد ذلك ننشئ صورة شرب. ويب. في حالتنا نحن نشير إلى صورنا ونخزنها في مجلد يسمى "images" في موقع مشروعنا wwwroot. ثم نقوم بعد ذلك بإعداد صورة sharp. Web الوسيطة إلى استخدام هذا المجلد كمصدر لصورنا.

يستخدم أيضا مجلد 'cach' لتخزين الملفات المجهزة (وهذا يمنعها من إعادة النظر في الملفات كل مرة).

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

هذه المجلّدات قريبة من الموقع wwwroot، لذا لدينا الهيكل التالي:

صورةSharp. Web لديها خيارات متعددة لـ حيث تخزن ملفاتك و Caching (انظر هنا لكل التفاصيل: المصدر: https://docs.ssix6labors.com/article/imagesharp.wweb/imagecedrs.html?tabs=tabid-112Ctabid-1a)

على سبيل المثال لخزن صورك في حاوية Azure plab (هاندي للتدرج) يمكنك استخدام مزود Azure مع AzureBlobCheas خيارات:

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

الصورة: Sharp.wb

الآن بما أن لدينا هذه المجموعة، فمن السهل حقاً استخدامها داخل تطبيقنا. على سبيل المثال إذا كنا نريد أن نخدم صورة إعادة الحجم، يمكننا أن نقوم بأي من استخدام الـ مُرسِل مُرسِم أو تعيين الواجهة مباشرة.

المسند::

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

لاحظ أن مع هذا نحن إعادة رسم الصورة، تعيين العرض والارتفاع، وأيضا تعيين نموذج إعادة تحجيم وإعادة تلون الصورة.

في هذا التطبيق نذهب الى الطريق الابسط ونستخدم معاملات الاستقالة فقط. بالنسبة للعلامة السفلية نستخدم امتداداً يسمح لنا بتحديد حجم الصورة و تنسيقها.

    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% من الجودة وفي شكل ويبب.

او يمكننا ان نستخدم الصورة كما هي وسوف يتم اعادة تشكيلها و تنسيقها كما هو محدد في الاستعلام

مُصد مُصد مُصد مُكر

ملاحظة cache لـلـورد الـذي إستعملتـه أعـلاه يجـب أن يكـون قابلـاً للكتابـة عـن طريـق الطعـام إذا كنت تستخدم (دوكر) فعليك التأكد من أن هذه هي القضية انظر S انظر سبق لي أن شغلت وظيفة سابقة للكيفية التي أدير بها هذا باستخدام الحجم.

ثالثاً - استنتاج

كما رأيتم الصورة Sharp.web تعطينا قدرة كبيرة لإعادة تحجيم و تشكيل الصور في تطبيقاتنا الأساسية ASP.net. من السهل إنشاءها واستخدامها وتوفر الكثير من المرونة في كيفية التلاعب بالصور في تطبيقاتنا.

logo

©2024 Scott Galloway