Methods and systems for print-processor-based printer status detection and print task distribution

Information

  • Patent Grant
  • 7679770
  • Patent Number
    7,679,770
  • Date Filed
    Wednesday, October 11, 2006
    18 years ago
  • Date Issued
    Tuesday, March 16, 2010
    14 years ago
Abstract
Embodiments of the present invention comprise methods and systems which enable a user to detect the status of printing devices without the use of additional hardware or application program modification for this purpose. These systems and methods are typically used in conjunction with a computer network comprising at least one computing device and a plurality of printing devices. When a print task is sent for printing it will activate a print processor for interpreting the print task. In addition to a print processor's interpretation function, the print processors of the present invention may detect the status of printing devices. Some embodiments may use this information to redirect or otherwise modify a print task for improved printing performance.
Description
FIELD OF THE INVENTION

Embodiments of the present invention comprise methods and systems for print-processor-based printer status detection and print task distribution.


BACKGROUND

Embodiments of the present invention relate to methods and systems for detecting printing devices and distributing print tasks to printers in a network. More particularly, these embodiments relate to methods and systems for detecting printer status and distributing print tasks in a network cluster printing environment through the use of novel print-processor-based applications. These embodiments provide increased print system performance and avoid failed print tasks without the use of additional hardware.


Many offices can generate a high volume of printer output or require high print rates to meet deadlines. When these needs are fairly constant, large, high-production printers and associated hardware may be required. These high-production units are expensive to procure and maintain and, generally, are only made economically feasible by a constant high demand for printer output. When printer requirements fluctuate, the costs of these high-production printers are difficult to justify. However, when sporadic, high printer throughput is a necessity, some offices are forced to bear the costs of expensive printer equipment that runs at well below its capacity most of the time.


Cluster printing has been introduced to avoid this problem. Cluster printing involves the use of multiple printers in a network. With cluster printing, print jobs can be sent to a multiple printer network with a capacity that rivals the capacity of expensive, high-throughput equipment. Generally, this network is comprised of multiple lower-production printers that may already exist in an office environment making the cost of the network very manageable.


Through the use of cluster printing, a user may choose to split a single print job among several printers to increase print job speed and decrease print time. Print jobs that include multiple copies may be divided so that each printer in a network prints some of the copies. Other variations of print job distribution may also be implemented.


Cluster printing may be implemented through specialized printers which contain cluster-enabling firmware. When these printers are interconnected via cables, they can share printing jobs. In some cases, the marking engines are connected to enable division of printing tasks between the connected printers.


Other methods of implementing cluster printing functions require the use of additional hardware or application software. Typically, a specialized print server is used. This server is generally a high-performance general purpose computer to which print jobs are directed by the network. Specialized software on the server allows print jobs or copies thereof to be distributed among multiple printers that are managed by the server.


These known cluster printing implementations require specialized printer or server hardware or software to provide cluster printing functions.


Another problem that exists in single printer, cluster printing, network printing and other environments is that of printer status detection. When a print job is initiated, a user typically selects a printer or printers based on the printersuser' location and/or capabilities. However, if one or more selected printers are offline, in an error state, busy, or for some other reason, unavailable, the print job may not be completed in an acceptable time period or may not be completed at all. Typically, an error message is returned to the user who must then select another printer or correct the problem preventing the selected printer from functioning. In some network printing cases involving print queues, no error message is returned and the user is left unaware of the printing problem. When a print job is time sensitive this process can be frustrating causing missed deadlines and tarnished reputations.


Printer status detection can be especially important in cluster printing environments where print tasks are divided among several printing devices. When a user or the user's computing device is not aware of the status of the printing devices selected for printing, a print task or portions thereof can be delayed, interrupted or lost.


SUMMARY

Embodiments of the present invention comprise methods and systems which enable a user to detect printer status and distribute print tasks to a plurality of printing devices without the use of additional hardware or server software for this purpose. These systems and methods are typically used in conjunction with a computer network comprising at least one computing device and a plurality of printing devices. Printing tasks which are typically sent to a user-selected printing device may be distributed to available printing devices to increase printing speed, volume and/or capacity. This printer status detection, availability determination and distribution capability can be achieved without the use of additional hardware and firmware and without modification to software applications.


