|
//------------------------------------------------------------------------------
// Microsoft Avalon
// Copyright (c) Microsoft Corporation, 2005
//
// File: BitmapEffect.cs
//------------------------------------------------------------------------------
using MS.Internal;
using System;
using System.IO;
using System.ComponentModel;
using System.ComponentModel.Design.Serialization;
using System.Diagnostics;
using System.Reflection;
using System.Windows.Threading;
using System.Threading;
using System.Runtime.InteropServices;
using System.Windows;
using System.Windows.Media;
using System.Windows.Markup;
using System.Windows.Media.Animation;
using System.Windows.Media.Composition;
using System.Windows.Media.Imaging;
using System.Security;
using MS.Internal.PresentationCore;
using System.Security.Permissions;
using SR = MS.Internal.PresentationCore.SR;
using SRID = MS.Internal.PresentationCore.SRID;
namespace System.Windows.Media.Effects
{
/// <summary>
/// BitmapEffect
/// </summary>
/// <SecurityNote>
/// We have the Inheritance demand, because we don't want
/// third parties to be able to subclass BitmapEffect in the partial trust scenario
/// </SecurityNote>
[UIPermissionAttribute(SecurityAction.InheritanceDemand, Window = UIPermissionWindow.AllWindows)]
public abstract partial class BitmapEffect
{
#region Constructors
/// <summary>
/// Constructor
/// </summary>
/// <SecurityNote>
/// Critical : Not allowed in partial trust
/// Safe : Demands UIWindow permission
/// </SecurityNote>
[SecuritySafeCritical]
protected BitmapEffect()
{
// Even though BitmapEffects are obsolete, to preserve compat they are
// still never allowed in partial trust scenarios. The previous BitmapEffects
// would create a native COM object in the constructor, which would demand.
// So, demand UIWindow permission immediately in the ctor.
SecurityHelper.DemandUIWindowPermission();
// STA Requirement
//
// Avalon doesn't necessarily require STA, but many components do. Examples
// include Cicero, OLE, COM, etc. So we throw an exception here if the
// thread is not STA.
if (Thread.CurrentThread.GetApartmentState() != ApartmentState.STA)
{
throw new InvalidOperationException(SR.Get(SRID.RequiresSTA));
}
}
#endregion
#region Protected Methods
/// <summary>
/// This method is called before calling GetOutput on an effect.
/// It gives a chance for the managed effect to update the properties
/// of the unmanaged object.
/// </summary>
/// <SecurityNote>
/// Critical - receives a security critical type SafeHandle.
/// </SecurityNote>
[SecurityCritical]
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
abstract protected void UpdateUnmanagedPropertyState(SafeHandle unmanagedEffect);
/// <summary>
/// Returns a safe handle to an unmanaged effect clone
/// </summary>
/// <SecurityNote>
/// Critical - returns a security critical type SafeHandle.
/// </SecurityNote>
[SecurityCritical]
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
unsafe abstract protected SafeHandle CreateUnmanagedEffect();
/// <summary>
/// SetValue
/// </summary>
/// <param name="effect"> SafeHandle to the unmanaged effect object</param>
/// <param name="propertyName">Name of the unmanaged property to be set</param>
/// <param name="value">Object value to set unmanaged property to</param>
/// <returns></returns>
/// <SecurityNote>
/// Critical - calls native code
/// TreatAsSafe - as there is a demand
/// </SecurityNote>
[SecurityCritical, SecurityTreatAsSafe]
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
unsafe static protected void SetValue(SafeHandle effect, string propertyName, object value)
{
SecurityHelper.DemandUIWindowPermission();
}
/// <summary>
/// Creates an IMILBitmapEffect object
/// </summary>
/// <returns>IMILBitmapEffect object</returns>
/// <SecurityNote>
/// Critical - calls native code
/// TreatAsSafe - as there is a demand
/// </SecurityNote>
[SecurityCritical, SecurityTreatAsSafe]
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
unsafe static protected SafeHandle /* IMILBitmapEffect */ CreateBitmapEffectOuter()
{
SecurityHelper.DemandUIWindowPermission();
return null;
}
/// <summary>
/// Initializes the IMILBitmapEffect object with the IMILBitmapEffectPrimitive object
/// </summary>
/// <param name="outerObject">The IMILBitmapEffect object</param>
/// <param name="innerObject">The IMILBitmapEffectPrimitive object</param>
/// <SecurityNote>
/// Critical - calls native code
/// TreatAsSafe - as there is a demand
/// </SecurityNote>
[SecurityCritical, SecurityTreatAsSafe]
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
unsafe static protected void InitializeBitmapEffect(SafeHandle /*IMILBitmapEffect */ outerObject,
SafeHandle/* IMILBitmapEffectPrimitive */ innerObject)
{
SecurityHelper.DemandUIWindowPermission();
}
#endregion
#region Public Methods
/// <summary>
/// This returns the output at index 0
/// </summary>
[Obsolete(MS.Internal.Media.VisualTreeUtils.BitmapEffectObsoleteMessage)]
public BitmapSource GetOutput(BitmapEffectInput input)
{
if (input == null)
{
throw new ArgumentNullException("input");
}
// if we don't have the input set, we should not be calling the output property
if (input.Input == null)
{
throw new ArgumentException(SR.Get(SRID.Effect_No_InputSource), "input");
}
if (input.Input == BitmapEffectInput.ContextInputSource)
{
throw new InvalidOperationException(SR.Get(SRID.Effect_No_ContextInputSource, null));
}
return input.Input.Clone();
}
#endregion
#region Internal Methods
/// <summary>
/// True if the effect can be emulated by the Effect pipeline. Derived classes
/// can override this method to indicate that they can be emulated using the ImageEffect
/// pipeline. If a derived class returns true it needs to also implement the GetEmulatingImageEffect
/// property to provide an emulating ImageEffect.
/// </summary>
internal virtual bool CanBeEmulatedUsingEffectPipeline()
{
return false;
}
/// <summary>
/// Derived classes need to return an emulating image effect if they return true from CanBeEmulatedUsingImageEffectPipeline.
/// </summary>
internal virtual Effect GetEmulatingEffect()
{
throw new NotImplementedException();
}
#endregion
}
}
|