GifImage

GifImage class

صورة gif .

public sealed class GifImage : RasterCachedMultipageImage, IMultipageImageExt

المنشئون

اسموصف
GifImage(GifFrameBlock)يقوم بتهيئة مثيل جديد لملفGifImage فئة .
GifImage(GifFrameBlock, IColorPalette)يقوم بتهيئة مثيل جديد لملفGifImage فئة .
GifImage(GifFrameBlock, IColorPalette, bool, byte, byte, byte, bool)يقوم بتهيئة مثيل جديد لملفGifImage فئة .

الخصائص

اسموصف
ActiveFrame { get; set; }الحصول على أو تحديد الإطار النشط.
AutoAdjustPalette { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كانت لوحة الضبط التلقائي.
override BackgroundColor { get; set; }الحصول على لون الخلفية أو تعيينه.
BackgroundColorIndex { get; set; }الحصول على فهرس لون الخلفية أو تعيينه.
override BitsPerPixel { get; }الحصول على عدد بتات الصورة لكل بكسل .
Blocks { get; }يحصل على كتل GIF .
Bounds { get; }يحصل على حدود الصورة .
BufferSizeHint { get; set; }الحصول على أو تعيين تلميح حجم المخزن المؤقت الذي تم تحديده بالحجم الأقصى المسموح به لجميع المخازن المؤقتة الداخلية.
Container { get; }يحصل على ملفImage حاوية .
DataStreamContainer { get; }يحصل على دفق بيانات الكائن.
Disposed { get; }يحصل على قيمة تشير إلى ما إذا كان هذا المثيل قد تم التخلص منه.
override FileFormat { get; }يحصل على قيمة تنسيق الملف
override HasAlpha { get; }يحصل على قيمة تشير إلى ما إذا كان هذا المثيل يحتوي على alpha.
override HasBackgroundColor { get; }يحصل على قيمة تشير إلى ما إذا كانت الصورة لها لون خلفية.
HasTrailer { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كان GIF يحتوي على مقطع دعائي .
override HasTransparentColor { get; set; }يحصل على قيمة تشير إلى ما إذا كان الإطار النشط له لون شفاف.
override Height { get; }الحصول على ارتفاع الصورة .
virtual HorizontalResolution { get; set; }الحصول على أو تعيين الدقة الأفقية ، بالبكسل في البوصة ، لهذاRasterImage .
override ImageOpacity { get; }الحصول على عتامة هذه الصورة (الإطار النشط) .
InterruptMonitor { get; set; }الحصول على أو تعيين شاشة المقاطعة.
IsCached { get; }يحصل على قيمة تشير إلى ما إذا كانت بيانات الصورة مخزنة مؤقتًا حاليًا.
IsInterlaced { get; }يحصل على قيمة تشير إلى ما إذا كان مثيل الصورة هذا متشابكًا.
IsPaletteSorted { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كانت اللوحة مرتبة أم لا.
IsRawDataAvailable { get; }يحصل على قيمة تشير إلى ما إذا كان تحميل البيانات الأولية متاحًا.
LoopsCount { get; set; }الحصول على عدد الحلقات (إذا كانت صورة gif تحتوي على معلومات حول الحلقات)
override PageCount { get; }الحصول على عدد الصفحات .
override PageExportingAction { get; set; }الحصول على إجراء تصدير الصفحة أو تعيينه . يرجى ملاحظة أن تعيين هذه الطريقة سيؤدي تلقائيًا إلى تحرير موارد الصفحة بعد تنفيذها. سيتم تنفيذها قبل حفظ كل صفحة مباشرةً.
override Pages { get; }الحصول على الصفحات .
Palette { get; set; }الحصول على لوحة الألوان أو تعيينها. لا يتم استخدام لوحة الألوان عندما يتم تمثيل وحدات البكسل مباشرةً.
PaletteColorResolutionBits { get; set; }الحصول على بتات دقة ألوان اللوحة أو تعيينها.
PixelAspectRatio { get; set; }الحصول على أو تعيين نسبة العرض إلى الارتفاع بالبكسل.
virtual PremultiplyComponents { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كان يجب مضاعفة مكونات الصورة مسبقًا.
RawCustomColorConverter { get; set; }الحصول على أو تعيين محول الألوان المخصص
virtual RawDataFormat { get; }يحصل على تنسيق البيانات الأولية.
RawDataSettings { get; }يحصل على إعدادات البيانات الأولية الحالية. ملاحظة عند استخدام هذه الإعدادات ، يتم تحميل البيانات بدون تحويل.
RawFallbackIndex { get; set; }الحصول على الفهرس الاحتياطي أو تعيينه لاستخدامه عندما يكون فهرس اللوحة خارج الحدود
RawIndexedColorConverter { get; set; }الحصول على أو تعيين محول الألوان المفهرس
virtual RawLineSize { get; }الحصول على حجم الخط الخام بالبايت.
Size { get; }يحصل على حجم الصورة .
override TransparentColor { get; }الحصول على لون شفاف للإطار النشط.
virtual UpdateXmpData { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كان سيتم تحديث بيانات تعريف XMP.
override UsePalette { get; }يحصل على قيمة تشير إلى ما إذا كانت لوحة الصور مستخدمة.
virtual UseRawData { get; set; }الحصول على أو تعيين قيمة تشير إلى ما إذا كان سيتم استخدام تحميل البيانات الأولية عند توفر تحميل البيانات الأولية.
virtual VerticalResolution { get; set; }الحصول على أو تحديد الدقة الرأسية ، بالبكسل في البوصة ، لهذاRasterImage .
override Width { get; }الحصول على عرض الصورة .
override XmpData { get; set; }الحصول على بيانات تعريف XMP أو تعيينها.

طُرق

اسموصف
AddBlock(IGifBlock)يضيف كتلة GIF جديدة.
AddPage(RasterImage)يضيف صفحة للصورة.
override AdjustBrightness(int)ضبط أbrightness للصورة .
override AdjustContrast(float)يضبط التباين .
override AdjustGamma(float)تصحيح جاما لصورة .
override AdjustGamma(float, float, float)تصحيح جاما لصورة .
override BinarizeBradley(double)ثنائية الصورة باستخدام خوارزمية العتبة التكيفية لبرادلي باستخدام عتبة الصورة المتكاملة
override BinarizeBradley(double, int)ثنائية الصورة باستخدام خوارزمية العتبة التكيفية لبرادلي باستخدام عتبة الصورة المتكاملة
override BinarizeFixed(byte)ثنائية الصورة مع عتبة محددة مسبقًا
override BinarizeOtsu()ثنائية الصورة مع عتبة Otsu
override CacheData()تخزين البيانات الخاصة.
CanSave(ImageOptionsBase)يحدد ما إذا كان يمكن حفظ الصورة بتنسيق الملف المحدد الذي تم تمثيله بواسطة خيارات الحفظ التي تم تمريرها.
ClearBlocks()يمسح كل كتل GIF .
override Crop(Rectangle)اقتصاص الصورة .
override Crop(int, int, int, int)اقتصاص الصورة مع التحولات .
Dispose()التخلص من المثيل الحالي .
Dither(DitheringMethod, int)يقوم بالتردد على الصورة الحالية.
override Dither(DitheringMethod, int, IColorPalette)يقوم بالتردد على الصورة الحالية.
override Filter(Rectangle, FilterOptionsBase)يقوم بتصفية المستطيل المحدد .
GetArgb32Pixel(int, int)الحصول على صورة ARGB بكسل 32 بت .
GetDefaultArgb32Pixels(Rectangle)الحصول على صفيف ARGB بكسل الافتراضي 32 بت.
virtual GetDefaultOptions(object[])يحصل على الخيارات الافتراضية .
GetDefaultPixels(Rectangle, IPartialArgb32PixelLoader)الحصول على مصفوفة البكسل الافتراضية باستخدام محمل البكسل الجزئي.
GetDefaultRawData(Rectangle, RawDataSettings)يحصل على مصفوفة البيانات الأولية الافتراضية.
GetDefaultRawData(Rectangle, IPartialRawDataLoader, RawDataSettings)الحصول على مصفوفة البيانات الأولية الافتراضية باستخدام محمل البكسل الجزئي.
virtual GetModifyDate(bool)الحصول على تاريخ ووقت آخر تعديل لصورة المورد.
override GetOriginalOptions()الحصول على الخيارات بناءً على إعدادات الملف الأصلية. يمكن أن يكون هذا مفيدًا للحفاظ على عمق البت والمعلمات الأخرى للصورة الأصلية دون تغيير . على سبيل المثال ، إذا قمنا بتحميل صورة PNG أبيض وأسود مع 1 بت لكل بكسل ثم احفظه باستخدام the Save الطريقة ، سيتم إنتاج صورة PNG الناتجة بمعدل 8 بت لكل بكسل. لتجنب ذلك وحفظ صورة PNG بمعدل 1 بت لكل بكسل ، استخدم هذه الطريقة للحصول على خيارات الحفظ المقابلة وتمريرها إلىSave الطريقة كمعامل ثاني.
GetPixel(int, int)الحصول على بكسل صورة .
GetSkewAngle()الحصول على زاوية الانحراف. هذه الطريقة قابلة للتطبيق على المستندات النصية الممسوحة ضوئيًا ، لتحديد زاوية الانحراف عند المسح.
override Grayscale()تحويل الصورة إلى تمثيلها بالتدرج الرمادي
InsertBlock(int, IGifBlock)يضيف كتلة GIF جديدة.
LoadArgb32Pixels(Rectangle)تحميل 32 بت ARGB بكسل .
LoadArgb64Pixels(Rectangle)تحميل 64 بت ARGB بكسل .
LoadCmyk32Pixels(Rectangle)تحميل وحدات البكسل بتنسيق CMYK .
LoadPartialArgb32Pixels(Rectangle, IPartialArgb32PixelLoader)تحميل 32 بت ARGB بكسل جزئيًا بواسطة الحزم.
LoadPartialPixels(Rectangle, IPartialPixelLoader)يتم تحميل وحدات البكسل جزئيًا بالحزم .
LoadPixels(Rectangle)تحميل بكسل .
LoadRawData(Rectangle, RawDataSettings, IPartialRawDataLoader)تحميل البيانات الأولية .
LoadRawData(Rectangle, Rectangle, RawDataSettings, IPartialRawDataLoader)تحميل البيانات الأولية .
NormalizeAngle()تطبيع الزاوية. هذه الطريقة قابلة للتطبيق على المستندات النصية الممسوحة ضوئيًا للتخلص من المسح المنحرف. تستخدم هذه الطريقةGetSkewAngle وRotate الطرق .
override NormalizeAngle(bool, Color)تطبيع الزاوية. هذه الطريقة قابلة للتطبيق على المستندات النصية الممسوحة ضوئيًا للتخلص من المسح المنحرف. تستخدم هذه الطريقة!:GetSkewAngle وRotate الطرق .
OrderBlocks()طلب كتل GIF وفقًا لمواصفات GIF. بعضGifGraphicsControlBlock قد تتم إزالتها لتخطيط GIF المناسب.
ReadArgb32ScanLine(int)يقرأ خط المسح بالكامل بواسطة فهرس خط المسح المحدد.
ReadScanLine(int)يقرأ خط المسح بالكامل بواسطة فهرس خط المسح المحدد.
RemoveBlock(IGifBlock)يزيل كتلة GIF .
ReplaceColor(Color, byte, Color)يستبدل لونًا بآخر بالاختلاف المسموح به ويحتفظ بقيمة ألفا الأصلية لحفظ الحواف المتجانسة.
override ReplaceColor(int, byte, int)يستبدل لونًا بآخر بالاختلاف المسموح به ويحتفظ بقيمة ألفا الأصلية لحفظ الحواف المتجانسة.
ReplaceNonTransparentColors(Color)يستبدل كل الألوان غير الشفافة بلون جديد ويحتفظ بقيمة ألفا الأصلية لحفظ الحواف الناعمة . ملاحظة: إذا كنت تستخدمها على صور بدون شفافية ، فسيتم استبدال كل الألوان بواحد.
override ReplaceNonTransparentColors(int)يستبدل كل الألوان غير الشفافة بلون جديد ويحتفظ بقيمة ألفا الأصلية لحفظ الحواف الناعمة . ملاحظة: إذا كنت تستخدمها على صور بدون شفافية ، فسيتم استبدال كل الألوان بأخرى.
Resize(int, int)يغير حجم الصورة. الافتراضيNearestNeighbourResample يستخدم .
override Resize(int, int, ImageResizeSettings)يغير حجم الصورة.
override Resize(int, int, ResizeType)يغير حجم الصورة.
ResizeFullFrame(int, int, ResizeType)يغير حجم الصورة باستخدام الإطارات الكاملة لكل صفحة GIF. مطلوب لتجنب ظهور القطع الأثرية المحتملة.
ResizeHeightProportionally(int)يغير حجم الارتفاع بشكل متناسب. الافتراضيNearestNeighbourResample يستخدم .
virtual ResizeHeightProportionally(int, ImageResizeSettings)يغير حجم الارتفاع بشكل متناسب .
override ResizeHeightProportionally(int, ResizeType)يغير حجم العرض بشكل متناسب .
ResizeProportional(int, int, ResizeType)يؤدي تغيير الحجم النسبي على الصورة. سيؤدي تغيير الحجم النسبي إلى تغيير حجم كل إطار وفقًا لنسبةnewWidth العرض وnewHeight / ارتفاع .
ResizeWidthProportionally(int)يغير حجم العرض بشكل متناسب. الافتراضيNearestNeighbourResample يستخدم .
virtual ResizeWidthProportionally(int, ImageResizeSettings)يغير حجم العرض بشكل متناسب .
override ResizeWidthProportionally(int, ResizeType)يغير حجم العرض بشكل متناسب .
virtual Rotate(float)تدوير الصورة حول المركز .
override Rotate(float, bool, Color)!:RasterCahcedMultipageImage.Rotate الصورة حول المركز .
override RotateFlip(RotateFlipType)يقوم بتدوير الإطار النشط فقط أو قلبه أو تدويره وقلبه.
Save()يحفظ بيانات الصورة في التدفق الأساسي.
Save(Stream)يحفظ بيانات الكائن في الدفق المحدد.
override Save(string)يحفظ الصورة في موقع الملف المحدد.
Save(Stream, ImageOptionsBase)يحفظ بيانات الصورة إلى التدفق المحدد بتنسيق الملف المحدد وفقًا لخيارات الحفظ.
virtual Save(string, bool)يحفظ بيانات الكائن في موقع الملف المحدد.
virtual Save(string, ImageOptionsBase)يحفظ بيانات الكائن في موقع الملف المحدد بتنسيق الملف المحدد وفقًا لخيارات الحفظ.
override Save(Stream, ImageOptionsBase, Rectangle)يحفظ بيانات الصورة إلى التدفق المحدد بتنسيق الملف المحدد وفقًا لخيارات الحفظ.
virtual Save(string, ImageOptionsBase, Rectangle)يحفظ بيانات الكائن في موقع الملف المحدد بتنسيق الملف المحدد وفقًا لخيارات الحفظ.
SaveArgb32Pixels(Rectangle, int[])يحفظ 32 بت ARGB بكسل .
SaveCmyk32Pixels(Rectangle, int[])يحفظ البكسل .
SavePixels(Rectangle, Color[])يحفظ البكسل .
SaveRawData(byte[], int, Rectangle, RawDataSettings)يحفظ البيانات الأولية .
SetArgb32Pixel(int, int, int)يضبط صورة ARGB بكسل 32 بت للوضع المحدد.
SetFrameTime(ushort)يضبط مدة كل الإطارات بالمللي ثانية. سيؤدي تغيير هذه القيمة إلى إعادة تعيين التأخير لجميع الإطارات .
override SetPalette(IColorPalette, bool)يضبط لوحة الصور .
SetPixel(int, int, Color)يضبط بكسل الصورة للوضع المحدد.
virtual SetResolution(double, double)يضبط الدقة لهذا الغرضRasterImage .
virtual ToBitmap()تحويل الصورة النقطية إلى الصورة النقطية.
WriteArgb32ScanLine(int, int[])يكتب خط المسح بالكامل إلى فهرس خط المسح المحدد.
WriteScanLine(int, Color[])يكتب خط المسح بالكامل إلى فهرس خط المسح المحدد.

أمثلة

تصدير جزء من الرسوم المتحركة من صورة GIF بناءً على الفاصل الزمني.

[C#]

using (var image = Image.Load("Animation.gif"))
{
    var options = new GifOptions
    {
        FullFrame = true,
        MultiPageOptions = new MultiPageOptions
        {
            Mode = MultiPageMode.TimeInterval,
            TimeInterval = new TimeInterval(0, 400)
        }
    };

    image.Save("PartOfAnimation.gif", options);
}

يوضح هذا المثال كيفية إنشاء صورة GIF وحفظها في ملف.

[C#]

string dir = "c:\\temp\\";

// قم بإنشاء كتلة إطار GIF بحجم 100 × 100 بكسل.
using (Aspose.Imaging.FileFormats.Gif.Blocks.GifFrameBlock firstBlock = new Aspose.Imaging.FileFormats.Gif.Blocks.GifFrameBlock(100, 100))
{
    // املأ الكتلة بالكامل باللون الأحمر.
    Aspose.Imaging.Graphics gr = new Aspose.Imaging.Graphics(firstBlock);
    Aspose.Imaging.Brushes.SolidBrush brush = new Aspose.Imaging.Brushes.SolidBrush(Aspose.Imaging.Color.Red);
    gr.FillRectangle(brush, firstBlock.Bounds);

    using (Aspose.Imaging.FileFormats.Gif.GifImage gifImage = new Aspose.Imaging.FileFormats.Gif.GifImage(firstBlock))
    {
        gifImage.Save(dir + "output.gif");
    }
}

قم بإنشاء صورة GIF متعددة الصفحات باستخدام صور نقطية من صفحة واحدة.

[C#]

static void Main(string[] args)
{
    // تحميل الإطارات
    var frames = LoadFrames("Animation frames").ToArray();

    // إنشاء صورة GIF باستخدام الإطار الأول
    using (var image = new GifImage(new GifFrameBlock(frames[0])))
    {
        // أضف إطارات إلى صورة GIF باستخدام طريقة AddPage
        for (var index = 1; index < frames.Length; index++)
        {
            image.AddPage(frames[index]);
        }

        // حفظ صورة GIF
        image.Save("Multipage.gif");
    }
}

private static IEnumerable<RasterImage> LoadFrames(string directory)
{
    foreach (var filePath in Directory.GetFiles(directory))
    {
        yield return (RasterImage)Image.Load(filePath);
    }
}

أنظر أيضا