Embodiments of the present invention comprise a novel print processor which is capable of detecting the status of printing devices. This detection may take place when a print task is sent to the print processor, prior to print task transmission, during the printing process or at some other time. Typically, printing device status is detected at the time a print task is sent to the print processor. If a print task is initially directed to a printing device that is unavailable or otherwise unable to function for the current task, the print processor of the present invention may redirect the print task to another printing device that is available for use.


In some cluster printing embodiments, the printing device status may be used to determine cluster printing parameters. For example, and not by way of limitation, a print task may be divided among the maximum number of available printing devices as determined by the status detection of embodiments of the present invention. As another non-limiting example, a print task may be divided among the maximum number of available printers within a given distance to a user. Other embodiments may use printing device status information to customize these and other cluster printing parameters.





BRIEF DESCRIPTION OF THE SEVERAL DRAWINGS

In order that the manner in which the above-recited and other advantages and objects of the invention are obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:



FIG. 1 is a diagram showing an embodiment of the present invention comprising printer availability detection for a local printer;



FIG. 2 is a diagram showing an embodiment of the present invention comprising printer availability detection for networked printers;



FIG. 3 is a diagram showing an embodiment of the present invention comprising printer availability detection for remote printers;



FIG. 4 is a diagram showing an embodiment of the present invention wherein printer availability is detected;



FIG. 5 is a diagram showing an embodiment of the present invention comprising printing device detection and a user selection interface;



FIG. 6 is a diagram showing an embodiment of the present invention comprising printing device detection and task rollover;



FIG. 7 is a diagram showing an embodiment of the present invention comprising printing device detection and rollover to available or busy devices;



FIG. 8 is a diagram showing an embodiment of the present invention comprising printing device detection and device group management; and



FIG. 9 is a diagram showing an embodiment of the present invention comprising printing device detection and preferred and backup group management.





DETAILED DESCRIPTION OF EXEMPLARY EMBODIMENTS

The figures listed above are expressly incorporated as part of this detailed description. It will be readily understood that the components of the present invention, as generally described and illustrated in the figures herein, could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of the embodiments of the systems and methods of the present invention, as represented in FIGS. 1 through 5 is not intended to limit the scope of the invention, as claimed, but it is merely representative of the presently preferred embodiments of the invention. The currently preferred embodiments of the present invention will be best understood by reference to the drawings, wherein like parts are designated by like numerals throughout.


The definitions in this and subsequent paragraphs apply throughout this specification and related claims. The term “print job” may refer to any combination of data that can be printed. A print job may comprise text and/or graphics and may comprise part of a page, a single page or many pages. Print jobs may be rendered or unrendered. Generally, a print job is generated by an application, such as a word processor, spread sheet, etc., however, a print job may also comprise a file or data in memory that may be sent directly to a print process.


The term “print copy” or “copy” may refer to data, code or commands which generate a single printing device output of a print job or may refer to the actual hard copy output of the print job.


The term “print task” may comprise any combination of print jobs and copies thereof. A print task may comprise one or more print jobs and one or more copies of each print job.


The term “copy splitting” may refer to a process by which a print task comprising multiple copies is divided into multiple modified print tasks with each modified print task comprising a portion of the total number of copies.


The term “job splitting” may refer to a process by which a print task comprising at least one print job is split into multiple modified print tasks with each modified print task comprising a portion of a print job.


References to a Microsoft Windows® or Windows® operating system may refer to any version or variation of a Microsoft Windows® operating system comprising Windows 95®, Windows 98®, Windows NT®, Windows 2000®, Windows ME®, Windows XP® and others. While exemplary embodiments of the present invention may be directed to a Windows® operating system and environment, systems and methods directed to other operating systems such as Macintosh®, UNIX, DOS, Linux, MVS and others are to be contemplated within the scope of the present invention.


Embodiments of the present invention may be embodied in software, firmware, hardware and other forms that achieve the function described herein. As embodiments of the present invention may be adapted to many environments with varying computing devices, operating systems, printing devices, network hardware and software, applications and other variables, these embodiments may take many forms to achieve their function. Some embodiments may also be transmitted as signals, for example, and not by way of limitation, embodiments may be transmitted as analog or digital electrical signals or as light in a fiber-optic line. All of these embodiments are to be considered within the scope of the present invention.


