mirror of
https://github.com/QL-Win/QuickLook.git
synced 2026-03-31 01:02:16 +08:00
abstract plugin interface
This commit is contained in:
@@ -43,10 +43,11 @@ namespace QuickLook.Plugin.ImageViewer.AnimatedImage
|
||||
BitmapSource previousStateRenderedFrame = null;
|
||||
foreach (var nextFrame in decoder.Frames)
|
||||
{
|
||||
var nextRenderedFrame = MakeNextFrame(header, nextFrame, currentFrame, currentRenderedFrame, previousStateRenderedFrame);
|
||||
var nextRenderedFrame = MakeNextFrame(header, nextFrame, currentFrame, currentRenderedFrame,
|
||||
previousStateRenderedFrame);
|
||||
|
||||
var delay = TimeSpan.FromSeconds(
|
||||
(double)nextFrame.fcTLChunk.DelayNum /
|
||||
(double) nextFrame.fcTLChunk.DelayNum /
|
||||
(nextFrame.fcTLChunk.DelayDen == 0 ? 100 : nextFrame.fcTLChunk.DelayDen));
|
||||
|
||||
animator.KeyFrames.Add(new DiscreteObjectKeyFrame(nextRenderedFrame, clock));
|
||||
@@ -79,40 +80,35 @@ namespace QuickLook.Plugin.ImageViewer.AnimatedImage
|
||||
if (nextFrame.fcTLChunk.BlendOp == BlendOps.APNGBlendOpSource)
|
||||
{
|
||||
var freeRegion = new CombinedGeometry(GeometryCombineMode.Xor,
|
||||
new RectangleGeometry(fullRect),
|
||||
new RectangleGeometry(frameRect));
|
||||
context.PushOpacityMask(new DrawingBrush(new GeometryDrawing(Brushes.Transparent, null, freeRegion)));
|
||||
new RectangleGeometry(fullRect),
|
||||
new RectangleGeometry(frameRect));
|
||||
context.PushOpacityMask(
|
||||
new DrawingBrush(new GeometryDrawing(Brushes.Transparent, null, freeRegion)));
|
||||
}
|
||||
|
||||
if (currentFrame != null && currentRenderedFrame != null)
|
||||
{
|
||||
switch (currentFrame.fcTLChunk.DisposeOp)
|
||||
{
|
||||
case DisposeOps.APNGDisposeOpNone:
|
||||
// restore currentRenderedFrame
|
||||
if (currentRenderedFrame != null)
|
||||
{
|
||||
context.DrawImage(currentRenderedFrame, fullRect);
|
||||
}
|
||||
if (currentRenderedFrame != null) context.DrawImage(currentRenderedFrame, fullRect);
|
||||
break;
|
||||
case DisposeOps.APNGDisposeOpPrevious:
|
||||
// restore previousStateRenderedFrame
|
||||
if (previousStateRenderedFrame != null)
|
||||
{
|
||||
context.DrawImage(previousStateRenderedFrame, fullRect);
|
||||
}
|
||||
break;
|
||||
case DisposeOps.APNGDisposeOpBackground:
|
||||
// do nothing
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// unprotect region and draw the next frame
|
||||
if (nextFrame.fcTLChunk.BlendOp == BlendOps.APNGBlendOpSource)
|
||||
context.Pop();
|
||||
context.DrawImage(fs, frameRect);
|
||||
}
|
||||
|
||||
var bitmap = new RenderTargetBitmap(
|
||||
header.Width, header.Height,
|
||||
Math.Floor(fs.DpiX), Math.Floor(fs.DpiY),
|
||||
|
||||
@@ -24,7 +24,7 @@ using System.Windows;
|
||||
using System.Windows.Controls;
|
||||
using System.Windows.Media.Animation;
|
||||
using System.Windows.Threading;
|
||||
using QuickLook.Helpers;
|
||||
using QuickLook.Common.Helpers;
|
||||
using QuickLook.Plugin.ImageViewer.Exiv2;
|
||||
|
||||
namespace QuickLook.Plugin.ImageViewer.AnimatedImage
|
||||
|
||||
@@ -83,6 +83,7 @@ namespace QuickLook.Plugin.ImageViewer.AnimatedImage
|
||||
|
||||
context.DrawImage(rawFrame, frameInfo.Rect);
|
||||
}
|
||||
|
||||
var bitmap = new RenderTargetBitmap(
|
||||
fullImage.PixelWidth, fullImage.PixelHeight,
|
||||
Math.Floor(fullImage.DpiX), Math.Floor(fullImage.DpiY),
|
||||
@@ -186,6 +187,7 @@ namespace QuickLook.Plugin.ImageViewer.AnimatedImage
|
||||
if (value != null)
|
||||
return (T) value;
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -16,8 +16,6 @@
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Windows;
|
||||
using System.Windows.Media.Animation;
|
||||
using ImageMagick;
|
||||
|
||||
Reference in New Issue
Block a user