Destination.cs :  » PDF » PDF-Clown » it » stefanochizzolini » clown » documents » interaction » navigation » document » C# / CSharp Open Source

Home
C# / CSharp Open Source
1.2.6.4 mono .net core
2.2.6.4 mono core
3.Aspect Oriented Frameworks
4.Bloggers
5.Build Systems
6.Business Application
7.Charting Reporting Tools
8.Chat Servers
9.Code Coverage Tools
10.Content Management Systems CMS
11.CRM ERP
12.Database
13.Development
14.Email
15.Forum
16.Game
17.GIS
18.GUI
19.IDEs
20.Installers Generators
21.Inversion of Control Dependency Injection
22.Issue Tracking
23.Logging Tools
24.Message
25.Mobile
26.Network Clients
27.Network Servers
28.Office
29.PDF
30.Persistence Frameworks
31.Portals
32.Profilers
33.Project Management
34.RSS RDF
35.Rule Engines
36.Script
37.Search Engines
38.Sound Audio
39.Source Control
40.SQL Clients
41.Template Engines
42.Testing
43.UML
44.Web Frameworks
45.Web Service
46.Web Testing
47.Wiki Engines
48.Windows Presentation Foundation
49.Workflows
50.XML Parsers
C# / C Sharp
C# / C Sharp by API
C# / CSharp Tutorial
C# / CSharp Open Source » PDF » PDF Clown 
PDF Clown » it » stefanochizzolini » clown » documents » interaction » navigation » document » Destination.cs
/*
  Copyright 2006,2008 Stefano Chizzolini. http://clown.stefanochizzolini.it

  Contributors:
    * Stefano Chizzolini (original code developer, http://www.stefanochizzolini.it)

  This file should be part of the source code distribution of "PDF Clown library"
  (the Program): see the accompanying README files for more info.

  This Program is free software; you can redistribute it and/or modify it under
  the terms of the GNU General Public License as published by the Free Software
  Foundation; either version 2 of the License, or (at your option) any later version.

  This Program is distributed in the hope that it will be useful, but WITHOUT ANY
  WARRANTY, either expressed or implied; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License for more details.

  You should have received a copy of the GNU General Public License along with this
  Program (see README files); if not, go to the GNU website (http://www.gnu.org/).

  Redistribution and use, with or without modification, are permitted provided that such
  redistributions retain the above copyright notice, license and disclaimer, along with
  this list of conditions.
*/

using it.stefanochizzolini.clown.documents;
using it.stefanochizzolini.clown.files;
using it.stefanochizzolini.clown.objects;

using System;