Embodiments of the present invention may be used to achieve printing device status detection and analysis, print task modification, copy splitting, job splitting and various combinations of these concepts along with related distribution tasks that allow modified or unmodified print tasks to be distributed to one or more printing devices. In some embodiments, printer status is detected and analyzed to determine a print task destination or modified print task destination. In other embodiments, printer status and printer capabilities may be used to modify a print task to print on a specific printer.


Some embodiments of the present invention may detect the status of a local printing device. A local printing device is a printing device that is directly connected to a communications port on a computing device and which is being used by a user of that computing device. For example, and not by way of limitation, a printer connected to a USB port, a parallel port or a serial port on a desktop computer is a local printer when it is being used by that computer. When a local printer is used, as shown in FIG. 1, a status detecting print processor (SDPP) 10 of the present invention may be used to detect the status of the local printer. This may be done by querying a port manager 12 which can access information about the devices connected to the various ports on a computer. The port manager 14 can communicate with the devices connected to its ports and determine their status. In some cases, a bi-directional communication 16 may be established between a port manager 12 and a printing device 14. This communication is generally carried out using a printing or communication protocol. Using this protocol or a similar process, a printing device status may be determined by the port manager 12 and communicated back to the MPP 10. In this way, a port manager may typically determine printing device status such as conditions where a printing device is offline, busy, ready to print, or in an error state. Other status conditions may also be determined according to the capabilities and limitations of the port manager, printing/communications protocol, printing device, operating system and other factors. Depending on these factors, an estimated time to current job completion, printer speeds (i.e., ppm) particular error state details and other status details may also be determined.


Embodiments of the present invention may also be used to detect printing device status on network printing devices. This may be done in several ways. Some of these methods are described in reference to FIG. 2. A status detecting print processor (SDPP) 20 may communicate with a port manager 22 and access information regarding devices connected to its ports. In a network environment, a port manager 22 may communicate with a print server 26 and obtain information about a network print queue 28. A port manager 22 may use an application program interface (API) to communicate with the print server 26 and obtain network queue 28 information. As a non-limiting example, in a Microsoft Windows® environment the “(GetPrinter)” call may be used to obtain printer queue 28 information. Printer queue 28 information may comprise the number of print jobs in the queue which may be used to determine if the associated printer 24 is busy or idle.


A SDPP 20 may communicate directly with a network printer 24 by pinging 30 the printer 24 to determine its status. If a printer 24 responds to the ping 30, the SDPP may determine that the printer 24 is online in a ready to print or busy state or offline in an error state (off.errorstate). If a printer 24 does not respond to a ping 30, the SDPP may determine that the printer 24 is offline.


Some embodiments of the present invention may also comprise a SDPP 20 which employs a communication protocol 32 to communicate directly with a network printing device 24. A SDPP 20 may use the Simple Network Management Protocol (SNMP) to send protocol data units (PDUs) to network devices and gather information from device Management Information Bases (MIBs) to determine device status. Using this technique, a SDPP 20 may determine if a printing device is offline, busy, ready to print, in an error state and other status information. When a printing device 24 is busy, more detail can be obtained such as print job identification, job size, estimated time to completion and other details. When a printing device 24 is ready, more detail may also be obtained such as whether the printing device 24 is idle (cool) or warm. A newer remote monitoring protocol (RMON) may also be used to determine printing device status. RMON embodiments utilize additional MIBs beyond those established for SNMP protocols. In addition to printing device information, RMON embodiments may also gather network traffic data to further refine a deviceuser's status. Other embodiment may comprise an Internet Printing Protocol (IPP) and HTTP servers.


Embodiments of the present invention may also detect the status of remote printing devices as shown in FIG. 3. Remote printing devices 44 may be connected to a computing device at a location that is not directly connected to the computing device and that is not directly connected to the network of the computing device. These printing devices are generally connected through an internet connection via an IP address 46.


The status of remote printing devices 44 may be detected by methods similar to those used for network printing devices. A SDPP 40 may ping 48 a remote printing device 44 directly via its IP address 46 and determine a ready or offline status based on a response or lack of response, respectively. A SDPP 40 may also utilize communications protocols 50 such as SNMP and RMON to communicate directly with a printing device 44 and access status information contained in the device's MIBs. These communications protocol methods may be used to determine if a printing device is offline, busy, ready to print, in an error state or other status information. When a printing device 44 is busy, more detail can be obtained such as print job identification, job size, estimated time to completion and other details. When a printing device 44 is ready, more detail may also be obtained such as whether the printing device 24 is idle (cool) or warm.


