ApngOptions.DefaultFrameTime
محتويات
[
يخفي
]ApngOptions.DefaultFrameTime property
يحصل أو يعيّن مدة الإطار الافتراضية.
public uint DefaultFrameTime { get; set; }
Property Value
مدة الإطار الافتراضية، بالمللي ثانية.
أمثلة
المثال التالي يوضح كيفية تصدير تنسيق ملف apng APNG من تنسيق متعدد الصفحات غير متحرك آخر.
[C#]
using Aspose.Imaging;
using Aspose.Imaging.ImageOptions;
using (Image image = Image.Load("img4.tif")) {
// إعداد مدة الإطار الافتراضية
image.Save("img4.tif.500ms.png", new ApngOptions() { DefaultFrameTime = 500 }); // 500 ms
image.Save("img4.tif.250ms.png", new ApngOptions() { DefaultFrameTime = 250 }); // 250 ms
}
يوضح المثال التالي كيفية إنشاء صورة APNG من صورة نقطية صفحة واحدة أخرى.
[C#]
using Aspose.Imaging;
using Aspose.Imaging.ImageOptions;
using Aspose.Imaging.FileFormats.Apng;
const int AnimationDuration = 1000; // 1 s
const int FrameDuration = 70; // 70 ms
using (RasterImage sourceImage = (RasterImage)Image.Load("not_animated.png"))
{
ApngOptions createOptions = new ApngOptions
{
Source = new FileCreateSource("raster_animation.png", false),
DefaultFrameTime = (uint)FrameDuration,
ColorType = PngColorType.TruecolorWithAlpha,
};
using (ApngImage apngImage = (ApngImage)Image.Create(
createOptions,
sourceImage.Width,
sourceImage.Height))
{
// يمكن تعيين الوقت الافتراضي لإطار الصورة هناك: apngImage.DefaultFrameTime = (uint)FrameDuration;
int numOfFrames = AnimationDuration / FrameDuration;
int numOfFrames2 = numOfFrames / 2;
// جارٍ التنظيف لأن الصورة تحتوي على إطار واحد افتراضيًا
apngImage.RemoveAllFrames();
// إضافة الإطار الأول
apngImage.AddFrame(sourceImage);
// إضافة إطارات وسطية
for (int frameIndex = 1; frameIndex < numOfFrames - 1; ++frameIndex)
{
apngImage.AddFrame(sourceImage);
ApngFrame lastFrame = (ApngFrame)apngImage.Pages[apngImage.PageCount - 1];
float gamma = frameIndex >= numOfFrames2 ? numOfFrames - frameIndex - 1 : frameIndex;
lastFrame.AdjustGamma(gamma);
}
// إضافة الإطار الأخير
apngImage.AddFrame(sourceImage);
apngImage.Save();
}
}
انظر أيضًا
- class ApngOptions
- namespace Aspose.Imaging.ImageOptions
- assembly Aspose.Imaging