minor image colour tweaking

This commit is contained in:
Paddy Xu
2020-05-15 00:02:26 +03:00
parent 1cd5019706
commit 8faa152960
8 changed files with 66 additions and 24 deletions

View File

@@ -27,21 +27,21 @@ using System.Windows.Media.Imaging;
using LibAPNG; using LibAPNG;
using QuickLook.Common.ExtensionMethods; using QuickLook.Common.ExtensionMethods;
namespace QuickLook.Plugin.ImageViewer.AnimatedImage namespace QuickLook.Plugin.ImageViewer.AnimatedImage.Providers
{ {
internal class APngAnimationProvider : AnimationProvider internal class APngProvider : AnimationProvider
{ {
private readonly Frame _baseFrame; private readonly Frame _baseFrame;
private readonly List<FrameInfo> _frames; private readonly List<FrameInfo> _frames;
private readonly List<BitmapSource> _renderedFrames; private readonly List<BitmapSource> _renderedFrames;
private int _lastEffectivePreviousPreviousFrameIndex; private int _lastEffectivePreviousPreviousFrameIndex;
private NativeImageProvider _nativeImageProvider; private NativeProvider _nativeImageProvider;
public APngAnimationProvider(string path, MetaProvider meta) : base(path, meta) public APngProvider(string path, MetaProvider meta) : base(path, meta)
{ {
if (!IsAnimatedPng(path)) if (!IsAnimatedPng(path))
{ {
_nativeImageProvider = new NativeImageProvider(path, meta); _nativeImageProvider = new NativeProvider(path, meta);
Animator = _nativeImageProvider.Animator; Animator = _nativeImageProvider.Animator;
return; return;
} }

View File

@@ -0,0 +1,29 @@
// Copyright © 2020 Paddy Xu
//
// This file is part of QuickLook program.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
using System;
namespace QuickLook.Plugin.ImageViewer.AnimatedImage.Providers
{
internal class DcrawProvider : NativeProvider
{
public DcrawProvider(string path, MetaProvider meta) : base(path, meta)
{
throw new NotImplementedException();
}
}
}

View File

@@ -24,15 +24,15 @@ using QuickLook.Common.ExtensionMethods;
using QuickLook.Common.Helpers; using QuickLook.Common.Helpers;
using Size = System.Windows.Size; using Size = System.Windows.Size;
namespace QuickLook.Plugin.ImageViewer.AnimatedImage namespace QuickLook.Plugin.ImageViewer.AnimatedImage.Providers
{ {
internal class GifAnimationProvider : AnimationProvider internal class GifProvider : AnimationProvider
{ {
private Bitmap _fileHandle; private Bitmap _fileHandle;
private BitmapSource _frame; private BitmapSource _frame;
private bool _isPlaying; private bool _isPlaying;
public GifAnimationProvider(string path, MetaProvider meta) : base(path, meta) public GifProvider(string path, MetaProvider meta) : base(path, meta)
{ {
_fileHandle = (Bitmap) Image.FromFile(path); _fileHandle = (Bitmap) Image.FromFile(path);

View File

@@ -23,9 +23,10 @@ using System.Windows.Media;
using System.Windows.Media.Animation; using System.Windows.Media.Animation;
using System.Windows.Media.Imaging; using System.Windows.Media.Imaging;
using ImageMagick; using ImageMagick;
using ImageMagick.Formats.Dng;
using QuickLook.Common.Helpers; using QuickLook.Common.Helpers;
namespace QuickLook.Plugin.ImageViewer.AnimatedImage namespace QuickLook.Plugin.ImageViewer.AnimatedImage.Providers
{ {
internal class ImageMagickProvider : AnimationProvider internal class ImageMagickProvider : AnimationProvider
{ {
@@ -80,9 +81,19 @@ namespace QuickLook.Plugin.ImageViewer.AnimatedImage
return new Task<BitmapSource>(() => return new Task<BitmapSource>(() =>
{ {
var settings = new MagickReadSettings
{
Defines = new DngReadDefines
{
OutputColor = DngOutputColor.SRGB,
UseCameraWhitebalance = true,
DisableAutoBrightness = false
}
};
try try
{ {
using (var mi = new MagickImage(Path)) using (var mi = new MagickImage(Path, settings))
{ {
var profile = mi.GetColorProfile(); var profile = mi.GetColorProfile();
if (profile?.Description != null && !profile.Description.Contains("sRGB")) if (profile?.Description != null && !profile.Description.Contains("sRGB"))

View File

@@ -23,11 +23,11 @@ using System.Windows.Media.Animation;
using System.Windows.Media.Imaging; using System.Windows.Media.Imaging;
using QuickLook.Common.Helpers; using QuickLook.Common.Helpers;
namespace QuickLook.Plugin.ImageViewer.AnimatedImage namespace QuickLook.Plugin.ImageViewer.AnimatedImage.Providers
{ {
internal class NativeImageProvider : AnimationProvider internal class NativeProvider : AnimationProvider
{ {
public NativeImageProvider(string path, MetaProvider meta) : base(path, meta) public NativeProvider(string path, MetaProvider meta) : base(path, meta)
{ {
Animator = new Int32AnimationUsingKeyFrames(); Animator = new Int32AnimationUsingKeyFrames();
Animator.KeyFrames.Add(new DiscreteInt32KeyFrame(0, Animator.KeyFrames.Add(new DiscreteInt32KeyFrame(0,

View File

@@ -22,7 +22,7 @@ using System.Linq;
using System.Windows; using System.Windows;
using QuickLook.Common.Helpers; using QuickLook.Common.Helpers;
using QuickLook.Common.Plugin; using QuickLook.Common.Plugin;
using QuickLook.Plugin.ImageViewer.AnimatedImage; using QuickLook.Plugin.ImageViewer.AnimatedImage.Providers;
namespace QuickLook.Plugin.ImageViewer namespace QuickLook.Plugin.ImageViewer
{ {
@@ -49,13 +49,13 @@ namespace QuickLook.Plugin.ImageViewer
{ {
AnimatedImage.AnimatedImage.Providers.Add( AnimatedImage.AnimatedImage.Providers.Add(
new KeyValuePair<string[], Type>(new[] {".apng", ".png"}, new KeyValuePair<string[], Type>(new[] {".apng", ".png"},
typeof(APngAnimationProvider))); typeof(APngProvider)));
AnimatedImage.AnimatedImage.Providers.Add( AnimatedImage.AnimatedImage.Providers.Add(
new KeyValuePair<string[], Type>(new[] {".gif"}, new KeyValuePair<string[], Type>(new[] {".gif"},
typeof(GifAnimationProvider))); typeof(GifProvider)));
AnimatedImage.AnimatedImage.Providers.Add( AnimatedImage.AnimatedImage.Providers.Add(
new KeyValuePair<string[], Type>(new[] {".bmp", ".jpg", ".jpeg", ".tif", ".tiff"}, new KeyValuePair<string[], Type>(new[] {".bmp", ".jpg", ".jpeg", ".tif", ".tiff"},
typeof(NativeImageProvider))); typeof(NativeProvider)));
AnimatedImage.AnimatedImage.Providers.Add( AnimatedImage.AnimatedImage.Providers.Add(
new KeyValuePair<string[], Type>(new[] {"*"}, new KeyValuePair<string[], Type>(new[] {"*"},
typeof(ImageMagickProvider))); typeof(ImageMagickProvider)));

View File

@@ -62,8 +62,8 @@
<Reference Include="LibAPNG"> <Reference Include="LibAPNG">
<HintPath>.\LibAPNG.dll</HintPath> <HintPath>.\LibAPNG.dll</HintPath>
</Reference> </Reference>
<Reference Include="Magick.NET-Q8-AnyCPU, Version=7.16.1.0, Culture=neutral, PublicKeyToken=2004825badfa91ec, processorArchitecture=MSIL"> <Reference Include="Magick.NET-Q8-AnyCPU, Version=7.17.0.0, Culture=neutral, PublicKeyToken=2004825badfa91ec, processorArchitecture=MSIL">
<HintPath>..\..\packages\Magick.NET-Q8-AnyCPU.7.16.1\lib\net40\Magick.NET-Q8-AnyCPU.dll</HintPath> <HintPath>..\..\packages\Magick.NET-Q8-AnyCPU.7.17.0\lib\net40\Magick.NET-Q8-AnyCPU.dll</HintPath>
</Reference> </Reference>
<Reference Include="PresentationCore" /> <Reference Include="PresentationCore" />
<Reference Include="PresentationFramework" /> <Reference Include="PresentationFramework" />
@@ -82,12 +82,13 @@
<Link>Properties\GitVersion.cs</Link> <Link>Properties\GitVersion.cs</Link>
</Compile> </Compile>
<Compile Include="AnimatedImage\AnimatedImage.cs" /> <Compile Include="AnimatedImage\AnimatedImage.cs" />
<Compile Include="AnimatedImage\APngAnimationProvider.cs" /> <Compile Include="AnimatedImage\Providers\APngProvider.cs" />
<Compile Include="AnimatedImage\GifAnimationProvider.cs" /> <Compile Include="AnimatedImage\Providers\DcrawProvider.cs" />
<Compile Include="AnimatedImage\Providers\GifProvider.cs" />
<Compile Include="AnimatedImage\AnimationProvider.cs" /> <Compile Include="AnimatedImage\AnimationProvider.cs" />
<Compile Include="Helper.cs" /> <Compile Include="Helper.cs" />
<Compile Include="AnimatedImage\ImageMagickProvider.cs" /> <Compile Include="AnimatedImage\Providers\ImageMagickProvider.cs" />
<Compile Include="AnimatedImage\NativeImageProvider.cs" /> <Compile Include="AnimatedImage\Providers\NativeProvider.cs" />
<Compile Include="ImagePanel.xaml.cs"> <Compile Include="ImagePanel.xaml.cs">
<DependentUpon>ImagePanel.xaml</DependentUpon> <DependentUpon>ImagePanel.xaml</DependentUpon>
</Compile> </Compile>
@@ -123,5 +124,6 @@
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</Content> </Content>
</ItemGroup> </ItemGroup>
<ItemGroup />
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
</Project> </Project>

View File

@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<packages> <packages>
<package id="Magick.NET-Q8-AnyCPU" version="7.16.1" targetFramework="net462" /> <package id="Magick.NET-Q8-AnyCPU" version="7.17.0" targetFramework="net462" />
<package id="System.ValueTuple" version="4.5.0" targetFramework="net462" /> <package id="System.ValueTuple" version="4.5.0" targetFramework="net462" />
</packages> </packages>