Summary: | More and more low-end printers have started relying on the Windows Workstations graphic services to render their output. While this lowers the cost of the printer slightly, there are distinct disadvantages to them in many cases. This FAQ deals with what exactly a GDI printer is, what the drawbacks of using one are, and how this affects applications that use them. |
This has several major implications for using GDI printers:
(1) GDI printers require high bandwidth to deliver their output. Rather than delivering a stream of characters and escape sequences describing how the printer is to render the output, all output is rendered graphically, requiring considerably more information to move between the PC and the printer to form any given output on the printer. It also means that the PC spends more time transmitting data on the printer interface.
(2) GDI printers impose a load on the host PC to format their printing. The act of rendition of the page is done dot-by-dot by the graphic engine of the host PC's operating system; the output occupies more space than a character stream, so that more PC memory (both RAM and disk space) are used, and must be maintained until the completion of the print job to allow for rewind and recovery.
(3) There are no fixed capabilities of the GDI printer. This can be a good or bad thing; as improvements are made in the GDI capabilities of Windows, the printer inherits these capabilities indirectly. But this is a bad thing, in that in the event that you want to use that old 32MB Win98 box that's about to get scrapped as a print server, the GDI is less capable, and the available resources are starting off on the short end of the stick.
(4) Programs that don't talk to Windows can't use the printer. Many of us are stuck with old apps that don't talk to the Windows GDI for output; perhaps we have reports that are formed by sending streams of characters and escape sequences to the printer directly to maximize print speed or suppress Windows page feed problems. Well, these apps will never be able to talk to the GDI printer, since it doesn't have an internal rendering engine or printer control language to rely on.
(5) GDI printers are saddled by the limitations of the GDI resources on the host. This is most severe under Win9x, where the 64K block of memory devoted to GDI buffering is shared amongst all processes on the system; at least under NT/2K/XP, each process gets its own 64K of GDI resource.
GDI printers are a different class of device, not just a different model of printer. They can be inkjet or laser printers; what makes them GDI printers is their stand-alone capabilities. Customers must be educated that they are investigating a class of printer, not a difference in manufacturer or model. They're investing in things that are as different as a bicycle and a motorcycle; the bicycle, like the GDI printer, is powered by the rider or host PC, where the motorcycle and non-GDI printer have their own power on-board.
For those of you caught in the dilemma of a client with a GDI device and an app that can't stand them, I can only suggest a couple of possibilities. The best is to scrap the printer. If you can't, try using an interrim print processor such as GhostScript to process the print stream, and then talk through WIndows to the GDI printer; the cost of setup is probably greater than the cost of a new printer, but sometimes it's an easier sell.
http://www.universalthread.com/ViewPageNewFAQ.aspx?ID=15418
Thanks for sharing nice list. Really Like your blog!!
ReplyDeleteDigital Copiers