The present disclosure relates to network printing, in which a population of computers can send print jobs to a population of printers over a network.
The concept of “network printing,” in which a set of digital printers or other machines, such as digital copiers or multifunction devices, are controlled using a network protocol, is well known. Heretofore, management of a network of printers, particularly at installation, has been a labor-intensive process. In order to set up a plurality of printers and make the printers accessible to a plurality of computers, a server on the network has to be configured, and this configuration process typically involves having a systems administrator, that is a person with the particular responsibility of maintaining the network, identify printers on the network, and configure drivers in order to access each of these printers. It would be desirable to provide a system in which a user could automatically obtain suitable drivers for printers of various types.
According to aspects of embodiments, there is provided methods of creating drivers for use in a network, the network including computers and devices, and corresponding apparatus and computer-readable medium. The methods include providing a platform, the platform including: 1) a plurality of selectable communication components, each communication component relating to a type of network communication associated with a type of device; 2) a plurality of selectable PDL components, each PDL component relating to a type of PDL associated with a type of device; 3) a user interface component, the user interface component having plurality of selectable user interface elements; 4) a plurality of selectable workflow components, each workflow component relating to a type of workflow to be associated with a device; and 5) a plurality of selectable vertical feature components; determining a type of the device for which the driver is to be created, the device being on the network; and based on the determined type of the device, selecting and activating one of the communication components, one of the PDL components, the user interface component, and one of the workflow components, and instantiating each of the selected components, thereby creating a driver suitable for the determined type of device on the network.
A printer driver is an application that enables printing a document to a particular printing device (a device can be a printer or any machine, such as a copier or facsimile, having printing functions). The present disclosure describes an architecture and apparatus of a printer driver platform. This architecture consists of a set of inter-related components that enable the creation of a variety of different printer drivers over a large number of printing devices. In this way, by selecting components suitable for the physical functionality of a given type of device, and instantiating each of the selected components to be suitable for the device, a driver for the device is generated.
As used herein, the term “providing” shall simply mean “making available for use,” and does not necessarily imply any sale, conveyance, or business or customer relationship.
Workflow Modules 12 manages the instantiation and the control flow within the printer driver being created. The Workflow Modules 12 utilizes a plurality of different workflow components that are selectable based on a type of workflow to be associated with a device. The workflow components may include a Traditional Workflow component (used for a device and PDL specific printer driver), a Universal Workflow component (used for a printer driver that supports feature-rich printing to any device) and a Mobile Workflow component (used for a printer driver that finds available devices within the local network and supports basic printing functionality to these devices).
The Workflow Modules 12 employs Device Capabilities files 14 to populate the platform's Data Model 16 with the appropriate feature data for the particular device (printer) the driver is created for or connected to. A Device Capabilities file 14 describes the set of features and their options that the device supports. The Device Capabilities file 14 also includes the set of the device's inter-feature limitations (termed constraints). Depending on the particulars of the specific printer driver, the Workflow Modules 12 may obtain the Device Capabilities file from the device (examples of which are here shown as 20), from a network location (e.g. Web), or have it present in the printer driver package. The device 20 is illustrated in
The Workflow Modules 12 controls the flow of information within the printer driver platform 10. In particular, when the printer driver is executing a print operation the Workflow Modules 12 creates a data flow pipe of the platform's components and manages the data flow from component to component in the production of the Page Description Language file sent to the printing device.
Data Model 16 manages the storage and manipulation of all of the printer driver's data. The data includes the device settings, feature capabilities, feature defaults, feature constraints, and saved settings. The data is stored in an internal data representation to optimize its storage and retrieval.
Data Model 16 contains a number of important sub-components (not shown individually). A Feature Dictionary is a data store of the present Printing Device's features and allowable values. A Constraint Engine manages and executes the feature constraints (as loaded from the Device Capability file). A Format Converter converts between the Data Module's internal data representation and another data format (e.g. Xerox Print Interchange Format, ASCII Job Ticket). An Observer Manager provides event switchboard capability. Platform components register for platform events that they need to be notified for. When an event occurs, a component within platform 10 notifies the Observer Manager of the event and the Observer Manager communicates the event to all registered components. The Observer Manager enables inter-component communication such that the individual components are isolated from other platform components.
User Interface Module 18 dynamically constructs the printer driver's user interface based on the functional capabilities of the target printing device (as defined in the Device Capabilities file). It creates a base user interface infrastructure of tabs and off-tab space upon which it adds feature's user interface specifics for a particular printer. The User Interface component employs a toolkit of well-defined UI controls (e.g. drop down boxes, text boxes, radio buttons and the like) and UI molecules (a combination of UI controls into a reusable unit such as a drop down box that supports text entry) that enable the ability to quickly create a wide variety of differing user interface presentations. Thus, the user interface created will vary depending on the features, options and constraints available in the Device Capabilities file 14.
The User Interface Module 18 also communicates to the Data Model 16 any UI selections made by a user. The Data Module executes the feature constraint based on the selection as well as communicating the user selection to registered components.
Rendering components 30 converts the print request's document information and objects (as communicated by the client operating system) into the specific PDL (page description language) objects and codes. Thus, the Rendering components 30 may include a plurality of rendering components of differing types for differing page description languages that may be used by a particular printer. The Rendering components may include a PostScript Renderer, a PCL5 renderer, and a PCL6 renderer, for example, corresponding to the most common types of page description languages in use. The appropriate rendering component 30 may then be selected based on the page description language used by the device 20. As shown, there is provided a base renderer 30, which is typically the renderer supplied with the operating system, and also a renderer component 32, that, when activated, can perform rendering functions in addition to those available to the base renderer 30.
Among other possible components in platform 10, a Print Processor (shown in dashed lines) enables pre-processing of the print data stream prior to the document's conversion into a PDL. The Print Processor may be necessary for the execution of some advanced functionality such as fit-to-new-size and fit-to-poster.
Device Interface 34 encapsulates all communication to the Printing Device 20 and provides interfaces to the other platform components to request specific Printing Device information and events. As such, platform clients of the Printing Device information do not need to know the details of the Printing Device or how the information is obtained from the Printing Device 20.
When information is acquired from the Printing Device 20, the Device Interface 34 updates the Data Model's 16 data store for the specific information. The Data Model 16, in turn, communicates the data change occurrence to all components registered for it. As mentioned previously, the use of the Data Model 16 as a communication intermediary enables clients of the information and the providers of the information to be fully independent of each other.
Communication Modules 24 manage all communication between the Platform 10 and the device 20. The Communication Modules 24 may include a plurality of types of communication components. Each of the types of communication components is used for a type of network communication that may be employed by a particular device. For example, devices may use network communication types such as SNMP (Simple Network Management Protocol), IPP (Internet Printing Protocol), and WSD (Web Services For Devices). By having a communication module for each of a variety of communication types, the platform may communicate with the device 20 no matter what type of communication type the device 20 may use.
Job Tracker 36 tracks a print job that has been submitted to a Printing Device. When the print job has completed its operation, the Job Tracker may display a notification to the user.
A Device Status and Printing Scout (not shown, but could be operatively associated with Device Interface 34) may present a printing device's dynamic state information to a user. The dynamic state information can include device error and warning messages, active job queue, completed job queue, and consumables state.
Also present in, or otherwise accessible to, the platform 10 is a set of Vertical Feature Components 50. A Vertical Feature component 50 is an encapsulation of a specific functional capability (e.g. watermarks, accounting, booklet making, facsimile, and the like). The printer driver platform contains a large number of vertical features that can be instantiated in printer driver user interface. A particular Vertical Feature component 50 is selected and activated only if it is desired and supported by a device 20. If a particular Vertical Feature component 50 is not selected for use in a driver, such as if the device does not have a booklet maker, no trace of the Vertical Feature will appear in, for example, in a UI associated with the driver.
As mentioned, a number of differing Workflow Module 12 instances exist; that is, the basic Workflow Module 12 can be instantiated in various ways to carry out a selected workflow. These Workflow Modules include (but are not limited to) a Traditional Workflow Module (for a device and PDL specific printer driver), a Universal Workflow Module (for a printer driver that support feature-rich printing to any device) and a Mobile Workflow Module (for a printer driver that finds available devices within the local network and supports basic printing functionality to these devices). With the Traditional Workflow module, the Workflow Module 12 is instantiated according to variables that make the Workflow Module operate in a manner suitable for a device of a known type: these variables are kept “on file” and are used as needed when a device of a certain type is installed on a network. With a Universal Workflow Module, the Workflow Module 12, either by itself or by activating other components, in effect performs a querying operation with a target device identified on the network: with this querying, the Workflow Module 12 finds out the proper settings for the device, such as what PDL is used, how many trays the device has, etc., and then is instantiated with variables suitable for operating the target device. A Mobile Workflow Module includes a capability for querying Internet addresses to identify a suitable device for printing; once a device is identified, the Workflow Module can then be instantiated to operate with the device.
When a specific printer driver is instantiated using the components in platform 10, the printer driver accesses a build script specifying the specific instances of the platform components to be used. For example, a Universal PCL6 Printer Driver will be built with the Universal Workflow Module, PCL6 Renderer, and all Vertical Components. Creating a different type of driver uses the Traditional Workflow Module, the PostScript Renderer, but would not include the Fax Vertical Component if the particular printer does not support fax. The platform components to be used are generally selected based on the Device Capabilities File 14.
The system generally shown in
The architecture of the feature components employs a clear separation between a feature's presentation (UI), a feature's data (representation of the feature), and the feature's execution (specific PDL emitted). This clean division enables the construction of differing printer drivers employing this platform architecture that varies the specifics of one feature layer without affecting the other two layers. For example, the Stapling feature has one UI presentation for smaller, less-featured A4 devices and a different presentation for highly featured devices (while the representation and execution of the stapling feature is the same). Some Vertical Features can conceptually be thought as multiple Vertical Features because one of the layers may vary greatly. For example, Booklet Vertical Feature can be considered conceptually two Vertical Features: a PostScript Booklet Vertical Feature and a PCL Booklet Vertical Feature. The PS and PCL Vertical Features use the same user interface and data but have very distinct execution code.
In one possible business scenario using the platform-based architecture of
Processor 630 may include at least one conventional processor or microprocessor that interprets and executes instructions. The processor 630 may be a general purpose processor or a special purpose integrated circuit, such as an ASIC, and may include more than one processor section. Additionally, the system 610 may include a plurality of processors 630.
Memory 620 may be a random access memory (RAM) or another type of dynamic storage device that stores information and instructions for execution by processor 630. Memory 620 may also include a read-only memory (ROM) which may include a conventional ROM device or another type of static storage device that stores static information and instructions for processor 630. The memory 620 may be any memory device that stores data for use by system 610.
Input/output devices 640 (I/O devices) may include one or more conventional input mechanisms that permit a user to input information to the system 610, such as a microphone, touchpad, keypad, keyboard, mouse, pen, stylus, voice recognition device, buttons, and the like, and output mechanisms such as one or more conventional mechanisms that output information to the user, including a display, one or more speakers, a storage medium, such as a memory, magnetic or optical disk, disk drive, a printer device, and the like, and/or interfaces for the above. The display 650 may typically be an LCD or CRT display as used on many conventional computing devices, or any other type of display device.
The system 610 may perform functions in response to processor 130 by executing sequences of instructions or instruction sets contained in a computer-readable medium, such as, for example, memory 620. Such instructions may be read into memory 620 from another computer-readable medium, such as a storage device, or from a separate device via a communication interface, or may be downloaded from an external source such as the Internet. The system 610 may be a stand-alone system, such as a personal computer, or may be connected to a network such as an intranet, the Internet, and the like. Other elements may be included with the system 610 as needed.
The memory 620 may store instructions that may be executed by the processor to perform various functions. For example, the memory may store printer driver instructions to allow the system to perform various printing functions in association with a particular printer connected to the system. The printer driver instructions are typically unique to each specific type of printer, and the system 610 may store a plurality of print drivers each for a different printer.
At 7300, a type of the device for which the driver is to be created is determined, the device being on the network. At 7400, based on the determined type of the device, one of the communication components, one of the PDL components, the user interface component, and one of the workflow components are selected and activated, and each of the selected components are instantiated, thereby creating a driver suitable for the determined type of device on the network.
Embodiments as disclosed herein may also include computer-readable media for carrying or having computer-executable instructions or data structures stored thereon. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions or data structures. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or combination thereof) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of the computer-readable media.
Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments. Generally, program modules include routines, programs, objects, components, and data structures, and the like that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described therein. The various elements of platform 10 shown in
The claims, as originally presented and as they may be amended, encompass variations, alternatives, modifications, improvements, equivalents, and substantial equivalents of the embodiments and teachings disclosed herein, including those that are presently unforeseen or unappreciated, and that, for example, may arise from applicants/patentees and others.
Number | Date | Country | Kind |
---|---|---|---|
60900032 | Feb 2007 | US | national |
This application claims priority from provisional application Ser. No. 60/900,032, filed Feb. 7, 2007.
Number | Date | Country | |
---|---|---|---|
60900032 | Feb 2007 | US |