Imaging For Windows
Imaging For Windows
Imaging For Windows
Developers Guide
Developers Guide
Software Notice
All software must be licensed to customers in accordance with the terms and conditions of any approved and authorized license. No title or ownership of the software is transferred, and any use of the software beyond the terms of the aforesaid license, without written authorization of the publisher, is prohibited.
Microsoft and Windows are registered trademarks of Microsoft Corporation in the USA and in other countries. Other product names mentioned in this guide may be trademarks or registered trademarks of their respective companies.
Contents
Developers Guide
About This Guide
Purpose xiv xiv xiv
Prerequisites
About Imaging
Introducing Imaging for Windows
Imaging Components 2 Imaging Application 2 Imaging Preview 3 Imaging Flow 3 Development Tools and Methods 4
Command-line Invocation 5 OLE 5 Embedded Image Files 5 Linked Image Files 6 Automation 6 ActiveX Controls 7 Which to Use: Command-line Interface, OLE, Automation, or ActiveX Controls? 8 Command-line Interface 8 OLE 8 Automation 9 ActiveX Controls 10
Contents
Sample Code 10 Automation Demonstration Project 11 ActiveX Demonstration Projects 11 ActiveX Sample Applications 11
13
17 18
Documentation Conventions
22
Demonstration Project
28
iv
Contents
Example 32 The Automation From Excel Project 32 Opening the Spreadsheet File 34 Opening and Displaying the Image File 34 Obtaining the Page Count 39 Rotating an Image Page 40 Setting the One Page View Mode 41 Setting the Thumbnail View Mode 41 Setting the Page and Thumbnails View Mode 42 Closing the Image File and the Imaging Application 42
Automation Lexicon
Overview 44 44 Application Object
Application Object Properties 44 ActiveDocument Property 45 AnnotationPaletteVisible Property 46 Application Property 46 AppState Property 46 DisplayScaleAlgorithm Property 46 Edit Property 47 FullName Property 47 Height Property 48 ImagePalette Property 48 ImageView Property 48 ImagingToolBarVisible Property 49 Left Property 49 Name Property 50 Parent Property 50 Path Property 50 ScannerIsAvailable Property 50 ScanToolBarVisible Property 50 ScrollBarsVisible Property 51 StatusBarVisible Property 51 ToolBarVisible Property 51 Top Property 52 TopWindow Property 52
Contents
Visible Property 52 WebToolBarVisible Property 53 Width Property 53 Zoom Property 53 Application Object Methods 54 CreateImageViewerObject Method FitTo Method 54 Help Method 55 Quit Method 55
54
ImageFile Object
56
ImageFile Object Properties 56 ActivePage Property 56 Application Property 57 FileType Property 57 Name Property 57 OCRLaunchApplication Property 58 OCROutputFile Property 58 OCROutputType Property 58 PageCount Property 58 Parent Property 59 Saved Property 59 ImageFile Object Methods 59 AppendExistingPages Method 60 Close Method 61 CreateContactSheet Method 61 FindOIServerDoc Method 62 Help Method 62 InsertExistingPages Method 62 New Method 63 Ocr Method 64 Open Method 64 Pages Method 65 Print Method 66 RotateAll Method 66 Save Method 66 SaveAs Method 67 SaveCopyAs Method 68 Update Method 68
vi
Page Object Properties 69 Application Property 69 CompressionInfo Property 69 CompressionType Property 70 Height Property 71 ImageResolutionX Property 71 ImageResolutionY Property 72 Name Property 72 PageType Property 72 Parent Property 73 ScrollPositionX Property 73 ScrollPositionY Property 73 Width Property 73 Page Object Methods 74 Delete Method 74 Flip Method 74 Help Method 74 Ocr Method 74 Print Method 75 RotateLeft Method 75 RotateRight Method 75 Scroll Method 75
PageRange Object
76
PageRange Object Properties 76 Application Property 76 Count Property 76 EndPage Property 76 Parent Property 77 StartPage Property 77 PageRange Object Methods 77 Delete Method 77 Ocr Method 78 Print Method 78
vii
Contents
80
Obtaining Help
84
Visual Basic 84 Object Browser 85 Toolbox 85 Form Window 86 Properties Window 86 Code Window 86 Visual C++ 87 Components and Controls Gallery Dialog Box Properties Window 87 Access 88 Object Browser 88 Properties Window 88 Module Window 89
87
Demonstration Projects
90
90
Displaying an Image and Applying Fit-To Options Fit-To Options Defined 90 Example 91 FitTo Options Project 92 Converting an Image 94 Image Conversion Defined 94 Example 95 Example 96 Example 98 Example 99 Example 99 Convert Image Project 100 Copying An Image 105 Clipboard Functions Defined 105 Clipboard Copy and Cut 105 Clipboard Paste 105
viii
Contents
Image Selection 106 Annotation Selection 106 Example 107 Copy Image Project 107 Printing An Image 110 Image Printing Defined 110 Example 110 Print Image Project 111 Scanning an Image Using a Template 117 Template Scanning Defined 117 Example 118 Template Scan Project 120 Managing an Image File Using Thumbnails 128 Thumbnails Defined 128 Example 128 Thumbnail Sorter Project 129 Subtracting the Value of X 141 Unloading a Multipage Image File 143 Multipage Image Files Defined 143 Page-Related Properties and Methods 145 Image Admin 145 Image Edit 145 Image Scan 146 Image Thumbnail 146 Example 147 Unload Project 148
156
ix
Logging Onto the Server 157 Setting Imaging 1.x Server Options 158 The following sections explain each server option setting and related property in detail. 161 File Location for Document Pages (FileStgLoc1x Property) 161 Force Lower-Case File Names (ForceLowerCase1x Property) 162 Link Files On Reference (ForceFileLinking1x Property) 162 Delete Files With Pages (ForceFileDeletion1x Property) 164 Browsing for Volumes or Image Files and Server Documents 165 Browsing for Volumes 165 Browsing for Files and Documents 166 Querying for Imaging 1.x Documents 169 Saving 1.x Image Files and Documents 170
173
Demonstration Project
176
Zooming an Image Defined 176 Zooming an Entire Image Page 176 Zooming a Portion of an Image Page 177 Example 177 Annotations Defined 178 Image Annotation Tool Button Control 180 Image Edit Control 181 Example 187 The Image Server Project 187 Setting Server Options 189 Browsing for Imaging 1.x File and/or Document Volumes 190 Opening 1.x Files and Documents 192 Querying 1.x Document Manager Databases 194 Zooming an Image 211
Contents
Invoking the Standard Annotation Tool Palette 213
Sample Applications
Image Editor Samples 217 Sample Application 217 Image Editor 218 Function Specific Samples 218 Image Print 219 Image Properties 219 Image Scan 220 Image Thumbnails 220 Imaging Flow Samples 221 Flow Program 221 Flow Variables 221
xi
In this Chapter
Purpose .............................................................................xiv Prerequisites ......................................................................xiv Related Information...........................................................xiv
Purpose
The Developers Guide describes the features of eiStream Imaging for Windows and provides software developers and MIS professionals with the information they need to produce and support image-enabled applications. This guide is a technical resource that supplements the on-line help and documentation included with the Imaging for Windows product.
Prerequisites
To use this product, you should be familiar with the Microsoft Windows environment. If you are using a printer, a scanner, or a TWAIN-compliant device, you should also know how to connect and operate it. If you plan to access documents residing on WMS Imaging Server (1.x) or a WMS Imaging and Workflow (WMS) server, you should be familiar with navigating document databases in those environments.
Related Information
For instructions on how to use the Imaging ActiveX controls, access the on-line help system for the controls from your development environment. For updated product information and general information about Imaging for Windows, visit our Web site at: www.eiStream.com Proceed to WMS|Kofile or eiStream WMS. Under products, select eiStream Imaging for Windows.
xiv
Support
Should you have questions regarding Imaging for Windows, or problems with your system after installation, consult your customer support representative. For technical support, visit our Web site at: www.eiStream.com Proceed to WMS|Kofile or eiStream WMS. Under products, select eiStream Imaging for Windows, and then click the Support link. The Support area includes technical bulletins, current documentation, and other relevant information. To request a patch, send an e-mail to Technical Support.
xv
1
About Imaging
This chapter describes the Imaging for Windows product and suggests ways in which the product features can be used in business and personal document imaging.
In This Chapter
Introducing Imaging for Windows ................................................. 2 What Imaging Lets You Do ............................................................ 5 What Imaging Lets Your Users Do................................................ 13 What Is Document Imaging? ....................................................... 14 Compiling and Distributing Your Image-Enabled Application........ 16 Use of LZW Compression............................................................. 17 Documentation Conventions ....................................................... 18
Chapter 1
Imaging for Windows is a multi-faceted product allowing users to transform paper documents and faxes into electronic documents for viewing, annotating, editing, converting, printing, and sharing. Today, eiStream is offering the latest version of Imaging for Windows. This product is an upgrade to the component included in various Microsoft operating systems and an upgrade to Imaging for Windows Professional Edition and Imaging for Windows Standard Edition. The latest version supports multi-byte character sets and runs on multiple Microsoft operating systems Windows 2000, Windows XP, Windows 98, and Windows NT.
Imaging Components
The components of Imaging for Windows are described in this section.
Imaging Application
The Imaging application is the main component of Imaging for Windows. It enables users to scan, view, annotate, manipulate, and store faxes, paper documents, and electronic images.
About Imaging
Imaging Preview
Imaging Preview is a lean version of the Imaging application. It lets users view image files quickly and, if necessary, load them into the Imaging application for editing.
Imaging Flow
Imaging Flow enables users to automatically capture, process, and output image files. An intelligent and editable procedure called a flow defines and controls the work Imaging Flow performs.
Flow tools included within each flow perform specific functions. They can:
Capture images from: Scanners. MAPI-compliant in-boxes. Local and network folders.
Chapter 1
Process images by: Converting them from one file type to another. Applying compression. Enhancing their appearance. Permitting their review. Converting them to text. Deleting specified pages. Entering information about an image document while the flow is processing. Running a custom process. Output images by: Posting them to Exchange folders. Saving them to local or network folders. Saving them to WMS Imaging or Imaging (1.x) servers Printing them. Sending them to others via e-mail. Running a custom process.
Microsoft Visual Basic Microsoft Visual C++ Microsoft Office (Visual Basic for Applications)
About Imaging
Imaging for Windows includes several development tools and methods that let you add Imaging functions to your 32-bit applications. The development tools and methods include: Command-line invocation OLE Automation ActiveX controls The following sections describe them, help you determine which one to use, and briefly describe the code samples contained on the media on which your software was distributed.
Command-line Invocation
You can invoke the Imaging application using its command line. Because the command line can accept a fully qualified image file name, you can use standard Shell functions within your application to invoke the Imaging application with an image on display. Within your call to the Shell function, include the path and file name of the Imaging application along with the path and file name of the image file you want it to display. (Refer to the example on page 8.)
OLE
You can use standard OLE functions to embed and link image files in your application and other applications, such as Microsoft Word, Excel, Access, and SQL Server. For example, you can use Visual Basics OLE Container control to easily embed or link image files in your application. Your application is the container, while the Imaging application is the server. Users can edit and open embedded or linked image files, as described in the following sections.
Chapter 1
let users edit the activated image file in-place; that is, within your application. When end users open an embedded image file, the Imaging application appears with the embedded image displayed within it. Changes users make to the image in the Imaging application also appear on the linked image in your application. If desired, users can save a copy of the image to another file by clicking SaveAs on the File menu.
Automation
You can use Automation to image-enable your application. Automation is a more powerful way to image-enable your application. It enables you to control the Imaging application programmatically from your application and provide your users with the capabilities contained within the Imaging application.
Note: You can also use Automation to control the Imaging application from other Automation-capable applications, such as Microsoft Word and Excel. However, you cannot use Automation to control the Imaging Preview and Imaging Flow applications.
The Imaging application implements Automation as a full object model, similar to the Automation model of Microsoft Word and Excel. The object hierarchy starts with the Application object, continues with an ImageFile object and one or more Page objects, and then concludes
About Imaging
with a Page Range object. Each object has its own set of properties and methods.
Note: Chapter 2 of this guide explains Imagings implementation of Automation. Chapter 3 describes the properties and methods of each object.
ActiveX Controls
You can use ActiveX controls to image-enable your application. Using ActiveX controls is another powerful way to include Imaging functions within your application. Imaging for Windows provides the following ActiveX controls: Image Admin control The Image Admin control manages administrative functions, such as: creating, opening, saving, and printing image files; appending, inserting, and deleting image pages; and entering Summary property information. Image Annotation Tool Button control The Image Annotation Tool Button control lets you create customized annotation tool bars for use within your application. The control links with the Image Edit control to provide annotation drawing and management functions to your end users. Image Edit control The Image Edit control manages all image display and annotation functions. Its huge array of properties, methods, and events provide Imaging functions, such as: displaying, annotating, and editing images; rotating, flipping, and zooming images; applying compression to images; and copying, cutting, and pasting images to and from the Clipboard. Image OCR control The Image OCR control manages the recognition and recomposition of image files. It lets users convert images into editable text documents. Output formats include Microsoft Word/ Rich Text Format (RTF), Corel WordPerfect, Hypertext Markup Language (HTML), and text. Image Scan control The Image Scan control manages the scanning of documents using TWAIN-compliant image acquisition devices. TWAIN (Technology Without An Interesting Name) is an industrystandard interface between image-enabled applications and image acquisition devices.
Chapter 1
Image Thumbnail control The Image Thumbnail control displays and manages thumbnail renditions of individual image pages.
Note: Chapters 4 and 5 of this guide explain how to get started with the Imaging ActiveX controls and walk you through several sample programs.
Command-line Interface
Command-line invocation is the most simple but least powerful way to implement Imaging functions in your application. You can invoke the Imaging application using standard Shell functions, by including the executable file name of the Imaging application and the fully qualified file name of a supported image file. For example, if you are developing under Imaging, you can use the following statement to invoke the Imaging application and display an image file:
Shell("c:\Program Files\Imaging\Imaging.exe c:\Quote.tif", 1)
Employing the command-line interface does not make the Imaging application a full-fledged component of your application. The command-line interface does not give you the opportunity to manipulate the application or the image after it is displayed.
OLE
OLE lets you add a subset of Imaging functions to your application. It is useful when you want to add Imaging functions with an absolute minimum of coding. Using a container control such as that provided by Visual Basic, you can add image files as insertable objects within your application at design time. Image files may be embedded or linked. As an alternative, you can use the container control to create a placeholder in your application for image files that will be added at run
About Imaging
time. Set the appropriate properties or provide end users with drag-anddrop capability so they can select image files for display at run time. Users can edit embedded images within your application and linked images within the Imaging application. OLE does not make the Imaging application a full-fledged component of your application. OLE does not give you the opportunity to manipulate the application or the image after it is displayed.
Automation
Automation lets you add Imaging functions to your application by making the Imaging application a full-fledged component of your application. Automation is useful when you want images to be displayed in a window that is separate from your application and when you want to control the Imaging application from your application. Your application can control the state of the Imaging application as well as manipulate the displayed image. But, unlike using the Imaging ActiveX controls, your application cannot respond to events that occur when users perform Imaging operations. Depending on the degree of control you want to exert, automating the Imaging application from your application can be accomplished with a minimal or substantial amount of coding.
Example
Imaging Flow, a component of Imaging for Windows, demonstrates a good example of Automation. The Review flow tool invokes the Imaging application to permit users to review image files as they are being processed by the current flow. At flow design time, the author can set Review tool options that manipulate the Imaging application as well as the image it displays. These options include:
Whether to view image pages, thumbnails, or both. The size and position of the Imaging application window. The zoom setting to apply to images. Whether to open image files as read only. Whether to scale black-and-white images to gray.
Chapter 1
ActiveX Controls
The Imaging ActiveX controls let you add Imaging functions to your application by making the functions an integral part your application. The controls are useful when you want to display images within a window in your application and when you want to manipulate all Imaging functions from within your application. While the ActiveX controls add overhead to your application, they give you the power to determine the range of Imaging functions to be provided. And, unlike Automation, the ActiveX controls support extender as well as intrinsic events, which enable your application to respond to events that occur when users perform Imaging operations. Depending on the Imaging functions you want to provide, imageenabling your application with ActiveX controls can require more coding when compared to Automation.
Example
The demonstration projects in Chapters 4 and 5 of this guide are excellent examples of using the Imaging ActiveX controls to imageenable applications.
Sample Code
Sample code that was designed to help you add Imaging functions to your applications is included on the media on which your Imaging for Windows software was distributed, and also on the eiStream Web site. Before you can use the sample code, you need to:
Set up Imaging for Windows on your development system, if necessary. Set up Microsoft Excel and be familiar with Visual Basic for Applications (for the Automation demonstration project). Set up and be familiar with Visual Basic (for the ActiveX demonstration projects and the ActiveX sample applications).
Note: When you set up Visual Basic 6.0 or greater, you must perform a Typical installation. If you dont, the sample code may not function correctly.
10
About Imaging
The following sections briefly describe the sample code.
11
Chapter 1
The code in each sample project is highly organized, heavily commented, and written using Hungarian notation. The sample applications show you how to: Create an application that is similar to the standard Imaging application. Develop an application that prepares separator pages for scanning several multipage documents in the Imaging Flow application. Perform template scanning. Use the Image Thumbnail control to create folder-based contact sheets. Print a selected portion of an image. Use General and Page properties to analyze image files in folders. Appendix A describes each sample application in greater detail.
12
About Imaging
Childrens drawings Hobby-related documents Household bills Legal documents Letters from friends Magazine and newspaper articles Medical and insurance records Receipts Tax forms Depending on how you design and code your application, you can enable your users to:
Scan images. Retrieve and display images. Annotate, edit, and manipulate images. Convert, copy, and OCR images. Append, insert, and replace image pages. Display and manage thumbnail representations. Set the Summary properties of images for easier retrieval. Print, save, and send images.
13
Chapter 1
14
About Imaging
15
Chapter 1
16
About Imaging
Note:
Do not distribute the Imaging OCX files with your application, because doing so will not install Imaging for Windows correctly. Instead, have your users set up the entire Imaging for Windows application to ensure that all of the required software is installed and registered properly.
Imaging for Windows 2000 ships as a component of Windows 2000. Imaging for Windows NT 4.0 ships as a component of Windows NT Workstation 4.0. Imaging for Windows 98 ships as a component of Windows 98..
17
Chapter 1
Documentation Conventions
This guide uses the following conventions.
Conventions Description
Words in bold with initial capitalization indicate names of properties, methods, and events. In the syntax section, words in lowercase italics indicate placeholders for information you must provide. In the syntax section, items appearing inside square brackets are optional. In the syntax section, braces and a vertical bar indicate a mandatory choice between two or more items. This font is used for code examples. This character indicates that a line of code was too long to fit on one line in the Example window.
[expressionlist]
{True | False}
Dim x As IFontDisp
You should keep the code on one line in your program, or use the line continuation character provided by your programming environment. Refer to the documentation that came with your programming environment for more information on the line continuation character and its proper placement in your code. Note that the character does not necessarily indicate the proper place for a line continuation character in your code.
18
2
Adding Imaging Using Automation
This chapter explains how to use Automation to image-enable your applications. It begins by describing the object hierarchy of the Imaging application and continues by describing how the Imaging application can function as an Automation server application or an Embedded server application. The chapter concludes by walking you through a sample project to help you get started.
In This Chapter
Overview ..................................................................................... 20 The Object Hierarchy ................................................................... 20 Automation Server and Embedded Server Modes......................... 22 Demonstration Project ................................................................. 28
Chapter 2
Overview
Imaging for Windows features a rich Automation interface that provides programmatic access to the internal services of the Imaging application. Using Automation, you can provide your users with the image display and manipulation functions that are contained within the Imaging application. You, in effect, make the Imaging application a fully functional, tested, and trusted component of your application.
Note: The Imaging Preview and Imaging Flow applications cannot be automated.
Components are software modules that can be plugged into applications from other vendors. They provide end users with a specific set of additional functions and capabilities.
In addition to automating the Imaging application from your programs, you can also automate it from other Automation-capable programs, such as Microsoft Word and Excel. The remainder of this chapter:
Outlines the Object Hierarchy of the Imaging application. Describes how the Imaging application can function as an Automation server application or an Embedded server application. Provides an example of automating the Imaging application from Microsoft Excel.
One top-level object, called the Application object; One document object, called the ImageFile object; and Two objects that support the ImageFile object, called the Page object and the PageRange object.
20
Application Object
Use the Application object to create an instance of the Imaging application and to control it. The Application object controls every other object you create as well as the environment of the application; such as the applications size and position.
ImageFile Object
The ImageFile object represents an image document file. Use it to specify the name of an image file and to provide basic filing functions such as open, save, close, print, insert, update, and append. Use it also to provide image manipulation functions such as rotate, create contact sheet, and perform OCR.
Page Object
Each Page object represents an image document page. Use it to manipulate the individual pages of an image file and to provide functions such as delete, flip, print, rotate, scroll, and perform OCR.
21
Chapter 2
PageRange Object
The PageRange object represents a range of consecutive pages within an ImageFile object starting at the StartPage property and ending at the EndPage property. Use it to manipulate a range of pages and to provide page manipulation functions such as delete, print, and perform OCR.
Note: Automation is not aware of the actions performed by users within the Imaging application. The objects known to Automation remain in the state they were in when last affected programmatically. In other words, if users change a displayed object, Automation does not update that object within its Application object. For example, if users change the active page, Automation does not update the ActivePage property. However, properties and methods are available that let you determine if a change has occurred. At your option, you can use them to update the corresponding objects known to Automation.
You can use the AppState property of the Application object to determine whether the Imaging application is running as an Automation server or an Embedded server.
Automation server application, or an Embedded server application. The following sections describe each mode and include examples.
22
Examples
This section contains examples that show you how to automate the Imaging application as a stand-alone Automation server application and as an Embedded server application.
Note: The example that demonstrates automating the Imaging application as an Automation server application is more extensive because:
The principles behind automating the Imaging application are similar no matter which mode is used. Use of the Imaging application as an Automation server application is more prevalent.
23
Chapter 2
To create the Application and Image File Objects
24
1 Invoke the Close method of the ImageFile object to close the image
file.
25
Chapter 2
Methods Not Available in Automation Server Mode
You cannot use the following methods when the Imaging application is functioning as an Automation server application:
SaveCopyAs method of the ImageFile object Update method of the ImageFile object
In this example, the Imaging application displays the embedded image document in a separate window for editing.
Set objApp = CreateObject("Imaging.Application") Set objImg = objApp.CreateImageViewerObject(1) oleImg.CreateEmbed("", "Imaging.Document") oleImg.DoVerb vbOLEOpen objImg.InsertExistingPages "Test.tif", 1, 1, 1, False
Example 2
In this example, the Imaging application is in-place active and displays a subset of its menus within your application. The menus provide access to functions that let users edit the image document object in-place that is, within your application.
Set objApp = CreateObject("Imaging.Application") oleImg.CreateEmbed("", "Imaging.Document") oleImg.DoVerb vbOLEShow Set objImg = objApp.CreateImageViewerObject(1) objImg.InsertExistingPages "Test.tif", 1, 1, 1, False
26
In this example, the Imaging application displays the embedded image document in an instance of the Imaging application that is already running.
oleImg.CreateEmbed("", "Imaging.Document") oleImg.DoVerb vbOLEOpen Set objApp = CreateObject("Imaging.Application") Set objImg = objApp.CreateImageViewerObject(1)
You cannot use the following properties and methods when the Imaging application is functioning as an Embedded server application:
Edit property of the Application object Height and Width properties of the Application object ImageView property of the Application object (if the application is in-place active) Left property of the Application object Top property of the Application object Close method of the ImageFile object FindOIServerDoc method of the ImageFile object New method of the ImageFile object Open method of the ImageFile object Quit method of the Application object (if the application is in-place active) SaveAs method of the ImageFile object
27
Chapter 2
Demonstration Project
This section demonstrates how to automate the Imaging application from Microsoft Excel. While a wide-ranging discussion of every Imaging function is beyond the scope of this chapter, the information presented here is sufficient to get started. The demonstration project was developed using Microsoft Visual Basic for Applications and Excel. Even if you are not going to automate the Imaging application, youll find the section in this chapter on View Modes useful.
To help you use Automation to image-enable your applications, a demonstration project called Automation From Excel shows you how to:
Invoke the Imaging application and open an image. Obtain the page count. Rotate an image page. Set the desired view mode. Close the image and the application.
Note: Chapter 3 of this guide describes the properties and methods of each Imaging Automation object.
Before walking through the demonstration project, read the following section, which describes the view modes of the Imaging application. Chapter 4 of this guide describes the concepts of image display, page counts, multipage image files, and image rotation.
View Modes
The Imaging application has three view modes that enable users to view and work with image files. Each view mode has its own set of advantages and capabilities. The ImageView property of the Application object enables you to invoke most likely in response to user input any one of the three view modes. You should consider making view mode selection available to your users when automating the Imaging application. The following sections describe the view modes.
Developers using the Imaging ActiveX controls can use the Image Edit and Image Thumbnail controls to simulate the View Mode behavior described in this section. Refer to the ActiveX controls Help for more information.
28
One Page
The One Page view mode lets users display image files one page at a time. It lets users display image pages in the entire window while maintaining complete access to the menus, toolbars, and functions of the application.
29
Chapter 2
Thumbnail
The Thumbnail view mode lets users display image files as a series of thumbnail images one for each image page. It lets users: View multiple image pages simultaneously. Rearrange pages using drag and drop. Delete pages. Drag and drop pages to and from other applications that support drag and drop functionality. Keep in mind that some Imaging functions like annotation and zoom are not available in this mode because they are not appropriate for use on such small images.
30
31
Chapter 2
Example
Users of Excel may want to display and manipulate an image file referenced within a spreadsheet.
Scenario
In her role as a product manager for a major computer company, Eileen regularly uses Microsoft Excel to create product configurations of PCs sold on contract to government agencies. After she completes a configuration spreadsheet, she typically submits it to review via e-mail. In the past, several reviewers have requested that she also include a scanned copy of the contract. At a recent employee meeting, Eileen asked you if there was any way her reviewers could display a scanned contract from Excel. Knowing that Imaging for Windows is on every desktop in the company, you told her that you could automate the Imaging application from Excel to give her reviewers quick access to a scanned contract, or any other image file for that matter. All Eileen needs to do is:
1 Scan the contract using Imaging for Windows. 2 Import your code module into her Excel spreadsheet. 3 Enter the path and file name of the scanned contract in Cell A1 of the
spreadsheet.
4 Send both the image file and the spreadsheet file to her reviewers.
As stated previously, the Automation From Excel project demonstrates: Invoking the Imaging application and opening an image from Excel. Obtaining the page count. Rotating an image page. Setting the desired view mode. Closing the image and the application. The project consists of the following files:
AutoFromExcel.bas A Visual Basic for Applications (VBA) code module that contains macros that automate the Imaging application. ImagingAutomation.xls A sample spreadsheet that contains the AutoFromExcel.bas code module.
32
33
Chapter 2
34
Click the s_DispImg macro and then click Run. When the macro runs, code in the General Declarations area of the code module defines the object variables that contain references to the Application and Image File objects.
Dim objApp As Object Dim objImg As Object
35
Chapter 2
Then, the s_DispImg() subroutine executes its code. The s_DispImg() subroutine obtains the path and file name of the image file to open from the active cell of the spreadsheet. Then it assigns the path and file name to the strCurrentFile local variable.
Sub s_DispImg() Dim strCurrentFile As String Dim strCurrentImageName As String 'Get file name to display from spread sheet strCurrentFile = ActiveCell.Value . . . 'If the Application object not created, create it. If objApp Is Nothing Then If f_InitializeApp() = False Then 'Continue if successful Exit Sub End If End If 'Make the Imaging application on-top. objApp.TopWindow = True On Error Resume Next 'If no file is open. 'Get the name of the open Image file. strCurrentImageName = objImg.Name On Error GoTo 0 'Reset error handler If strCurrentImageName <> "" Then 'Always close existing image file before opening a new one. objImg.Close End If On Error GoTo OpenImageMethodError 'Open the Image file in the ActiveCell objImg.Open strCurrentFile Exit Sub OpenImageMethodError: sMsg = "Error => " & Str$(Err.Number) & " " & Err.Description MsgBox (sMsg) 'Close the Imaging application s_CloseImg End Sub
36
With the Application and ImageFile objects now fully instantiated, control returns to the s_DispImg() subroutine. The _DispImg() subroutine sets the TopWindow property of the Application object to True to have the Imaging application window remain on top of all other applications that may be running. Then it checks to see if an image file is already displayed by examining the value of the Name property of the ImageFile object. If the Name property is not blank, the subroutine invokes the Close method of the ImageFile object to close the displayed image file.
37
Chapter 2
Next, the subroutine invokes the Open method of the ImageFile object, passing to it the path and file name of the image to display (from strCurrentFile). The Open method opens the image file in the Imaging application window.
Now that the image is open and on display, you can use some of the other macros to manipulate it and the Imaging application.
38
39
Chapter 2
40
41
Chapter 2
'Close open image 'Quit Automation application 'Destroy Image object 'Destroy Application object 'Reset Error handler
42
3
Automation Lexicon
This chapter describes the properties and methods of each Imaging for Windows Automation object.
In This Chapter
Overview ..................................................................................... 44 Application Object ....................................................................... 44 ImageFile Object .......................................................................... 56 Page Object ................................................................................. 69 PageRange Object ....................................................................... 76
Chapter 3
Overview
This chapter describes the properties and methods of each object in the Imaging application object hierarchy.
Automation enables you to control the Imaging application programmatically from within your application. Using it, you can provide your end users with all of the capabilities of the Imaging application. Each object has its own set of properties and methods. The remainder of this chapter describes each one.
Note: Refer to Chapter 2 of this guide for more information about using Automation to image-enable your applications.
Application Object
The Application object is a top-level object that controls every other object you create. The Application object also allows you to set the environment. For example, you can control the size and position of the Imaging application window and the visibility of scroll bars, the status bar, and the toolbar.
Returns the active ImageFile object. Sets or returns the visibility of the application's annotation palette. Returns the Application object. Returns the state of the image viewer application. Sets or returns the scaling algorithm used for displaying images. Sets or returns the applications ability to edit the displayed object. Returns the file specification for the Application object. Sets or returns the distance between the top and bottom edge of the application window. Sets or returns the image palette used for image display.
44
Automation Lexicon
Application Object Properties (cont.) Property Description
ImageView ImagingToolBarVisible Left Name Parent Path ScannerIsAvailable ScanToolBarVisible ScrollBarsVisible StatusBarVisible ToolBarVisible Top TopWindow Visible WebToolBarVisible Width Zoom
Sets or returns the present image view. Sets or returns the visibility of the applications scan toolbar. Not available in all releases. Sets or returns the distance between the left edge of the physical screen and the main application window. Returns the name of the Application object. Returns the Application object. Returns the path specification for this applications executable file. Sets or returns the state of the scanner. Sets or returns the visibility of the applications imaging toolbar. Sets or returns the visibility of the applications scroll bars. Sets or returns the visibility of the applications status bar. Sets or returns the visibility of the applications toolbar. Sets or returns the distance between the top edge of the physical screen and applications window. Sets or returns the applications top window flag. Returns the visibility of the application. Sets or returns the visibility of the web toolbar. Sets or returns the distance between the left and right edges of the applications window. Sets or returns the zoom factor for image display.
ActiveDocument Property
Description Returns the active ImageFile object in the Application object. This is a read-only property. Usage Data Type Example ApplicationObject.ActiveDocument
Object.
'This example returns the ImageFile object in the application. Dim Img as Object Set Img = App.ActiveDocument
45
Chapter 3
AnnotationPaletteVisible Property
Description Sets or returns the visibility of the annotation palette. This is a read/write property. Usage Data Type Remarks ApplicationObject.AnnotationPaletteVisible = [{True|False}]
True False
(Default) The annotation palette is visible. The annotation palette is not visible.
Application Property
Description Returns the Application object. This is a read-only property. Usage Data Type Example ApplicationObject.Application
Object.
'This example returns the Application object. Dim Parent As ObjectSet Parent = App.Application
AppState Property
Description Returns the state of the Application object. The state indicates whether the application is
1 2
The application is running as an embedded server. The application is running as an automation server.
DisplayScaleAlgorithm Property
Description Sets or returns the scaling algorithm used for displaying images. This is a read/write
property.
Usage Data Type ApplicationObject.DisplayScaleAlgorithm [=value]
Short.
46
Automation Lexicon
Remarks
The DisplayScaleAlgorithm value can be specified before or after an image is displayed. The property settings are:
Setting Description
0 1 2 3 4
(Default) Normal decimation. Gray4 4-bit gray scale (16 shades of gray). Gray8 8-bit gray scale (256 shades of gray). Stamp Represents the image as a thumbnail. Optimize Changes the display scale algorithm based on the image type of the displayed image. Black and white images are scaled to gray. Palettized 4- and 8-bit, RGB, and BGR images remain color.
This property must be set prior to opening the ImageFile object. For this property to take effect after an image is open, you must reopen the image.
Note:
Edit Property
Description Sets or returns the Application objects ability to edit the displayed object. You should set
the Edit property prior to opening each ImageFile object. This is a read/write property.
Usage Data Type Remarks ApplicationObject.Edit = [{True|False}]
True False
Note:
FullName Property
Description Returns the file specification for the Application object, including the path. This is a read-
only property.
Usage Data Type ApplicationObject.FullName
String.
47
Chapter 3
Height Property
Description Sets or returns the distance, in pixels, between the top and bottom edge of the Application
Long. This property must be set prior to opening the ImageFile object. It only takes effect if the Width, Top, and Left properties are also set. If you set the Height property to less than the minimum allowable window size, the value is ignored. The minimum setting is usually 27. The Height property only returns the value that you set programmatically prior to opening the window. It does not return changes made to the window after it has been opened.
ImagePalette Property
Description Sets or returns the image palette used to display an image. This is a read/write property. Note: The ImagePalette property must be set prior to opening the ImageFile object. For this property to take effect after an image is open, you must reopen the image.
ApplicationObject.ImagePalette [=value]
0 1 2 3 4
(Default) Custom Common Gray8 8-bit grayscale (256 shades of gray) RGB24 24-bit (millions of colors) Black and white
ImageView Property
Description Sets or returns the present image view. This is a read/write property. Usage Data Type ApplicationObject.ImageView [=value]
Short.
48
Automation Lexicon
Remarks
0 1 2
(Default) One page view Thumbnails view Page and Thumbnails view
The ImageView property and the ImageFileObject.ActivePage property have the following relationships:
View Relationship
(Default) The active page is displayed. The active page appears in thumbnail view. The active page is the page that is displayed.
ImageFileObject.ActivePage property.
ImagingToolBarVisible Property
Description Sets or returns the visibility of this Application objects imaging toolbar. This is a read/write
property.
Usage Data Type Remarks ApplicationObject.ImagingToolBarVisible = [{True|False}]
True False
(Default) The imaging toolbar is visible. The imaging toolbar is not visible.
Left Property
Description Sets or returns the distance, in pixels, between the left edge of the physical screen and the
Long. The Left property must be set prior to opening the ImageFile object. This property only takes effect if the Height, Width, and Top properties are also set. The Left property only returns the value that you set programmatically prior to opening the window. It does not return changes made to the window after it has been opened.
49
Chapter 3
Name Property
Description Returns the name of this Application object. This is a read-only property. Usage Data Type ApplicationObject.Name
String.
Parent Property
Description Returns the parent of the Application object. This is a read-only property. Usage Data Type ApplicationObject.Parent
Object.
Path Property
Description Returns the path specification for the Application objects executable file. This is a read-
only property.
Usage Data Type ApplicationObject.Path
String.
ScannerIsAvailable Property
Description Sets or returns the availablity of the scanner. This is a read/write property. Usage Data Type Remarks ApplicationObject.ScannerIsAvailable = [{True|False}]
True False
(Default) The scanner is available. If no scanner is attached to the system, this property setting is False. The scanner is unavailable.
ScanToolBarVisible Property
Description Sets or returns the visibility of this Application objects scan toolbar. This is a read/write
property.
Usage Data Type ApplicationObject.ScanToolBarVisible = [{True|False}]
Integer (Boolean).
50
Automation Lexicon
Remarks
True False
The scan toolbar is visible. (Default) The scan toolbar is not visible.
ScrollBarsVisible Property
Description Sets or returns the visibility of the Application objects scroll bars. This is a read/write
property.
Usage Data Type Remarks ApplicationObject.ScrollBarsVisible = [{True|False}]
True False
Note:
(Default) The scroll bars are visible. The scroll bars are not visible.
The ScrollBarsVisible property must be set prior to opening the ImageFile object. For this property to take effect after an image is open, you must reopen the image.
StatusBarVisible Property
Data Type Usage Data Type Remarks
Sets or returns the visibility of this Application objects status bar. This is a read/write property.
ApplicationObject.StatusBarVisible = [{True|False}]
True False
(Default) The status bar is visible. The status bar is not visible.
ToolBarVisible Property
Data Type Usage Data Type
Sets or returns the visibility of this Application objects standard toolbar. Read/write property.
ApplicationObject.ToolBarVisible = [{True|False}]
Integer (Boolean).
51
Chapter 3
Remarks
True False
Top Property
Description Sets or returns the distance, in pixels, between the top edge of the physical screen and main
Long. The Top property must be set prior to opening the ImageFile object. This property only takes effect if the Height, Width, and Left properties are also set. The Top property only returns the value that you set programmatically prior to opening the window. It does not return changes made to the window after it has been opened.
TopWindow Property
Description Sets or returns this Application objects top window flag. This is a read/write property. Usage Data Type Remarks ApplicationObject.TopWindow = [{True|False}]
True False
Example
The application is a stay-on-top window. (Default) The application is not a stay-on-top window.
'This example makes the application window a stay-on-top window. App.TopWindow = True
Visible Property
Description Returns the visibility of the Application object. This is a read-only property. Usage Data Type ApplicationObject.Visible
Integer (Boolean).
52
Automation Lexicon
Remarks
True False
WebToolBarVisible Property
Description Sets or returns the visibility of this Application objects web toolbar. This is a read/write
property.
Usage Data Type Remarks ApplicationObject.WebToolBarVisible = [{True|False}]
True False
The web toolbar is visible. (Default) The web toolbar is not visible.
Width Property
Description Sets or returns the distance, in pixels, between the left and right edges of the Application
Long. The Width property must be set prior to opening the ImageFile object. This property only takes effect if the Top, Left, and Height properties are also set. If you set the Width property to less than the minimum allowable window size, the value is ignored. The minimum setting is usually 112. The Width property only returns the value that you set programmatically prior to opening the window. It does not return changes made to the window after it has been opened.
Zoom Property
Data Type Usage Data Type Remarks Example
Sets or returns the zoom factor used for displaying images. This is a read/write property.
ApplicationObject.Zoom [=value]
53
Chapter 3
'This example returns the current zoom factor. x = App.Zoom
Creates an Imaging object of the specified class. Displays the image at the specified zoom option. Displays online Help. Exits this application and closes all open objects.
CreateImageViewerObject Method
Description Creates and returns an ImageFile object. The ImageFile object is empty, with no image file
associated with it. Use the object's Open or New method to associate a specific image file.
Usage Data Type Remarks Example ApplicationObject.CreateImageViewerObject([ObjectClass])
Object. This method only supports the ImageFile object, for which the setting is 1.
'This example creates an ImageFile object. Dim Img as Object Set Img = App.CreateImageViewerObject(1)
FitTo Method
Description Displays the current image at the specified zoom option. This method updates the
Application objects Zoom property with the actual zoom factor. This method affects each view as follows:
View Display
The page is zoomed. No effect The Application property is changed and affects other views when they are used. The page is zoomed No effect on thumbnails.
ApplicationObject.FitTo (ZoomOption)
Short.
54
Automation Lexicon
Remarks
1 2 3 4
Help Method
Description Displays the Imaging online Help table of contents. Usage ApplicationObject.Help
Quit Method
Description Closes all open objects and exits the application. The Application object is no longer active
or available.
Usage ApplicationObject.Quit
55
Chapter 3
ImageFile Object
An ImageFile object represents an image file. An ImageFile object can have
One Page object, representing the currently displayed page of the ImageFile object. One or more PageRange objects, each representing different and possibly overlapping page ranges.
Sets or returns the ImageFile objects current page number. Returns the Application object. Returns the ImageFile objects file type. Returns the name of the active image file.
OCRLaunchApplication Launches an application with an output file after OCRa processing is complete. OCROutputFile OCROutputType PageCount Parent Saved Sets or returns the output file for OCR processing. Sets or returns the output file format for OCR processing. Returns the number of pages in the ImageFile object. Returns the parent of the ImageFile object. Returns a flag indicating whether or not the file has ever been saved.
ActivePage Property
Description Sets or returns the ImageFile objects active page number. This is a read/write property.
Setting the ActivePage property to a page number causes that page to become active, which updates the display if the Application object is visible. Refer to the Application objects ImageView property for more information about the relationships between the active page and different views of the page. Page selection and navigation by the end-user have no effect on the ActivePage property. The active page is always the active page according to automation.
Note: If you set the ActivePage property to a page number beyond those contained in the document, an error is returned.
56
Automation Lexicon
Usage Data Type Remarks See Also ImageFileObject.ActivePage [=value]
Application Property
Description Returns the Application object. This is a read-only property. Usage Data Type Example ImageFileObject.Application
Object.
'This example returns the Application object. Dim Parent As Object Set Parent = Img.Application
FileType Property
Description Returns the file type of this ImageFile object. This is a read-only property. Usage Data Type Remarks ImageFileObject.FileType
0 1 2 3 4 5 6 7 8 9
Unknown TIFF Not supported BMP PCX DCX JPG-JFIF XIF GIF WIFF
Name Property
Description Returns a string that contains the name of the active image file. This is a read-only
property.
Usage ImageFileObject.Name
57
Chapter 3
Data Type
String.
OCRLaunchApplication Property
Description Launches the Application object with an output file after OCR processing is complete.
True False
OCROutputFile Property
Description Sets or returns the output file name. If blank, the SaveAs dialog box is displayed. This is a
read/write property.
Usage Data Type ImageFileObject.OCROutputFile = [FileName]
String.
OCROutputType Property
Description Sets or returns the output file type. This is a read/write property. Usage Data Type Remarks ImageFileObject.OCROutputType = [Type]
0 1 2 3
PageCount Property
Description Returns the number of pages in this ImageFile object. This is a read-only property. Usage Data Type ImageFileObject.PageCount
Long.
58
Automation Lexicon
Parent Property
Description Returns the parent of the ImageFile object. This is a read-only property. Usage Data Type Example ImageFileObject.Parent
Object.
'This example returns the parent of the ImageFile object. Dim App As Object App = Img.Parent
Saved Property
Description Returns the saved state of the ImageFile object. Read-only property. Usage Data Type Remarks ImageFileObject.Saved
True False
Example
The ImageFile object has been saved and has not changed since it was last saved. The imageFile object has never been saved and has changed since it was created; or, it has been saved but has changed since it was last saved.
'This example returns the saved state of the file. bIsSaved = Img.Saved
Appends existing pages to the end of the ImageFile object. Closes the ImageFile object. Saves a contact sheet rendition of the ImageFile object. Finds Imaging 1.x documents and WMS Imaging documents. Not available when the application is running as an embedded server. Displays online Help. Inserts existing pages in the ImageFile object. Creates a new blank ImageFile object. Not available when the application is running as an embedded server.
59
Chapter 3
ImageFile Object Methods (cont.) Method Description
OCRs opened Image File. Opens the ImageFile object. Not available when the application is running as an embedded server. Returns a Page or PageRange object for the ImageFile object. Prints the ImageFile object. Rotates all ImageFile object pages. Saves changes to the ImageFile object. Saves the ImageFile object under another name. Saves a copy of the ImageFile object. The application must be running as an embedded server. Updates the ImageFile object embedded within the container application with the current data from the server application. The application must be running as an embedded server.
AppendExistingPages Method
Description Appends specified page(s) to the end of the current ImageFile object. If the page(s) being
appended come from an image file of a type different than the active image file, the pages are converted before being appended. After appending page(s), all PageRange objects are invalid. You can optionally display a dialog box that allows the end-user to select a file from which to append page(s).
Usage ImageFileObject.AppendExistingPages [ImageFile],[Page], [Count],[DisplayUIFlag]
Arguments The AppendExistingPages method has the following parameters: Parameter Data Type Description
ImageFile Page
String Long
The image file from which pages will be appended (source image file). The page from which to start appending pages (in the source image file). The number of pages to append. True Displays a dialog box that allows the end-user to select an image file to append. False (Default) Does not display a dialog box. If you specify True and the selected file is a multi-page file, the user is prompted to select the pages to append.
60
Automation Lexicon
Example 'This example appends the first page from the file, BW.TIF. Img.AppendExistingPages "c:\bw.tif", 1 'This example appends a file selected from a dialog box 'currently displayed image file. After the user selects 'to append, the application prompts the user to specify 'starting page number and the number of pages to append 'the selected file. Img1.AppendExistingPages "", 0, 0, True to the a file the from
'This example appends pages to an Imaging Server 1.x file. ImgFileObj.AppendExistingPages "Image://nqa11\SYS:\tmp\3PAGES.tif", 1, 3 'This example appends pages to an Imaging Server 1.x document. ImgFileObj.AppendExistingPages "Image://PATRIOTS\CABINET\DRAWER\FOLDER\doc1", 3, 2 'This example appends pages to a WMS Imaging Server 'document. ImgFileObj.AppendExistingPages "Imagex://sixpage", 1, 6
Close Method
Description Closes the ImageFile object. Closing an ImageFile object deletes it; all Page and PageRange
objects associated with it are also deleted. The Application object no longer has an ImageFile object associated with it.
Usage Data Type Remarks ImageFileObject.Close [SaveChangeFlag]
Integer (Boolean). The Close method SaveChangeFlag argument has the following settings:
Setting Description
True False
Changes are saved when the image file closes. (Default) Changes are not saved when the image file closes.
CreateContactSheet Method
Description Saves a contact sheet rendition of the ImageFile object. This method is unavailable when
String.
61
Chapter 3
Arguments The CreateContactSheet method has the following parameters: Parameter Data Type Description
The image file object. Option to include annotations on the image stamps. Option to open the contact sheet file after it has been created.
FindOIServerDoc Method
Description Finds 1.x documents or WMS Imaging documents. This method displays an Imaging
server document Find dialog box, from which the user may search for 1.x documents or WMS Imaging documents. After the user selects a document and chooses the Open button, the Find dialog box is closed and returns the selected document name, with a path, to the user. A null string is returned if the user chooses Cancel in the Find dialog box. The user may use the returned document name string as input for the Image Object Open method.
Data Type Usage
String.
ImageFileObject.FindOIServerDoc
Help Method
Description Displays the Imaging online Help table of contents. Usage ImageFileObject.Help
InsertExistingPages Method
Description Inserts page(s) into the ImageFile object.
Page(s) to be inserted must come from an existing file. If the pages being inserted come from an image file of a type different than the active image file, the pages are converted before being inserted. After inserting page(s), all PageRange objects are invalid. You can optionally cause a dialog box to open for the end-user to select a file from which to insert page(s).
Usage ImageFileObject.InsertExistingPages (ImageFile, ImagePage, Count, Page, DisplayUIFlag)
Arguments The InsertExistingPages method has the following parameters: Parameter Data Type Description
ImageFile ImagePage
String Long
The image file from which page(s) are to be inserted (the source image file). The page before which the new page(s) are to be inserted.
62
Automation Lexicon
Parameter Data Type Description
Count Page
Long Long
DisplayUIFlag Flag
The number of pages to insert. The page in the source image file from which to start inserting pages. True Displays a dialog box that allows the end-user to select a source image file. False (Default) Does not display a dialog box. If you specify True and the selected file is a multi-page file, the user will be prompted to select the pages to append.
Example
'This example inserts pages 4 and 5 from the file BW.TIF 'before page 1. Img.InsertExistingPages "c:\bw.tif", 1, 2, 4 'This example inserts page(s) into the current file at the 'current page. (A dialog box prompts the user for the image 'file to be selected for insertion. Another dialog box 'prompts for a page range.) Page, count, and pagenumber 'arguments are required but ignored when dialogflag is True. Img.InsertExistingPages "", 1, 1, 2, True 'This example inserts pages in an Imaging Server 1.x file. ImgFileObj.InsertExistingPages "Image://nqa11\SYS:\tmp\3PAGES.tif", 2, 3, 1 'This example inserts pages in an Imaging Server 1.x document. ImgFileObj.InsertExistingPages "Image://PATRIOTS\CABINET\DRAWER\FOLDER\doc1", 2, 3, 1 'This example inserts pages in an WMS Imaging Server document. ImgFileObj.InsertExistingPages "Imagex://sixpage", 1, 2, 5
New Method
Description Displays a dialog box that allows the end-user to create a new ImageFile object that
Creating a new ImageFile object causes the new object to become active. If the active ImageFile object is unsaved, the end-user is prompted to save it before the new object is created. No image file is associated with the object until you save it. The file type of the new object is the same as the file type of the active object.
Usage ImageFileObject.New ([DisplayUIFlag])
63
Chapter 3
Remarks
DisplayUIFlag
Flag
True Displays a dialog box that allows the end-user to create a new image file. False (Default) Does not display a dialog box.
Example
'This example creates a new image object. 'Create the image object Dim App, Img As Object Set App = CreateObject("Imaging.Application") Set Img = App.CreateImageViewerObject(1) 'Call the image object New Method Img.New
Ocr Method
Description OCRs all image file pages. Usage Remarks Example ImageFileObject.Ocr
The Image file must be open. The Ocr method uses the OcrOutputFile and OcrOutputFileType properties.
'This example performs an OCR on an image object. Dim App, Img As Object Set App = CreateObject("Imaging.Application") Set Img = App.CreateImageViewerObject(1) Img.Open "d:\pcx.tif" Img.Ocr
Open Method
Description Opens an image file in the parent application window. This associates an image file with the
ImageFile object. If a file is currently open, it should be closed before a new file is opened. (See the Close Method).
Note: This method is unavailable when the application is running as an embedded server.
The Imaging application has the focus after an Open. You can reset the focus programmatically after an Open, if desired.
Usage ImageFileObject.Open(ImageFile,[IncludeAnnotation],[Page], [DisplayUIFlag])
64
Automation Lexicon
Remarks
Page
Long
DisplayUIFlag
Flag
Name string of the ImageFile object to open. True (Default) The image has annotations that are displayed. False The image has annotations that are not displayed. Page number in the image file to display. This parameter must be a constant, or use the ActivePage property to specify the page that you want displayed when you open the file. True Displays a dialog box that allows the end-user to select a file to open. False (Default) Does not display a dialog box.
Example
'This example opens an image file named 5page.tif: Img.Open "C:\images\5page.tif" 'This example opens the same file to page 4 with annotations 'displayed: Img.Open "C:\images\5page.tif",TRUE,4 'This example opens a dialog box so the user can select a 'file to open: Img.Open "",,,TRUE 'This example opens an Imaging Server 1.x file. Img.Open "Image://nqa11\SYS:\tmp\3PAGES.tif", TRUE, 1 'This example opens an Imaging Server 1.x document. Img.Open "Image://PATRIOTS\CABINET\DRAWER\FOLDER\doc1" 'This example opens an WMS Imaging document. Img.Open"Imagex://sixpage"
See Also
ApplicationObject.Edit.
Pages Method
Description Returns the Page or PageRange object for the ImageFile object. Usage Data Type Remarks ImageFileObject.Pages(StartPage, EndPage)
Long. If you specify one page number, this method returns a Page object. If you specify two page numbers, this method returns a PageRange object. To return a range of pages, specify the
65
Chapter 3
starting page number and ending page number. The first page number can be a variable, but the second page number must be a constant. The Pages method uses these parameters:
Parameter Data Type Description
StartPage EndPage
Example
Long Long
The starting page of the page range to be returned. The ending page of the page range to be returned.
'This example returns a Page object and a PageRange object. Dim Page As Object Dim PageRange As Object Set Page = Img.Pages(1) Set PageRange = Img.Pages(1,3)
Print Method
Description Prints the image file associated with the ImageFile object. You can optionally display a
True False
Example
Displays a dialog box that allows the end-user to select print file options. (Default) No dialog box is displayed.
RotateAll Method
Description Rotates all ImageFile object pages. Pages are rotated clockwise in 90 degree increments. Usage Example ImageFileObject.RotateAll 'This example rotates all pages of the currently displayed image. Img.RotateAll
Save Method
Description Saves changes to the ImageFile object. If no image file is associated with the ImageFile
66
Automation Lexicon
SaveAs Method
Description Saves the ImageFile object as another ImageFile object. Copies its image file and renames it.
This method allows you to specify the new object's image parameters. If specified, the file can be converted from one type to another. The current image file is closed without being saved and the Save As object becomes the active image file. You can optionally display a dialog box that allows the end-user to name the file for the first time or select a file to overwrite.
Usage Data Type Remarks ImageFileObject.SaveAs (ImageFile, [FileType], [DisplayUIFlag])
ImageFile FileType
String Short
DisplayUIFlag
Flag
The destinations ImageFile object name string. The file type that you want to save the image as. This number must be a constant. It must be present in the command if the dialog flag option is used, even though its value is ignored when the DisplayUIFlag is set to True. True Displays a dialog box that allows the end-user to enter or select a filename and options for saving the file. False (Default) Does not display a dialog box.
1 2 3
Example
'This example saves a file in TIF format. Img.SaveAs "picture1.tif", 1 'This example opens a Save As dialog box so that the end-user can 'name the file for the first time or overwrite an existing file: Img.SaveAs "", 0, True
67
Chapter 3
SaveCopyAs Method
Description Saves a copy of the ImageFile object as another ImageFile object. You may specify the
FileType of the destination file. The FileType can be TIFF or BMP. This method allows you to specify the new objects image parameters. If specified, the file can be converted from one type to another. The current image file remains the active image file. This method can only be used after launching the embedded server application in a separate window.
Usage Data Type Remarks ImageFileObject.SaveCopyAs (ImageFile, FileType, DisplayUIFlag)
ImageFile FileType
String Short
DisplayUIFlag
Flag
The destinations ImageFile object name string. The image file type that you want to save the image as. This number must be a constant. It must be present in the command if the dialog flag option is used, even though its value is ignored when the DisplayUIFlag is set to True. True Displays a dialog box that allows the end-user to enter or select a filename and options for saving the file. False (Default) Does not display a dialog box.
Update Method
Description Updates the ImageFile object embedded within the container application with the current
data from the server application. This method can only be used after launching the embedded server application in a separate window.
Usage ImageFileObject.Update
68
Automation Lexicon
Page Object
A Page object represents a single page in an ImageFile object. Page objects can only be accessed by using the Pages method of the parent ImageFile object.
Application CompressionInfo CompressionType Height ImageResolutionX ImageResolutionY Name PageType Parent ScrollPositionX ScrollPositionY Width
Returns the Application object. Returns the pages compression information. Returns the pages compression type. Returns the pages height. Sets or returns the pages horizontal resolution. Sets or the returns pages vertical resolution. Returns the page number of this page. Returns the pages image type. Returns the parent of the Page object. Sets or returns this pages horizontal scroll position. Sets or returns this pages vertical scroll position. Returns the pages width.
Application Property
Description Returns the Application object. This is a read-only property. Usage Data Type Example PageObject.Application
Object.
'This example returns the Application object. Dim Img As ObjectDim Parent As ObjectSet Parent = Img.Pages(1).Application
CompressionInfo Property
Description Returns this pages compression information. This is a read-only property. Usage Data Type PageObject.CompressionInfo]
Long.
69
Chapter 3
Remarks
0 1 2 4 8
16
No compression options set. Only applicable to uncompressed image files. EOL (Include/expect End Of Line). Each line is terminated with an end-ofline bit. Not used for JPEG compression. Packed Lines (Byte align new lines). Not used for JPEG compression. Prefixed EOL (Include/expect prefixed End Of Line). Each strip of data is prefixed by a standard end-of-line bit sequence. Not used for JPEG compression. Compressed LTR (Compressed bit order, left to right). The bit order for the compressed data is the most significant bit to the least significant bit. Not used for JPEG compression. Expanded LTR (Expanded bit order, left to right). The bit order for the expanded data is the most significant bit to the least significant bit. Not used for JPEG compression. Negate (Invert black and white on expansion). Indicates the setting of the Photometric Interpretation field of a TIFF file. Not used for JPEG compression. Low Resolution/High Quality (JPEG compression only). Low Resolution/Medium Quality (JPEG compression only). Low Resolution/Low Quality (JPEG compression only). Medium Resolution/High Quality (JPEG compression only). Medium Resolution/Medium Quality (JPEG compression only). Medium Resolution/Low Quality (JPEG compression only). High Resolution/High Quality (JPEG compression only). High Resolution/Medium Quality (JPEG compression only). High Resolution/Low Quality (JPEG compression only).
Image files that do not have a compression type of JPEG will have a value between 1 and 63. This value is a combination of the values of 1 to 32. For JPEG files, the value is from 64 to 16384, and is only one of these values.
'This example returns the page's compression information. x = Img.Pages(1).CompressionInfo
Example
CompressionType Property
Description Returns this pages compression type. This is a read-only property. Usage Data Type PageObject.CompressionType[=value]
Short.
70
Automation Lexicon
Remarks
0 1 2 3 4 5 6 7 8 9
Example
Unknown No Compression Group 3 1D FAX Group 3 Modified Huffman PackBits Group 4 2D FAX JPEG Reserved Group 3 2D FAX LZW
Height Property
Description Returns this pages height in pixels. This is a read-only property. Usage Data Type Example PageObject.Height
Long.
'This example returns this page's height in pixels. x = Img.Pages(1).Height
ImageResolutionX Property
Description Sets or returns this pages horizontal resolution, in dots-per-inch. An error occurs when a
value less than 20 or greater than 1200 dpi is specified. This is a read/write property.
Usage Data Type Example PageObject.ImageResolutionX [= value]
Long.
'This example sets this page's horizontal resolution. Img.Pages(1).ImageResolutionX = 200 'This example returns this page's horizontal resolution. XRes = Img.Pages(1).ImageResolutionX
71
Chapter 3
ImageResolutionY Property
Description Sets or returns this pages vertical resolution, in dots-per-inch. An error occurs when a
value less than 20 or greater than 1200 dpi is specified. This is a read/write property.
Usage Data Type Example PageObject.ImageResolutionY [= value]
Long.
'This example sets this page's vertical resolution. Img.Pages(1).ImageResolutionY = 200 'This example returns this page's vertical resolution. YRes = Img.Pages(1).ImageResolutionY
Name Property
Description Returns the page number of the page in the ImageFile object. This is a read-only property. Usage Data Type Example PageObject.Name
Long.
'This example returns the page number of the page in the 'ImageFile object. x = Img.Pages(1).Name
PageType Property
Description Returns the pages image type. This is a read-only property. Usage Data Type Remarks PageObject.PageType
1 2 3 4 5 6
Example
72
Automation Lexicon
Parent Property
Description Returns the parent of the Page object. This is a read-only property. Usage Data Type Example PageObject.Parent
Object.
'This example returns the parent of the Page object. x = Img.Pages(1).Parent
ScrollPositionX Property
Description Sets or returns this pages horizontal scroll position, in pixels. This is a read/write property. Usage Data Type Example PageObject.ScrollPositionX [=value]
Long.
'This example sets this page's horizontal scroll position. Img.Pages(1).ScrollPositionX = 200 'This example returns this page's horizontal scroll position. xpos = Img.Pages(1).ScrollPositionX
ScrollPositionY Property
Description Sets or returns this pages vertical scroll position, in pixels. This is a read/write property. Usage Data Type Example PageObject.ScrollPositionY [=value]
Long.
'This example sets this page's vertical scroll position. Img.Pages(1).ScrollPositionY = 200 'This example returns this page's vertical scroll position. ypos = Img.Pages(1).ScrollPositionY
Width Property
Description Returns this pages width, in pixels. This is a read-only property. Usage Data Type Example PageObject.Width
Long.
'This example returns this page's width in pixels. x = Img.Pages(1).Width
73
Chapter 3
Deletes the page. Rotates the page 180 degrees. Displays online Help. OCRs Image Page. Prints the page. Rotates the page counterclockwise 90 degrees. Rotates the page clockwise 90 degrees. Scrolls the page.
Delete Method
Description Deletes the specified page from the active object. After deleting a page, the next page is
Flip Method
Description Rotates the specified page 180 degrees. This change becomes permanent when the image
file is saved.
Usage Example PageObject.Flip 'This example flips the page. Img.Pages(1).Flip
Help Method
Description Displays the Imaging online Help table of contents. Usage PageObject.Help
Ocr Method
Description OCRs the image page. Usage PageObject.Ocr
74
Automation Lexicon
Print Method
Description Prints the page. Usage Example PageObject.Print 'This example prints the page. x = Img.Pages(1).Print
RotateLeft Method
Description Rotates the page 90 degrees counterclockwise. This change becomes permanent when the
RotateRight Method
Description Rotates the page 90 degrees clockwise. This change becomes permanent when the image
file is saved.
Usage Example PageObject.RotateRight 'This example rotates the page 90 degrees to the right. Img.Pages(1).RotateRight
Scroll Method
Description Scrolls the page. Usage Remarks PageObject.Scroll Direction,ScrollAmount
Direction
Integer
ScrollAmount
Example
Long
Direction in which to scroll the image: 0 (Default) Scrolls down 1 Scrolls up 2 Scrolls right 3 Scrolls Left Number of pixels to scroll the image
'This example scrolls the page down 200 pixels. Img.Pages(1).Scroll 0 200
75
Chapter 3
PageRange Object
A PageRange object represents a range of consecutive pages in an ImageFile object. A page range is a set of pages starting at the StartPage property and ending at the EndPage property. PageRange objects can only be accessed by using the Pages method of the parent ImageFile object.
Returns the Application object. Returns the number of pages in this range. Returns or sets the page number of the last page in the range. Returns the parent of the PageRange object. Returns or sets the page number of the first page in the range.
Application Property
Description Returns the Application object. This is a read-only property. Usage PageRangeObject.Application
Description Object.
Count Property
Description Returns the number of pages in this range. This is a read-only property. Usage Data Type PageRangeObject.Count
Long.
EndPage Property
Description Returns or sets the page number of the last page in the range. This is a read/write property. Usage Data Type Remarks PageRangeObject.EndPage [=value]
Long. This property setting is the number of the last page. The value of EndPage must be greater than or equal to the value of StartPage.
76
Automation Lexicon
Parent Property
Description Returns the parent of the PageRange object. This is a read-only property. Usage Data Type Example PageRangeObject.Parent
Object.
'This example returns the parent of the PageRange object. x = Img.Pages(1,7).Parent
StartPage Property
Description Returns or sets the page number of the first page in the range. This is a read/write
property.
Usage Data Type Remarks PageRangeObject.StartPage [=value]
Long. This property setting is the number of the first page. The value of StartPage must be less than or equal to the value of EndPage.
Deletes the page range. OCRs the page range. Prints the page range.
The Delete, Ocr, and Print methods of the PageRange object use the following parameters:
Parameter Data Type Description
StartPage NumPages
Long Long
Delete Method
Description Removes pages from the ImageFile object. After deleting a PageRange object, all page
77
Chapter 3
Ocr Method
Description OCRs the page range. Usage Example PageRangeObject.Ocr( ) 'This example OCRs pages 2 through 6. x = Img.Pages(2,6).Ocr
Print Method
Description Prints the page range. Usage Example PageRangeObject.Print( ) 'This example prints pages 1 through 5. x = Img.Pages(1,5).Print
78
4
Adding Imaging Using ActiveX Controls
This chapter demonstrates how to use the Imaging ActiveX controls to image-enable your applications. It begins by explaining how to load the Imaging ActiveX controls into your development environment. Then it explains how to access the on-line help for the controls. It concludes by walking you through some sample applications to help you get started.
In This Chapter
Loading the Controls ................................................................... 80 Obtaining Help ............................................................................ 84 Demonstration Projects................................................................ 90
Chapter 4
Before you can use the Imaging ActiveX controls, you must load them into your development environment. Loading the controls consists of the following basic tasks:
Selecting each Imaging ActiveX control from a list of registered ActiveX controls on your system. Inserting each Imaging ActiveX control icon into the controls toolbox of your development environment. The following list shows how the Imaging ActiveX controls appear on your system:
Image Admin Control Image Edit Control Image OCR Control Image Scan Control Image Thumbnail Control Image Server Access Object
80
Image Admin
Available with all versions of Imaging. A member of the Image Edit control. Available with all versions of Imaging. Available with some versions of Imaging. Available with all versions of Imaging. Available with all versions of Imaging.
Image OCR
Image Scan
Image Thumbnail
81
Chapter 4
Visual Basic
To add the Imaging ActiveX controls to Visual Basic
1 Start Visual Basic and create a new project. 2 On the Project menu, click Components. 3 On the Components dialog box, click the Controls tab. 4 Select the Imaging ActiveX controls from the controls listed. (Refer
A control is selected when a check mark appears next to it.
to Loading the Controls earlier in this chapter to see a list of Imaging ActiveX controls.)
5 Click OK. Visual Basic adds the controls to your project and the
control icons to your toolbox.
6 Work with the Imaging ActiveX controls as you would any other
type of ActiveX control.
Visual C++
To add the Imaging ActiveX controls to Visual C++
1 Start Visual C++ and create a new project. 2 On the Project menu, point to Add to Project, and click
Components and Controls. The Component and Controls Gallery dialog box appears.
3 In the Look In list box, click SharedIDE and then Gallery. 4 Below the Look In list box, double-click Registered ActiveX
Controls. A list of registered ActiveX controls appears.
5 For each Imaging ActiveX control: a Click the desired control among the list of registered controls and
then click Insert. (Refer to Loading the Controls earlier in this chapter to see a list of Imaging ActiveX controls.)
b On the Confirm Classes dialog box, click OK. Visual C++ adds
the control to your project and its icon to the Controls toolbox, which is visible when you edit a dialog box in Resource View.
6 When you have finished adding the Imaging ActiveX controls, click
Close on the Components and Controls Gallery dialog box.
7 Work with the Imaging ActiveX controls as you would any other
type of ActiveX control.
Note: If you are using Microsoft Foundation Classes (MFC), be sure to call AfxEnableControlContainer within InitInstance.
82
Access
To add the Imaging ActiveX controls to Access
1 Start Access and create a new database. 2 On the Tools menu, click ActiveX Controls. 3 If the ActiveX Controls dialog box lists all of the Imaging ActiveX
controls as available, click Close and proceed to Step 4.
If you selected the OLE Controls check box in the Setup program when you installed Microsoft Access, the Imaging ActiveX controls are available automatically.
For each control the dialog box does not list as available:
a Click Register. b On the Add ActiveX Control dialog box, navigate to your
Imaging folder.
c Click the file name of the control not listed as available. Then
click Open to register the control. The following table lists the file names of each Imaging ActiveX control.
Imaging ActiveX Control File Names Click This File To Register This Control
Image Admin Image Annotation Tool Button Image Edit Image OCR Image Scan Image Thumbnail
d When you finish registering the controls, click Close to exit the
ActiveX Controls dialog box.
4 Enter Form or Report design view. 5 On the View menu: a If necessary, click Toolbox to display the Controls toolbox. b Point to Toolbars and click Customize. 6 On the Customize dialog box, click the Commands tab.
83
Chapter 4 7 In the Categories list box: a Click ActiveX Controls. b From the Commands list box, drag each Imaging ActiveX
control and drop it onto the Controls toolbox.
8 Work with the Imaging ActiveX controls as you would any other
type of ActiveX control.
Obtaining Help
This section explains how to access the on-line help system of the Imaging ActiveX controls.
How you access the Imaging ActiveX Controls on-line help system differs within each of the following programming environments: Visual Basic Visual C++ Access The following sections describe how to access help in each environment.
Note:
Several methods in the Imaging ActiveX controls present dialog boxes to the end user. Each dialog box provides its own contextsensitive help, which the user can invoke by clicking the question mark at the top of the dialog box and then the desired control.
Visual Basic
There are many ways to access the Imaging ActiveX Controls on-line help in Visual Basic. You can access help from the: Object Browser Toolbox Form window Properties window Code window Before attempting to access help, make sure that the Imaging ActiveX controls have been added to your current project. (Refer to Loading the Controls for instructions.)
84
Object Browser
To access Imaging ActiveX help from the Object Browser
2 In the Project/Library list box, click the library name of the desired
Imaging ActiveX control. The following table lists the library and class names of each Imaging ActiveX control.
Imaging ActiveX Control Library and Class Names Library Name Class Name Imaging Control
Image Admin Image Annotation Tool Button Image Edit Image OCR Image Scan Image Thumbnail
3 In the Classes list box, click the class name of the control. (Refer to
the preceding table for a list of class names.)
Toolbox
To access Imaging ActiveX help from the Toolbox
Click the desired Imaging ActiveX control in the toolbox, and then press F1. The overview topic for the selected control appears. From the overview topic, you can navigate to other topics that describe the properties, methods, and events of the selected control.
85
Chapter 4
Form Window
To access Imaging ActiveX help from the Form window
1 Draw at least one Imaging ActiveX control on a form. 2 Select the Imaging ActiveX control on the form. 3 Press F1. The overview topic for the selected control appears.
From the overview topic, you can navigate to other topics that describe the properties, methods, and events of the selected control.
Properties Window
To access Imaging ActiveX help from the Properties window
2 Click the desired property in the Properties window and then press
F1. The help topic for the selected property appears.
Note: Keep in mind that only the design-time properties appear in the Properties window. If the property you select is an extender property, Visual Basics on-line help appears.
Code Window
To access Imaging ActiveX help from the Code window
1 Make sure that at least one Imaging ActiveX control has been drawn
on a form.
2 Invoke the Code window. 3 Within your code, select the Imaging property, method, or event for
which you want help. Then press F1. The help topic for the selected property, method, or event appears I.
Note: If the property, method, or event you select is an extender property, method, or event, Visual Basics on-line help appears.
86
Visual C++
There are two ways to access the Imaging ActiveX Controls on-line help in Visual C++. You can access help from the:
Components and Controls Gallery dialog box Properties window Before attempting to access help, make sure that the Imaging ActiveX controls have been added to your current project. (Refer to Loading the Controls for instructions.)
2 Click the desired Imaging ActiveX control below the Lookin box,
and then click More Info. The overview topic for the selected control appears. From the overview topic, you can navigate to other topics that describe the properties, methods, and events of the selected control.
Properties Window
To access Imaging ActiveX help from the Properties window
1 Select an Imaging ActiveX control that has been drawn on a form. 2 On the View menu, click Properties. 3 Click the desired property in the Properties window, and then press
F1. The help topic for the selected property appears.
Note: Keep in mind that only the design-time properties appear in the Properties window. If the property you select is an extender property, the contents window for the Imaging ActiveX help system appears.
87
Chapter 4
Access
There are three ways to access the Imaging ActiveX Controls on-line help in Access. You can access help from the: Object Browser Properties window Module window Before attempting to access help, make sure that the Imaging ActiveX controls have been added to your current database. (Refer to Loading the Controls for instructions.)
Object Browser
To access Imaging ActiveX help from the Object Browser
1 Make sure the Module window is currently on display. 2 On the View menu, click Object Browser. The Object Browser
appears.
4 In the Classes list box, click the class name of the desired control.
(Refer to the aforementioned list.)
Properties Window
To access Imaging ActiveX help from the Properties window
1 Select an Imaging ActiveX control that has been drawn on a form. 2 On the View menu, click Properties. 3 On the Properties window, click the Other tab or the All tab.
88
Adding Imaging Using ActiveX Controls 4 Click the desired property in the Properties window and then press
F1. The help topic for the selected property appears.
Note: Keep in mind that only the design-time properties appear in the Properties window. If the property you select is an extender property, Access on-line help appears.
Module Window
To access Imaging ActiveX help from the Module window
1 Make sure that at least one Imaging ActiveX control has been drawn
on a form.
2 Invoke the Module window. 3 Select the Imaging property, method, or event within your code for
which you want help. And then press F1. The help topic for the selected property, method, or event appears I.
Note: If the property, method, or event you select is an extender property, method, or event, Visual Basics on-line help appears provided Visual Basic is installed on your system.
89
Chapter 4
Demonstration Projects
This section demonstrates how to add a variety of Imaging functions to your applications. A wide-ranging discussion of every Imaging function is beyond the scope of this chapter; however it does discuss many of the popular ones. All demonstration projects were developed using Microsoft Visual Basic.
To help you use the Imaging ActiveX controls, seven demonstration projects show you how to:
Display an image and apply fit-to options. Convert an image. Copy an image. Print an image. Scan images using a template. Manage an image file using thumbnails. Unload a multipage image file.
Note: The ActiveX Controls on-line help system identifies the properties, methods, events, parameters, and constants that are available in each version of Imaging for Windows.
90
You can provide your users with even more control over a displayed image by using the Zoom property of the Image Edit control in addition to the FitTo method.
Example
Users of your application may want control over the display of image documents to make them easy to read. Scenario Assume Eileen receives several scanned business documents in her role as product manager for a major computer company. Because she receives these documents from others via e-mail, she has no control over how they are scanned, but she really needs to be able to read them. Because you included all of Image Edits fit-to options in your application, Eileen can select the one that produces the best display quality enabling her to view the image documents clearly and read them easily.
91
Chapter 4
One Image Edit control Four Option Button controls in a control array One Frame control One Command Button control It uses the following methods in the Image Edit control to provide the display and fit-to functions: Display Displays the image file specified in the Image property of the Image Edit control. FitTo Scales the image relative to the Image Edit control.
92
To change the FitTo setting, click the desired option button in the FitTo Setting frame on the FitTo Options window. The optFitTo_Click() event procedure fires and executes the appropriate code in its Select Case statement. Each Case expression corresponds to the Index value of the FitTo option buttons in the frame. Further, each Case expression invokes the FitTo method of the Image Edit control, passing to it the appropriate parameter values: FitTo parameter Determines the FitTo option applied:
0 invokes BEST_FIT (literal 0). 1 invokes FIT_TO_WIDTH (literal 1). 2 invokes FIT_TO_HEIGHT (literal 2). 3 invokes INCH_TO_INCH (literal 3).
93
Chapter 4
Repaint parameter Determines whether the image is refreshed immediately. All Case expressions invoke the FitTo method with a Repaint setting of True. As you try the various FitTo options, notice the impact on the displayed image and how the scrollbars appear and disappear as needed.
You can control whether scrollbars appear in the Image Edit control by setting the ScrollBars property to the appropriate value.
Private Sub optFitTo_Click(Index As Integer) Select Case Index Case 0 'Best Fit ImgEdit1.FitTo BEST_FIT, True Case 1 'Fit To Width ImgEdit1.FitTo FIT_TO_WIDTH, True Case 2 'Fit To Height ImgEdit1.FitTo FIT_TO_HEIGHT, True Case 3 'Inch To Inch (Actual Size) ImgEdit1.FitTo INCH_TO_INCH, True End Select End Sub
Converting an Image
This demonstration project shows how to add image conversion functions to your image-enabled applications. Before walking through the demonstration project, read the following sections, which explain the concept of image conversion.
94
Example
Users of your application may want to change the file type to take advantage of the new file types special features. Scenario Assume Krystina sends Tom two BMP image files of an automobile that was involved in an accident recently. Because the two BMP files are separate and quite large, Tom converts each one to the TIFF file format to take advantage of its special features. Once in the TIFF format, Tom can:
Combine the two files into one multipage TIFF image file. Apply compression to save disk space. Annotate the images without making the annotations a permanent part of the image. Add Summary property information to the image file.
Color Type The color type also known as the page type or data type specifies the number of colors images can have. Your users will want to use, or convert images to, the color type that best satisfies their color and storage requirements. The factor that determines the color content of images is the number of data bits that compose each picture element (pixel). The formula for determining the color content of image documents is 2 number of bits. The more color an image contains, the greater the number of data bits in each pixel.
95
Chapter 4
Aesthetics aside, the most important consideration when selecting the color type is file size. The greater the number of data bits per pixel, the greater the memory and storage requirements. The following color types are available: Black and White One bit makes up each pixel. Images can therefore have only two colors: black and white. 16 Shades of Gray Four bits make up each pixel. Images can therefore have a maximum of 16 shades of gray. 256 Shades of Gray Eight bits make up each pixel. Images can therefore have a maximum of 256 shades of gray. 16 Colors Four bits make up each pixel. Images can therefore have a maximum of 16 colors. 256 Colors Eight bits make up each pixel. Images can therefore have a maximum of 256 colors. True Color Twenty-four bits make up each pixel. Images can therefore have a maximum of 16,777,216 colors.
Example
Users of your application may want to change a color type to save disk space. Scenario Assume Tom scans a text-only insurance document in True Color and then sends the image to Krystina so she can view it. When Krystina receives the image, she notices that its file size is a little large for a textbased image. Realizing that color is not a requirement for this type of image, she converts its color type to Black and White. File size drops 27%, and the document is completely readable. Compression Type When saved to disk, images can require a large amount of storage space. Compression is a technique that reduces this large disk space requirement. The more compression applied when saving images, the lower the disk space requirement. Your users will want to use, or convert images to, the compression type that best satisfies their storage requirements.
96
JPEG is a lossy compression type, which means that some data is altered and lost during compression. Usually, data alteration and loss are not significant. Lossy compression types often offer higher compression ratios than do lossless types, like LZW.
JPEG Can be used to compress TIFF images with a color type of 256 Shades of Gray or True Color. Should be used when users want to significantly reduce the storage requirement, and they dont mind if the image is altered by the compression process. When users select this compression type, they can also specify JPEG compression options, which comprise all combinations of high, medium, or low Resolution and high, medium, or low Quality. The higher the Resolution and Quality settings, the greater the image quality, but the greater the disk space requirement. For example, an image compressed with the High Resolution/High Quality option has the highest image quality and the highest disk space requirement. Conversely, an image compressed with the Low Resolution/Low Quality option has the lowest image quality and the lowest disk space requirement. LZW Can be used to compress TIFF image documents of any color type, except black-and-white. Should be used when users do not want the image to be altered by the compression process. PackBits Can be used to compress black-and-white TIFF image documents for any purpose. Uncompressed No compression options are set.
97
Chapter 4
Example
Users of your application may want to change the compression type to save disk space. Scenario In an earlier scenario, Krystina sent Tom two True Color bitmap (BMP) image files of an automobile that was involved in a recent accident. Tom converted each BMP file to the TIFF file format and saved both of the images in a single TIFF image file. The resulting uncompressed file was quite large at 21 megabytes (MB); so, Tom elected to compress the file using the JPEG compression type with the following compression options:
JPEG Compression: Medium JPEG Resolution: Medium The resulting image file was reduced to just under 2 MB.
Resolution Resolution determines the display quality of an image. Typically expressed as horizontal and vertical dots per inch (dpi), resolution describes the density of the dots that make up the image. The higher the resolution or dots per inch the better the display quality. An important consideration when setting the resolution is file size. The greater the dots per inch, the greater the memory and storage requirements. For example, the file size of an image with a resolution of 200 x 200 dpi is four times greater than the file size of the same image at 100 x 100 dpi. Another important consideration when setting the resolution is how the images are to be used: Displayed on the screen For images that are displayed on the screen, resolution need not be any greater than the display resolution of the monitor, typically 75 x 75 dpi to 100 x 100 dpi. Faxed For images that are faxed, resolution should conform to the international fax standard of 200 x 200 dpi. Converted to text or printed For images that are printed, resolution should be set to 300 x 300 dpi. Your users want to use, or convert images to, the resolution that best satisfies their aesthetic, storage, and usage requirements.
98
Example
Users of your application may want to change the resolution of an image to save disk space. Scenario Assume Tom received a complimentary letter from a customer that he wants to post on the companys intranet page for all to see. Tom knows that he can use your application to scan the letter and convert it to HTML using the OCR functions you have provided. Because you stated in your documentation that the OCR engine processes images with optimum efficiency when their resolution is 300 x 300 dpi, Tom scans the letter at that resolution. After performing OCR on the image and uploading its HTML file to the Web server, Tom realizes that he wants to save the image on his PC just in case he needs it later. Knowing that an image with a resolution of 300 x 300 dpi takes more storage space than one with a lower resolution, Tom uses the conversion functions in your program to convert the image to 200 x 200 dpi just prior to saving it. Size The size settings determine the dimensions of an image. Your users may want to change the size of the image and/or the unit of measure employed to suit their purposes.
Example
Users of your application may want to change the size of an image to accommodate an annotation. Scenario Assume Krystina scans a claim form and then wants to add a rubber stamp annotation to the bottom of it. The problem is: theres no room at the bottom of the image to accommodate the annotation. To make room for the annotation, Krystina converts the size of the image from 8 1/2 x 11 inches to 8 1/2 x 12 inches, thereby making room for the annotation.
99
Chapter 4
The project consists of one form and the following controls: One Image Admin control One Image Edit control Three Command Button controls in a control array It uses the following Imaging methods to provide the image conversion functions:
ShowFileDialog (Image Admin) To enter the path and file name and select the new file type of the converted image. SaveAs (Image Edit) To save the image file with the new file type. ShowPageProperties (Image Edit) To change the color type, compression type, resolution, and/or size of the image page. Save (Image Edit) To save the image file after changing its color type, compression type, resolution, and/or size.
Note: Users can change the color type, compression type, resolution, and size on a page-by-page basis only.
Changing the File Type Start the Convert Image project. The application begins by displaying an Open dialog box, which lets you select the image file you want to convert. After you select the image file, the application displays it. To change the file type of the displayed image, click the File Type button. The cmdConvert_Click() event procedure fires and executes the code in Case 0 of the Select Case statement. The procedure invokes the ShowFileDialog method of the Image Admin control, passing to it the following parameter values:
Similar to the Microsoft Common Dialog box, you can use the Filter property of the Image Admin control to populate the Files of Type list box with the file types you desire.
SaveDlg (literal 1) To display a Save As dialog box frmConvertImage.hWnd To assign the parent window handle to
the Save As dialog box The Save As dialog box lets you specify the new path and file name and the new file type you want for the image. It assigns the new path and file name to the Image property of the Image Admin control, and it assigns
100
101
Chapter 4
Private Sub cmdConvert_Click(Index As Integer) Dim intFileType As Integer Dim iResponse As Integer Select Case Index Case 0 'File Type button 'Set the Filter property to include the file types that can be 'written to disk. ImgAdmin1.Filter = "TIFF Image file (*.tif)|*. tif| Bitmap Image file (*.bmp)|*. bmp|" 'Set the FilterIndex property to the file type of the displayed image 'if it can be written; otherwise to TIFF. If ImgAdmin1.FileType = FileTypeBMP Then ImgAdmin1.FilterIndex = 2 Else ImgAdmin1.FilterIndex = 1 End If 'Invoke ShowFileDialog method. On Error GoTo CancelPressed_EH ImgAdmin1.ShowFileDialog SaveDlg, frmConvertImage.hWnd 'Set Image property of the Image Edit control to the filename 'returned by theOpen dialog box. ImgEdit1.Image = ImgAdmin1.Image 'Set the iFileType variable to the file type returned by the 'Open dialog box. If ImgAdmin1.FilterIndex = 2 Then iFileType = iFileTypeBMP Else iFileType = FileTypeTIFF End If 'Invoke the SaveAs method using the new file name and file type ImgEdit1.SaveAs ImgEdit1.Image, intFileType . . . End Select CancelPressed_EH: End Sub
The ShowPageProperties method returns an integer that indicates whether the user has pressed the OK or Cancel button on the dialog
102
Private Sub cmdConvert_Click(Index As Integer) Dim intFileType As Integer Dim iResponse As Integer Select Case Index . . . Case 1 'Page button 'Display the ShowPageProperties dialog box to let users convert the 'image iResponse = ImgEdit1.ShowPageProperties(False) If iResponse = vbOK Then 'User clicked OK on the dialog box so save the converted image ImgEdit1.Save ElseIf iResponse = vbCancel Then 'User clicked Cancel on the dialog box so exit without saving Exit Sub End If . . . End Select CancelPressed_EH: End Sub
103
Chapter 4
Copying An Image
The Image Copy demonstration project shows how to add a Clipboard copy function to your image-enabled applications. Before walking through the demonstration project, read the following section, which explains the concept of using the Clipboard with image data.
Copy or cut image and/or annotation data to the Clipboard. Paste image or annotation data from the Clipboard onto an image displayed in the Image Edit control or into any application that supports the pasting of image data (for example, Microsoft Word, WordPad, Exchange, or Excel). Depending on how you code your application, you can let your users copy or cut an entire image page, a selected portion of an image page, or selected annotations. The following sections briefly describe the properties, methods, and events of the Image Edit control youll find useful when adding Clipboard functions to your applications.
Clipboard Paste
IsClipboardDataAvailable method Checks to see if image or annotation data is present in the Clipboard. You can use this method to see if data is available for pasting. ClipboardPaste method Pastes image or annotation data from the Clipboard onto an image in the Image Edit control.
104
Image Selection
SelectionRectangle property Sets whether a selection rectangle is drawn when an end user clicks the left mouse button and drags the mouse pointer over a displayed image. Can be used to select a portion of an image to copy or cut to the Clipboard. DrawSelectionRect method Draws a selection rectangle on an image programmatically. SelectionRectDrawn event Fires after a selection rectangle has been drawn by the end user or by the DrawSelectionRect method.
Note: A selection rectangle can be used to select a portion of an image with or without annotations; however, it cannot be used to select annotations alone.
Annotation Selection
AnnotationType property When set to the Select Annotations annotation type, lets end users select one or more annotations for copying or cutting to the Clipboard (or for some other Imaging purpose). Draw method Draws an annotation. Can be used to select annotations programmatically by drawing a Select Annotations annotation type. MarkSelect event Fires after an end user or the program selects one or more annotations for copying or cutting to the Clipboard (or for some other Imaging purpose, such as ZoomToSelection, for example).
Note: The Select Annotations annotation type selects annotations exclusively. It does not select the underlying image data.
105
Chapter 4
Example
Users of your application may want to copy an image page to the Clipboard so they can paste the image into a word processing document. Scenario Assume Susan is writing a follow-up letter to her insurance company about a reimbursement claim she has yet to receive. Before she sent the original receipt, she scanned it and saved it to disk. Now she wants to include a copy of the receipt in her follow-up letter. With the image of the receipt displayed in your application, she copies it to the Clipboard using the Clipboard functions you provided. Then, in Word, she pastes the image into her letter.
One Image Admin control One Image Edit control One Picture Box control Two Frame controls
106
The Left and Top coordinates of the image relative to the Image Edit control (0,0). The Width and Height of the image in pixels, as provided by the current values of the ImageScaleWidth and ImageScaleHeight properties of the Image Edit control.
107
Chapter 4
Finally, the procedure obtains the current image content of the Clipboard using Visual Basics GetData method and displays it in the PictureBox control (which is inside the Data In Clipboard frame) I.
Private Sub Form_Load() Dim vntTemp As Variant Dim lngRPosition As Long Dim sngLeftChar As Single, sngRightChar As Single . . . 'Check for valid TIFF file. If ImgAdmin1.FileType <> 1 Then GoTo File_EH Else 'Use the FitTo method to make the displayed image fit into the width 'of the Image Edit control. ImgEdit1.FitTo FIT_TO_WIDTH 'Display the image. ImgEdit1.Display 'Copy the whole image onto the Clipboard. ImgEdit1.ClipboardCopy 0, 0, ImgEdit1.ImageScaleWidth, _ ImgEdit1.ImageScaleHeight 'Get the image data from the the Clipboard and display it in 'the PictureBox control to make show it was copied. picImage = Clipboard.GetData() End If Exit Sub File_EH: MsgBox "Quitting the program now. Please select a TIFF file to use the _ program." 'Quit the program End End Sub
108
Printing An Image
The Print Image demonstration project shows how to add image printing to your image-enabled applications. Before walking through the demonstration project, read the following section, which explains the concept of printing an image file.
Example
Users of your application may want to print an image file on a particular printer and have complete control over the process of doing so. Scenario Assume Geoff is using your application to view an image of a technical drawing. As he views it, he annotates it with his comments. After entering his last comment, Geoff realizes that he is supposed to meet Susan for lunch in just 15 minutes. He would like her to take a look at the technical drawing too only he doesnt want her to see his annotated comments. On the File menu of your application, Geoff clicks Print. Then, on the Print dialog box, he clicks the Options button.
109
Chapter 4
On the Print Options dialog box, he unchecks the Print displayed annotations and zones check box and then clicks OK to return to the Print dialog box. On the Print dialog box, Geoff selects the printer he wants use and specifies the page range and number of copies to print. When he clicks OK, your application prints the drawing without Geoff s annotations.
The project consists of one form and the following controls: One Image Admin control One Image Edit control Two Command button controls in a control array And it uses the following Imaging methods to provide the print image function:
ShowPrintDialog (Image Admin) To display a Print dialog box to the end user. PrintImage (Image Edit) To actually print the image.
110
The ShowPrintDialog method displays a Print dialog box, which lets you specify the print options mentioned earlier.
111
Chapter 4
After you click the OK button on the Print dialog box, the Image Admin control sets several of its print-related properties to values that correspond to the selections made on the Print and Print Options dialog boxes. (Keep in mind that the Print Image project does not use all of these properties.)
Print-Related Properties Set By the Print and Print Options Dialog Boxes Image Admin Property Set Associated Field and Dialog Box Value Property Contains
You can set the print-related properties to preferred values prior to invoking the Print dialog box. Doing so lets you preset dialog box fields to default settings.
PrintAnnotations
Print displayed annotations and zones check box on the Print Options dialog box Collate check box on the Print dialog box Pages to text box on the Print dialog box Number of copies text box on the Print dialog box Print orientation list box on the Print Options dialog box Print format list box on the Print Options dialog box
PrintCollate
True or False Indicating whether to collate image pages The ending page number in the range of pages to print The number of copies to print
PrintEndPage
PrintNumCopies
PrintOrientation
The page orientation: 0 Portrait 1 Landscape 2 Automatic The output format to use: 0 Pixel to pixel 1 Actual size 2 Fit to page 3 Best fit
PrintOutputFormat
112
PrintRangeOption
The following option buttons on the Print dialog box: All pages Current page Selection Pages Pages from text box on the Print dialog box Print to file check box on the Print dialog box
PrintStartPage
The start page number in a range of pages to print True or False Indicating whether to print to a file
PrintToFile
113
Chapter 4
The procedure continues by evaluating the value of the PrintRangeOption property. It invokes the PrintImage method of the Image Edit control with the StartPage and EndPage parameter values that are appropriate for the PrintRangeOption value selected on the Print dialog box (as described in the following table).
StartPage and EndPage Parameter Values Passed PrintRangeOption Constant (Literal) StartPage Parameter EndPage Parameter
PrintAll (0)
The value of the PrintStartPage property of Image Admin control The value of the PrintStartPage property of Image Admin control The value of the Page property of Image Edit control
The value of the PrintEndPage property of Image Admin control The value of the PrintEndPage property of Image Admin control The value of the Page property of Image Edit control
PrintRange (1)
PrintCurrent (2)
Each invocation of the PrintImage method also includes the OutputFormat and Annotation parameter values supplied by the PrintOutputFormat and PrintAnnotations properties of the Image Admin control. Once invoked, the PrintImage method prints the image to the printer or file specified.
114
115
Chapter 4
A path to where the images are saved. A file name prefix, which is used to generate the file names. The end user of the application usually provides the path and prefix. Responding to input from your end user, you can place the Imaging software in Template Scanning mode by setting the ScanTo property of the Image Scan control to the appropriate value. You can then specify the template by setting the Image property of the Image Scan control to the path and prefix provided.
The ScanTo property also has settings that permit scanning directly to a file (non-Template Scanning). When scanning to a file, consider using the ShowScanNew and the ShowScanPage methods of the Image Scan control to quickly add scanning functions to your applications.
For example, if the user wants image files to be saved to the c:\claims\automobile path using file names prefixed with auto, enter the following string in the Image property of the Image Scan control:
imgScan1.Image = c:\claims\automobile\auto
Using this template, the Imaging software will save images to files named auto0001.tif, auto0002.tif, and so on in the c:\claims\automobile folder (TIFF file format assumed). The file type as well as the setting of the PageCount and MultiPage properties of the Image Scan control determines the number of image files generated and the number of image pages saved per file. When scanning images using the BMP file type, each image page is always saved to a separate file. For example:
c:\claims\automobile\auto0001.bmp c:\claims\automobile\auto0002.bmp c:\claims\automobile\auto0003.bmp
This occurs because the BMP file type does not support multiple image pages per file.
116
0 0
True False
1 One file for each page scanned Total number of pages scanned divided by X X
Xa
True
False
For example, if you set the PageCount property to 5 and the MultiPage property to True, and then you scan 20 pages, the Imaging software creates four image files with five pages in each one.
Example
Users of your application may want to use a scanner equipped with an automatic document feeder (ADF) to automatically scan multiple pages into one or more image files. Scenario Assume Gloria has five 10-page documents she wants to scan using her ADF-equipped scanner and your application. She wants each 10-page document to be saved to its own TIFF image file in the c:\employees path, and she wants the file name of each document to be prefixed with the word review.
117
Chapter 4
Because you provided a way for users to: Specify the desired path, Enter the file prefix, Select the file type, Set the PageCount property, and Set the MultiPage property, Gloria was able to specify that:
All documents are saved in the c:\employees folder. Each file name begins with the word review. Each document is scanned and saved as TIFF. Each document contains 10 pages. Each image file contains multiple image pages. When Gloria commences scanning, your application:
3 Sets the FileType property of the Image Admin control to TIFF. 4 Sets the PageCount property of the Image Admin control to 10. 5 Sets the MultiPage property of the Image Admin control to True. 6 Scans 50 pages and saves each set of 10 scanned pages to 5 individual
TIFF image files each one generated and incremented using the template specified:
c:\employees\revi0001.tif c:\employees\revi0002.tif c:\employees\revi0003.tif c:\employees\revi0004.tif c:\employees\revi0005.tif
118
The project consists of the following forms and modules: frmFileType Enables the user to select the desired file type. frmHelp Presents a brief help message to the user. frmMain Lets the user enter the template prefix, specify the number of pages per file, commence scanning, and view the first page of the image file. frmPaperSize Enables the user to specify the desired paper size. frmPath Enables the user to specify the desired template path. modMain Contains global constant definitions and global variable declarations. The scanning functions exist in the Main form (frmMain), which contains the following controls:
One Image Scan control One Image Edit control Two text box and label controls One Command button control
119
Chapter 4
Three menus The form uses the following methods of the Image Scan control to provide the scanning functions: ShowSelectScanner To select the scanner to use. StartScan To scan images.
Template Scanning Start the Template Scan project. The Main form appears. In the File Prefix text box, enter the prefix you want for the template. Then, in the Pages per File text box, enter the number of pages you want each image file to contain. On the File menu:
Click File Type. On the File Type form, click the file type you want and then click OK. Depending on the option button you clicked, the cmdOK_Click() event of the File Type form (frmFileType) sets the FileType property of the Image Scan control contained on the Main form (frmMain) to the file type specified. Click Path. On the Folder dialog box, specify the template path, which is where the image files are saved, and then click OK. The cmdOK_Click() event of the Path form (frmPath) sets the global variable, gstrFolder, to the path specified. (Later, the cmdStartScan_Click() event of the Main form uses the value of gstrFolder to set the Image property of the Image Scan control).
Click Paper Size. On the Paper Size dialog box, click the paper size you expect to scan and then click OK. Depending on the option button you clicked, the cmdOK_Click() event of the Paper Size form (frmPaperSize) sets the global variable, gsngAspect, to the size specified. It then calls the Form_Resize() event of the Main form, which uses the value of gsngAspect, to resize the Main form and its controls (not shown).
120
Private Sub cmdOK_Click() 'Set the global path variable to the path specified gstrFolder = dirPath.Path 'Set the Caption of the Main form to the path specified frmMain.Caption = gstrFolder + " - " + gstrCMainCaption 'Unload the Path form Unload Me End Sub
121
Chapter 4
Private Sub cmdOK_Click() 'Set the global Aspect variable to either 'the size selected using an option button 'or the custom values entered If optLetter Then gsngAspect = 11 / 8.5 ElseIf optLegal Then gsngAspect = 14 / 8.5 ElseIf optOther Then If CSng(txtWidth.Text) < 1 Then txtWidth.Text = 1 Beep End If If CSng(txtHeight.Text) < 1 Then txtHeight.Text = 1 Beep End If msngTmpWidth = CSng(txtWidth.Text) msngTmpHeight = CSng(txtHeight.Text) gsngOtherWidth = CSng(txtWidth.Text) gsngOtherHeight = CSng(txtHeight.Text) gsngAspect = gsngOtherHeight / gsngOtherWidth End If 'Hide this form, resize frmMain, and reset the 'Image Edit control to Best Fit frmPaperSize.Hide frmMain.Form_Resize End Sub
122
Click Scan Options to apply compression. The mnuCompressionOptions_Click() event in the Main form invokes the ShowScanPreferences method of the Image Scan control. The method displays a Scan Options dialog box that lets you specify the compression you want.
Private Sub mnuCompressionOptions_Click() 'Invoke the ShowScanPreferences method which 'displays the Scan Options dialog box ImgScan1.ShowScanPreferences End Sub
123
Chapter 4
Click Select Scanner to select the scanner you want to use. The mnuSelectScanner_Click() event in the Main form invokes the ShowSelectScanner method of the Image Scan control. The method displays a Select Scanner dialog box that lets you select the scanner you want.
Private Sub mnuSelectScanner_Click() 'Invoke the ShowSelectScanner method which 'displays the Select Scanner dialog box ImgScan1.ShowSelectScanner End Sub
Click Stop Button to have the Imaging software display a Stop button while scanning.
The mnuStopButton_Click() event in the Main form sets the StopScanBox property to True or False (as appropriate) to either display, or not display, the Stop button. The Stop button enables you to abort a scanning operation in progress.
124
Private Sub mnuStopButton_Click() 'Set the StopScanBox property in accordance with 'the Checked status of the mnuStopButton menu 'selection If mnuStopButton.Checked Then mnuStopButton.Checked = False ImgScan1.StopScanBox = False Else mnuStopButton.Checked = True ImgScan1.StopScanBox = True End If End Sub
To begin scanning, click the Start Scan button. The cmdStartScan_Click() event procedure in the Main form fires and executes its code. The procedure sets several properties of the Image Scan control to enable template scanning: DestImageControl Set to the same value as the ImageControl property of the Image Edit control to permit image display while scanning.
Note: Setting the DestImageControl property to the value of the ImageControl property is essential whenever you want to display the image being scanned. It may be used for all types of scanning not just template scanning.
ScanTo Set to DisplayAndUseFileTemplate (literal 3) to select template scanning. Image Set to the template, which is a concatenated string containing:
The path (as specified on the Path form and assigned to the
gstrFolder global variable),
A backslash (\), and The file name prefix (as specified in the File Prefix text box).
PageCount Set to the value entered in the Pages per File text box to establish the number of pages per file. MultiPage Set to True to permit the scanning of multiple image pages.
125
Chapter 4
Next, the procedure invokes the StartScan method of the Image Scan control, which scans multiple image pages:
To the appropriate number of image files. Using auto-incremented path and file names that begin with the template specified. Containing the number of image pages specified.
Private Sub cmdStartScan_Click() On Error GoTo Scan_EH . . . 'Link the Image Scan and Image Edit controls to permit display 'while scanning ImgScan1.DestImageControl = "ImgEdit1" 'Set the ScanTo property to enable template scanning ImgScan1.ScanTo = DisplayAndUseFileTemplate 'Concatenate the path, backslash, and template prefix. Then assign the 'string to the Image property ImgScan1.Image = gstrFolder + "\" + txtPrefix.Text 'Assign the Pages per File value to the PageCount property ImgScan1.PageCount = txtPages 'Set the MultiPage property to enable multipage scanning ImgScan1.MultiPage = True 'Commence scanning ImgScan1.StartScan Exit Sub
Scan_EH: 'Display the error message lblStatus.Caption = "ERROR - " + Err.Description Beep End Sub
126
Thumbnails Defined
The Image Thumbnail control lets you view each page of an image file in miniature boxes called thumbnails. There is one thumbnail image for each page in the file. Each thumbnail has a caption beneath it that indicates its page position within the image file and an annotation indicator if one or more annotation marks exist on the corresponding image page. In addition to viewing image pages, the Image Thumbnail control in conjunction with the Image Admin control also lets you provide image file management functions to your end users. These functions enable them to:
The Image Thumbnail control has several properties that enable you to assign different fonts, colors, and styles to the captions, as well as to the control itself.
Select an image page for display, edit, manipulation, deletion, or some other Imaging function. Reorganize pages within the image file. Drag and drop image pages to and from other applications that support drag-and-drop.
Example
Users of your application may want to view image files as a series of thumbnail images. They may also want to manage image files using drag and drop. Scenario Assume Chris and his staff regularly review large fax files that contain mostly blueprint drawings. Chris is concerned that in the middle of any of these files there might be a letter, or other piece of important information, that could go unnoticed when someone is scrolling through the file. Using your application, Chris and his staff can quickly review each fax file by looking at its thumbnail images. When they find pages that have important information, they can drag and drop them into an another Image Thumbnail control, whose ThumbDrop() event contains code that routes the image pages to the appropriate personnel.
127
Chapter 4
Reorganize images pages within the file. Drag and drop image pages from Explorer. Delete image pages from the file by dragging and dropping them into another Image Thumbnail control.
The project consists of one form and the following controls: One Image Admin control Two Image Thumbnail controls Three Command button controls Two Text Box box controls Two Label controls One Frame control The project uses the following Imaging methods to provide the thumbnail file management functions:
128
Sorting an Image File (Using Specified Page Numbers) Start the Thumbnail Sorter project. The Form_Load() event procedure displays an Open dialog box to let you select the TIFF image file you want to work with. Be sure to select a multipage image file. After you select the image file, the procedure:
Sets the Image property of the Image Thumbnail control to the complete path and file name you selected (as supplied by the Image property of the Image Admin control). Invokes the DisplayThumbs method of the Image Thumbnail control to display each page of the file as a thumbnail in the Image Thumbnail control located inside the Thumbnails frame. Sets the AutoSelect property of the Image Thumbnail control to True to have the control handle all thumbnail selections made using the mouse.
129
Chapter 4
The EnableDragDrop property lets you set the desired drag-and-drop behavior.
Sets the EnableDragDrop property of the Image Thumbnail control to a literal value of 15, which is a bit-wise combination of the settings described in the following table.
Note: The EnableDragDrop property value determines the drag-anddrop behavior of the Thumbnail Sorter application, which is described in the sections entitled Sorting an Image File (Using Drag and Drop) and Deleting Image Pages (Using Drag and Drop) . Combined EnableDragDrop Property Settings Literal Value Setting Description
1 2 4 8 Result = 15
Enable drag using left mouse button Enable drag using right mouse button Enable drop into Enable dropping of image files DropFilesDropDragLeftRight
Gets the number of thumbnail images displayed from the ThumbCount property of the Image Thumbnail control. Sets up another Image Thumbnail control to serve as a trash bin by setting its ThumbWidth and ThumbHeight properties to the desired dimensions, and its Image property to a bitmap of a trash bin.
130
Sub Form_Load() strPathName As String strTemp As String strRightChar As String, strLeftChar As String intRPosition As Integer
'Invoke the ShowFileDialog box ImgAdmin1.ShowFileDialog OpenDlg End If 'Display an error message if the image file is not TIFF If ImgAdmin1.FileType <> 1 Then GoTo File_EH Else 'Set the Image property of the Thumbnail control. ImgThumbnail.Image = ImgAdmin1.Image 'Get the path of the application strPathName = App.Path 'Display a thumbnail for each image page in the file ImgThumbnail.DisplayThumbs 'Set AutoSelect to true to enable drag and drop, and 'EnableDragDrop to DropFilesDropDragLeftRight (literal 15) ImgThumbnail.AutoSelect = True ImgThumbnail.EnableDragDrop = 15 'Get the thumbnail page count mlngThumbCount = ImgThumbnail.ThumbCount 'Set up an Image Thumbnail control as a trash bin 'to provide a way to delete pages ImgThumbnailTrash.ThumbWidth = 50 ImgThumbnailTrash.ThumbHeight = 50 ImgThumbnailTrash.Image = strPathName + "\trashbin.bmp" . . . End Sub
In the Insert Page text box, enter the number of the page you want to insert before another page in the file. Then in the Before Page text box, enter the number of the page you want the Insert page to appear before.
131
Chapter 4
For example, to insert page 4 before page 2, enter 4 in the Insert Page text box and 2 in the Before Page text box. Click the Execute button. The cmdExecute_Click() event procedure fires and executes its code. The procedure performs the following actions:
Gets the complete path and file name of the current image file from the Image property of the Image Thumbnail control and assigns it to the strName local variable. Gets the Insert page number from the Insert Page text box and assigns it to the lngInsertPage local variable. Gets the Insert Before page from the Before Page text box and assigns it to the lngInsertBeforePage local variable. Invokes the Insert method of the Image Admin control, passing to it the: Path and file name of the current image file (from strName). Insert Page number (from lngInsertPage). Insert Before page number (from lngInsertBeforePage). 1 (which specifies the number of pages to insert). The Insert method inserts a copy of the Insert page before the Insert Before page in the current image file.
Note: You must call the Insert method of the Image Admin control before calling the InsertThumbs method of the Image Thumbnail control.
Invokes the InsertThumbs method of the Image Thumbnail control, passing to it the:
Insert Before page number (from lngInsertBeforePage). 1 (which specifies the number of pages to insert).
The InsertThumbs method refreshes the control. Were you to set a breakpoint after invoking this method, youd see two copies of the Insert page in the Image Thumbnail control. Determines the page number of the unwanted, leftover copy of the image page (from the value of lngInsertPage) so it can be deleted from the file. If the unwanted page is after the Insert Before page, the procedure increments lngInsertPage by one to delete the correct page.
132
Invokes the DeletePages method of the Image Admin control, passing to it the: Number of the page to delete (from lngInsertPage). 1 (which specifies the number of pages to delete). The DeletePages method deletes the unwanted, leftover copy of the image page from the file.
Note: You must call the DeletePages method of the Image Admin control before calling the DeleteThumbs method of the Image Thumbnail control.
Invokes the DeleteThumbs method of the Image Thumbnail control, passing to it the: Number of the page to delete (from lngInsertPage). 1 (which specifies the number of pages to delete). The DeleteThumbs method refreshes the control without the unwanted page.
133
Chapter 4
'Get the path and file name of the displayed image strName = ImgThumbnail.Image 'Get the Insert page and the Insert Before page lngInsertPage = CLng(txtInsertPage.Text) lngInsertBeforePage = CLng(txtInsertBeforePage.Text) 'Check to see if the Insert page is to be inserted 'before itself. If it is, abort processing. If lngInsertPage = lngInsertBeforePage Or lngInsertPage = lngInsertBeforePage - 1 Then Exit Sub End If 'Place the Insert page before the Insert Before page in the current 'image file ImgAdmin1.Insert strName, lngInsertPage, lngInsertBeforePage, 1 'Refresh the Image Thumbnail control to display the reordered 'image file ImgThumbnail.InsertThumbs lngInsertBeforePage, 1 'Delete the "leftover" page If strName = ImgThumbnail.Image Then 'If the InsertPage number is greater than the Insert Before 'number, increment the lngInsertPage variable by 1 to set 'the appropriate page for deletion If lngInsertPage > lngInsertBeforePage Then lngInsertPage = lngInsertPage + 1 End If 'Delete the "leftover" page from the image file and the Image 'Thumbnail control ImgAdmin1.DeletePages lngInsertPage, 1 ImgThumbnail.DeleteThumbs lngInsertPage, 1 End If End Sub
134
You can select multiple thumbnails by holding down the Shift or Ctrl keys.
Private Sub ImgThumbnail_MouseDown(ByVal Button As Integer, _ ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single, _ ByVal ThumbNumberAs Long) 'Invoke the Drag operation ImgThumbnail.Drag End Sub
Note:
As an alternative, you can point to an image file in Explorer and then hold down the left mouse button.
Next, drag the thumbnail (or image file) to the desired position and release the left mouse button. The ThumbDrop() event procedure of the Image Thumbnail control fires and performs the following actions:
Gets the complete source path and file name from the ThumbDropNames property of the Image Thumbnail control for each image page being inserted and assigns it to the strName local variable. If youre dragging and dropping pages within the current image file, the ThumbDropNames property returns the path and file name of the displayed image file. If youre dragging and dropping pages from Explorer, the ThumbDropNames property returns the path and file name of the source image file. Gets the Insert page number from the ThumbDropPages property of the Image Thumbnail control for each image page being inserted, and assigns it to the lngInsertPage local variable.
135
Chapter 4
Invokes the Insert method of the Image Admin control, passing to it the: Path and file name of the current image file (from strName). Insert Page number (from lngInsertPage). Insert Before page number (from the InsertBefore argument of the ThumbDrop() event). 1 (which specifies the number of pages to insert). The Insert method inserts a copy of the Insert page before the Insert Before page in the current image file.
Note: You must call the Insert method of the Image Admin control before calling the InsertThumbs method of the Image Thumbnail control.
Invokes the InsertThumbs method of the Image Thumbnail control, passing to it the: Insert Before page number (from InsertBefore). 1 (which specifies the number of pages to insert). The InsertThumbs method refreshes the control. As in the previous section, were you to set a breakpoint after invoking this method, youd see two copies of the Insert page in the Image Thumbnail control. Determines the page number of the unwanted, leftover copy of the image page (from the value of lngInsertPage) so it can be deleted from the file. If the unwanted page is after the Insert Before page, the procedure increments lngInsertPage by one to delete the correct page. Invokes the DeletePages method of the Image Admin control, passing to it the: Number of the page to delete (from lngInsertPage). 1 (which specifies the number of pages to delete). The DeletePages method deletes the unwanted, leftover copy of the image page from the file.
Note: You must call the DeletePages method of the Image Admin control before calling the DeleteThumbs method of the Image Thumbnail control.
136
Invokes the DeleteThumbs method of the Image Thumbnail control, passing to it the: Number of the page to delete (from lngInsertPage). 1 (which specifies the number of pages to delete). The DeleteThumbs method refreshes the control without the unwanted page.
137
Chapter 4
Private Sub ImgThumbnail_ThumbDrop(ByVal InsertBefore As Long, _ ByVal DropCount As Long, ByVal Shift As Integer) Dim X As Integer Dim strName As String Dim lngInsertPage As Long 'Move all selected pages or insert from Explorer For X = 0 To DropCount - 1 'Get the path and name of the file containing the Insert page strName = ImgThumbnail.ThumbDropNames(X) 'Get the Insert page lngInsertPage = ImgThumbnail.ThumbDropPages(X) 'Check to see if the Insert page is to be inserted 'before itself. If it is, abort processing. If strName = ImgThumbnail.Image Then If lngInsertPage = InsertBefore Or lngInsertPage = InsertBefore - 1 Then Exit Sub End If End If 'Place the Insert page before the Insert Before page in the image file ImgAdmin1.Insert strName, lngInsertPage, InsertBefore, 1 'Refresh the Image Thumbnail control to display the reordered image file ImgThumbnail.InsertThumbs InsertBefore, 1 'Delete the "leftover" page If strName = ImgThumbnail.Image Then 'If the InsertPage number is greater than the Insert Before 'number, increment the lngInsertPage variable by 1 to set 'the appropriate page for deletion If lngInsertPage > InsertBefore Then lngInsertPage = lngInsertPage + 1 End If 'Delete the "leftover" page from the image file and the Image 'Thumbnail control ImgAdmin1.DeletePages lngInsertPage, 1 ImgThumbnail.DeleteThumbs lngInsertPage, 1 End If Next X End Sub
138
You can select multiple thumbnails by holding down the Shift or Ctrl keys.
Private Sub ImgThumbnail_MouseDown(ByVal Button As Integer, _ ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single, _ ByVal ThumbNumber As Long) 'Invoke the Drag operation ImgThumbnail.Drag End Sub
Next, drag the thumbnail to the Image Thumbnail control resembling a trash bin and release the left mouse button. The ThumbDrop() event procedure of the Image Thumbnail (trash bin) control fires and performs the following actions for each selected page in the For...Next loop:
Note: The DropCount argument of the ThumbDrop() event provides the array-maximum value. Subtracting 1 from DropCount is required because the For...Next loop is 0-relative.
Gets the complete path and file name from the ThumbDropNames property of the Image Thumbnail control for each image page being deleted and assigns it to the strName local variable. Gets the Delete page number from the ThumbDropPages property of the Image Thumbnail control for each image page being deleted and assigns it to the lngDeletePage local variable. Makes sure that only pages from the current image file are deleted by comparing the value returned by the Image property of the source Image Thumbnail control to the value returned by the ThumbDropNames property of the destination Image Thumbnail (trash bin) control (from strName). If the path and file name values dont match, the event procedure is exited. This action prevents using the Thumbnail Sorter to delete image files from Windows Explorer.
139
Chapter 4
Invokes the DeletePages method of the Image Admin control, passing to it the: Number of the page to delete (from lngDeletePage-X). 1 (which specifies the number of pages to delete). The DeletePages method deletes the image page from the file.
Note: You must call the DeletePages method of the Image Admin control before calling the DeleteThumbs method of the Image Thumbnail control.
Invokes the DeleteThumbs method of the source Image Thumbnail control, passing to it the: Number of the page to delete (from lngDeletePage-X). 1 (which specifies the number of pages to delete). The DeleteThumbs method refreshes the control without the deleted page.
140
141
Chapter 4
142
The following table describes the multipage support provided by the file types that the Imaging software can read and read/write.
Multipage Support By File Type File Type Supports Multiple Pages? Read/Write Status
Read/Write Read Only Read Only Read/Write Read Only Read/Write Read Only Read Only
143
Chapter 4
The following list briefly describes the properties and methods youll find useful when working with multipage image documents.
Image Admin
PageCount property Returns the number of pages in an image file. PageNumber property Returns or sets a page number in an image file. PageType property Returns the page type also known as the color type or data type of a specified page. Append method Adds one or more pages to an image file. DeletePages method Deletes a range of pages from an image file. Replace method Replaces one or more pages in an image file.
Image Edit
Page property Returns or sets the page number of an image file where an imaging action was or will be performed. PageCount property Returns the number of pages in the displayed image file. PageType property Returns the page type of the image specified in the Image property and the page specified in the Page property of the Image Edit control. ConvertPageType method Converts a displayed image page to a specific page type. SavePage method Saves the displayed image page to the path and file name specified.
144
Image Scan
MultiPage property Determines whether multiple image pages will be scanned to an image file. Page property Returns or sets the starting page for a scanning session. PageCount property Returns or sets the number of pages scanned per image file. Works in conjunction with the MultiPage property to determine how many pages are scanned to how many files. (Refer to the PageCount and Multipage Property Influence table earlier in this chapter for more information.) PageOption property Returns or sets whether a page will be appended, inserted, or overwritten during a scanning session. ShowScanPage method Displays the Scan Page dialog box, which lets users scan a page into an image file.
Image Thumbnail
FirstSelectedThumb property Returns the page number of the first selected thumbnail. LastSelectedThumb property Returns the page number of the last selected thumbnail. SelectedThumbCount property Returns the number of thumbnails currently selected. ThumbCount property Returns the total number of pages in the current image file. ThumbDropNames property Returns the file name(s) of image pages dropped on the Thumbnail control. ThumbDropPages property Returns a list of pages for the file name(s) dropped on the Thumbnail control. ThumbSelected property Returns or sets the selection status of a specified thumbnail. DeleteThumbs method Refreshes the Thumbnail control without the image pages that have been deleted from an image file.
145
Chapter 4
GetManualThumbPage method Returns the page within the image file corresponding to the thumbnail array subscript. InsertThumbs method Refreshes the Thumbnail control with the image pages that have been inserted into the current image file.
Example
Users of your application may want to unload a multipage image file when the individual pages have no logical relationship to each other or when the individual pages need to be routed to different people. Scenario As described in an earlier scenario, Chris regularly reviews large multipage fax files as part of his job. Sometimes Chris encounters pages that contain memos, letters, or forms that are of interest to different people but have no relationship with the remainder of the file. Using your application, Chris can quickly unload these pages and save them to disk as individual image files or send them to the appropriate people via e-mail if you have included e-mail support in your application.
146
Unload Project
The Unload project demonstrates unloading the pages of a multipage image file and saving them to disk as a series of single-page image files.
The file name for the Unload project is Unload.vbp.
One Image Admin control One Image Edit control Two Command button controls
One list box control And it uses the following methods of the Image Admin control to provide the unload functions: Append To create the individual image files. Delete To remove existing image files. VerifyImage To see if an image file already exists.
Unloading an Image File Start the Unload project. The Form_Activate() event procedure displays an Open dialog box to let you select the TIFF image file you want to unload. Be sure to select a multipage image file. After you select the image file, the Unload form appears.
147
Chapter 4
To unload the image file, click the Unload button. The cmdUnload_Click() event procedure fires and executes its code. The procedure begins by setting two local string variables to the path and file name of the multipage image file you selected (the source file). The strSourceFile variable will retain the path and file name throughout the procedure. The strPrefix variable will be gradually parsed until it contains only the first three letters of the source image file name becoming a prefix of the destination file names. The procedure continues by obtaining the number of image pages in the source file from the PageCount property of the Image Edit control, assigning it to the intPageCount local variable. It also obtains the current path, assigning it to the strCurrentPath local variable. It is into this path that the individual destination file names will be written. Next, the procedure parses the strPrefix variable until it consists of a three-character prefix: First, it gets rid of the path information. Second, it gets rid of all of the remaining characters including the file extension, which is assigned to the strExt variable for later use. Before building the individual (Unloaded) file names, the procedure appends a slash to the current path variable, strCurrentPath.
With all of these preliminaries out of the way, the procedure is now ready to build the Unloaded file names. A For...Next statement executes for each page in the image file starting at 1 and continuing until it exceeds the maximum number of pages in the image file (from intPageCount). For each iteration of the For...Next loop, the procedure concatenates the following six items to build an Unloaded path and file name, which it assigns to the strUnloadedFileName local variable (the examples assume a source path and file name of c:\Images\Faxes.tif):
148
The procedure invokes the VerifyImage method with a parameter value of 0 (Verify Existence). Other parameter values let you check an image files read/write attributes.
149
Chapter 4
Private Dim Dim Dim Dim Dim Dim Sub cmdUnload_Click() intPageCount As Integer, intPageNumber As Integer intSlashPos As Integer, intDotPos As Integer intVerifyExistence As Integer strPrefix As String, strCurrentPath As String strSourceFile As String, strUnloadedFileName As String strExt As String, strPageNum As String
'Get the path and file name of the source file strSourceFile = ImgEdit1.Image strPrefix = ImgEdit1.Image 'Get the number of pages in the source file intPageCount = ImgEdit1.PageCount 'Get the current path strCurrentPath = CurDir 'Establish an appropriate prefix for the Unloaded file names intSlashPos = 7 'First, eliminate the characters to the left of the slashes Do While intSlashPos <> 0 intSlashPos = InStr(1, strPrefix, "\", 1) strPrefix = Right(strPrefix, Len(strPrefix) - intSlashPos) Loop 'Second, eliminate the characters to the right of the dot intDotPos = InStr(1, strPrefix, ".", 1) strExt = Right(strPrefix, Len(strPrefix) - intDotPos) If intDotPos > 4 Then strPrefix = Left(strPrefix, 3) Else strPrefix = Left(strPrefix, intDotPos - 1) End If 'Append a slash to the current path specification intSlashPos = InStr(1, strCurrentPath, "\", 1) If intSlashPos <> Len(strCurrentPath) Then strCurrentPath = strCurrentPath + "\" End If (Continued next page)
150
151
Chapter 4
152
5
Developing Client/Server Applications
This chapter explains how to use the Imaging ActiveX controls to develop applications that can access and interact with WMS Imaging Server (1.x) and WMS Imaging and Workflow (WMS) servers. It also explains how to add zoom and annotation functions to your applications. Even if you are not going to include Imaging server access in your applications, youll find the sections on these functions useful.
In This Chapter
Imaging Server Concepts ........................................................... 154 Imaging 1.x Server Programming Considerations ....................... 157 WMS Server Programming Considerations ................................. 173 Demonstration Project ............................................................... 176
Chapter 5
Using the Imaging ActiveX controls, you can develop applications that can access and interact with both WMS Imaging Server (1.x) and WMS Imaging and Workflow (WMS) servers. Using the controls, you can enable your users to:
Read and display image files and server documents from Imaging 1.x servers. Write image files and documents to Imaging 1.x servers. Read and display documents from WMS Imaging servers. Save 1.x image files and server documents and WMS Imaging documents to local and network drives.
Note: To use the Imaging ActiveX controls with Imaging and Workflow servers, you and your users must install and configure Imaging Server Access when installing Imaging for Windows.
Before getting into the specifics, read the following sections that:
List the file types supported by each Imaging server. Describe the standard, server-related dialog boxes available with the Imaging ActiveX controls. Explain the difference between image files and server documents. Describe how your program can interact with each Imaging server.
Note: Because a wide-ranging discussion of each Imaging server is beyond the scope of this chapter, you should also review the documentation that came with the server you and your users use.
154
Imaging 1.x
TIFF 6.0 BMP DCX (read only) GIF (read only) JPG-JFIF PCX (read only) WIFF (read only) XIF (read only)
WMS Imaging
Log onto the desired server either Imaging 1.x or WMS Imaging. Set Imaging 1.x server options. Browse for Imaging 1.x file and document volumes. Browse the Imaging 1.x file and document volumes for files and documents to open. Query Imaging 1.x document volumes by document name, location, creation date, modification date, or keywords to locate documents to open. Query WMS Imaging and Workflow servers by document name or field values to locate documents to open. Save 1.x image files, 1.x documents, and WMS Imaging documents to an Imaging 1.x file volume, an Imaging 1.x document volume, or a local or network drive, respectively.
155
Chapter 5
Document Volume
Formerly known as a document manager database, a document volume is where server documents are stored. A document volume does not contain the actual image files, only references to the files in the file repository. Server documents are stored using a familiar hierarchy. Documents are stored within a Folder; Folders are stored within a Drawer; and Drawers are stored within a Cabinet; using the following format:
Image://server/doc volume:\cabinet\drawer\folder\doc
156
Several properties and methods in the Imaging ActiveX controls let you provide Imaging 1.x server access functions to your end users. Specifically, they permit your users to: Log onto the server. Set server options. Browse for Imaging 1.x file and document volumes. Browse the Imaging 1.x file and document volumes for files and documents to open. Query Imaging 1.x document volumes by document name, location, creation date, modification date, or keywords to locate documents to open. Save 1.x image files and server documents to Imaging 1.x file or document volumes or to local or network drives. The following sections describe each function in detail by pointing out the properties and methods you can use.
In your call to the LoginToServer method, you can optionally display the standard Server Login dialog box, which permits users to enter their user name and password and then click OK to log onto the server.
157
Chapter 5
The Username text box can accommodate up to 20 alphanumeric characters; the Password text box can contain up to 36 alphanumeric characters. You can also bypass the dialog box and simply pass the user name and password as parameters to the LoginToServer method, most likely in response to a user completing and closing a logon dialog box of your own design. If a user is not logged on and attempts to access the server, the Imaging software displays the standard Server Login dialog box automatically thereby prompting the user to log onto the server.
The Image Admin control also provides a LogOffServer method that lets you programmatically log your users off an Imaging 1.x server.
158
When users click OK on the Imaging Server Options dialog box, the Image Adman control sets several of its server-related properties to values that correspond to the selections made on the dialog box. The following table lists the properties set.
Imaging 1.x Server-Related Properties Set By the Server Options Dialog Box Image Admin Property Set Associated Field on Dialog Box Value Property Contains
FileStgLoc1x
The path to the file repository, where your program stores new or copied image files that comprise server documents. True or False Indicating whether paths and file names are converted to lower case before being passed to the Imaging 1.x server.
ForceLowerCase1x
159
Chapter 5
Imaging 1.x Server-Related Properties Set By the Server Options Dialog Box (continued) Image Admin Property Set Associated Field on Dialog Box Value Property Contains
ForceFileLinking1x
True or False Indicating whether pages being added to an Imaging 1.x document from an existing 1.x image file are linked (True) or copied (False). True or False Indicating whether the file referenced by an Imaging 1x server document page is deleted when the document page is deleted.
ForceFileDeletion1x
If desired, you can set these properties in advance to present default dialog box settings to your users. You can also bypass the standard dialog box and set these properties within your code most likely in response to a user completing and closing a server options dialog box of your own design.
160
Note:
Update List of Server Volumes There are no properties or methods associated with the Update list of server volumes automatically check box or the Update Now button on the Server Options dialog box. Both invoke a facility that updates the list of server volumes in the current domain. Users can access this list by clicking the Browse button on the dialog box. They use the list to locate and enter the desired file location for document pages. Hide Server File Volumes Likewise, there are no properties or methods associated with the Hide server volume files check box. This check box specifies whether Imaging 1.x server file volumes are displayed or hidden on the Open dialog box, which you can display by invoking the ShowFileDialog method of the Image Admin control. Hiding server file volumes is useful when users only want to browse server document volumes. Invoke the Show1xServerOptDlg method if you want to provide the Update List of Server Volumes function and the Hide Server File Volumes function to your end users.
The following sections explain each server option setting and related property in detail.
161
Chapter 5
Admin control. Each of these methods creates a new image file with a unique file name in the following situations:
When a page from a local or redirected file is being inserted, appended, or saved to an Imaging 1.x document. When the ForceFileLinking1x property is set to False and a page from an Imaging 1.x image file or document is being inserted, appended, replaced, or saved in another Imaging 1.x document.
162
Then to add pages to an Imaging 1.x document, use one of the following: the Append, Replace, or Insert method of the Image Admin control; the SaveAs or SavePages method of the Image Edit control; or the SaveAs method of the Image Thumbnail control. When you do, the value of the ForceFileLinking1x property and where the source image file resides determine the behavior of the Imaging software, as follows:
When the ForceFileLinking1x property is set to True and the source image file resides on an Imaging 1.x server, the Imaging software links the document to the source image file where the file resides on the server. When the ForceFileLinking1x property is set to False and the source image file resides on an Imaging 1.x server, the Imaging software copies the image file to the location specified within the FileStgLoc1x property. Then it links the document to the copied file. Regardless of the setting of the ForceFileLinking1x property, when the source image file resides outside of an Imaging 1.x server (for example, on a local or redirected drive), the Imaging software copies the image file to the location specified within the FileStgLoc1x property. Then it links the document to the copied file. When the SaveAs or SavePage method is used to save changes to an existing 1.x document page, the Imaging software replaces the original file page regardless of the setting of the ForceFileLinking1x property (unless the original file is write-protected).
163
Chapter 5
The Imaging software ignores the True setting of the ForceFile Linking1x property when two or more pages of a server document are linked to the same image file and not all of these pages have been deleted from the document. The Imaging software does not delete the linked image file because one or more pages in the document are still linked to the file.
Example
Assume a server document named Claims contains 5 pages and that pages 1 and 4 in the document are linked to the autoclaims.tif image file. Assume you delete page 1 of Claims. Even though the ForceFileDeletion1x property is set to True, the Imaging software does not delete autoclaims.tif . Why? Because the file contains the image that is still linked to page 4 of the Claims document.
Note: Keep in mind that the referential integrity behavior of the ForceFileDeletion1x property provides protection against inadvertently deleting image files that are referenced within the same document only. It provides no protection against deleting image files that are referenced within two or more documents.
164
Browse the server for image file or server document volumes, or Browse the server for image files and/or server documents.
165
Chapter 5
In your call to the Browse1x method, you can specify:
Whether to browse: File volumes By passing the BrowseFiles constant or a literal value of 0. Document volumes By passing the BrowseDocuments constant or a literal value of 1. Both file and document volumes By passing the
BrowseBoth constant or a literal value of 2.
A string that becomes the title bar caption of the dialog box (for example, Browse Imaging 1.x Server in the preceding figure). Another string that instructs the user to browse the server (for example, Select the desired path in the preceding figure). The handle to the parent window (optional). After users make their selection and click OK, the Imaging software writes the path selected to the Browse1xReturnedPath property of the Image Admin control.
Keep in mind that the Get VolumeType method of the Image Admin control lets you determine whether a specified Imaging 1.x volume is a file volume or a document volume.
The Imaging software also writes the type of volume selected to the Browse1xReturnedPathType property, which can contain one of the following integer values: 0 To indicate that users selected a file volume. 1 To indicate that users selected a document volume.
166
Invoke the ShowFileDialog method, therefore, whenever you want users to browse for and then select an Imaging 1.x file or server document they want to display. When users select 1.x Files and Documents from the Look for list box, they can use the Look in list box to browse the file and document volumes in the current domain, as illustrated in the following figure2
167
Chapter 5
Once users select the desired directory or folder, the area below the Look in box lists the files or documents contained within it, as illustrated in the following figure.
When users select the desired file or document and then click Open, the Imaging software writes the path and name of the file or document to the Image property of the Image Admin control. Use the Image property and the Display method of the Image Edit control and/or the Image property and the DisplayThumbs method of the Image Thumbnail control to display the image file or document. Refer to Chapter 4 for more information about displaying images and thumbnails as well as for more information about the ShowFileDialog method.
168
Prior to your call to the ShowFindDialog method, you can set the Init1xFindDir property of the Image Admin control to the name of the document volume you want to initially display in the Look in list box (as a default). If desired, you can also include a cabinet; cabinet and drawer; or cabinet, drawer, and folder. In your call to the ShowFindDialog method, you can specify the handle to the parent window. Doing so sets the state of the dialog box to application-modal; not doing so sets the state of the dialog box to modeless.
Note: Refer to the Imaging for Windows Getting Started Guide for instructions on how to use the Find Image Document dialog box to find Imaging 1.x documents.
Clicking the Find button on the Open dialog box (described in the previous section) also displays the Find Image Document dialog box.
169
Chapter 5
After users make their selection and click Open, the Imaging software writes the path and name of the document to the Image property of the Image Admin control.
Note: The Imaging software does not alter the value of the Init1xFindDir property.
The ImgQuery and ImgQueryEnd methods of the Image Admin control enable you to query a 1.x document volume programmatically. The Demonstration Project section of this chapter describes and demonstrates these methods.
Use the Image property and the Display method of the Image Edit control and/or the Image property and the DisplayThumbs method of the Image Thumbnail control to display the Imaging 1.x document. Refer to Chapter 4 for more information about displaying images and thumbnails and for more information about the ShowFindDialog method.
170
171
Chapter 5
Once users select the desired directory or folder, the area below the Look in box lists the files or documents contained within it, as illustrated in the following figure.
When users select or enter the name of the file or document and then click Save, the Imaging software writes the path and name of the file or document to the Image property of the Image Admin control. Use the Image property and the SaveAs or SavePage method of the Image Edit control to save the image file or server document.
172
Several properties and methods in the Imaging ActiveX controls let you provide WMS Imaging and Workflow server access functions to your end users. Specifically, they permit your users to:
Log onto the server. Query WMS Imaging and Workflow servers by document name as well as by Class and Index field values. The following sections describe each function in detail by pointing out the properties and methods you can use.
The Domain property is initialized to either an empty string or the name of the WMS Imaging and Workflow server last accessed.
The Username, Password, and Domain text boxes can contain up to 80 alphanumeric characters.
173
Chapter 5
You can also bypass the dialog box and simply pass the user name and password as parameters to the LoginToServer method, most likely in response to a user completing and closing a logon dialog box of your own design. If a user is not logged on and attempts to access the server, the Imaging software displays the standard Server Login dialog box automatically thereby prompting the user to log onto the server.
Note: If the unified logon facility is enabled on the WMS Imaging and Workflow server being accessed, there is no need to explicitly call the LoginToServer method. Each user will be logged on automatically using the Windows user name and password.
The Image Admin control also provides a LogOffServer method that lets you programmatically log your users off an WMS Imaging and Workflow server.
If users attempt to access WMS Imaging documents via the Open dialog box, the Imaging software prompts them to click the Find button to access the Find Image Document dialog box.
In your call to the ShowFindDialog method, you can specify the handle to the parent window. Doing so sets the state of the dialog box to application-modal; not doing so sets the state of the dialog box to modeless.
Note: Refer to the Imaging for Windows Getting Started Guide for instructions on how to use the Find Image Document dialog box to find WMS Imaging documents.
174
The ImgQuery and ImgQueryEnd methods of the Image Admin control enable you to query a WMS Imaging and Workflow server programmatically. The Demonstration Project section of this chapter describes and demonstrates these methods.
175
Chapter 5
Demonstration Project
This section demonstrates how to add Imaging 1.x server access functions to your image-enabled applications. While a wide-ranging discussion of Imaging server access functions is beyond the scope of this chapter, the information presented here is sufficient to get started. The demonstration project was developed using Microsoft Visual Basic. Even if you are not going to include Imaging Server Access in your applications, you will find the sections on adding zoom and annotation functions useful.
To help you use the Imaging ActiveX controls to interact with Imaging 1.x servers, a demonstration project called Image Server shows you how to:
Set server options. Browse for Imaging 1.x file and document volumes. Browse Imaging 1.x file and document volumes for files and documents to open. Query Imaging 1.x document volumes to locate documents to open. Zoom an image. Invoke the standard annotation tool palette. Show and hide annotations.
Note: The Imaging ActiveX Controls on-line help system identifies the properties, methods, events, parameters, and constants that are available in Imaging for Windows.
Before walking through the demonstration project, read the following sections, which explain the concepts of zooming an image and of working with annotations. Chapter 4 of this guide explains the concepts of displaying an image in the Image Edit control and of multipage image files.
176
Example
Users of your application may want control over the display of image documents to make them easy to read.
Scenario
As described in Chapter 4, Eileen receives several scanned business documents in her role as product manager for a major computer company. Because the documents contain important information, she really needs to be able to read them, which is why you included all of Image Edits fit-to options in the first version of your application. But now you realize that users like Eileen need even more control over how image files or documents are displayed. So, in the second version of your application, you include a wide range of zoom options in addition to the fit-to options provided earlier. Users can now select the fit-to or zoom option that produces the best display quality.
177
Chapter 5
Annotations Defined
The Image Edit and Image Annotation Tool Button controls provide several ways to add annotation functions to your image-enabled applications. Using them you can: Create an annotation tool palette of your own design. Invoke a single method that displays a fully-functional, standard annotation tool palette to your users. Implement custom annotations programmatically. The method you choose depends on the annotation requirements of your users.
Annotations are digitized versions of the marks or items commonly applied to paper-based documents; for example, highlighting, rubber stamps, lines, and post-it notes. People typically use annotations to emphasize important portions of documents or to add their comments to documents being circulated for review. Digital annotations go well beyond the capabilities of paper-based annotations. With digital annotations, users can: Add, move, and delete annotations at will. Modify their attributes such as color, size, text, and visibility. Use them to add hypertext links to other pages in the same file, to other files, and to pages on the World Wide Web. The following table lists the annotation types that are available with the Imaging ActiveX controls.
Enters text into a background rectangle on an image. Covers a portion of the image with a polygon that can be stretched to the desired size and shape. An auto polygon is text-aware, so if text is detected during creation, the text boundaries will be used to set the polygon boundaries. Because an Auto Polygon annotation starts with only two points, it is easy to create.
178
Filled Polygon
Covers a portion of an image with a polygon that can be stretched to the desired size and shape. Covers a portion of an imageHighlights text when drawn using the transparent line style. Draws a freehand line on a section of text or a portion of an image for emphasis. Places a polygon around an area of an image for emphasis. The polygon can be stretched to the desired size and shape. Places a border around areas of an image for emphasis. Enters a hypertext link directly on an image; invokes the Link To dialog box to permit end users to specify the desired link. Embeds an actual copy of another image in an image file. Includes another image in an image file by reference (that is, it links to an external file that contains the image). Places system-generated data onto the image including the initials of the user who is logged on, the date, and the time. Draws an OCR Text or Picture zone on an image. Selects annotation marks for deleting, modifying, moving, or resizing. Underlines text, demarcates a section of a page, or draws callout linesHighlights text when drawn using the transparent line style. Enters text directly on an image.
Initials
Text
179
Chapter 5
Imaging for Windows Annotation Types (continued) Annotation Type Description
Enters text from a file on an image. Places a text stamp directly on an image.
Users can save annotations separately from the image data within TIFF image files only. Users can also merge annotations with the image data in a process known as burning-in. To save annotations to any file type other than TIFF, the annotations must be burned-in.
When using a Filled Rectangle annotation to redact images, make sure that your users select the opaque fill style and that they burn-in the annotation to cover the image permanently.
Discrete annotation types; for example, a Freehand Line annotation type and a Rubber Stamp annotation type. The same annotation type with different annotation styles; for example, two buttons that each invoke an Attach-a-Note annotation one with a yellow background and black text, the other with a red background and white text. A combination of both.
The Image Edit control shares several properties and one method with the Image Annotation Tool Button control. Together they let you manage annotation functions when creating a tool bar or palette of your own design. Refer to the next section for more information.
180
You can invoke the ShowAnnotationToolPalette method to display the standard annotation tool palette to your users. The following illustration lists the annotation types the tool palette provides.
Select Annotations and Zones Highlighter Hollow Rectangle Hollow Polygon Auto Polygon Hyperlink Text From File Initials
Freehand Line Straight Line Filled Rectangle Filled Polygon Text Attach-a-Note Rubber Stamp
Once displayed, users can right-click a button on the tool palette to set an annotations properties. Then they can left-click the button to draw the annotation.
Note: The Highlighter annotation is actually a Filled Rectangle annotation with its transparent property selected and its background color property set to yellow.
Programmatic Annotations
The Image Edit control also has an array of properties, methods, and events that enable you to add annotation functions to your applications programmatically. The properties, methods, and events also let you and your users edit and manage existing annotations whether they were drawn programmatically, drawn using the Image Annotation Tool Button control, or drawn using the standard annotation tool palette. The remainder of this section briefly describes the properties, methods, and events of the Image Edit and Image Annotation Tool Button controls youll find useful when adding annotation functions to your applications.
181
Chapter 5
Properties, Methods, and Events of Both the Image Edit Control and the Image Annotation Tool Button Control
AnnotationBackColor property Returns or sets the background color of an Attach-a-Note annotation. AnnotationFillColor property Returns or sets the color used to fill a Filled Rectangle, Filled Polygon, or Auto Polygon annotation. AnnotationFillStyle property Returns or sets the pattern used to fill Image Embedded, Image Reference, and Filled Polygon, Auto Polygon, or Filled Rectangle annotations. AnnotationFont property Returns or sets font object properties for all text-related annotation types. AnnotationFontColor property Returns or sets the font color for all text-related annotation types. AnnotationImage property Returns or sets the fully-qualified file name of the image file used in Image Embedded and Image Reference annotations. AnnotationLineColor property Returns or sets the line color for Straight Line, Freehand Line, and Hollow Polygon, and Hollow Rectangle annotations. AnnotationLineStyle property Returns or sets the line style for Straight Line, Freehand Line, Hollow Polygon, and Hollow Rectangle annotations. AnnotationLineWidth property Returns or sets the line width for Straight Line, Freehand Line, Hollow Polygon, and Hollow Rectangle annotations. AnnotationStampText property Returns or sets the stamp text to be placed on an image by the Text Stamp annotation type. The stamp text can consist of text, text macros (like the current date and time), or a combination of both. AnnotationTextFile property Returns or sets the fully-qualified file name of the text file to be placed on an image by the Text From File annotation type. AnnotationType property Returns or sets the type of annotation to draw. Draw method Draws the annotation.
182
AnnotationGroupCount property Returns the number of annotation groups that are on an image page. AnnotationOcrType property Returns or sets the type of OCR zone to be drawn on an image page. OcrZoneVisibility property Determines the visibility of OCR zones on the image page. AddAnnotationGroup method Adds a new annotation group to an image page. BurnInAnnotations method Burns annotations onto an image page, permanently incorporating them into the image.
Use the BurnInAnnotations method with care because once annotations are burnedin, they cannot be removed or modified as annotation data.
DeleteAnnotationGroup method Deletes an annotation group and its associated annotations, and then redisplays the image. DeleteSelectedAnnotations method Deletes selected annotations from an image page. EditSelectedAnnotationText method Displays a dialog box that lets end users modify Text, Attach-a-Note, and Hyperlink annotations.
The EditSelected AnnotationText method is very useful. It enables users to modify text annotations. You should consider using it whether users draw annotations from the standard annotation tool palette, a tool palette of your own design, or from functions you provide programmatically. For non-text annotations, use the ShowAttribs Dialog method. It enables users to modify non-text annotations.
ExecuteTextEditCommand method Executes commands on the Text Edit dialog box when the Image Edit control is operating in the Text Edit mode (which is invoked using the EditSelected AnnotationText method). EditingTextAnnotation event Fires immediately after the Image Edit control enters or exits the Text Edit mode. GetAnnotationGroup method Returns the name of the annotation group based on the index specified. GetAnnotationMarkCount method Returns the number of annotation marks on an image page or in an annotation group. GetCurrentAnnotationGroup method Returns the name of the annotation group to which subsequent annotations will belong. GetRubberStampItem method Returns the item number of the currently selected rubber stamp according to its position on the Rubber Stamp Properties dialog box and in the shortcut menu of the standard annotation tool palette.
183
Chapter 5
SetRubberStampItem method Sets the item number for a rubber stamp annotation according to its position on the Rubber Stamp Properties dialog box and in the shortcut menu of the standard annotation tool palette. It also activates the Rubber Stamp annotation type. GetRubberStampMenuItems method Returns the menu items of the Rubber Stamp tool on the standard annotation tool palette. ShowRubberStampDialog method Shows the Rubber Stamp Properties dialog box, which permits end users to create, delete, and edit rubber stamp annotation properties. GetSelectedAnnotationBackColor method Returns the background color of a selected Attach-a-Note annotation. SetSelectedAnnotationBackColor method Sets the background color of a selected Attach-a-Note annotation. GetSelectedAnnotationFillColor method Returns the color used to fill a selected Filled Rectangle annotation. SetSelectedAnnotationFillColor method Sets the color used to fill a selected Auto Polygon, Filled Polygon, or Filled Rectangle annotation. GetSelectedAnnotationFillStyle method Returns the style used to fill selected Image Embedded, Image Reference, Auto Polygon, Filled Polygon, and Filled Rectangle annotations. SetSelectedAnnotationFillStyle method Sets the style used to fill selected Image Embedded, Image Reference, Auto Polygon, Filled Polygon, and Filled Rectangle annotations. GetSelectedAnnotationFont method Returns font object properties for selected text-related annotation types. SetSelectedAnnotationFont method Sets font object properties for selected text-related annotation types. GetSelectedAnnotationFontColor method Returns the font color used in selected text-related annotation types. SetSelectedAnnotationFontColor method Sets the font color to use in selected text-related annotation types. GetSelectedAnnotationImage method Returns the fullyqualified file name of the image being used in selected Image Embedded and Image Reference annotations.
184
185
Chapter 5
LoadAnnotations method Loads annotations from a data file and places them on the specified page(s) of the displayed image file. SaveAnnotations method Saves annotations from the specified page(s) of the displayed image file to a data file. RemoveAllOCRMarks method Removes OCR zones from all image pages in the displayed image document. SelectAnnotationGroup method Selects all annotation marks within a specific annotation group on an image page. SelectFirstOcrZone method Selects the first OCR zone on the displayed image page. SelectNextOcrZone method Selects the next OCR zone on the displayed image page. SetCurrentAnnotationGroup method Sets the annotation group to which subsequent annotations will belong. ShowAttribsDialog method Shows an annotation attributes dialog box, which lets end users change the properties of a selected annotation mark. HyperlinkGoToDoc event Fires when users click a Hyperlink annotation that is linked to a page in an external image file. HyperlinkGoToPage event Fires when users click a Hyperlink annotation that is linked to a page within the current image file. MarkEnd event Fires immediately after the user or the program completes the drawing of an annotation mark. MarkMove event Fires immediately after the user or the program moves or resizes an annotation mark. MarkSelect event Fires immediately after the user or the program selects an annotation mark. ToolTip event Fires immediately after a tool tip is displayed on the standard annotation tool palette.
The ShowAttribsDialog method is very useful. It enables users to edit existing non-text annotations. You should consider using it whether users draw annotations from the standard annotation tool palette, a tool palette of your own design, or from functions you provide programmatically. For text annotations, use the EditSelectedAnnotationText method. It enables users to modify text annotations.
186
Example
Users of your application may want to annotate image files with important comments. They may also want to link image pages to related Web pages.
Scenario
Kim manages a QA (quality assurance) group in a software company that produces applications for engineer-to-order manufacturing firms around the world. Some of the development and testing of the applications is performed in the United States, the remainder is performed in Ireland. As part of their jobs, Kim and her staff regularly distribute and peerreview scanned specification and test plan documents. Because the QA group is spread across two continents, each analyst relies on e-mail exclusively to exchange the image documents. Because you included e-mail and image annotation functions in your program, Kim and her staff can use it to retrieve, annotate, and send the image documents. Analysts use its text-related annotation types to enter their review comments directly on the documents. And they use its Hyperlink annotation type to link their comments to related reference pages on the companys intranet site.
Setting server options. Browsing for Imaging 1.x file and document volumes. Browsing Imaging 1.x file and document volumes for files and documents to open. Querying Imaging 1.x document volumes for documents to open. Zooming an image. Invoking the standard annotation tool palette. Showing and hiding annotations. The project consists of the following forms and modules:
frmMain Lets users open image files that reside on their PCs or image files and server documents that reside on Imaging 1.x servers. It also lets users browse Imaging 1.x servers for file or document volumes, as well as zoom and annotate the image files or documents they open.
187
Chapter 5
frm1xCDFD Enables users to query an Imaging 1.x document volume for documents by location, using the following hierarchy:
Cabinet\Drawer\Folder\Document
frm1xQuery Enables users to query an Imaging 1.x document volume for documents by name, creation date, modification date, or keyword. The project uses the following Imaging controls: One Image Admin control One Image Edit control It uses the following methods of the Image Admin control to provide setup, open, browse, and query functions:
Show1xServerOptDlg method To display the Imaging Server Options dialog box, which lets users set Imaging 1.x server options. ShowFileDialog method To display the Open dialog box, which lets users select the image files or server documents they want to open. Browse1x method To display the Browse 1.x dialog box, which lets users browse the Imaging 1.x server for server file and/or document volumes. CreateDirectory method To create a cabinet, drawer, and/or folder. ConvertDate method To convert conventional (Gregorian) dates to Julian dates when using the ImgQuery method to query 1.x document volumes. ImgQuery method To query Imaging 1.x document volumes. ImgQueryEnd method To complete a query and free associated resources. And it uses the following methods in the Image Edit control to provide the image display and annotation functions: Display method To display the image file or server document specified in the Image property of the Image Edit control. Refresh method To redisplay the current image in the Image Edit control. ShowAnnotationToolPalette method To show the standard annotation tool palette. HideAnnotationToolPalette method To hide the standard annotation tool palette.
188
189
Chapter 5
Index = 2 passes the BrowseFiles constant (literal 0). Index = 3 passes the BrowseDocuments constant (literal 1). Index = 4 passes the BrowseBoth constant (literal 2).
Title parameter Determines the text that appears in the title bar of the Browse1.x dialog box:
Index = 2 passes Browse 1.x File Volumes. Index = 3 passes Browse 1.x Document Volumes. Index = 4 passes Browse 1.x File and Document
Volumes.
Caption parameter Determines the prompt that appears in the title bar of the Browse 1.x dialog box. Each invocation of the Browse1.x method passes Select the Desired Path. hParentWnd parameter Assigns a parent window handle to the Browse 1.x dialog box. Each invocation of the Browse1.x method passes frmMain.hWnd, which is the handle to the main form. The Browse1x method displays the Browse 1.x dialog box described in the Browsing for Volumes section of this chapter.
When the user clicks Cancel, a Cancel is pressed error condition occurs. The mnuServerItem_Click() event shows you how to handle it.
Browse the file and/or document volumes. Then make your selection and click OK. The Imaging software writes the path selected to the Browse1xReturnedPath property of the Image Admin control and the type of path selected to the Browse1xReturnedType property.
190
191
Chapter 5
When the user clicks Cancel, a Cancel is pressed error condition occurs. The mnuFileOpen_Click() event shows you how to handle it.
192
193
Chapter 5
To query an Imaging 1.x database, on the Server menu, click: 1.x Query by Cabinet\Drawer\Folder\Document To query 1.x document manager databases by Cabinet, Drawer, Folder, and Document. 1.x Query To query 1.x document manager databases by document name, date, or keyword. The following sections discuss each type of query.
Performing a 1.x Query by Cabinet\Drawer\Folder\Document
After you make your menu selection, the 1.x Cabinet\Drawer\ Folder\Document window (frm1.xCDFD) loads without being shown. Its Form_Load() event procedure (shown in the following code snippet) invokes the ImgQueryEnd method of the Image Admin control to clear any previous Imaging queries and to free associated system resources. Next, the procedure invokes the ImgQuery method to initiate a new query, passing to it the following parameters:
Refer to the on-line help for more information about the ImgQuery method of the Image Admin control.
vScope parameter Constant DMVOLUMES (literal 1), which sets the method so it performs a query for Imaging 1.x document manager databases. szQueryTerms parameter A blank string, which makes the method return the available Imaging 1.x databases. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. You can extract the results of a query by using a For Each...Next statement in the following format:
For Each VariantItem In objResults ' Your code that processes each VariantItem Next VariantItem
The query finds the available Imaging 1.x databases. Then the Form_Load() event procedure loads them from the objResults
194
Showing the 1.x Cabinet\Drawer\Folder\Document window. Displaying the number of document manager databases found. Giving focus to the Document Manager combo box.
195
Chapter 5
Private Sub Form_Load() Dim objResults As Object Dim strSinglePlural As String Dim vntItem As Variant . . . '-------------------------------------------------------------------------' Perform an ImgQuery for all Document Manager databases. '-------------------------------------------------------------------------ImgAdmin1.ImgQueryEnd ImgAdmin1.ImgQuery "DMVOLUMES", "", objResults '-------------------------------------------------------------------------' If an error occurred, display a message box and exit. '-------------------------------------------------------------------------If ImgAdmin1.StatusCode <> 0 Then MsgBox Err.Description & " (ImgAdmin error " & _ Hex(ImgAdmin1.StatusCode) & ")", vbCritical Exit Sub End If '-------------------------------------------------------------------------' Store the results in the cboDocManager combo box. '-------------------------------------------------------------------------For Each vntItem In objResults If vntItem <> "" Then cboDocManager.AddItem vntItem End If Next vntItem '-------------------------------------------------------------------------' End the query. '-------------------------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd '-------------------------------------------------------------------------' Display the number of Document Managers found. '-------------------------------------------------------------------------If cboDocManager.ListCount = 1 Then strSinglePlural = " Document Manager:" Else strSinglePlural = " Document Managers:" End If lblDocumentManager.Caption = cboDocManager.ListCount & strSinglePlural '-------------------------------------------------------------------------' Show the form, set focus to cboDocManager. '-------------------------------------------------------------------------Me.Show cboDocManager.SetFocus End Sub
196
Once you select a document manager database, you can create a new cabinet, drawer, and/or folder by entering the names in the respective combo boxes and clicking the Create button. The cmdCreate_Click() event procedure concatenates a string containing your entries and invokes the Create Directory method of the Image Admin control to create the cabinet, drawer, and/or folder you specified (code not shown).
szQueryTerms parameter The string findcabinets, which is contained in the mstrQuery module variable. This parameter value makes the method return the cabinets in the referenced database. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. The query finds the cabinets in the selected database and returns them via the collection object in the following format:
Image://server/database:\cabinet
Because were only interested in cabinet names, the procedure invokes the public function GetEndString(), which returns just the cabinet names. The cboDocManager_Click() event procedure then loads the cabinet names into the Cabinets combo box (cboCabinet). The procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. The procedure wraps up its work by displaying the number of cabinets found and giving focus to the Cabinets combo box.
197
Chapter 5
Private Dim Dim Dim Sub cboDocManager_Click() objResults As Object strSinglePlural As String vntItem As Variant
. . .
mstrDocManager = cboDocManager.Text '---------------------------------------------------------' Perform an ImgQuery for Cabinet names, load them in the ' cboCabinet combo box. '---------------------------------------------------------mstrQuery = "findcabinets" ImgAdmin1.ImgQuery Mid(mstrDocManager, 9), mstrQuery, objResults For Each vntItem In objResults If vntItem <> "" Then cboCabinet.AddItem GetEndString(vntItem, "\") End If Next vntItem '---------------------------------------------------------' End the query. '---------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd '---------------------------------------------------------' Display the number of Cabinets found. '---------------------------------------------------------If cboCabinet.ListCount = 1 Then strSinglePlural = " Cabinet:" Else strSinglePlural = " Cabinets:" End If lblCabinet.Caption = cboCabinet.ListCount & strSinglePlural '---------------------------------------------------------' Set the focus to cboCabinet. '---------------------------------------------------------cboCabinet.SetFocus End Sub
198
Make sure that the Enable Drawers check box has a check mark next to it. If it does not, the cboCabinet_Click() procedure performs a query for folders.
Because were only interested in drawer names, the procedure invokes the public function GetEndString(), which returns just the drawer names. The cboCabinet_Click() event procedure then loads the drawer names into the Drawers combo box (cboDrawer). The procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. The procedure wraps up its work by displaying the number of drawers found and giving focus to the Drawers combo box.
199
Chapter 5
Private Dim Dim Dim Sub cboCabinet_Click() objResults As Object strSinglePlural As String vntItem As Variant
. . .
mstrDocManager = cboDocManager.Text mstrCabinet = cboCabinet.Text '---------------------------------------------------------' Perform an ImgQuery, and store the Drawer or Folder names ' in the appropriate combo box. '---------------------------------------------------------If chkEnableDrawers.Value = Checked Then mstrQuery = "finddrawers cabinet=" & mstrCabinet ImgAdmin1.ImgQuery Mid(mstrDocManager, 9), mstrQuery, objResults For Each vntItem In objResults If vntItem <> "" Then cboDrawer.AddItem GetEndString(vntItem, "\") End If Next vntItem
. . .
End If '---------------------------------------------------------' End the query. '---------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd
. . .
End Sub
200
This parameter value makes the method return the folders in the referenced database, cabinet, and drawer. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. The query finds the folders in the selected database and returns them via the collection object in the following format:
Image://database:\cabinet\drawer\folder
Because were only interested in folder names, the procedure invokes the public function GetEndString(), which returns just the folder names. The cboDrawer_Click() event procedure then loads the folder names into the Folders combo box (cboFolder). The procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. The procedure wraps up its work by displaying the number of folders found and giving focus to the Folders combo box.
201
Chapter 5
Private Dim Dim Dim Sub cboDrawer_Click() objResults As Object strSinglePlural As String vntItem As Variant
. . .
mstrDocManager = cboDocManager.Text mstrCabinet = cboCabinet.Text mstrDrawer = cboDrawer.Text '---------------------------------------------------------' Perform an ImgQuery, and store the Folder names in the ' cboFolder combo box. '---------------------------------------------------------mstrQuery = "findfolders cabinet=" & mstrCabinet & ";drawer=" & mstrDrawer ImgAdmin1.ImgQuery Mid(mstrDocManager, 9), mstrQuery, objResults For Each vntItem In objResults If vntItem <> "" Then cboFolder.AddItem GetEndString(vntItem, "\") End If Next vntItem '---------------------------------------------------------' End the query. '---------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd '---------------------------------------------------------' Display the number of Folders found. '---------------------------------------------------------If cboFolder.ListCount = 1 Then strSinglePlural = " Folder:" Else strSinglePlural = " Folders:" End If lblFolder.Caption = cboFolder.ListCount & strSinglePlural '---------------------------------------------------------' Set the focus to cboFolder. '---------------------------------------------------------cboFolder.SetFocus End Sub
202
return the documents in the referenced database, cabinet, drawer, and folder. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. The query finds the documents in the selected database and returns them via the collection object in the following format:
Image://database:\cabinet\drawer\folder\document
Because were only interested in document names, the procedure invokes the public function GetEndString(), which returns just the document names. The cboFolder_Click() event procedure then loads the document names into the Documents combo box (cboDocument). The procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. The procedure wraps up its work by displaying the number of documents found and giving focus to the Documents combo box.
203
Chapter 5
Private Dim Dim Dim Sub cboFolder_Click() objResults As Object strSinglePlural As String vntItem As Variant
. . .
mstrDocManager = cboDocManager.Text mstrCabinet = cboCabinet.Text mstrDrawer = cboDrawer.Text mstrFolder = cboFolder.Text '---------------------------------------------------------' Perform an ImgQuery, and store the Document names in the ' cboDocument combo box. '---------------------------------------------------------mstrQuery = "finddocs cabinet = " & mstrCabinet & " drawer = " _ & mstrDrawer & " folder = " & mstrFolder ImgAdmin1.ImgQuery Mid(mstrDocManager, 9), mstrQuery, objResults For Each vntItem In objResults If vntItem <> "" Then cboDocument.AddItem GetEndString(vntItem, "\") End If Next vntItem '---------------------------------------------------------' End the query. '---------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd '---------------------------------------------------------' Display the number of Documents found. '---------------------------------------------------------If cboDocument.ListCount = 1 Then strSinglePlural = " Document:" Else strSinglePlural = " Documents:" End If lblDocument.Caption = cboDocument.ListCount & strSinglePlural '---------------------------------------------------------' Set the focus to cboDocument. '---------------------------------------------------------cboDocument.SetFocus End Sub
204
After you select 1.x Query on the Server menu, the 1.x Query window (frm1.xQuery) loads without being shown. Its Form_Load() event procedure (shown in the following code snippet) invokes the ImgQueryEnd method of the Image Admin control to clear any previous Imaging queries and to free associated system resources. Next, the procedure invokes the ImgQuery method, passing to it the following parameters: vScope parameter Constant DMVOLUMES (literal 1), which sets the method so it performs a query for Imaging 1.x document manager databases. szQueryTerms parameter A blank string, which makes the method return the available Imaging 1.x databases. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. The query finds all of the available Imaging 1.x databases. The Form_Load() event procedure loads them from the objResults object variable into the Document Manager combo box (cboDocManager). The procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. Both actions free system resources associated with the query.
205
Chapter 5
The procedure wraps up its work by:
Showing the 1.x Query window. Displaying the number of document manager databases found. Giving focus to the Document Manager combo box.
206
207
Chapter 5
On the 1.x Query window, click the desired document manager database in the Document Managers combo box. The cboDocManager_Click() event procedure assigns the document manager database you selected to the mstrDocManager module variable (code not shown). In the Find 1.x Document area, click the type of query you want to perform. If you clicked the: Name option button (Query by Document) Click the desired boolean operator and then enter the name of the document you are trying to locate in the adjacent text box. Date option button (Query by Date) Click whether to search for documents that were created or modified, then click the desired boolean operator (including before, after, and on). Finally, enter the desired date in the adjacent text box. Keyword option button (Query by Date) Click the desired boolean operator and then enter, in the adjacent text box, the keyword whose documents you want to search for. Use the date format set in Regional Settings. Click the Find button. The cmdFind_Click() event procedure fires and executes its code (as shown in the following code snippet). The basic task of this event procedure is to find all of the Imaging 1.x documents that satisfy the parameters you specified and to load them in the list box control at the bottom of the window. To accomplish this task, the procedure evaluates the Value property of each option button on the form. When it finds the option button you clicked, it builds an appropriate Query Terms string and assigns it to the mstrQuery module variable. (The procedure passes the value of this variable to the ImgQuery method later as the szQueryTerms parameter.) The composition of the Query Terms string depends on the type of query you are performing. If you are performing a: Query by Document The string contains:
When you select the Like operator, you can use the asterisk (*) wildcard character to represent a group of characters and a question mark(?) to match any single character.
When building your own QueryTerms strings, be sure to include a space between each element.
The finddocs document qualifier. The selected boolean operator from the adjacent combo box. The document name entered in the adjacent text box.
208
The finddocs keyword qualifier. The selected boolean operator from the adjacent combo box. The keyword entered in the adjacent text box. With the Query Terms string now composed and assigned, the cmdFind_Click() event procedure invokes the ImgQuery method, passing to it the following parameters:
vScope parameter The result of Mid(mstrDocManager, 9), which sets the method so it performs a query on the selected document manager. szQueryTerms parameter The concatenated Query Terms string from the mstrQuery module variable, which sets the method so it performs the query you specified. iDispatch parameter The object variable, objResults, which represents the collection object that contains the results of the query. The query finds the documents in the selected database and returns them via the collection object in the following format:
Image://database:\cabinet\drawer\folder\document
Then, the cmdFind_Click() event procedure ends the query by setting objResults to Nothing and by invoking the ImgQueryEnd method. The procedure wraps up its work by displaying the documents in the list box at the bottom of the window.
209
Chapter 5
Private Dim Dim Dim Sub cmdFind_Click() objResults As Object vntItem As Variant strConvertedDate As String
lstResults.Clear '-----------------------------------------------------------' Perform a query; store Doc names in the lstResults listbox. '-----------------------------------------------------------If optQuery(0).Value = True Then 'Query by Document mstrQuery = "finddocs document " & _ cboName.List(cboName.ListIndex) & " " & txtName.Text ElseIf optQuery(1).Value = True Then 'Query by Date strConvertedDate = ImgAdmin1.ConvertDate(txtDate.Text) mstrQuery = "finddocs " & _ cboDateName.List(cboDateName.ListIndex) & " " & _ cboDate.List(cboDate.ListIndex) & " " & strConvertedDate ElseIf optQuery(2).Value = True Then 'Query by Keyword mstrQuery = "finddocs keyword " & _ cboKeyword.List(cboKeyword.ListIndex) & " " & txtKeyword.Text End If ImgAdmin1.ImgQuery Mid(mstrDocManager, 9), mstrQuery, objResults For Each vntItem In objResults If vntItem <> "" Then lstResults.AddItem vntItem End If Next '---------------------------------------------------------' End the query. '---------------------------------------------------------Set objResults = Nothing ImgAdmin1.ImgQueryEnd '---------------------------------------------------------' Display the number of documents found. '---------------------------------------------------------If lstResults.ListCount = 0 Then lblResults.Caption = SELECT_NONE ElseIf lstResults.ListCount = 1 Then lblResults.Caption = SELECT_SINGULAR Else lblResults.Caption = SELECT_PLURAL1 & lstResults.ListCount & SELECT_PLURAL2 End If End Sub
210
Zooming an Image
Open an image file or server document. After the image appears in the Image Edit control, on the Zoom menu, click the desired zoom factor. The mnuZoomFactorItem_Click event procedure fires and executes the appropriate code in its Select Case statement (as shown in the following code snippet). Each Case expression corresponds to the Index value of a Zoom menu item. Further, each Case expression sets the Zoom property of the Image Edit control to an appropriate zoom factor. With the Zoom property now set, the procedure completes its work by invoking the Refresh method of the Image Edit control, which redisplays the image at its new zoom factor.
211
Chapter 5
Private Sub mnuZoomFactorItem_Click(Index As Integer) Dim intIndex As Integer '---------------------------------------------------------' Uncheck all the zoom menu items. '---------------------------------------------------------For intIndex = 0 To 5 mnuZoomFactorItem(intIndex).Checked = False Next intIndex '---------------------------------------------------------' Set the zoom factor. '---------------------------------------------------------Select Case Index Case 0 '25% ImgEdit1.Zoom = 25 Case 1 '50% ImgEdit1.Zoom = 50 Case 2 '75% ImgEdit1.Zoom = 75 Case 3 '100% ImgEdit1.Zoom = 100 Case 4 '200% ImgEdit1.Zoom = 200 Case 5 '400% ImgEdit1.Zoom = 400 End Select '---------------------------------------------------------' Check the menu item that was clicked. '---------------------------------------------------------mnuZoomFactorItem(Index).Checked = True '---------------------------------------------------------' Refresh the image at the new zoom factor. '---------------------------------------------------------ImgEdit1.Refresh End Sub
212
If desired, you can include parameters in your call to the ShowAnnotationTool Palette method. The parameters control:
Whether users can set annotation properties. Where the tool palette will appear on the screen. The tool tip text the appears when the mouse pointer hovers over a button on the tool palette.
213
Chapter 5
Private Sub mnuAnnotationItem_Click(Index As Integer) Select Case Index Case 0 'Show Annotations If mnuAnnotationItem(Index).Checked = True Then mnuAnnotationItem(Index).Checked = False ImgEdit1.HideAnnotationGroup Else mnuAnnotationItem(Index).Checked = True ImgEdit1.ShowAnnotationGroup End If Case 1 'Show Annotation Toolbar If mnuAnnotationItem(Index).Checked = True Then mnuAnnotationItem(Index).Checked = False ImgEdit1.HideAnnotationToolPalette Else mnuAnnotationItem(Index).Checked = True ImgEdit1.ShowAnnotationToolPalette End If End Select End Sub
214
A
Imaging ActiveX Sample Applications
This appendix describes the Imaging ActiveX sample applications that are available on the media on which your software was distributed.
In This Appendix
Overview ................................................................................... 216 Sample Applications .................................................................. 217
Appendix A
Overview
This section introduces you to the Imaging ActiveX sample applications.
The Imaging ActiveX sample applications are relatively large Visual Basic projects that demonstrate how to use the Imaging ActiveX controls to build comprehensive and useful, image-enabled applications. It is beyond the scope of this appendix to walk you through each and every application. eiStream WMS, Inc. suggests that you run each one and analyze its code to determine whether you can use it:
Requirements
With the exception of the sample application, to compile and run the Imaging ActiveX sample applications, you must use:
Microsoft Visual Basic 6.0. Imaging for Windows. To compile and run the sample application, you must use: Microsoft Visual Basic 6.0 with Service Pack 3 or later. Imaging for Windows.
216
Sample Applications
This section describes the Imaging ActiveX sample applications.
The code in each sample application is highly organized, commented, and written using Hungarian notation. There are eight sample applications in the following categories: Image Editor samples Function Specific samples Imaging Flow samples The following sections describe them.
Sample Application
The sample application emulates the look and feel of the Imaging for Windows application. It is a baseline image editor that due to its simplicity is the best one from which to study and learn. Sample functions include: Delete Pages Deletes selected pages from a displayed image document file. Note that looping through the image pages is performed from last to first to prevent the renumbering of image pages as they are deleted. See the code within the mnuEditActionItem_Click event procedure. Drag Hand Emulates the Drag Hand behavior evident in the Imaging for Windows application. The drag hand enables you to pan an image page; that is, to scroll the image page horizontally and vertically without using the scroll bars. See the code within the ImgEdit1_MouseMove event procedure. Splitter Bar Emulates the splitter bar behavior evident in the Imaging for Windows application. Note that the splitter bar (imgDivider) has a Top value of -20000 and a Height value of 40000 to prevent the top and bottom of the splitter bar from being visible as you drag it. See the code within the ImgEdit1_DragDrop and ImgThumbnail1_DragDrop event procedures.
217
Appendix A
Image Editor
Image Editor is a more sophisticated application that emulates the look and feel of the Imaging for Windows application.
The file name for the Image Editor project is ImgEditr.vbp.
After you master the sample application, investigate Image Editor, which includes toolbars and advanced features, such as:
Contact sheet creation Image enhancement Magnification Optical Character Recognition (OCR) Summary properties (TIFF image document files only)
The Tools menu of the Image Scan and Image Thumbnails sample applications provides access to an interesting facility called the Event Tracker. The Event Tracker lets you track the events fired by any of the Imaging ActiveX controls.
218
Image Print Image Print shows you how to print image document files from the standard Print dialog box, as well as programmatically from a custom Print Settings dialog box (frmSettings).
The application has two functions that the Imaging for Windows application doesn't have: Page with Header Prints an image with a header at the top. The header is created by programmatically generating an annotation and then shifting the image down so that it begins below the header. You can find the code that performs this task in the GenerateHeaderWorkFile procedure of frmMain. Displayed Portion When you zoom in on an image in the display window, this function prints only the portion of the image that is displayed. You can find the code that performs this task in the GenerateDisplayedPortionWorkFile procedure of frmMain. You can select the Page with Header and Displayed Portion functions from the Area to Print frame on the Print Settings dialog box. They are functional only when you invoke printing via the Print via Program Control option on the Print menu.
Image Properties
Image Properties shows you how to display and print the general, summary, and page property values of image files.
The file name for the Image Properties project is ImgProp.vbp.
It uses the standard dialog boxes provided by the controls, as well as a few custom dialog boxes, to display the property values. You can display and print the properties of:
A single image file. All of the image files contained within a single folder. All of the image files contained within a folder and all of its subfolders.
219
Appendix A
In addition to the general, summary, and page property values, the application displays additional information, such as the:
Total number of bytes the files consume. Minimum/maximum file size. Average (mean) file size. Total number of pages. Smallest and largest page size. Total number of annotations by type and group.
Image Scan
Image Scan demonstrates a variety of scanning functions.
The file name for the Image Scan project is ImgScan.vbp.
In addition to using the standard scanning dialog boxes provided by the controls, Image Scan also shows you how to get and set scanner capabilities programmatically using a series of custom dialog boxes. The application also demonstrates how to scan double-sided originals on a simplex scanner and how to collate the pages into the correct order. This feature makes a simplex scanner function like a duplex scanner.
Image Thumbnails
Image Thumbnails shows you how to manage and manipulate the individual thumbnail images within an Image Thumbnail control.
The file name for the Image Thumbnails project is ImgThumb.vbp.
Specifically, the application shows you how to: Display thumbnails. Drag and drop thumbnails. Change thumbnail format and size. In addition to displaying as thumbnail images the pages of a single image file, the program can also display as thumbnail images the first page of every image file within a specified folder.
220
Flow Program
The Flow Program demonstrates how a third-party program can be invoked from within a flow and how it may be used to control or affect the current flow. The program has two operating modes: Separator Page mode Locates separator pages so it can assemble scanned pages into discreet, single- or multi-page image document files. Form Number mode Reads form numbers by performing zoned OCR on images. And then uses the OCR results to name the image document files. If you invoke the program with command line arguments from the process version of the Run Program tool, it functions in the background. Two command line arguments are available; the one you pass selects the operating mode of the program:
/separatorpage Places the program in Separator Page mode. /formnumber Places the program in Form Number mode.
If you invoke the program without command line arguments, it assumes that you want to change its settings. Accordingly, it provides a user interface for doing so.
Note: The OCR function within Flow Program is an excellent example of using OCR text zones to perform targeted OCR processing. Refer to the Imaging Flow on-line help system for more information on the Run Program flow tool (Process version).
Flow Variables
The Flow Variables program also demonstrates how a third-party program can be invoked from within a flow. The program shows you how to monitor and set flow variables. This program is designed as a diagnostic tool only; however, you may get some interesting ideas from analyzing it. Refer to the Flow Variables Reference within Imaging Flows on-line help system to learn more about flow variables.
221
B
Imaging ActiveX Tips and Tricks
This appendix describes some tips and tricks you might find useful when working with the Imaging ActiveX controls.
In This Appendix
Tips and Tricks ........................................................................... 224
Appendix B
Use the tips and tricks in this section as guidelines when you use the Imaging ActiveX controls to image-enable your applications. Refer to the remainder of this guide for more information about the controls.
1 Use a text editor to view the .frm files within each sample
application distributed with your software.
2 Ensure that the functions you use in your applications are supported
by the vsrsion of Imaging that your users are running.
Note: When setting a property, invoking a method, or responding to an event, if you encounter results you consider unusual, consider changing the parameter(s) you are using.
Specify tenths of degrees when calling rotation methods The RotateAll, RotateLeft, and RotateRight methods of the Image Edit control permit you to specify the degree of image rotation to apply. When you do so, keep in mind that you must specify the rotation amount in tenths of degrees. For example, to rotate an image page 45 degrees to the right, specify 450 when you invoke the RotateRight method. Use the DisplayScaleAlgorithm property to scale black-andwhite image pages to gray eiStream WMS, Inc. recommends that you set the DisplayScaleAlgorithm property of the Image Edit control to wiScaleOptimize (literal 4) when you want to make black-and-white
224
225
Appendix B
Always pass the parent window handle when invoking the ShowPrintDialog method Even though passing the handle to the parent window is optional, for best results always include it when you invoke the ShowPrintDialog method of the Image Admin control. The ShowPrintDialog method displays a Print dialog box, which enables users to print image files. Retain generated file names when template scanning As you know from Chapter 4, you can assign a template to the Image property of the Image Admin control to perform template scanning. The Imaging software uses the template you assign to automatically generate the file names for each document it scans. Unfortunately, if you need to know the name of each generated file, you cannot use the Image property to return the file names when template scanning. However, you can use the following alternative procedure to retain each file name while template scanning. Perform the following steps:
2 Assign the generated file name to the Image property of the Image
Scan control, which is a prerequisite for scanning.
226
The table on the following page lists the results of varying these factors on a one-page newsletter. The newsletter consists of:
An image that occupies approximately one-quarter of the page. Three columns of text that fill the remainder of the page.
Use the table as a guideline when providing file type and page property options to your end users. You may want to include a table like it in your documentation.
227
Appendix B
Results of Varying Image File Type and Page Property Options File Type Color Type Compression Applied Resolution 100 x 100 Resolution 200 x 200 Resolution 300 x 300
BMP
Not available Not available Not available None Group3 (1d) Group3 Mod. Huffman Group4 (2d) PackBits
114 KB 898 KB 2.6 MB 112 KB 68 KB 67 KB 68 KB 59 KB 449 KB 132 KB 898 KB 585 KB 128 KB 899 KB 137 KB 2.6 MB 897 KB 144 KB
448 KB 3.5 MB 10.5 MB 449 KB 134 KB 132 KB 92 KB 193 KB 1.8 MB 261 KB 3.5 MB 1.5 MB 367 KB 3.5 MB 367 KB 10.5 MB 2.2 MB 448 KB
1.0 MB 7.9 MB 23.6 MB 1.0 MB 226 KB 223 KB 115 KB 389 KB 3.9 MB 579 KB 7.9 MB 2.5 MB 703 KB 7.9 MB 670 KB 23.6 MB 3.9 MB 907 KB
TIFF
By adjusting JPEG resolution and quality compression options, you can increase or decrease the file size by 20 to 30%. In our newsletter example, the JPEG compression option applied was medium resolution and medium quality. The image file would be larger if we applied high resolution and high quality and smaller if we applied low resolution and low quality.
228
Use the Append method to assemble several image files into one multipage TIFF image file You can use the Append method of the Image Admin control to copy image pages from one image file to another. The following Visual Basic statements copy the first two pages of the source.tif file to the destination.tif file:
ImgAdmin1.Image = "c:\images\destination.tif" ImgAdmin1.Append "c:\images\source.tif", 1, 2
The copied pages become the last two pages of the destination.tif file. Always clear a displayed image page before deleting it You must clear an image page from the Image Edit control before you delete it. Failure to do so results in a run-time error. The following code snippet from the sample program demonstrates the recommended way of deleting an image page:
'-------------------------------------------------' Delete: Loop through the image pages, deleting ' those pages which have been selected. '-------------------------------------------------For intCounter = ImgThumbnail1.ThumbCount To 1 Step -1 If ImgThumbnail1.ThumbSelected(intCounter) = True Then lngDeletedPageNo = intCounter ImgEdit1.ClearDisplay ImgAdmin1.DeletePages lngDeletedPageNo, 1 ImgThumbnail1.DeleteThumbs lngDeletedPageNo, 1 End If Next intCounter
229
Appendix B
Use caution when copying selected image data to the Clipboard When copying the image data within a selection rectangle to the Clipboard, do not pass the parameters received from the SelectionRectDrawn event to the ClipboardCopy method. If you do, the ClipboardCopy method may not copy the expected image area. Although the SelectionRectDrawn event and the ClipboardCopy method both use Left, Top, Width, and Height parameters, they each work with different base locations. The SelectionRectDrawn event uses the image pixel position relative to the upper-left corner of the Image Edit control, while the ClipboardCopy property uses the absolute image pixel position. When you want to copy the data in a selection rectangle, invoke the ClipboardCopy method with its Left, Top, Width, and Height parameters empty.
Annotation Tips
Let your users modify the properties of a drawn annotation After drawing an annotation, your users may want to change its properties. For example, they may want to change a line color from red to blue. To provide this capability, invoke the ShowAttribsDialog method of the Image Edit control. It displays an annotation attributes dialog box that lets your end users change the properties (attributes) of a selected annotation. For text annotations, invoke the EditSelectedAnnotationText method of the Image Edit control. It enables end users to modify the text. Guidelines for making annotations permanent You can use the BurnInAnnotations method of the Image Edit control to make annotations a permanent part of the image. When you or your users burn-in annotations, keep the following points in mind:
Once annotations are burned-in, they cannot be removed or modified as annotations. They can, however, be edited or manipulated just like image data clearing as well as copying and cutting to the Clipboard is available. BurnInAnnotations works only on the currently displayed image page. If you or your users want to burn-in the annotations of an
230
How to retain annotations when users navigate multipage image files When users draw annotations on a page in a multipage image file and then navigate to another page in the file, the Imaging software does not automatically retain the annotations drawn. When users return to the annotated image page, the annotations are no longer there. To retain annotations under these circumstances, create a temporary image file and use it as a work file. When users draw annotations on a page, invoke the Save method of the Image Edit control to save the entire image file to the work file. This action forces the Imaging software to retain the annotations because they have been saved to a file. Then, when users close the image file or exit your application, prompt them to indicate whether they want to save any changes. If users respond with Yes Copy the work file to the original image file and then delete the work file. If users respond with No Simply delete the work file. When printing annotations Keep in mind that some printers may not print annotations correctly especially Image Embedded and Image Reference annotations. The reason for this behavior is that printer drivers function differently, making it impossible to print annotations consistently on all printers. The solution to this problem is to have your users:
1 Burn the annotations onto the image page. 2 Save the image file. 3 Print the image file.
If users do not want to permanently alter an image, have them save the image to a temporary file before performing the preceding steps.
231
Appendix B
When you assign a training file to the TrainingFile property of the Image OCR control, make sure that the training file actually exists. If it does not, training does not occur. Interactive Training is not available when performing OCR to the Clipboard. If you or your users perform Interactive Training on a skewed image, the yellow highlights that indicate each questionable word may not appear directly over the appropriate word. You or your users should invoke the AutoDeskew or ManualDeSkew method of the Image Edit control to straighten a skewed image and then save the image prior to performing Interactive Training.
Performing OCR Keep the following points in mind when performing OCR processing:
Do not attempt to OCR a severely skewed image. You or your users should invoke the AutoDeskew or ManualDeSkew method of the Image Edit control and then save the file prior to performing OCR. You or your users must save the image file because the OCR engine reads from the file and not from the display buffer. Communicate to your users that OCR processing occurs more efficiently when there is less blank space on an image. For example, if users want to OCR a 3x5-inch card, you should tell them to scan the card as a 3x5-inch image instead of, for example, a letter-size image. In addition to saving disk space, scanning a 3x5-inch card as a 3x5inch image makes OCR processing occur more efficiently because the OCR engine traverses less blank space as it looks for characters to convert. The OCR engine performs its processing on a black-and-white image. If your users are receiving poor OCR results from a page that looks good, provide a way for them to turn off scale-to-gray. With scale-to-gray turned off, users see what the OCR engine is actually analyzing and may come to the realization that rescanning or enhancing the image is necessary. The Imaging software can perform OCR processing in three ways. Providing your users with the appropriate OCR functions may improve OCR results:
232
Keep in mind that setting the OutputFile property of the Image OCR control to blank does not invoke the Save As dialog box. To have the Imaging software prompt the user to specify where the OCR results should be saved, simply omit the OutputFile property from your code.
233