namespace it.stefanochizzolini.clown.documents.interaction.navigation.document{
  /**
    <summary>Interaction target [PDF:1.6:8.2.1].</summary>
    <remarks>It represents a particular view of a document, consisting of the following items:
      <ul>
        <li>the page of the document to be displayed;</li>
        <li>the location of the document window on that page;</li>
        <li>the magnification (zoom) factor to use when displaying the page.</li>
      </ul>
    </remarks>
  */
  public abstract class Destination
    : PdfObjectWrapper<PdfArray>
  {
    #region types
    /**
      <summary>Destination mode [PDF:1.6:8.2.1].</summary>
    */
    public enum ModeEnum
    {
      /**
        <summary>Display the page at the given upper-left position,
        applying the given magnification.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>left coordinate</li>
            <li>top coordinate</li>
            <li>zoom</li>
          </ol>
        </remarks>
      */
      XYZ,
      /**
        <summary>Display the page with its contents magnified just enough to fit
        the entire page within the window both horizontally and vertically.</summary>
        <remarks>No view parameters.</remarks>
      */
      Fit,
      /**
        <summary>Display the page with the vertical coordinate <code>top</code> positioned
        at the top edge of the window and the contents of the page magnified
        just enough to fit the entire width of the page within the window.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>top coordinate</li>
          </ol>
        </remarks>
      */
      FitHorizontal,
      /**
        <summary>Display the page with the horizontal coordinate <code>left</code> positioned
        at the left edge of the window and the contents of the page magnified
        just enough to fit the entire height of the page within the window.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>left coordinate</li>
          </ol>
        </remarks>
      */
      FitVertical,
      /**
        <summary>Display the page with its contents magnified just enough to fit
        the rectangle specified by the given coordinates entirely
        within the window both horizontally and vertically.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>left coordinate</li>
            <li>bottom coordinate</li>
            <li>right coordinate</li>
            <li>top coordinate</li>
          </ol>
        </remarks>
      */
      FitRectangle,
      /**
        <summary>Display the page with its contents magnified just enough to fit
        its bounding box entirely within the window both horizontally and vertically.</summary>
        <remarks>No view parameters.</remarks>
      */
      FitBoundingBox,
      /**
        <summary>Display the page with the vertical coordinate <code>top</code> positioned
        at the top edge of the window and the contents of the page magnified
        just enough to fit the entire width of its bounding box within the window.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>top coordinate</li>
          </ol>
        </remarks>
      */
      FitBoundingBoxHorizontal,
      /**
        <summary>Display the page with the horizontal coordinate <code>left</code> positioned
        at the left edge of the window and the contents of the page magnified
        just enough to fit the entire height of its bounding box within the window.</summary>
        <remarks>
          <para>View parameters:</para>
          <ol>
            <li>left coordinate</li>
          </ol>
        </remarks>
      */
      FitBoundingBoxVertical
    }
    #endregion

    #region static
    #region interface
    #region public
    /**
      <summary>Wraps a destination base object into a destination object.</summary>
      <param name="baseObject">Destination base object.</param>
      <param name="container">Destination base object container.</param>
      <returns>Destination object associated to the base object.</returns>
    */
    public static Destination Wrap(
      PdfDirectObject baseObject,
      PdfIndirectObject container
      )
    {
      /*
        NOTE: This is a factory method for any destination-derived object.
      */
      if(baseObject == null)
        return null;

      PdfArray dataObject = (PdfArray)File.Resolve(baseObject);
      PdfDirectObject pageObject = dataObject[0];
      if(pageObject is PdfReference)
        return new LocalDestination(baseObject,container);
      else if(pageObject is PdfInteger)
        return new RemoteDestination(baseObject,container);
      else
        throw new ArgumentException("'baseObject' parameter doesn't represent a valid destination object.");
    }
    #endregion
    #endregion
    #endregion

    #region dynamic
    #region constructors
    /**
      <summary>Creates a new destination within the given document context.</summary>
      <param name="context">Document context.</param>
      <param name="pageObject">Page reference. It may be either an actual page reference (PdfReference)
        or a page index (PdfInteger).</param>
      <param name="mode">Destination mode.</param>
      <param name="viewParams">View parameters. Their actual composition depends on the <code>mode</code> value
        (see ModeEnum for more info).</param>
    */
    protected Destination(
      Document context,
      PdfDirectObject pageObject,
      ModeEnum mode,
      double[] viewParams
      ) : base(
        context.File,
        new PdfArray()
        )
    {
      PdfArray destinationObject = BaseDataObject;

      destinationObject.Add(pageObject);

      switch(mode)
      {
        case ModeEnum.Fit:
          destinationObject.Add(PdfName.Fit);
          break;
        case ModeEnum.FitBoundingBox:
          destinationObject.Add(PdfName.FitB);
          break;
        case ModeEnum.FitBoundingBoxHorizontal:
          destinationObject.Add(PdfName.FitBH);
          destinationObject.Add(new PdfReal(viewParams[0]));
          break;
        case ModeEnum.FitBoundingBoxVertical:
          destinationObject.Add(PdfName.FitBV);
          destinationObject.Add(new PdfReal(viewParams[0]));
          break;
        case ModeEnum.FitHorizontal:
          destinationObject.Add(PdfName.FitH);
          destinationObject.Add(new PdfReal(viewParams[0]));
          break;
        case ModeEnum.FitRectangle:
          destinationObject.Add(PdfName.FitR);
          destinationObject.Add(new PdfReal(viewParams[0]));
          destinationObject.Add(new PdfReal(viewParams[1]));
          destinationObject.Add(new PdfReal(viewParams[2]));
          destinationObject.Add(new PdfReal(viewParams[3]));
          break;
        case ModeEnum.FitVertical:
          destinationObject.Add(PdfName.FitV);
          destinationObject.Add(new PdfReal(viewParams[0]));
          break;
        case ModeEnum.XYZ:
          destinationObject.Add(PdfName.XYZ);
          destinationObject.Add(new PdfReal(viewParams[0]));
          destinationObject.Add(new PdfReal(viewParams[1]));
          destinationObject.Add(new PdfReal(viewParams[2]));
          break;
      }
    }

    protected Destination(
      PdfDirectObject baseObject,
      PdfIndirectObject container
      ) : base(
        baseObject,
        container
        )
    {}
    #endregion

    #region interface
    #region public
    public override object Clone(
      Document context
      )
    {throw new NotImplementedException();}

    public ModeEnum Mode
    {
      get
      {
        PdfName modeObject = (PdfName)BaseDataObject[1];

        if(modeObject == PdfName.FitB) return ModeEnum.FitBoundingBox;
        if(modeObject == PdfName.FitBH) return ModeEnum.FitBoundingBoxHorizontal;
        if(modeObject == PdfName.FitBV) return ModeEnum.FitBoundingBoxVertical;
        if(modeObject == PdfName.FitH) return ModeEnum.FitHorizontal;
        if(modeObject == PdfName.FitR) return ModeEnum.FitRectangle;
        if(modeObject == PdfName.FitV) return ModeEnum.FitVertical;
        if(modeObject == PdfName.XYZ) return ModeEnum.XYZ;

        return ModeEnum.Fit;
      }
    }

    /**
      <summary>Gets the target page reference.</summary>
    */
    public abstract object PageRef
    {get;}
    #endregion
    #endregion
    #endregion
  }
}
ww___w__.___ja_va2s_.__c_o_m___ | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.