A SDPP 40 may also communicate 52 with a remote printing device 44 through a port manager 42. Through the port manager 42, an API may be used to communicate with the remote printing device 44 and ascertain the status of the printing device. In some embodiments, a Graphical Device Interface (GDI) API may be used to determine printing device status.


Some embodiments of the present invention, as shown diagrammatically in FIG. 4, enable a computing device to detect the status of printing devices and direct a print task according to device availability. Typically, a print task is initiated 60 from an application program, an operating system command or some other method. This initial procedure generally activates a print driver which may allow a user to select a print destination and format. A user generally selects a destination device that is appropriate for the desired task. The capabilities and limitations of this selected destination device may be used by these embodiments to determine compatible devices parameters.


Once the task is defined by the driver, it may create a print task spool file which is sent to a spooler. The spooler, then, sends the print task to a print processor for interpretation. In these embodiments of the present invention, the print processor may detect 62 the status of printing devices to determine their availability and capacity to perform a print task. When an available printing device is detected, the print processor may direct 64 the print task to the available device. This device to which the task is directed may be the device initially selected by a user, or another device selected by the print processor according to availability or some other parameter. The initially selected device may also be a virtual device.


Embodiments of the present invention may switch or redirect tasks between any printing devices that are compatible. Printing devices, such as printers, are generally compatible when they share the same Page Description Language (PDL) and have marking engines that share a similar geometric format. Other types of printing devices may be compatible when they share the same driver or description language.


Other embodiments of the present invention may employ a user interface to prompt for user selection of available devices as shown in FIG. 5. In these embodiments, a print task is initiated 70 and the task is transmitted through the necessary drivers, spoolers and other processes until it arrives at a print processor. The print processor, then, checks 72 the status of printing devices in communication with it and compiles a list of available printing devices. This list of available devices is presented 74 to a user and the user is prompted to make a selection among the available devices. Any form of user interface may be used to prompt the user, such as a dialog box, checkbox list or some other selection interface. The user selects 76 a preferred device in the case of a single device task or, in the case of a cluster printing task, a user may select a group of available devices. Once a device or devices has been selected, the print processor of the present invention directs 78 the print task to the selected printing device or devices.


Further embodiments of the present invention may be used to accomplish a print task rollover process as illustrated in FIG. 6. A print rollover process is used to prevent print task delays when a default or preferred printer or printers are busy, offline or otherwise unavailable or unusable. In the print rollover process, a user generally selects a default printing device 80 which may be stored according to many known methods. A user then initiates a print task 82. This can be done in a variety of ways including, but not limited to, selecting a print option in an application, running a batch file and others. Once the print task is initiated 82, or during initiation, a print driver is typically used to create a spool file that is sent to a spooler for spooling to a print processor. In embodiments of the present invention, the print processor is a SDPP which checks the status 84 of printing devices that are in communication with the SDPP. These may be local, network or remote printing devices. Among these printing devices is the default printing device previously selected 80. The SDPP of these embodiments checks the status of the default printing device 84 and determines its availability. When the default printer is available 86, the print job is sent to the default printer 88 through typical printing channels. Once the print job has been sent, the SDPP or related code may notify 90 the user of the job destination. However, when the job is sent to the default printer 88, as expected by the user, notification 90 is optional.


When the default printer is not available 86, these embodiments check the status of other printing devices to determine if any of them are available 92. If another printing device is available, the print task is “rolled over” 94 or directed to that available printing device instead of the default device. When this occurs, the user may be notified 96 of the new destination of the print task. If no printing devices are available 92, other options may be executed. In some embodiments, the print task may be cancelled 98 and the user may be notified 100 of the unsuccessful attempt. In other embodiments, the print processor may wait 102 for a period of time, suspend until re-initiated by the user or wait for some other event to occur after which it may again check the status of printing devices 84. If the default device or another device becomes available during the wait period, the print task may be directed to that device as if it were available before the wait period.


Other embodiments of the present invention, illustrated diagrammatically in FIG. 7, may consider printing devices in a busy state. In these embodiments, a default device is generally selected 110 at some time prior to initiating a print task 112. After print task initiation 112, a print task follows typical print processes until it is routed to a print processor. When the task arrives at the print processor, the print processor checks the status 114 of printing devices and determines whether the devices are available or busy. A status of available or busy may depend on several parameters, but typically, an available printing device will be idle with no print tasks in its queue or memory and a busy printing device will be printing with or without print task in its queue. The actual conditions defining a busy or available status may vary according to a user's needs. Variables such as the number of tasks in a print queue, task size, estimated time to completion and other factors may be used to determine a device status as available, busy or other states.


