182 lines
7.0 KiB
C#
182 lines
7.0 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
|
||
|
||
using System;
|
||
using System.Diagnostics;
|
||
|
||
namespace PdfSharp.Pdf.AcroForms
|
||
{
|
||
/// <summary>
|
||
/// Represents the base class for all choice field dictionaries.
|
||
/// </summary>
|
||
public abstract class PdfChoiceField : PdfAcroField
|
||
{
|
||
/// <summary>
|
||
/// Initializes a new instance of the <see cref="PdfChoiceField"/> class.
|
||
/// </summary>
|
||
protected PdfChoiceField(PdfDocument document)
|
||
: base(document)
|
||
{ }
|
||
|
||
/// <summary>
|
||
/// Initializes a new instance of the <see cref="PdfChoiceField"/> class.
|
||
/// </summary>
|
||
protected PdfChoiceField(PdfDictionary dict)
|
||
: base(dict)
|
||
{ }
|
||
|
||
/// <summary>
|
||
/// Gets the index of the specified string in the /Opt array or -1, if no such string exists.
|
||
/// </summary>
|
||
protected int IndexInOptArray(string value)
|
||
{
|
||
PdfArray opt = Elements.GetArray(Keys.Opt);
|
||
|
||
#if DEBUG // Check with //R080317 implemention
|
||
PdfArray opt2 = null;
|
||
if (Elements[Keys.Opt] is PdfArray)
|
||
opt2 = Elements[Keys.Opt] as PdfArray;
|
||
else if (Elements[Keys.Opt] is Advanced.PdfReference)
|
||
{
|
||
//falls das Array nicht direkt am Element h<>ngt,
|
||
//das Array aus dem referenzierten Element holen
|
||
opt2 = ((Advanced.PdfReference)Elements[Keys.Opt]).Value as PdfArray;
|
||
}
|
||
Debug.Assert(ReferenceEquals(opt, opt2));
|
||
#endif
|
||
|
||
if (opt != null)
|
||
{
|
||
int count = opt.Elements.Count;
|
||
for (int idx = 0; idx < count; idx++)
|
||
{
|
||
PdfItem item = opt.Elements[idx];
|
||
if (item is PdfString)
|
||
{
|
||
if (item.ToString() == value)
|
||
return idx;
|
||
}
|
||
else if (item is PdfArray)
|
||
{
|
||
PdfArray array = (PdfArray)item;
|
||
if (array.Elements.Count != 0)
|
||
{
|
||
if (array.Elements[0].ToString() == value)
|
||
return idx;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return -1;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets the value from the index in the /Opt array.
|
||
/// </summary>
|
||
protected string ValueInOptArray(int index)
|
||
{
|
||
PdfArray opt = Elements.GetArray(Keys.Opt);
|
||
if (opt != null)
|
||
{
|
||
int count = opt.Elements.Count;
|
||
if (index < 0 || index >= count)
|
||
throw new ArgumentOutOfRangeException("index");
|
||
|
||
PdfItem item = opt.Elements[index];
|
||
if (item is PdfString)
|
||
return item.ToString();
|
||
|
||
if (item is PdfArray)
|
||
{
|
||
PdfArray array = (PdfArray)item;
|
||
if (array.Elements.Count != 0)
|
||
return array.Elements[0].ToString();
|
||
}
|
||
}
|
||
return "";
|
||
}
|
||
|
||
/// <summary>
|
||
/// Predefined keys of this dictionary.
|
||
/// The description comes from PDF 1.4 Reference.
|
||
/// </summary>
|
||
public new class Keys : PdfAcroField.Keys
|
||
{
|
||
// ReSharper disable InconsistentNaming
|
||
|
||
/// <summary>
|
||
/// (Required; inheritable) An array of options to be presented to the user. Each element of
|
||
/// the array is either a text string representing one of the available options or a two-element
|
||
/// array consisting of a text string together with a default appearance string for constructing
|
||
/// the item<65>s appearance dynamically at viewing time.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Array | KeyType.Optional)]
|
||
public const string Opt = "/Opt";
|
||
|
||
/// <summary>
|
||
/// (Optional; inheritable) For scrollable list boxes, the top index (the index in the Opt array
|
||
/// of the first option visible in the list).
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Integer | KeyType.Optional)]
|
||
public const string TI = "/TI";
|
||
|
||
/// <summary>
|
||
/// (Sometimes required, otherwise optional; inheritable; PDF 1.4) For choice fields that allow
|
||
/// multiple selection (MultiSelect flag set), an array of integers, sorted in ascending order,
|
||
/// representing the zero-based indices in the Opt array of the currently selected option
|
||
/// items. This entry is required when two or more elements in the Opt array have different
|
||
/// names but the same export value, or when the value of the choice field is an array; in
|
||
/// other cases, it is permitted but not required. If the items identified by this entry differ
|
||
/// from those in the V entry of the field dictionary (see below), the V entry takes precedence.
|
||
/// </summary>
|
||
[KeyInfo(KeyType.Array | KeyType.Optional)]
|
||
public const string I = "/I";
|
||
|
||
/// <summary>
|
||
/// Gets the KeysMeta for these keys.
|
||
/// </summary>
|
||
internal static DictionaryMeta Meta
|
||
{
|
||
get { return _meta ?? (_meta = CreateMeta(typeof(Keys))); }
|
||
}
|
||
static DictionaryMeta _meta;
|
||
|
||
// ReSharper restore InconsistentNaming
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets the KeysMeta of this dictionary type.
|
||
/// </summary>
|
||
internal override DictionaryMeta Meta
|
||
{
|
||
get { return Keys.Meta; }
|
||
}
|
||
}
|
||
}
|