110 lines
4.8 KiB
C#
110 lines
4.8 KiB
C#
#region PDFsharp - A .NET library for processing PDF
|
||
//
|
||
// Authors:
|
||
// Stefan Lange
|
||
//
|
||
// Copyright (c) 2005-2017 empira Software GmbH, Cologne Area (Germany)
|
||
//
|
||
// http://www.pdfsharp.com
|
||
// http://sourceforge.net/projects/pdfsharp
|
||
//
|
||
// Permission is hereby granted, free of charge, to any person obtaining a
|
||
// copy of this software and associated documentation files (the "Software"),
|
||
// to deal in the Software without restriction, including without limitation
|
||
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||
// and/or sell copies of the Software, and to permit persons to whom the
|
||
// Software is furnished to do so, subject to the following conditions:
|
||
//
|
||
// The above copyright notice and this permission notice shall be included
|
||
// in all copies or substantial portions of the Software.
|
||
//
|
||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||
// DEALINGS IN THE SOFTWARE.
|
||
#endregion
|
||
|
||
#if GDI
|
||
using System.Drawing;
|
||
using System.Drawing.Imaging;
|
||
#endif
|
||
#if WPF
|
||
using System.Windows.Media;
|
||
#endif
|
||
|
||
namespace PdfSharp.Pdf.Advanced
|
||
{
|
||
/// <summary>
|
||
/// Represents a PDF soft mask.
|
||
/// </summary>
|
||
public class PdfSoftMask : PdfDictionary
|
||
{
|
||
/// <summary>
|
||
/// Initializes a new instance of the <see cref="PdfXObject"/> class.
|
||
/// </summary>
|
||
/// <param name="document">The document that owns the object.</param>
|
||
public PdfSoftMask(PdfDocument document)
|
||
: base(document)
|
||
{
|
||
Elements.SetName(Keys.Type, "/Mask");
|
||
}
|
||
|
||
/// <summary>
|
||
/// Predefined keys of this dictionary.
|
||
/// </summary>
|
||
public class Keys : KeysBase
|
||
{
|
||
/// <summary>
|
||
/// (Optional) The type of PDF object that this dictionary describes;
|
||
/// if present, must be Mask for a soft-mask dictionary.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Name | KeyType.Optional, FixedValue = "Mask")]
|
||
public const string Type = "/Type";
|
||
|
||
/// <summary>
|
||
/// (Required) A subtype specifying the method to be used in deriving the mask values
|
||
/// from the transparency group specified by the G entry:
|
||
/// Alpha: Use the group<75>s computed alpha, disregarding its color.
|
||
/// Luminosity: Convert the group<75>s computed color to a single-component luminosity value.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Name | KeyType.Required)]
|
||
public const string S = "/S";
|
||
|
||
/// <summary>
|
||
/// (Required) A transparency group XObject to be used as the source of alpha
|
||
/// or color values for deriving the mask. If the subtype S is Luminosity, the
|
||
/// group attributes dictionary must contain a CS entry defining the color space
|
||
/// in which the compositing computation is to be performed.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Stream | KeyType.Required)]
|
||
public const string G = "/G";
|
||
|
||
/// <summary>
|
||
/// (Optional) An array of component values specifying the color to be used
|
||
/// as the backdrop against which to composite the transparency group XObject G.
|
||
/// This entry is consulted only if the subtype S is Luminosity. The array consists of
|
||
/// n numbers, where n is the number of components in the color space specified
|
||
/// by the CS entry in the group attributes dictionary.
|
||
/// Default value: the color space<63>s initial value, representing black.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Array | KeyType.Optional)]
|
||
public const string BC = "/BC";
|
||
|
||
/// <summary>
|
||
/// (Optional) A function object specifying the transfer function to be used in
|
||
/// deriving the mask values. The function accepts one input, the computed
|
||
/// group alpha or luminosity (depending on the value of the subtype S), and
|
||
/// returns one output, the resulting mask value. Both the input and output
|
||
/// must be in the range 0.0 to 1.0; if the computed output falls outside this
|
||
/// range, it is forced to the nearest valid value. The name Identity may be
|
||
/// specified in place of a function object to designate the identity function.
|
||
/// Default value: Identity.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.FunctionOrName | KeyType.Optional)]
|
||
public const string TR = "/TR";
|
||
}
|
||
}
|
||
} |