Once the status of devices has been determined, the print processor determines whether the default printing device is available 114. If the default device is available, the print processor will direct the print task to the default device 118. Optional notification to the user of the destination of the print task 120 may be performed. If the default device is not available, the print processor may determine if other printing devices are available 122. If another printing device is available, the print processor may direct the task 124 to the available device and notify the user of the task destination 126.


When no printing devices are available 122, these embodiments may determine if the unavailable printing devices are simply in a busy state 128. If a printing device is simply busy, the print job is rolled over 130 to the busy printing device and the user is notified 132 of the final destination of the print job. When no printing devices are available and none are busy, the print job may be cancelled 134 and the user notified 136 that no printing devices are currently responding. Alternatively to task cancellation 134, some embodiments may wait for a period of time 138 and re-check the status of the printing devices. After a wait period these embodiments may re-evaluate device status and direct the print task to any available or busy devices which have changed status during the wait period as displayed in FIG. 7. Other embodiments may prompt for user input 138 to determine whether a wait period is desired, to determine the duration of a wait period, to offer task cancellation options or some other user choice. A wait period of user prompt 138 may be activated from any step in the device status detection and task direction processes. For example, and not by way of limitation, a wait period or user prompt 138 may be activated when default device is not available 116, when another device is not available 122, when a busy device cannot be found 128 or at some other point in these processes.


Some embodiments of the present invention are adapted for use in cluster printing environments as shown in FIG. 8. In these embodiments, a user may select one or more preferred printing devices 140 from a pool of printing devices in communication with the user's computing device. Preferred printing devices may be ranked in an order of preference, have no preference or a combination of ranked and non-ranked devices. These devices may also be ranked in multiple ways according to criteria such as speed, availability, location or other criteria. In some embodiments, a group of printers may be selected for cluster printing tasks as a preferred set of printers while one of these printers or another printer may be designated as a preferred printer for a single-printer task.


Once printers have been selected 140, a print task is initiated 142 in a typical manner as described above. When cluster printing options are desired, a cluster-enabled print processor (CPP) 143 of some embodiments of the present invention may modify a print task for cluster printing. Alternatively, a multiple-printer task configured without a CPP may be directed to a status-detecting print processor (SDPP) print processor.


When a SDPP of embodiments of the present invention receives a print task or set of print tasks, the SDPP may check the status 144 of printing devices in communication with it. When, in this example, a multiple-printer task or cluster print task is sent to the SDPP, the SDPP will check whether all printers in the preferred group are available 146. If all the preferred printers are available 146, the SDPP will direct the print tasks or modified print tasks to the preferred printers 148 and notify the user of the task destinations 150.


If all the preferred printers are not available 146, the SDPP may check to see if other printers are available 152. If a sufficient number of other printers are available to make up for the lack of preferred printers, a new group 154 may be formed to which the print tasks may be directed 156 by the SDPP. When print tasks are redirected in this manner, a user may be notified of the final destination of each print task or modified print task.


When a sufficient number of printers are not available to match the number in the preferred group 152, a SDPP may check for busy printers 160. These may be printers which are printing at the time of the status check, printers which will be available within a given time period, printers which have only a given number of jobs in their queue or printers in some other situation that would indicate they will soon be available. Many algorithms may be used to determine a busy status. As a non-limiting example, the maximum time to complete the current load or queue combined with a printer's estimated time to start or load a task. If enough busy printers are found such that when combined with all available printers they are as numerous as the preferred printer group, a new group will be formed 162 with the busy and available printers and the SDPP will direct the print tasks to this group 164. A user may again be notified 166 of the final destination of the print tasks.


If a sufficient number of available and busy printers cannot be found to make up a group equal in size to the initial preferred printer group 160, the initial print task may be reconfigured as a cluster print task that requires fewer printers, such as the number of available printers 168 or the number of available and busy printers combined. When this reconfiguration can be performed, a new smaller group of printers is formed 170 and the SDPP directs the new modified print tasks to printers in this new printer group 172. Again, users may be notified of the destination and configuration of the final modified print tasks 174.


