|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
using System.Runtime.InteropServices;
using MS.Internal;
using MS.Win32;
using Microsoft.Win32.SafeHandles;
using UnsafeNativeMethodsMilCoreApi = MS.Win32.PresentationCore.UnsafeNativeMethods;
namespace System.Windows.Media
{
#region SafeProfileHandle
internal class SafeProfileHandle : SafeHandleZeroOrMinusOneIsInvalid
{
/// <summary>
/// Use this constructor if the handle exists at construction time.
/// </summary>
internal SafeProfileHandle()
: base(true)
{
}
/// <summary>
/// Use this constructor if the handle exists at construction time.
/// </summary>
internal SafeProfileHandle(IntPtr profile)
: base(true)
{
SetHandle(profile);
}
protected override bool ReleaseHandle()
{
return UnsafeNativeMethodsMilCoreApi.Mscms.CloseColorProfile(handle);
}
}
#endregion
#region ColorContextHelper
/// <summary>
/// Helper struct to call into MSCMS color context APIs
/// </summary>
internal struct ColorContextHelper
{
/// Opens a color profile.
///
/// NOTE: This may fail. It is up to the caller to handle it by checking IsInvalid.
///
internal void OpenColorProfile(ref UnsafeNativeMethods.PROFILE profile)
{
// No need to get rid of the old handle as it will get GC'ed
_profileHandle = UnsafeNativeMethodsMilCoreApi.Mscms.OpenColorProfile(
ref profile,
NativeMethods.PROFILE_READ, // DesiredAccess
NativeMethods.FILE_SHARE_READ, // ShareMode
NativeMethods.OPEN_EXISTING // CreationMode
);
}
/// Retrieves the profile header
///
///
/// NOTE: This may fail. It is up to the caller to handle it by checking the bool.
///
internal bool GetColorProfileHeader(out UnsafeNativeMethods.PROFILEHEADER header)
{
if (IsInvalid)
{
throw new InvalidOperationException(SR.Image_ColorContextInvalid);
}
return UnsafeNativeMethodsMilCoreApi.Mscms.GetColorProfileHeader(_profileHandle, out header);
}
/// Retrieves the color profile from handle
internal void GetColorProfileFromHandle(byte[] buffer, ref uint bufferSize)
{
Invariant.Assert(buffer == null || bufferSize <= buffer.Length);
if (IsInvalid)
{
throw new InvalidOperationException(SR.Image_ColorContextInvalid);
}
// If the buffer is null, this function will return FALSE because it didn't actually copy anything. That's fine and that's
// what we want.
if (!UnsafeNativeMethodsMilCoreApi.Mscms.GetColorProfileFromHandle(_profileHandle, buffer, ref bufferSize) && buffer != null)
{
HRESULT.Check(Marshal.GetHRForLastWin32Error());
}
}
internal bool IsInvalid
{
get
{
return _profileHandle == null || _profileHandle.IsInvalid;
}
}
/// <summary>
/// ProfileHandle
/// </summary>
internal SafeProfileHandle ProfileHandle
{
get
{
return _profileHandle;
}
}
#region Data members
SafeProfileHandle _profileHandle;
#endregion
}
#endregion
}
|