1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
|
#region PDFsharp - A .NET library for processing PDF
//
// Authors:
// Stefan Lange (mailto:Stefan.Lange@pdfsharp.com)
//
// Copyright (c) 2005-2008 empira Software GmbH, Cologne (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;
using System.Collections;
using System.Text;
using System.IO;
using PdfSharp.Pdf.Advanced;
using PdfSharp.Drawing;
using PdfSharp.Fonts.TrueType;
using PdfSharp.Internal;
namespace PdfSharp.Pdf.Advanced
{
/// <summary>
/// Represents the imported objects of an external document. Used to cache objects that are
/// already imported when a PdfFormXObject is added to a page.
/// </summary>
internal sealed class PdfImportedObjectTable
{
/// <summary>
/// Initializes a new instance of this class with the document the objects are imported from.
/// </summary>
public PdfImportedObjectTable(PdfDocument owner, PdfDocument externalDocument)
{
if (owner == null)
throw new ArgumentNullException("owner");
if (externalDocument == null)
throw new ArgumentNullException("externalDocument");
this.owner = owner;
this.externalDocumentHandle = externalDocument.Handle;
this.xObjects = new PdfFormXObject[externalDocument.PageCount];
}
PdfFormXObject[] xObjects;
/// <summary>
/// Gets the document this table belongs to.
/// </summary>
public PdfDocument Owner
{
get { return this.owner; }
}
PdfDocument owner;
/// <summary>
/// Gets the external document, or null, if the external document is garbage collected.
/// </summary>
public PdfDocument ExternalDocument
{
get
{
if (this.externalDocumentHandle.IsAlive)
return this.externalDocumentHandle.Target;
return null;
}
}
PdfDocument.DocumentHandle externalDocumentHandle;
public PdfFormXObject GetXObject(int pageNumber)
{
return this.xObjects[pageNumber - 1];
}
public void SetXObject(int pageNumber, PdfFormXObject xObject)
{
this.xObjects[pageNumber - 1] = xObject;
}
/// <summary>
/// Indicates whether the specified object is already imported.
/// </summary>
public bool Contains(PdfObjectID externalID)
{
return this.externalIDs.Contains(externalID.ToString());
}
/// <summary>
/// Adds a cloned object to this table.
/// </summary>
/// <param name="externalID">The object identifier in the forein object.</param>
/// <param name="iref">The cross reference to the clone of the forein object, which belongs to
/// this document. In general the clone has a different object identifier.</param>
public void Add(PdfObjectID externalID, PdfReference iref)
{
this.externalIDs[externalID.ToString()] = iref;
}
/// <summary>
/// Gets the cloned object that corresponds to the specified external identifier.
/// </summary>
public PdfReference this[PdfObjectID externalID]
{
get { return (PdfReference)this.externalIDs[externalID.ToString()]; }
}
/// <summary>
/// Maps external object identifiers to cross reference entries of the importing document
/// {PdfObjectID -> PdfReference}.
/// </summary>
Hashtable externalIDs = new Hashtable();
}
}
|