When a sufficient number of printers is simply not available or otherwise unusable, a print task may be cancelled 176 and the user notified 178 of the cancellation and printers' status. Alternatively or additionally, a wait period or user prompt 165 may be added to these processes. A wait period or user prompt may be activated from any point in these processes in order to allow user input to decision-making processes and to allow devices to become available or otherwise change status when a current situation is unacceptable. After a wait period, the initial task or tasks may be re-initialized and printer status checking may begin anew as in some above-described embodiments.


When the number of printers in a network is large and the printers are geographically diverse, a user may want to limit the printers accessed by the SDPP to one or more select groups. Other reasons may also motivate a user to limit accessible printers. Some embodiments of the present invention may accommodate these needs. In some embodiments, illustrated in FIG. 9, a user may select a preferred group of printers 180 to which print tasks will be sent when they are available. Further, a user may select a group of backup printers 182 which may be substituted into the preferred group when printers in that group are not available, busy or otherwise unusable. Preferred and backup printing devices may be ranked in order of preference in some embodiments. Optionally, a user may designate printing devices which should not be used as preferred 180 or backup 182 printing devices thereby eliminating them from consideration by the SDPP. These selection processes allow a user to eliminate printing devices from consideration which are not acceptable to a user by virtue of their location, capability or some other reason.


Once preferred and backup printers have been selected, a user may initiate a cluster printing task or multiple-printer task 184 which is sent to a SDPP of embodiments of the present invention. This may be done through a CPP or my other means. In some embodiments, a CPP may be integrated with a SDPP to perform both cluster-enabling functions and status detection functions. The SDPP, upon receiving task or group of tasks, checks the status of printers in the preferred and backup printer groups 186. If all printers in the preferred group are available 188, the SDPP will direct the print tasks to the preferred group 190 and notify the user of the tasks' destinations.


When some of the preferred printers are not available 188, the SDPP may determine whether backup printers are available 194. If backup printers are available 194, they may be added to the preferred printers which are available to form a new group of available printers 196. The SDPP will then direct the print tasks to this new printer group 198 and notify the user of the destination of the print tasks 200.


When enough backup printers are not available to fill out the preferred group 194, the SDPP may add any busy printers in the preferred group 202 until the number of printers equals the number of preferred printers or the number of printers required for the particular task or tasks. If the addition of busy printers to a group creates a group of sufficient size, a new group is formed 204 and the SDPP may direct the print task or tasks to this new group 206. As in other embodiments, a user may be notified of task destinations and modifications.


If a sufficient number of available or busy printers cannot be found 202, a task may be cancelled 210, and the user notified of the cancellation 212. Alternatively, a SDPP may enter a wait period and restart the status checking process after a period of time. As an additional alternative to cancellation 210, the SDPP may reconfigure a task or tasks for output on a smaller number of printers as described in relation to FIG. 8.


As in some above-described embodiments, a wait period or user prompt 205 may be utilized in these embodiments to allow devices to become available or otherwise change status or to solicit user input at different points in these processes.


The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.

Claims
  • 1. A method of printing using a status-detecting print processor, said method comprising: a) generating a print task on a computing device;b) sending said print task to a print driver wherein said print driver resides on said computing device;c) sending said print task from said print driver to a status-detecting print processor wherein said status-detecting print processor resides on said computing device;d) receiving a print task at said status-detecting print processor;e) detecting, in response to said receiving, the availability of at least one printing device wherein said detecting comprises a direct communication between said status-detecting print processor and said at least one printing device, wherein said detecting further comprises communication using a protocol selected from the group consisting of Simple Network Management Protocol (SNMP), Remote Management (RMON) and Internet Printing Protocol (IPP) andf) directing said print task to an available printing device among said at least one printing device.
  • 2. The method of claim 1 wherein said status-detecting print processor is an integral part of an operating system.
  • 3. The method of claim 1 wherein said detecting further comprises accessing data from a Management Information Base (MIB).
  • 4. The method of claim 1 wherein said detecting further comprises the use of an Application Program Interface (API) call.
  • 5. A method for detecting the status of a printing device on a network, said method comprising: a) receiving a print task at a print processor wherein said receiving is from a print driver and wherein said print processor and said print driver reside on a computing device on which said print task was generated; andb) detecting, in response to said receiving, the status of a printing device on a network wherein said detecting comprises a direct communication between said print processor and said printing device, wherein said detecting further comprises communication using a protocol selected from the group consisting of Simple Network Management Protocol (SNMP), Remote Management (RMON) and Internet Printing Protocol (IPP) and wherein said detecting further comprises the use of an Application Program Interface (API) call; and wherein said communication does not access a remote computing device.
  • 6. The method of claim 5 wherein said print processor is an integral part of an operating system.
  • 7. The method of claim 5 wherein said detecting further comprises accessing data from a Management Information Base (MIB).
  • 8. A method of improving the probability of successful print task completion using a status-detecting print processor, said method comprising: a) receiving a print task at a status-detecting print processor wherein said receiving is from a print driver and wherein said status-detecting print processor and said print driver reside on a computing device on which said print task was generated;b) detecting, in response to said receiving, through a direct communication between said status-detecting print processor and at least one printing device, the availability of said at least one printing device; wherein said detecting further comprises communication using a protocol selected from the group consisting of Simple Network Management Protocol (SNMP), Remote Management (RMON) and Internet Printing Protocol (IPP) and wherein said status of said at least one printing device is presented to a user for selection of one or more available devices and said directing directs said print task to a device selected by said user;c) directing said print task to an available printing device among said at least one printing device.
