DLI Implementation and Reference Guide
Total Page:16
File Type:pdf, Size:1020Kb
Implementation and Reference Guide Datalogics Interface Datalogics® Datalogics DATALOGICS INTERFACE Implementation and Reference Guide This guide is part of the Adobe® PDF Library v6.1.1Plus suite; 02/15/05. Copyright 1999-2005 Datalogics Incorporated. All Rights Reserved. Use of Datalogics software is subject to the applicable license agreement. DL Interface is a trademark of Datalogics Incorporated. Other products mentioned herein as Datalogics prod- ucts are also trademarks or registered trademarks of Datalogics, Incorporated. Adobe, Adobe PDF Library, Portable Document Format (PDF), PostScript, Acrobat, Distiller, Exchange and Reader are trademarks of Adobe Systems Incorporated. HP and HP-UX are registered trademarks of Hewlett Packard Corporation. IBM, AIX, AS/400, OS/400, MVS, and OS/390 are registered trademarks of International Business Machines. Java, J2EE, J2SE, J2ME, all Java-based marks, Sun and Solaris are trademarks or registered trademarks of Sun Microsystems, Inc. in the United States and other countries. Linux is a registered trademark of Linus Torvalds. Microsoft, Windows and Windows NT are trademarks or registered trademarks of Microsoft Corporation. SAS/C is a registered trademark of SAS Institute Inc. UNIX is a registered trademark of The Open Group. VeriSign® is a registered trademark of VeriSign, Inc. in the United States and/or other countries. All other trademarks and registered trademarks are the property of their respective owners. For additional information, contact: Datalogics, Incorporated 101 North Wacker Drive, Suite 1800 Chicago, Illinois 60606-7301 Phone: 312-853-8200 Fax: 312-853-8282 www.datalogics.com [email protected] Table of Contents i Table of Contents 1 Getting Started 1.1 An Introduction to DLI 1.2 How to Create a PDF Document with DLI 1.2 How to Use this Book 1.5 What’s New in This Release 1.11 Enhancements in Prior Releases 1.20 2 Initializing and Terminating the Library 2.1 Overview 2.2 Adobe PDF Library Data Structure 2.2 Adobe PDF Library Version Control 2.6 Files In Memory Activation 2.8 Initializing and Terminating via DLI 2.8 Writing PDF Output to Memory 2.15 API Comparison 2.17 3 Beginning and Ending a Document 3.1 Overview 3.2 4 Fonts 4.1 PDF Font Overview 4.2 Structure of a DLI Font 4.4 Font Creation Calls 4.6 Predefined Font Encodings 4.11 Unicode Text Support 4.13 Code Page Support 4.13 Performance Considerations 4.13 ii DLI Implementation and Reference Guide Accessing Fonts 4.15 5 Multibyte Text Work 5.1 Concepts and Facilities: Guide to the DL Pager Composition System Introduction 5.2 Loading and Creating Fonts 5.3 Creating DLPDFTEXT Areas 5.5 Working With DLPDFTEXT Areas 5.7 Performance Considerations 5.10 6 Working with Pages 6.1 Introduction to Page Interface 6.2 Page Interface Calls 6.2 7 Containers within Pages 7.1 What are Containers? 7.2 8 Working with Content 8.1 Overview of Content Interface 8.2 Content Interface Calls 8.3 9 Working with Forms 9.1 Overview of Forms 9.2 Form Calls 9.3 10 Displaying Line Drawings 10.1 Overview 10.2 Approaches to Line Drawing 10.3 Graphic State and Line Drawing 10.17 Table of Contents iii 11 Image Display 11.1 Overview 11.2 Graphic Image Structures 11.2 Graphic Image Forms 11.3 Image Creation Methods 11.5 Creating Transparent Graphics 11.12 12 Color and its Use 12.1 Library Color Descriptions 12.2 Colors in Images 12.3 Creating and Destroying Color Spaces 12.3 Values for Color Channels 12.6 Basic Color Spaces 12.7 Advanced Color Spaces 12.11 Building Patterned Color Spaces 12.13 Conversion between Models 12.16 13 Annotations and Links 13.1 Overview 13.2 Annotation Components 13.2 Modifying the Link Cos Object 13.9 14 Bookmark Creation 14.1 Overview 14.2 15 Digital Signatures 15.1 Overview 15.2 Public and Private Keys 15.2 iv DLI Implementation and Reference Guide Digital Signature Calls 15.4 16 Error Concepts and Facilities: Guide to the DL Pager Composition System Testing and Recovery 16.1 Overview 16.2 OS/390 Platform Concerns 16.4 17 Samples and Links 17.1 Running DLI Sample Applications 17.2 A DLI Reference Guide A.1 1 Getting Started This chapter introduces the Datalogics Interface. Experienced users may want to skip directly to the section “What’s New in This Release” on page 1.11 for information on the latest enhancements and additions. 1.1 1.2 DLI Implementation and Reference Guide An Introduction to DLI The Datalogics Interface (DLI) facilitates the rapid creation of PDF documents and improves performance, throughput and graphics handling. It does this by bypassing many of the functions of the PDF Edit layer and eliminating redundant calls to the COS layer used in the Adobe® PDF Library. For information on the various layers of Adobe PDF Library please see the Acrobat Core API Overview. How to Create a PDF Document with DLI The DLI package exists at the output end of the page creation process. As such, most of the intricacies of line breaking, page breaking and general composition are outside of its scope. The process of writing pages is where this package fits into an application. An overview of this process follows: 1 Initialize DLI. (start of all processing) 2 Define the document. 3 Define fonts: i.e. Identify and describe each font to be used in the job to DLI. These can be done as encountered, if so desired. 4 Define forms: i.e. Identify and describe each form to be used in the job to DLI. These can be done as encountered, if so desired. 5 Define graphics: i.e. Identify and define each graphic to be used multiple times to DLI. These can be done as encountered, if so desired. 6 For each page: • Create a dlpdfpage object. • Create a dlpdfcontent object. 7 Generate the content of a single page: • For each graphic reference on the page, create the graphic in content. • For each text line on the page, create the text in content. 8 End the content and inform DLI that the content is complete. 9 End the page and inform DLI that the page is complete. Getting Started 1.3 10 End the document. 11 End the job. Error handling during application execution is handled through the raising and handling of exceptions, as defined by the Adobe PDF Library. These are similar to operation exceptions in C++. For details on handling exceptions, please see the chapter “Error Testing and Recovery” on page 16.1. What You Should Know This document is intended for programmers who are familiar with text composition and the creation of output drivers, or by application designers who are constructing an application based on the DLI package. You should have access to the Adobe PDF Library Applications Programming Interface (API) manual and the Adobe PDF Specifications manual for your system. For Adobe PDF Library v5.x releases, Adobe PDF Specification 1.4 is appropriate.For Adobe PDF Library v6.x releases, Adobe PDF Specification 1.5 is appropriate. NOTE: Some structures permitted in Adobe PDF Specification 1.5 may not be permitted in Adobe PDF Specification 1.4, and some structures defined in Adobe PDF Specification 1.4 are not available in Adobe PDF Specification 1.3. The explanations, assumptions and samples provided in this guide refer to Adobe PDF Library v6.1.0Plus and DLI v3.0 or higher. DLI Initialization Required Starting with DLI v2.1, the initialization process has been simplified such that you must initialize DLI to automatically initialize the Adobe PDF Library. Though it may be functionally possible to bypass the initialization of DLI for versions 2.1 and higher, an application should not do so. Using the DLI initialization and termination routines not only simplifies application programming but also allows the use of the Datalogics 1.4 DLI Implementation and Reference Guide Files In Memory (FIM) System, and the enabling of certain optimizations in jobs which span multiple documents. NOTE: The Adobe PDF Library and DLI are not intended to be initialized more than once within a single instance of an application. Doing so can produce undesirable results. Versions of Adobe PDF Library prior to v6.1 are not thread-safe. gcc Compilation Version Adobe compiles their PDF Library components with gcc 2.95.2 on the Solaris®, AIX® and Linux® operating systems. Datalogics does not recompile Adobe components on any other compiler on these operating systems. Datalogics only distributes the Adobe PDF Library and the DLI components compiled using gcc on these operating systems. For the latest information on supported operating-system compilers and versions, please see the readme.txt file of last-minute updates accompanying your software release files. Unix Compiler Run-Time Libraries For clients who are using native (i.e. platform-resident) UNIX® compilers, the run- time libraries for each of these operating systems are available from the Free Software Foundation. Any clients wishing to integrate the Adobe PDF Library and DLI components with their natively-compiled applications can retrieve these run-time libraries free of charge from the Free Software Foundation at http:// www.gnu.org/software/gcc/. Getting Started 1.5 How to Use this Book This book has been created to guide you through the process of creating PDF documents with DLI. It consists of two main sections: • An Implementation section • A Reference Guide appendix The Implementation section begins with Chapter 1: Getting Started. It follows the steps needed to create PDF and introduces DLI in relation to the Adobe PDF Library, explains the methods used in DLI, how they fit together, and provides various samples.