RELATED REFERENCES

This application is a continuation of U.S. patent application Ser. No. 09/681,409, filed Mar. 30, 2001 now abandoned, which is a continuation-in-part of U.S. patent application Ser. No. 09/681,208, filed Feb. 22, 2001 now abandoned; U.S. patent application Ser. No. 09/681,409 also claims the benefit of U.S. Provisional Application No. 60/261,132, filed Jan. 11, 2001.

US Referenced Citations (104)
Number Name Date Kind
5128878 Gore et al. Jul 1992 A
5241397 Yamada Aug 1993 A
5287194 Lobiondo Feb 1994 A
5467434 Hower et al. Nov 1995 A
5528734 Sanchez Jun 1996 A
5547178 Costello Aug 1996 A
5550954 Campbell et al. Aug 1996 A
5630062 Okutsu May 1997 A
5697040 Rabjohns et al. Dec 1997 A
5699495 Snipp Dec 1997 A
5822500 Utsunomiya et al. Oct 1998 A
5845058 Shaw et al. Dec 1998 A
5859711 Barry et al. Jan 1999 A
5867706 Martin et al. Feb 1999 A
5897260 Zingher Apr 1999 A
5918988 H.A.M. Van Oijen Jul 1999 A
5940186 Barry et al. Aug 1999 A
5960168 Shaw et al. Sep 1999 A
5978560 Tan et al. Nov 1999 A
5978650 Fischer et al. Nov 1999 A
5982996 Snyders Nov 1999 A
5995721 Rourke et al. Nov 1999 A
5995723 Sperry et al. Nov 1999 A
6049394 Fukushima Apr 2000 A
6055063 Yang et al. Apr 2000 A
6057930 Blossey et al. May 2000 A
6078960 Ballard Jun 2000 A
6088120 Shibusawa et al. Jul 2000 A
6101508 Wolff Aug 2000 A
6118546 Sanchez et al. Sep 2000 A
6148346 Hanson Nov 2000 A
6157465 Suda et al. Dec 2000 A
6172765 Kawamoto Jan 2001 B1
6173295 Goertz et al. Jan 2001 B1
6219151 Manglapus et al. Apr 2001 B1
6229622 Takeda May 2001 B1
6248996 Johnson et al. Jun 2001 B1
RE37258 Patel et al. Jul 2001 E
6266150 Brossman et al. Jul 2001 B1
6320667 Mitsuhashi Nov 2001 B1
6337745 Aiello, Jr. et al. Jan 2002 B1
6348971 Owa et al. Feb 2002 B2
6348972 Taniguchi et al. Feb 2002 B1
6397245 Johnson et al. May 2002 B1
6452692 Yacoub Sep 2002 B1
6474881 Wanda Nov 2002 B1
6476927 Schwarz, Jr. Nov 2002 B1
6509974 Hansen Jan 2003 B1
6529286 King Mar 2003 B1
6552813 Yacoub Apr 2003 B2
6570669 Onuma May 2003 B1
6580521 Nishikawa et al. Jun 2003 B1
6584503 Carney et al. Jun 2003 B1
6609210 Onuma Aug 2003 B1
6618167 Shah Sep 2003 B1
6654136 Shimada Nov 2003 B2
6654509 Nishikawa et al. Nov 2003 B2
6661531 Murphy et al. Dec 2003 B1
6665082 Takeoka et al. Dec 2003 B1
6697165 Wakai et al. Feb 2004 B2
6700678 Luman Mar 2004 B1
6707568 Yu Mar 2004 B1
6724494 Danknick Apr 2004 B1
6748471 Keeney et al. Jun 2004 B1
6757071 Goodman et al. Jun 2004 B1
6816270 Cooper et al. Nov 2004 B1
6825943 Barry et al. Nov 2004 B1
6863367 Hamamoto et al. Mar 2005 B2
6981632 Schwartz May 2005 B2
6956664 Kutty Oct 2005 B1
6965958 Sugiyama Nov 2005 B1
6985245 Takahashi Jan 2006 B1
7031014 Ohwa Apr 2006 B2
7046384 Ferlitsch et al. May 2006 B2
7072057 Hansen Jul 2006 B1
7081969 Motomed et al. Jul 2006 B1
7084998 Blair et al. Aug 2006 B2
7139085 Sakaguchi Nov 2006 B1
7148980 Tominaga Dec 2006 B2
7155669 Nakagiri et al. Dec 2006 B1
7161693 Kizaki et al. Jan 2007 B2
7239411 Kelsey Jul 2007 B2
20010038462 Teeuwen et al. Nov 2001 A1
20020001495 Mochizuki Jan 2002 A1
20020027673 Roosen et al. Mar 2002 A1
20020042798 Takei et al. Apr 2002 A1
20020059489 Davis et al. May 2002 A1
20020060801 Motomed et al. May 2002 A1
20020101600 Sabbagh et al. Aug 2002 A1
20020101604 Mima et al. Aug 2002 A1
20020112037 Koss Aug 2002 A1
20020113989 Ferlitsch et al. Aug 2002 A1
20020138564 Treptow et al. Sep 2002 A1
20020163665 Iwata et al. Nov 2002 A1
20020186407 Laughlin Dec 2002 A1
20030002069 Bhogal et al. Jan 2003 A1
20030011812 Sesek et al. Jan 2003 A1
20030038964 Ferlitsch Feb 2003 A1
20030048472 Perdu et al. Mar 2003 A1
20030184782 Perkins et al. Oct 2003 A1
20040042042 Utsunomiya Mar 2004 A1
20040105122 Schaeffer Jun 2004 A1
20060033958 d'Entrecasteaux Feb 2006 A1
20060155825 Torii Jul 2006 A1
Foreign Referenced Citations (35)
Number Date Country
0738949 Dec 1996 EP
64-014043 Jan 1989 JP
03282727 Dec 1991 JP
04-199218 Jul 1992 JP
04217550 Aug 1992 JP
05-270064 Oct 1993 JP
06-004239 Jan 1994 JP
07219731 Aug 1995 JP
08-101754 Apr 1996 JP
09-030040 Feb 1997 JP
09222964 Aug 1997 JP
09-319530 Dec 1997 JP
10-027149 Jan 1998 JP
10027076 Jan 1998 JP
10-031750 Feb 1998 JP
10154049 Jun 1998 JP
10-187393 Jul 1998 JP
10-207643 Aug 1998 JP
10240477 Sep 1998 JP
10-283130 Oct 1998 JP
10-340166 Dec 1998 JP
10-340167 Dec 1998 JP
11-015608 Jan 1999 JP
11-024860 Jan 1999 JP
11110143 Apr 1999 JP
11-143661 May 1999 JP
11219265 Aug 1999 JP
11296333 Oct 1999 JP
2000003258 Jan 2000 JP
2000-099303 Apr 2000 JP
2000-132347 May 2000 JP
2000-151873 May 2000 JP
2001071590 Mar 2001 JP
2001-088405 Apr 2001 JP
WO0131432 May 2001 WO
Related Publications (1)
Number Date Country
20070127063 A1 Jun 2007 US
Provisional Applications (1)
Number Date Country
60261132 Jan 2001 US
Continuations (1)
Number Date Country
Parent 09681409 Mar 2001 US
Child 11548683 US
Continuation in Parts (1)
Number Date Country
Parent 09681208 Feb 2001 US
Child 09681409 US