[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP5763904B2 - プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム - Google Patents

プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム Download PDF

Info

Publication number
JP5763904B2
JP5763904B2 JP2010222435A JP2010222435A JP5763904B2 JP 5763904 B2 JP5763904 B2 JP 5763904B2 JP 2010222435 A JP2010222435 A JP 2010222435A JP 2010222435 A JP2010222435 A JP 2010222435A JP 5763904 B2 JP5763904 B2 JP 5763904B2
Authority
JP
Japan
Prior art keywords
print
request
print job
format
printer driver
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2010222435A
Other languages
English (en)
Other versions
JP2012078998A5 (ja
JP2012078998A (ja
Inventor
光則 飯田
光則 飯田
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Canon Inc filed Critical Canon Inc
Priority to JP2010222435A priority Critical patent/JP5763904B2/ja
Priority to US13/224,916 priority patent/US8630010B2/en
Priority to CN201110295314.5A priority patent/CN102446076B/zh
Publication of JP2012078998A publication Critical patent/JP2012078998A/ja
Publication of JP2012078998A5 publication Critical patent/JP2012078998A5/ja
Application granted granted Critical
Publication of JP5763904B2 publication Critical patent/JP5763904B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K15/00Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers
    • G06K15/002Interacting with the operator
    • G06K15/005Interacting with the operator only locally
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1207Improving or facilitating administration, e.g. print management resulting in the user being informed about print result after a job submission
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1253Configuration of print job parameters, e.g. using UI at the client
    • G06F3/1256User feedback, e.g. print preview, test print, proofing, pre-flight checks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • G06F3/1288Remote printer device, e.g. being remote from client or server in client-server-printer device configuration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K15/00Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers
    • G06K15/40Details not directly involved in printing, e.g. machine management, management of the arrangement as a whole or of its constitutive parts
    • G06K15/4005Sharing resources or data with other data processing systems; Preparing such data
    • G06K15/402Sharing data concerning the arrangement's configuration or current state

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Accessory Devices And Overall Control Thereof (AREA)

Description

本発明は、プルプリント制御を行うプリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラムに関する。
従来、ユーザが印刷装置からサーバ上に一時蓄積された印刷データに対して印刷要求を行うことで当該印刷装置から印刷データの出力を可能にする所謂「プルプリント」の印刷システムが提案されている(例えば、特許文献1参照)。これにより、ユーザはアプリケーションからの印刷時に特定の印刷装置への出力ではなく、所望の印刷装置からの印刷データ出力を可能としている。
また、ユーザが出力を行う印刷文書を指定する際には、サーバ上に一時蓄積されている文書の文書名といくつかの文書属性(両面設定やページ数等)を、印刷装置上の操作パネルに一覧表示している。ユーザはその一覧表示の中から所望の文書を選択することで印刷データを選択することが可能である。
特許第4033857号明細書
しかしながら、プルプリントシステムでは、印刷装置上で印刷文書を特定する時点では、印刷装置に印刷データ自体は存在しないのでプレビュー表示を行うことが困難であった。加えて、サーバ上に一時蓄積された印刷データはPDL(Page Description Language)であり、多種多様な仕様及び機種依存性が存在する。そのため、印刷データからプレビュー画像を生成するためには、対応しようとする機種について、そのPDLを解析可能とする必要があり、多大な労力が必要であった。また、新機能が追加される場合には、PDLも拡張されることが多く、その度にシステムのプログラムを改変していくことは現実的ではない。
一方、印刷装置上のプレビュー表示はおおよその文書内容がわかれば十分であるが、プレビューを表示するためだけに印刷データを印刷装置に送信するのは通信上の負荷が高い。さらに、印刷データからプレビュー画像を生成する処理は、印刷装置上の処理としては負荷が高い。
上記課題を解決するため、本発明は以下の構成を有する。すなわち、印刷装置に送信される前の形式である中間形式の印刷ジョブを記憶するプリントサーバと印刷装置とを含むプリントシステムであって、前記プリントサーバは、前記中間形式の印刷ジョブを記憶する記憶手段と、前記印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶手段に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成手段と、前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール手段と、前記インストール手段によるインストール処理の対象となった前記プリンタドライバを用いて、前記記憶手段に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成手段と、前記第1生成手段により生成されたプレビュー画像、または、前記第2生成手段により生成された前記印刷データを前記印刷装置に送信する送信手段とを有し、更に、前記インストール手段は、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行し、前記印刷装置は、操作パネルを介して受け付けた指示に従って印刷ジョブを選択する選択手段と、前記選択手段により選択された印刷ジョブの前記プレビュー画像要求を前記プリントサーバへ送信するプレビュー要求送信手段と、前記プレビュー画像要求に従って前記プリントサーバが送信した前記プレビュー画像を受信し、表示する表示手段と、前記選択手段により選択された印刷ジョブの設定変更の要求を前記プリントサーバへ送信する変更要求送信手段と、前記選択手段により選択された印刷ジョブの前記印刷要求を前記プリントサーバへ送信する印刷要求送信手段と、前記印刷要求に従って前記プリントサーバが送信した前記印刷データを受信し、前記印刷データに基づく印刷処理を実行する印刷制御手段とを有する。
本発明により、ユーザが印刷装置からサーバ上に一時蓄積された印刷データに対して印刷要求を行う際に、蓄積されている文書のプレビュー画像を印刷装置上のパネルに表示可能となる。さらに、サーバ上で動作しているジョブ管理プログラムが中間形式の印刷データからプレビュー画像を生成するので、プレビュー表示の処理はPDLや機種に依存せずに本機能を実現することができる。
また、プレビュー表示のためにサーバと印刷装置間を流れるデータはプレビュー表示に必要な小さな画像データのみであるので、通信にかかる負荷を抑えることが可能である。さらに、印刷装置上でプレビューを表示する処理は、サーバからプレビュー画像を受信して画面に表示するだけなので、印刷装置にかける負荷を抑えることができる。
本発明に係るプリントシステムの構成の一例を示すシステム構成図。 本発明に係るハードウェア構成を示すブロック図。 本発明に係る複合機のコントローラユニットの構成の例を示すブロック図。 プリントシステムにおけるプルプリントの全体の流れを説明する模式図。 本発明に係る各データフローの詳細を示す図。 本発明に係るアプリケーションプログラムの印刷画面の一例を示す模式図。 プリントシステムにおける第1の制御処理の例を示すフローチャート。 プリントシステムにおける第2の制御処理の例を示すフローチャート。 プリントシステムにおける第3の制御処理の例を示すフローチャート。 プリントシステムにおける論理プリンタ作成を示すフローチャート。 プリントシステムにおける第4の制御処理の例を示すフローチャート。 プリントシステムにおける第5の制御処理の例を示すフローチャート。 本発明に係るデータ詳細を示す図。 本発明に係るデータ詳細を示す図。 本発明に係るデータ詳細を示す図。 複合機の操作部の表示部に表示される画面の模式図。 複合機の操作部の表示部に表示される画面の模式図。 複合機の操作部の表示部に表示される画面の模式図。 プリントシステムにおける第2の制御処理の例を示すフローチャート。
<第一実施形態>
[システム構成]
以下、本発明を実施するための最良の形態について図面を用いて説明する。図1は、本発明に係る情報処理装置およびプリントサーバ、アドレス管理サーバ、および印刷装置を適用可能なプリントシステムの構成の一例を示すシステム構成図である。図1の「事業所A」に示すように、本実施形態のプリントシステムは、1又は複数のクライアントPC100、1又は複数のプリントサーバ101、1又は複数の複合機102、アドレス管理サーバ103、1又は複数のログインサービスPC104、ディレクトリサービスサーバ105がローカルエリアネットワーク(LAN)106を介して接続される構成となっている。
クライアントPC100には、仮想プリンタドライバがインストールされている。この仮想プリンタドライバは、クライアント・アプリケーションから受け取ったデータに基づいて、特定の複合機に依存しない中間形式の印刷ジョブを生成し、プリントサーバ101へ送信する。なお、中間形式の印刷ジョブとは、フォーマットに関する共通仕様が一般に公開されていて、かつ再編集が容易な形式の印刷データを意味する。例えば、EMFSPOOL形式(Enhanced Metafile Spool Format)、XPS(XML Paper Specification)などがある。本実施形態においては、EMFSPOOL形式を使って説明するが、XPSやPDFなど他の中間形式の印刷データであってもかまわない。
プリントサーバ101は、受信した該印刷ジョブを所定の格納場所に保存する。また、プリントサーバ101は、ジョブ管理データベース(以後、ジョブ管理DBと呼ぶ)を備え、該印刷ジョブに関するメタデータを、ジョブ管理DBに記憶する。プリントサーバ101は、ジョブ管理DBに記録しているメタデータから印刷ジョブ一覧情報(印刷ジョブ一覧データ)を生成し、複合機102へ転送する。プリントサーバ101は、ジョブ管理DBに記憶しているメタデータと複合機102から受信する印刷設定情報とを使って、印刷設定情報の更新を行い、複合機102へ更新した印刷設定情報を転送する。さらに、プリントサーバ101は、上記所定の格納場所に保存している印刷ジョブ及とジョブ管理DBに記録管理しているメタデータとからPDL(Printer Description Language)データを生成し、複合機102へ転送する。
アドレス管理サーバ103は、アドレス管理データベース(以後、アドレス管理DBと呼ぶ)を備える。アドレス管理サーバ103は、本実施形態の「プルプリント」処理の実行時に、印刷ジョブを管理するプリントサーバ101のアドレス情報(以下、アドレス)とユーザ識別子を、アドレス管理DBに記憶する。さらに、アドレス管理サーバ103は、複合機102からの印刷ジョブ一覧要求に応じて、複合機102から受信したユーザ識別子に対応するプリントサーバ101のアドレスを複合機102へ送信する。
ログインサービスPC104は、複合機102のログインサービスとして、ディレクトリサービスサーバ105で記憶されているクライアントPC100のログインユーザ名、パスワード(例えば、マイクロソフト社のWindows(登録商標)のログインユーザ名、パスワード)に基づく認証処理を行う。ここでの認証処理の例として、SSO(Single Sign−ON)が挙げられる。ログインサービスPC104の例として、キヤノン社のセキュリティエージェント(Security Agent)を搭載したパーソナルコンピュータが挙げられる。
ディレクトリサービスサーバ105は、ネットワーク上に存在するサーバ、クライアント、プリンタ等のハードウェア資源や、それらを使用するユーザの属性(クライアントPC100のログインユーザ名、パスワード(例えば、マイクロソフト社のWindows(登録商標)のログインユーザ名、パスワード)を含む)、アクセス権等の情報を記憶する。ディレクトリサービスサーバ105の一例として、アクティブディレクトリ(Active Directory)機能を搭載したサーバが挙げられる。
また、「事業所B」は、1又は複数のクライアントPC100,1又は複数のプリントサーバ101,1又は複数の複合機102がLAN106を介して接続される構成を有する。本実施形態のプリントシステムは、上述した構成の「事業所A」と、1又は複数の「事業所B」とが、WAN107を介して接続される構成であってもよい。
また、各サーバの機能は、一台の装置で複数のサーバとしての機能を実現しても良いし、複数台の装置で、一つの機能を協働して実現しても構わない。
[情報処理装置]
図2を用いて、図1に示したクライアントPC100、プリントサーバ101、アドレス管理サーバ103、ログインサービスPC104、ディレクトリサービスサーバ105に適用可能な情報処理装置のハードウェア構成について説明する。図2は、図1に示したクライアントPC100、プリントサーバ101、アドレス管理サーバ103、ログインサービスPC104、ディレクトリサービスサーバ105に適用可能な情報処理装置のハードウェア構成を示すブロック図である。
図2において、CPU201は、システムバス204に接続される各デバイスやコントローラを統括的に制御する。また、ROM202あるいは外部メモリ211には、CPU201の制御プログラムであるBIOS(Basic Input/Output System)やオペレーティングシステムプログラム(以下、OS)や、各サーバ或いは各PCの実行する機能を実現するために必要な後述する各種プログラム等が記憶されている。RAM203は、CPU201の主メモリ、ワークエリア等として機能する。CPU201は、処理の実行に際して必要なプログラム等をROM202あるいは外部メモリ211からRAM203にロードして、該ロードしたプログラムを実行することで各種動作を実現するものである。また、入力コントローラ205は、キーボード209やマウス(不図示)等のポインティングデバイス等からの入力を制御する。
ビデオコントローラ206は、モニタ210への表示を制御する。一般に、モニタ210は液晶ディスプレイやCRT等の表示器である。これらは必要に応じて管理者が使用するものである。メモリコントローラ207は、ブートプログラム、各種のアプリケーション、編集ファイル、各種データ等を記憶するハードディスク(HD)、SSD(Solid State Drive)、SDメモリーカード等の外部メモリ211へのアクセスを制御する。通信I/Fコントローラ208は、ネットワーク(例えば、図1に示したLAN106)を介して外部機器と接続・通信し、ネットワークでの通信制御処理を実行する。例えば、TCP/IPを用いた通信等が可能である。なお、CPU201は、例えばRAM203内の表示情報用領域へアウトラインフォントの展開(ラスタライズ)処理を実行することにより、モニタ210上での表示を可能としている。
また、CPU201は、モニタ210上のマウスカーソル(不図示)等でのユーザ指示を可能とする。本発明を実現するための後述する各種プログラムは、外部メモリ211に記録されており、必要に応じてRAM203にロードされることによりCPU201によって実行されるものである。さらに、上記プログラムの実行時に用いられる定義ファイル及び各種情報テーブル等も、外部メモリ211に格納されており、これらについての詳細な説明も後述する。
[コントローラユニット]
図3を用いて、図1に示した複合機102を制御するコントローラユニットのハードウェア構成について説明する。図3は、図1に示した複合機102のコントローラユニットのハードウェア構成の一例を示すブロック図である。図3において、コントローラユニット316は、画像入力デバイスとして機能するスキャナ314や、画像出力デバイスとして機能するプリンタ312と接続する。その一方で、コントローラユニット316は、LAN(例えば、図1に示したLAN106)や公衆回線(WAN)(例えば、PSTNまたはISDN等)と接続することで、画像データやデバイス情報の入出力を行う。コントローラユニット316において、CPU301は、システム全体を制御するプロセッサである。RAM302は、CPU301が動作するためのシステムワークメモリであり、プログラムを記録するためのプログラムメモリや、画像データを一時記録するための画像メモリでもある。ROM303は、システムのブートプログラムや各種制御プログラムが格納されている。ハードディスクドライブ(HDD)304は、システムを制御するための各種プログラム、画像データ等を格納する。
操作部インタフェース(操作部I/F)307は、操作部(UI)308とのインタフェース部であり、操作部308に表示する画像データを操作部308に対して出力する。また、操作部I/F307は、操作部308から本システム使用者が入力した情報(例えば、ユーザ情報等)をCPU301に伝える役割をする。なお、操作部308はタッチパネルを有する表示部を備え、該表示部に表示されたボタンを、ユーザが押下(指等でタッチ)することにより、各種指示を行うことができる。ネットワークインタフェース(Network I/F)305は、ネットワーク(LAN)に接続し、データの入出力を行う。モデム(MODEM)306は、公衆回線に接続し、FAXの送受信等のデータの入出力を行う。外部インタフェース(外部I/F)318は、USB、IEEE1394、プリンタポート、RS−232C等の外部入力を受け付けるI/F部である。なお、本実施形態においては認証で必要となるICカードの読み取り用のカードリーダ319が外部I/F318に接続されている。そして、CPU301は、この外部I/F318を介してカードリーダ319によるICカードからの情報読み取りを制御し、該ICカードから読み取られた情報を取得可能である。以上のデバイスがシステムバス309上に配置される。
イメージバスインタフェース(IMAGE BUS I/F)320は、システムバス309と画像データを高速で転送する画像バス315とを接続し、データ構造を変換するバスブリッジである。画像バス315は、PCIバスまたはIEEE1394で構成される。画像バス315上には以下のデバイスが接続される。ラスタイメージプロセッサ(RIP)310は、例えば、PDLコード等のベクトルデータをビットマップイメージに展開する。311はプリンタインタフェース(プリンタI/F)で、プリンタ312とコントローラユニット316を接続し、画像データの同期系/非同期系の変換を行う。また、313はスキャナインタフェース(スキャナI/F)で、スキャナ314とコントローラユニット316を接続し、画像データの同期系/非同期系の変換を行う。317は画像処理部で、入力画像データに対し補正、加工、編集を行い、プリント出力画像データに対して、プリンタの補正、解像度変換等を行う。また、これに加えて、画像処理部317は、画像データの回転や、多値画像データに対してはJPEG、2値画像データはJBIG、MMR、MH等の圧縮伸張処理を行う。
スキャナ314は、原稿となる紙上の画像を照明し、CCDラインセンサで走査することで、ラスタイメージデータとして電気信号に変換する。原稿用紙は原稿フィーダーのトレイにセットし、装置使用者が操作部308から読み取り起動指示することにより、CPU301がスキャナ314に指示を与え、フィーダーは原稿用紙を1枚ずつフィードし原稿画像の読み取り動作を行う。プリンタ312は、ラスタイメージデータを用紙上の画像に変換する部分であり、その方式は感光体ドラムや感光体ベルトを用いた電子写真方式、微少ノズルアレイからインクを吐出して用紙上に直接画像を印字するインクジェット方式等がある。本発明が適用可能であれば、どの方式の装置を用いても構わない。プリント動作の起動は、CPU301からの指示によって開始する。なお、プリンタ312には、異なる用紙サイズまたは異なる用紙向きを選択できるように複数の給紙段を持ち、それに対応した用紙カセットがある。
操作部308は、LCD表示部を有し、LCD上にタッチパネルシートが貼られており、システムの操作画面を表示するとともに、表示してあるキーが押されるとその位置情報を操作部I/F307を介してCPU301に伝える。また、操作部308は、各種操作キーとして、例えば、スタートキー、ストップキー、IDキー、リセットキー等を備える。ここで、操作部308のスタートキーは、原稿画像の読み取り動作を開始する時などに用いる。スタートキーの中央部には、緑と赤の2色LEDがあり、その色によってスタートキーが使える状態にあるかどうかを示す。また、操作部308のストップキーは、稼働中の動作を止める働きをする。また、操作部308のIDキーは、使用者のユーザIDを入力する時に用いる。リセットキーは、操作部からの設定を初期化する時に用いる。
カードリーダ319は、CPU301からの制御により、ICカード(例えば、ソニー社のフェリカ(FeliCa)(登録商標))内に記憶されている情報を読み取り、該読み取った情報を外部I/F318を介してCPU301へ通知する。以上のような構成によって、複合機102は、スキャナ314から読み込んだ画像データをLAN106上に送信し、LAN106から受信した印刷データをプリンタ312により印刷出力することができる。また、スキャナ314から読み込んだ画像データをモデム306により、公衆回線上にFAX送信し、公衆回線からFAX受信した画像データをプリンタ312により出力することできる。
[プルプリント処理の流れ]
図4を用いて、本実施形態のプリントシステムにおけるプルプリントの全体の流れについて説明する。その前に、まず、本実施形態のプルプリントを実行するための前提について説明する。本実施形態のプルプリントを実現するための仮想プリンタドライバ401をクライアントPC100に共有プリンタとしてインストールしておく。仮想プリンタドライバは、クライアント・アプリケーション400から指示された印字や描画命令の出力に基づいてEMFSPOOL形式の印刷ジョブを生成する機能を有する。更に、印刷設定情報の設定を受け付ける機能(ユーザインタフェース)と、その印刷設定情報をインストールされた論理プリンタごとに外部記憶装置に記憶する機能等を有する。また、この印刷設定情報は、米国Microsoft社のWindows(登録商標)の場合、DEVMODE構造体に格納される。このDEVMODE構造体とは、プリンタが使用可能な機能,レイアウト設定,仕上げ設定,給・排紙設定,印字品質設定等の論理プリンタに関するデフォルトの動作条件を含む各種設定を記憶するために、米国Microsoft社が規定したものである。この情報は、インストールされた論理プリンタごとに外部記憶装置に記憶される。各クライアントPC100は、仮想プリンタドライバを前記プリントサーバ101からポイント&プリント等でダウンロードしてインストールして、仮想プリンタドライバの論理プリンタを追加しておく。また、プリントサーバ101は、各プリンタ固有のプリンタドライバをインストールする。図4では、複合機102のプリンタドライバ408が、プリントサーバ101にインストールされている。
以下、本実施形態のプルプリントの全体の流れについて説明する。図4は、本実施形態のプリントシステムにおけるプルプリント(どこでもプリント(登録商標))の全体の流れを説明する模式図である。図4に示すように、まず、ユーザは、クライアントPC100にログインし、該クライアントPC100で実行されるクライアント・アプリケーション400から仮想プリンタドライバ401に対応する論理プリンタへの印刷指示を行う(1−1)。この際、ユーザは仮想プリンタドライバを使って印刷設定情報を設定できる。ただし、ここで設定できる印刷設定情報は、特定のプリンタに特化した設定はできず、汎用的な内容に限られる。具体的には、全てのプリンタで対応できる印刷設定情報である。この印刷指示に応じて、クライアントPC100のクライアント・アプリケーション400は、グラフィックエンジンを介して、仮想プリンタドライバ401にデータを送信する。クライアントPC100の仮想プリンタドライバ401は、該クライアント・アプリケーションからグラフィックエンジン(不図示)を介して受け取ったデータに基づいてデバイスに依存しないEMFSPOOL形式の印刷ジョブを生成する。そして、クライアントPC100は、生成したEMFSPOOL形式の印刷ジョブをプリントサーバ101に送信する(1−2)。
プリントサーバ101にて、プリントプロセッサ402は、仮想プリンタドライバ401から送信されてきたEMFSPOOL形式の印刷ジョブを読み取り、印刷ジョブのメタデータを生成する。そして、プリントプロセッサ402は、ジョブ管理サービス403へメタデータと印刷ジョブを送信する(1−3)。ジョブ管理サービス403は、プリントサーバ101上の所定の格納場所にEMFSPOOL形式の印刷ジョブを保存する。さらにジョブ管理サービス403は、メタデータをジョブ管理DB404(プリントサーバ101の外部記憶装置上に構築される)に登録する(1−4)。このとき、プリントサーバ101は、上記所定の格納場所にEMFSPOOL形式の印刷ジョブを保存するだけで、印刷装置への送信は行わない。さらに、プリントサーバ101は、印刷ジョブの識別子とユーザ識別子をアドレス管理サーバ103上のアドレス管理サービス405へ登録するために送信する(1−5)。
アドレス管理サービス405は、ジョブ管理サービス403から、印刷ジョブの識別子とユーザ識別子を受信すると、プリントサーバ101のアドレスも加えてアドレス管理DB406に登録する(1−6)。なお、アドレス管理DB406は、アドレス管理サーバ103の外部記憶装置上に構築される。本実施形態において、アドレス管理DB406は、アドレス管理サーバ103の外部記憶装置上に構築される。なお、本実施形態では、機器を判別するためのアドレスとしてIPアドレスを使用する。本実施形態では、ジョブ識別子としてGUID(Global Unique Identifier)を使用する。
複合機102は、カードリーダ319により読み取り可能なICカードを検知すると、該ICカード内の個人認証情報を読み取り、該読み取った個人認証情報を認証要求として認証サーバ(不図示)に送信する。個人認証情報は、認証に用いられる情報であり該ICカードの製造番号でも良い。ユーザが一意に特定できる情報であればよく、特に限定するものではない。認証サーバは、複合機102より個人認証情報を受信すると、該個人認証情報の認証処理を認証サーバの外部記憶装置上に記憶されるICカード認証用テーブルに基づいて行い、認証結果を複合機102に返信する。なお、認証処理に成功した場合には、認証結果として、クライアントPC100のユーザ識別子を送信するものとする。なお、この認証サーバの機能を実現できればその機能を有する機器はいずれでも良く、例えば、アドレス管理サーバ103にあってもよい。
複合機102上のパネル・アプリケーション407は、認証に成功した旨の認証結果(クライアントPC100のログインユーザ識別子)を受信する。本実施形態では、ユーザ識別子としてユーザ名を使用する。もちろん、ユーザを識別する手段としてICカードの製造番号などでもかまわない。
パネル・アプリケーション407は、プリントサーバ101に印刷ジョブ一覧を要求するが、その前に印刷ジョブ一覧を取得するためにプリントサーバ101のIPアドレスを取得する前処理を実施する。パネル・アプリケーション407は、アドレス管理サーバ103上のアドレス管理サービス405にユーザ名を送信する(2−1)。これにより、アドレス解決指示手段を実現する。アドレス管理サービス405は、受信したユーザ名に対応するプリントサーバ101のアドレスをアドレス管理DB406から取得する(2−2)。そして、アドレス管理サービス405は、パネル・アプリケーション407へプリントサーバ101のアドレスを返信する(2−3)。このアドレスを受信することにより、パネル・アプリケーション407は、アドレス受信手段を実現する。
パネル・アプリケーション407は、アドレス管理サービス405からプリントサーバ101のIPアドレスを受信すると、取得したアドレスに基づいて、プリントサーバ101上のジョブ管理サービス403へ対し印刷ジョブ一覧を要求する(2−4)。これにより、パネル・アプリケーション407は、一覧要求送信手段を実現する。また、この印刷ジョブ一覧要求を受信することで、ジョブ管理サービス403は、一覧要求受信手段を実現する。ジョブ管理サービス403は、ジョブ管理DB404を参照して(2−5)、該ユーザ名に対応する印刷ジョブ一覧を生成し、パネル・アプリケーション407へ印刷ジョブ一覧を返信する(2−6)。これにより、一覧送信手段を実現する。また、この印刷ジョブ一覧を受信することで、パネル・アプリケーション407は、一覧受信手段を実現する。パネル・アプリケーション407は、ジョブ管理サービス403から印刷ジョブ一覧を受信すると、該印刷データ一覧を操作部308のUI上に表示する。
ユーザにより印刷ジョブが選択され、プレビュー指示がなされると、パネル・アプリケーション407は、該選択された印刷ジョブのプレビュー画像をジョブ管理サービス403に要求する(2−7)。これにより、プレビュー要求送信手段を実現する。また、このプレビュー要求を受信することにより、ジョブ管理サービス403は、プレビュー要求受信手段を実現する。ジョブ管理サービス403は、ジョブ管理DB404を参照して(2−8)、EMFSPOOL形式の該印刷ジョブからプレビュー画像を生成する。これにより、プレビュー生成手段を実現する。そして、ジョブ管理サービス403は、パネル・アプリケーション407へプレビュー画像を返信する(2−9)。これにより、プレビュー送信手段を実現する。また、このプレビュー画像を受信し表示することにより、パネル・アプリケーション407は、プレビュー受信手段を実現する。パネル・アプリケーション407は、ジョブ管理サービス403からプレビュー画像を受信すると、該プレビュー画像を操作部308のUI上に表示する。
そして、ユーザにより、印刷ジョブが選択され、印刷設定情報の変更指示、及び印刷指示がなされると、パネル・アプリケーション407は、該選択された印刷ジョブの印刷設定情報をジョブ管理サービス403に送信する(3−1)。これにより設定変更送信手段を実現する。また、この印刷設定情報の変更を受信することにより、ジョブ管理サービス403は、設定変更受信手段を実現する。ジョブ管理サービス403は、パネル・アプリケーション407から印刷設定情報を受信すると、ジョブ管理DB404を参照して(3−2)、印刷設定情報の変更を行う。そして、ジョブ管理サービス403は、パネル・アプリケーション407へ変更した印刷設定情報を返信する(3−3)。これにより、設定送信手段を実現する。また、送信された印刷設定情報を受信することで、パネル・アプリケーション407は設定受信手段を実現する。パネル・アプリケーション407は送信した印刷設定情報と受信した印刷設定情報を比較し、印刷設定変更が正しく機能したかどうか判定する。正しく機能しなかった場合は、パネル・アプリケーション407は、操作部308のUI上にその旨のメッセージを表示する。
そして、パネル・アプリケーション407は、改めてジョブ管理サービス403に対し印刷要求(出力指示)を行う(4−1)。これにより印刷要求送信手段を実現する。また、この印刷要求を受信することにより、ジョブ管理サービス403は、印刷要求受信手段を実現する。ジョブ管理サービス403は、パネル・アプリケーション407から印刷指示を受信すると、ジョブ管理DB404を参照して印刷ジョブの印刷に必要な情報を取得する(4−2)。そして、ジョブ管理サービス403は、該印刷指示に基づいて印刷処理を実行するために、ジョブ管理DB404から取得した情報に基づいて、EMFSPOOL形式の印刷ジョブを取得する。そして、そのEMFSPOOL形式の印刷ジョブに対するPDL変換処理等の指示をプリンタドライバへ行う(4−3)。その後、プリンタドライバ408は、複合機102にPDLジョブを送信して複合機102で印刷する(4−4)。これにより、ジョブ送信手段を実現する。なお、ここでのPDLジョブとは、印刷ジョブに対して、印刷可能なPDL形式に変換したジョブを指す。このPDL形式のジョブに変換することにより、複合機102にて出力が可能となる。
最後に、ユーザにより、印刷ジョブの削除が指示されると、パネル・アプリケーション407は、ジョブ管理サービス403に対し指定された印刷ジョブの削除を指示する(5−1)。ジョブ管理サービス403は、パネル・アプリケーション407から印刷ジョブの削除要求を受信すると、まず、アドレス管理サービス405へ登録した印刷ジョブ識別子の削除を指示する(5−2)。アドレス管理サービス405は、ジョブ管理サービス403から印刷ジョブ識別子の登録解除要求を受信すると、アドレス管理DB406の該当するレコードを削除する(5−3)。次に、ジョブ管理サービス403は、ジョブ管理DBの該当するレコードを削除し(5−4)、EMFSPOOL形式の印刷ジョブファイルも削除する。
以上、プリントシステム全体の流れを説明した。なお、図5は、図4のプリントシステムにおけるデータの詳細を表形式で表したものである。以降、フローチャートを使って詳細に説明するが、その際に図5を併用して説明を補足していく。
[印刷指示動作]
図1に示したクライアントPC100上で動作するクライアント・アプリケーション400上での印刷指示について説明する。図6は、図1に示したクライアントPC100上で動作するクライアント・アプリケーション400の印刷画面の一例を示す模式図であり、クライアントPC100のCPUの制御により表示器に表示される。610は論理プリンタ選択部で、クライアントPC100に設定されている論理プリンタから、印刷を行う論理プリンタを選択するためのものである。
このプリンタ選択部610において、「どこでも印刷」601は、本実施形態のプルプリント設定された仮想プリンタドライバに対応する論理プリンタとする。さらに、プリンタ選択部610における「Cxxxx ix3250」602,「Cxxxx ix5051」603は、通常のプリンタドライバに対応する論理プリンタとする。ユーザは、プリンタ選択部610で、いずれかの論理プリンタを選択し、OKボタン605をポインティングデバイス(不図示)等で指示する。すると、クライアント・アプリケーション400は、印刷のためのデータを、プリンタ選択部610で選択された論理プリンタに対応するプリンタドライバにグラフィックエンジンを介して送信する。以下、プリンタ選択部610で「どこでも印刷」601が選択されて印刷指示がなされた場合の仮想プリンタドライバの動作について説明する。
[第1の制御処理]
図7は、本発明のプリントシステムにおける第1の制御処理手順の一例を示すフローチャートであり、図4に示した1−1から1−6までの処理手順に対応する。なお、図7に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SA700〜SA702は、図4に示した仮想プリンタドライバ401による印刷ジョブ投入処理に対応する。これらフローチャートの処理は、図1に示したクライアントPC100のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SB700〜SB706は、図4に示したプリントプロセッサ402によるメタデータ生成・送信処理及び印刷ジョブ転送処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC700〜SC709は、図4に示したジョブ管理サービス403によるメタデータ登録処理及び印刷ジョブ保存処理対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SD700〜SD704は、図4に示したアドレス管理サービス405による印刷ジョブ識別子登録処理に対応する。これらフローチャートの処理は、図1に示したアドレス管理サーバ103のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、クライアントPC100の仮想プリンタドライバ401による印刷ジョブ投入処理を説明する。SA700において、仮想プリンタドライバ401の処理が開始する。SA701において、仮想プリンタドライバ401は、図4のクライアント・アプリケーション400から入力されたデータをEMFSPOOL形式の印刷ジョブとして出力する。これは図4の1−1と1−2に相当する。米国Microsoft社のWindows(登録商標)の場合、プリンタドライバへの入力はDDI(Device Driver Interface)と呼ばれるOS(Operating System)による関数呼び出しによって実施される。
仮想プリンタドライバ401は、DDIの呼び出しと同時に渡されるパラメータを解釈して、EMFSPOOL形式の印刷ジョブを生成し、OSが管理するスプーラ(不図示)へ生成したジョブを出力する。一般に、プリンタドライバの役割は、出力対象のデバイスに依存した印刷ジョブを生成し出力することであるが、本実施形態においては、複合機102に依存しない中間形式の印刷ジョブを生成し、出力することが重要である。これによって、複合機102の構成が変更されたとしても、本発明のプリントシステムにおいて仮想プリンタドライバ401の構成に変更は生じない。つまり、複合機固有の機能をプルプリントシステムで使用することが容易に実現できる。SA702で処理を終了する。
次にプリントサーバ101のプリントプロセッサ402によるメタデータ生成・送信処理及び印刷ジョブ転送処理を説明する。米国Microsoft社のWindows(登録商標)の場合、OSがプリントプロセッサに対し印刷ジョブの処理を依頼する際に呼び出すPrintDocumentOnPrintProcessor関数の内部処理を示す。SB700において、プリントプロセッサ402は、プリントサーバ101上で処理を開始する。SB701において、プリントプロセッサ402は、仮想プリンタドライバ401から出力され、OSにて管理されている印刷ジョブの形式に関する情報を取得する。そして、プリントプロセッサ402は、OSのスプーラに出力されたジョブの種類がRAW形式かどうか判定する。RAW形式とは、プリンタドライバが出力した印刷ジョブを意味する。つまり、仮想プリンタドライバ401はSA701にて印刷ジョブを出力しているので、ここではRAW形式と判断され、SB702へ進む。RAW形式と判定されない場合は、SB706へ進み、処理を終わる。SB702において、メタデータを生成する。
メタデータは、図5の「1−3」行の「送信データ」列にある、GUID(Global Unique Identifier)、ジョブ名、ユーザ名、DEVMODE、仮想プリンタドライバの論理プリンタ名である。具体的には、図13(a)のようなXML形式で表現される。JobInfo要素のGuid属性には、本発明のプリントシステムにおいて一意となる印刷ジョブの識別子を記述する。JobInfo要素のJobName属性には、図4の1−1の過程で指定されたジョブの名前を記述する。JobInfo要素のUserName属性には、図4の1−1の過程で印刷を実行したユーザの名前を記述する。JobInfo要素のPrintQueueName属性には、図4の1−1の過程で使用された論理プリンタの名前を記述する。DocumentSettings要素のDEVMODESnapshot属性には、図4の1−1の過程で指定された最初のページの印刷設定情報(DEVMODE)を記述する。なお、DEVMODEはバイナリ形式なので、XMLで記述するためにBase64と呼ばれる手法によりテキスト化している。
SB703において、プリントプロセッサ402は、SB702で生成したメタデータをジョブ管理サービス403へ送信する。米国Microsoft社のWindows(登録商標)の場合、送信プロトコルとして名前付きパイプを使うと高効率である。しかも、後述するユーザトークン取得に関しても名前付きパイプの使用は都合が良い。SB704において、プリントプロセッサ402は、OSのスプーラからスプールデータを読み込む。ここでのスプールデータとは、仮想プリンタドライバ401により出力されたEMFSPOOL形式の印刷ジョブに対応する。そして、SB705において、プリントプロセッサ402は、読み込んだスプールデータをジョブ管理サービス403へ送信する。SB706で処理を終了する。
次にジョブ管理サービス403によるメタデータ登録処理及び印刷ジョブ保存処理を説明する。SC700において、ジョブ管理サービス403はプリントサーバ101上で処理を開始する。SC701において、ジョブ管理サービス403は名前付きパイプのサーバとして機能することによって、プリントプロセッサ402からSB703で送信されたメタデータを図13(a)のようなXML形式で受信する。なお、プリントプロセッサ402とのコネクションを確立する際に、ジョブ管理サービス403は、名前付きパイプのクライアント(即ちプリントプロセッサ402)のユーザトークンを取得する(SC702)。ユーザトークンの使用方法については後述する。
SC703において、ジョブ管理サービス403は、印刷ジョブを保存するファイルパスを決定する。SC704において、ジョブ管理サービス403は、プリントプロセッサ402によるSB706にてSB705から送信されたEMFSPOOL形式の印刷ジョブを受信する。SC705において、ジョブ管理サービス403は、受信したEMFSPOOL形式の印刷ジョブをSC703で決定したファイル名で保存し、SC706において現在の日付・時刻を生成する。これをもって印刷ジョブ投入時刻とする。
SC707において、ジョブ管理サービス403は、SC701で受信したメタデータとSC702で取得したユーザトークンとSC703で決定したファイル名とSC706で生成した日付・時刻を新規レコードとして図4のジョブ管理DB404に登録する。SC708において、ジョブ管理サービス403は、アドレス管理サービス405へ印刷ジョブ識別子登録コマンドを送信する。このとき、ジョブ管理サービス403は、SC701で受信したメタデータに含まれるGUIDとユーザ名も送信する。SC709で処理を終了する。
次にアドレス管理サービス405による印刷ジョブ識別子登録処理を説明する。SD700において、アドレス管理サービス405は、アドレス管理サーバ103上で処理を開始する。SD701において、ジョブ管理サービス403からSC708で送信されたGUIDとユーザ名を受信する。なお、ジョブ管理サービス403とのコネクションを確立する際に、アドレス管理サービス405は、プリントサーバ101のIPアドレスを取得する(SD702)。SD703において、アドレス管理サービス405は、SD701で受信したGUIDとユーザ名とSD702で取得したIPアドレスを図4のアドレス管理DB406に新規レコードとして登録する。SD704で処理を終了する。
[第2の制御処理]
図8は、本発明のプリントシステムにおける第2の制御処理手順(印刷ジョブ一覧表示処理)の一例を示すフローチャートであり、図4に示した2−1から2−6までの処理手順に対応する。なお、図8に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SE800〜SE813は、図4に示したパネル・アプリケーション407による印刷ジョブ一覧表示処理に対応する。これらフローチャートの処理は、図1に示した複合機102のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SD800〜SD807は、図4に示したアドレス管理サービス405によるアドレス解決処理に対応する。これらフローチャートの処理は、図1に示したアドレス管理サーバ103のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC800〜SC810は、図4に示したジョブ管理サービス403による印刷ジョブ一覧生成処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、パネル・アプリケーション407による印刷ジョブ一覧表示処理を説明する。SE800において、パネル・アプリケーション407の処理が開始する。SE801において、パネル・アプリケーション407は、ログイン表示画面(図16(a))を操作部308の表示部に表示するように制御する。そして、SE802において、パネル・アプリケーション4−7は、ICカード等によるユーザ認証を行う。本実施形態において、ユーザ認証は重要なプロセスではないので、ここでは、認証カードの検出方法やICカードの識別ID取得方法や認証サーバによる認証処理といった詳細説明を省略する。
SE803において、パネル・アプリケーション407は、認証結果を判定する。SE803にて認証エラーである旨の認証結果が得られた場合には、SE804において、パネル・アプリケーション407は、エラー表示画面(図16(b))を操作部308の表示部に表示するように制御する。パネル・アプリケーション407は、該エラー表示画面にてOKボタンの押下を受け付けると、SE801に戻り、再度、ログイン表示画面を表示制御する。一方、SE803にて認証が成功したと判定した場合、SE805へ進む。SE805において、パネル・アプリケーション407は、認証に成功したユーザ名を取得する。SE806において、パネル・アプリケーション407は、アドレス管理サービス405にユーザ名を送信する。次に、SE807において、パネル・アプリケーション407は、アドレス管理サービス405からプリントサーバ101のIPアドレスのリストを受信する。つまり、アドレス管理サービス405に対し、ユーザ名で対象となる印刷ジョブを絞り込み、その印刷ジョブを保持するジョブ管理サービスのIPアドレスを返信することを要求している。
続くSE808からSE811までは、IPアドレスのリストからIPアドレスを列挙するループ処理である。SE808において、パネル・アプリケーション407は、IPアドレスのリストからIPアドレスを取り出す。SE809において、パネル・アプリケーション407は、IPアドレスを取り出せたか否かを判定する。IPアドレスを取り出せた場合、SE810へ進み、パネル・アプリケーション407は、ジョブ管理サービス403に印刷ジョブ一覧要求コマンドを送信する。このときユーザ名も併せて送信する。SE811において、パネル・アプリケーション407は、ジョブ管理サービス403から印刷ジョブ一覧を受信する。
この印刷ジョブ一覧は、図5の「2−6」行の「送信データ」列にある、GUID、ジョブ名、部数、両面、カラーモード、ページ集約、日付・時刻である。具体的には、図14のようなXML形式の印刷ジョブ一覧情報として表現される。JobList要素は、ジョブの数だけのJobInfo子要素を保持する。JobInfo要素のGuid属性は図13(a)で説明したGuidと同じものである。JobInfo要素のJobName属性も図13(a)で説明したJobNameと同じものである。一方、DocumentSettings要素が保持する各種属性は図8のものと大きく異なる。
CopyCount属性は、印刷部数を指定する。Duplexing属性は片面印刷を使用するか、両面印刷を使用するかを指定する。具体的には、“OneSided”と記述すると、片面印刷を指定する。“TwoSideLongEdge”と記述すると、両面(長辺綴じ)を指定する。“TwoSidedShortEdge”と記述すると、両面(短辺綴じ)を指定する。OutputColor属性は、色に関する出力方法を指定する。“Color”と記述すると、カラーを指定する。“Monochrome”と記述すると、モノクロを指定する。PagePerSheet属性は、用紙の片面に印刷するように選択できるページ数を指定する。DateTime属性は、ジョブ投入時刻を指定する。SE808からSE811において、パネル・アプリケーション407は、IPアドレスのリストからIPアドレスを取り出し終えると、SE812に進む。SE812にて、パネル・アプリケーション407は、印刷ジョブ一覧表示画面(図16(c))を操作部308の表示部に表示するように制御する。SE813で処理を終了する。
次にアドレス管理サービス405によるアドレス解決処理を説明する。SD800において、アドレス管理サービス405の処理が開始する。SD801において、アドレス管理サービス405は、パネル・アプリケーション407のSE806から送信されるユーザ名を受信する。SD802において、アドレス管理サービス405は、図4のアドレス管理DB406からSD801で得たユーザ名と一致するレコードを探索する。SD803において、アドレス管理サービス405は、探索したレコードから1つのレコードを取り出す。SD804において、アドレス管理サービス405は、レコードを取り出せたかどうか判定する。レコードが取り出せるときは、SD805へ進み、アドレス管理サービス405は、レコードからジョブ管理サービス403が動作するプリントサーバ101のIPアドレスを取り出す。SD803からSD805において、探索した全レコードからIPアドレスを取り出し終えると、SD806へ進み、アドレス管理サービス405は、パネル・アプリケーション407へIPアドレスのリストを返信する。SD807で処理を終了する。
次にジョブ管理サービス403による印刷ジョブ一覧生成処理を説明する。SC800において、ジョブ管理サービス403の処理が開始する。SC801において、ジョブ管理サービス403は、パネル・アプリケーション407のSE810から印刷ジョブ一覧要求を受け付ける。このときジョブ管理サービス03はユーザ名も併せて受信する。SC802において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC801で得たユーザ名と一致するレコードを探索する。SC803において、探索したレコードから1つのレコードを取り出す。
SC804において、ジョブ管理サービス403は、レコードを取り出せるかどうかを判定する。レコードを取り出せるときは、SC805へ進み、ジョブ管理サービス403は、レコードからGUIDとジョブ名とDEVMODEと仮想プリンタドライバの論理プリンタ名とユーザトークンと日付・時刻を取り出す。SC806において、ジョブ管理サービス403は、SC804で得たユーザトークンを使って、自身のスレッドを“偽装”する。スレッドを偽装している間、スレッドは図4のクライアント・アプリケーション400で印刷を実行したユーザのセキュリティコンテキストで実行される。つまり、ここでの“偽装”するとは、ユーザのセキュリティコンテキストを用いて、その権限によりスレッドを実行することを意味する。また、ここで、“スレッド”とは、印刷設定情報の変更により生じるスレッドを意味する。
SC807において、ジョブ管理サービス403は、SC805で得たDEVMODEからカラーモード、両面、ページ集約、部数、といった個々の情報を取り出す。DEVMODEは、プリンタドライバが管理するプリンタドライバ固有のデータ形式であるので、DEVMODEから個々の情報を取り出すためには、DEVMODEを生成したプリンタドライバに問い合わせる必要がある。SC807で仮想プリンタドライバの論理プリンタ名を取得済みなので、この論理プリンタを使ってDEVMODEから個々の情報を取り出すことになる。
一般に、DEVMODEから個々の情報を取り出す手法としては、プリンタドライバにDEVMODEを操作する独自の拡張インタフェースを設けて、そのインタフェースを経由することが多い。近年は、プリントチケットと呼ばれる米国Microsoft社が規定したXMLによる印刷設定格納形式を利用する方法も利用ある。即ち、プリンタドライバがプリントチケットをサポートするならば、DEVMODEをプリントチケットに変換し、プリントチケットから個々の情報を取り出してもよい。
SC808において、ジョブ管理サービス403は、スレッドの偽装を解除する。SC803からSC808において、探索した全レコードから個々の印刷設定情報を取り出し終えると、SC809へ進み、ジョブ管理サービス403は、印刷ジョブ一覧(図14)を生成する。そして、ジョブ管理サービス403は、パネル・アプリケーション407へ印刷ジョブ一覧を返信する。SC810で処理を終了する。
[第2の制御処理(プレビュー表示処理)]
図19は、本発明のプリントシステムにおける第2の制御処理(プレビュー表示処理)の一例を示すフローチャートであり、図4に示した2−7から2−9までの処理手順に対応する。なお、図19に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SE1500〜SE1511は、図4に示したパネル・アプリケーション407によるプレビュー表示処理に対応する。これらフローチャートの処理は、図1に示した複合機102のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC1500〜SC1510は、図4に示したジョブ管理サービス403によるプレビュー画像生成処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、パネル・アプリケーション407によるプレビュー表示処理を説明する。SE1500において、パネル・アプリケーション407の処理が開始する。なお、図8のSE812において、印刷ジョブ一覧表示画面(図16(c))を操作部308の表示部に表示するように制御している。SE1501において、パネル・アプリケーション407は、印刷ジョブの選択とプレビューボタン1423の押下をユーザから受け付ける。すると、SE1502において、パネル・アプリケーション407は、プレビュー画面(図18)を操作部308の表示部に表示するように制御する。
図18のスクロール1451は、プレビュー領域の左右スクロールを制御し、スクロール1452はプレビュー領域の上下スクロールを制御する際に用いられる。ボタン1453は、プレビュー画像を表示するページを制御する際に用いられる。ボタン1554はズームを制御する際に用いられる。拡大ボタン、縮小ボタンを押下するとプレビュー画像の拡大、縮小が行える。なお、図18は、図16(c)において文書名「決算報告書」の印刷ジョブの選択を受け付けて、プレビューボタン1423の押下を受け付けた場合のプレビュー画面の例を示している。
SE1503において、パネル・アプリケーション407は、プレビュー表示に用いるプレビュー画像が既に取得済みであるか否かを判定する。ここでの判定により、表示するページ数や、ズームに変更がなく、既に取得済みのプレビュー用画像にてプレビュー表示が可能である場合には、プレビュー画像を要求しない。プレビュー画像を取得済みである場合には、SE1506へと進む。プレビュー画像が取得されていない場合には、SE1504において、パネル・アプリケーション407は、ジョブ管理サービス403へプレビュー画像要求コマンドを送信する。この際、プレビュー対象の印刷ジョブのGUIDも送信される。
このプレビュー画像要求コマンドでは、図5の「2−7」行の「送信データ」列にある、GUID、プレビュー幅、プレビュー高さ、イメージタイプ、開始ページ、終了ページである。具体的には、図15(a)のようなXML形式で表現される。QueryThumbnail要素のGuid属性は、図13(a)で説明したGuidと同じものである。ThumbnailInfo要素は要求するプレビュー画像の属性を指定する。MaxWidth属性は、要求するプレビュー画像の最大幅を指定する。MaxHeight属性は、要求するプレビュー画像の最大の高さを指定する。ImageType属性は、要求するプレビュー画像の画像形式を指定する。“PNG”と記述するとPNG(Portable Network Graphics)形式画像、“JPEG”と記述するとJPEG(Joint Photographic Expert Group)形式画像、“TIFF”と記述するとTIFF(Tagged Image File Format)形式画像を指定する。StartPage属性は要求するプレビュー画像の開始ページを指定する。EndPage属性は要求するプレビュー画像の終了ページを指定する。図15(a)においては、幅370ドット、高さ370ドットに収まる画像サイズで、画像形式はPNG、1ページ目から1ページ目まで、すなわち、1ページ目のプレビュー画像を指定している。
SE1505において、パネル・アプリケーション407は、ジョブ管理サービス403からプレビュー画像データを受信する。このプレビュー画像データは、図5の「2−9」行の「送信データ」列にある、プレビュー幅、プレビュー高さ、画像データサイズ、画像データである。
具体的には図15(b)のようなXML形式で表現される。ThumbnailList要素は、プレビュー画像のページ数分のThumbnailData子要素を保持する。ThumbnailData要素のWidth属性は、プレビュー画像の幅(実サイズ)を指定する。Height属性は、プレビュー画像の高さ(実サイズ)を指定する。Size属性はプレビュー画像の画像データサイズ(バイト)を指定する。Data属性にはプレビュー画像の画像データを指定する。なお、画像データはバイナリ形式なので、XMLで記述するためにBase64と呼ばれる手法によりテキスト化している。図15(b)においては、幅262ドット、高さ370ドットで画像データサイズが58164バイトとなる1ページ分のプレビュー画像データを示している。
SE1506において、パネル・アプリケーション407は、プレビュー表示領域をクリアする。SE1507において、パネル・アプリケーション407は、プレビュー表示領域にSE1505で受信したプレビュー画像データを用いてプレビュー画像を描画する。SE1508において、パネル・アプリケーション407は、ユーザの入力待ちとなる。SE1509において、パネル・アプリケーション407は、ユーザの入力に応じて、入力コマンドの処理を行う。SE1510において、パネル・アプリケーション407は、SE1508でのユーザ入力が「閉じる」ボタンの押下であったかを判定する。「閉じる」ボタンの押下でなかった場合には、SE1503に戻り、「閉じる」ボタンの押下であった場合には、SE1511で処理を終了する。
なお、SE1503からSE1505の処理については、プレビューに必要なページを必要なサイズで必要となった時点でジョブ管理サービスに対して要求を行っている。この処理については別スレッドを起動して、プレビュー表示を行う印刷ジョブの他ページのプレビュー画像データを取得するようにしてもよい。
次に、ジョブ管理サービス403によるプレビュー画像生成処理を説明する。SC1500において、ジョブ管理サービス403の処理が開始する。SC1501において、ジョブ管理サービス403は、パネル・アプリケーション407のSE1504からプレビュー画像要求コマンドを受信する。SC1502において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC1501で得たGUIDと一致するレコードを探索する。SC1503において、ジョブ管理サービス403は、探索して得られたレコードからEMFSPOOLのファイル名を取得する。SC1504において、ジョブ管理サービス403は、SC1501で受信したプレビュー画像要求コマンドから、生成するプレビュー画像のサイズを算出する。
SC1505において、ジョブ管理サービス403は、引数としてPageCountをSC1501で受信したプレビュー画像要求コマンドの開始ページに設定する。ここで、PageCountは、プレビューを生成するデータにおける取得開始ページからのページ数をカウントする。SC1506において、PageCountページ目のプレビュー画像をSC1503で得たEMFSPOOLから生成する。なお、EMFSPOOL形式の各ページデータはEMF(Enhanced Metafile Format)として格納されている。米国Microsoft社のWindows(登録商標)の場合、EMFからビットマップに変換するにはWindows(登録商標)が備えるAPI(Application Program Interface)を呼び出すことで、容易に実現できる。取得した画像データは、SC1501で受信したプレビュー画像要求コマンドで指定された画像形式に変換される。
SC1507において、ジョブ管理サービス403は、PageCountの値を1増加する。SC1508において、ジョブ管理サービス403は、PageCountがSC1501で受信したプレビュー画像要求コマンドの終了ページよりも大きいか否かを判定する。大きい場合はSC1509に進み、大きくない場合は、SC1506へ戻る。SC1509において、パネル・アプリケーション407へ生成したプレビュー画像データを返信する。SC1510で処理を終了する。
[第3の制御処理]
図9は、本発明のプリントシステムにおける第3の制御処理手順の一例を示すフローチャートであり、図4に示した3−1から3−3までの処理手順に対応する。なお、図9に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SE900〜SE913は、図4に示したパネル・アプリケーション407による印刷設定情報の変更確認、及び印刷指示処理に対応する。これらフローチャートの処理は、図1に示した複合機102のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC900〜SC911は、図4に示したジョブ管理サービス403による印刷設定情報の変更処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、パネル・アプリケーション407による印刷設定情報の変更確認及び印刷指示処理を説明する。SE900において、パネル・アプリケーション407の処理が開始する。なお、図8のSE812において、印刷ジョブ一覧表示画面(図16(c))を操作部308の表示部に表示するように制御している。
SE901において、パネル・アプリケーション407は、印刷ジョブの選択とプリントするボタン1422の押下をユーザから受け付ける。すると、SE902において、パネル・アプリケーション407は、印刷設定情報の変更画面(図17(a))を操作部308の表示部に表示するように制御する。図17(a)の設定1431は、カラーモードの指定を意味し、モノクロとカラーのどちらかをチェックできる。図17(a)の設定1432は、両面・片面の指定を意味し、片面、両面(長辺綴じ)、両面(短辺綴じ)のうち1つを選択できる。図17(a)の設定1433は、ページ集約の指定を意味し、1in1、2in1、4in1、6in1、8in1、9in1、16in1のうち1つを選択できる。図17(a)の設定1434は、印刷部数の指定を意味し、1から9999までの値を指定できる。なお、図17(a)は、図16(c)において文書名「決算報告書」の印刷ジョブの選択を受け付けて、プリントするボタン1422の押下を受け付けた場合の印刷設定情報の変更例を示している。
SE903において、パネル・アプリケーション407は、印刷設定情報の変更をユーザから受け付ける。ここでは、図17(a)の設定1432の両面・片面指定を、片面から両面(長辺綴じ)に変更したとする。SE904において、パネル・アプリケーション407は、印刷設定情報が変更されたかどうか判定する。印刷設定情報が変更されていない場合は、以後の印刷設定変更確認処理をスキップし、SE911へ進む。印刷設定情報が変更された場合は、SE905へ進む。SE905において、パネル・アプリケーション407は、ジョブ管理サービス403へ印刷設定情報を送信する。この印刷設定情報は、図5の「3−1」行の「送信データ」列にある、GUID、部数、両面、カラーモード、ページ集約、複合機のモデル名である。
具体的には、図13(b)のようなXML形式で表現される。JobInfo要素のGuid属性は図13(a)で説明したGuidと同じものである。JobInfo要素のDeviceModelName属性は、図1の複合機102のモデル名を記述する。DocumentSettings要素が保持する各種属性は図14で説明したものと同様である。ただし、SE903で片面を両面(長辺綴じ)に変更しているので、Duplexing属性は“TwoSideLongEdge”になる。SE906において、パネル・アプリケーション407は、ジョブ管理サービス403から印刷設定変更指示が反映された印刷設定情報を受信する。この印刷設定情報は、図5の「3−3」行の「送信データ」列にある、GUID、部数、両面、カラーモード、ページ集約である。具体的には、図13(c)のようなXML形式で表現される。内容は図13(b)とほぼ同じなので説明は省略する。
SE907において、パネル・アプリケーション407は、SE905で送信した印刷設定情報とSE906で受信した印刷設定情報を比較する。前に述べたようにSE905で送信した印刷設定情報ではDuplexing属性を“TwoSideLongEdge”と指定した。しかし、SE906で受信した印刷設定情報のDuplexing属性は“OneSided”となったとする。このように送信設定と受信設定が一致しないことは原理的に大いにありうる。
例えば、SE903で変更対象外の設定情報として用紙サイズがあるが、図4の1−1の段階で用紙サイズは「はがき」になっていたとする。そして、印刷設定情報の禁則条件として、用紙が「はがき」の場合、両面・片面指定は片面しか選択できないとする。かつ、禁則条件適用の優先度は両面・片面指定よりも用紙サイズの指定の方が高いとする。となると、Duplexing属性は常に“OneSided”にならざるを得ない。パネル・アプリケーションに407にプリンタドライバと同様の高度な禁則処理を実装すれば、図17(a)設定変更入力の時点で両面指定を変更できないようにすることも可能であるが、パネル・アプリケーションの実装難易度が非常に高くなる。本実施形態のように、パネル・アプリケーション407では印刷設定情報の禁則処理を行わず、印刷設定情報を変更したら都度、変更可能かどうかプリンタドライバに問い合わせる方が容易な上、汎用性も増す。
SE905で送信した印刷設定情報とSE906で受信した印刷設定情報を比較した結果、差異が無い場合は、SE911へ進む。一方、差異がある場合は、SE908へ進み、パネル・アプリケーション407は、エラー表示画面(図17(b))を操作部308の表示部に表示するように制御する。ここでは、SE906で受信した印刷設定情報のDuplexing属性は“OneSided”になっているので、図17(b)のエラー表示も「片面」から「両面(長辺綴じ)」に変更できなかった旨の内容となっている。SE909において、パネル・アプリケーション407は、印刷続行指示の入力を受け付ける。SE910において、パネル・アプリケーション407は、OKボタン1442の押下を受け付けると、SE911へ進む。SE911の印刷指示処理については後述する。そしてSE912へ進む。一方、図17(b)のエラー表示画面でキャンセルボタン1441の押下をユーザから受け付けると、SE912へ進み、図17(b)のエラー表示画面及び図17(a)の印刷設定情報の変更画面を閉じる。SE913で処理を終了する。
次にジョブ管理サービス403による印刷設定情報の変更処理を説明する。SC900において、ジョブ管理サービス403の処理を開始する。SC901において、ジョブ管理サービス403は、パネル・アプリケーション407のSE905から図13(b)のようなXML形式で印刷設定情報を受信する。SC902において、ジョブ管理サービス403は、印刷設定情報の変更のための論理プリンタを生成する。詳細は図10にて後述する。
SC903において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC901で得たGUIDと一致するレコードを探索する。SC904において、ジョブ管理サービス403は、探索して得られたレコードからDEVMODEとユーザトークンを取得する。SC905において、ジョブ管理サービス403は、SC904で得たユーザトークンを使って、自身のスレッドを偽装する。スレッドを偽装している間、スレッドは図4のクライアント・アプリケーション400で印刷を実行したユーザのセキュリティコンテキストで実行される。SC906において、ジョブ管理サービス403は、SC901で得た個々の印刷設定情報をSC904で得たDEVMODEに適用する。DEVMODEは、プリンタドライバが管理するプリンタドライバ固有のデータ形式であるので、DEVMODEに個々の情報を適用するためには、DEVMODEを生成したプリンタドライバにDEVMODEの更新を依頼する必要がある。
図9におけるSC902で論理プリンタを生成済みなので、この論理プリンタを使ってDEVMODEに対し個々の情報を適用することになる。一般に、DEVMODEに個々の情報を適用する手法としては、プリンタドライバにDEVMODEを操作する独自の拡張インタフェースを設けて、そのインタフェースを経由することが多い。近年は、プリントチケットと呼ばれる米国Microsoft社が規定したXMLによる印刷設定格納形式を利用する方法もある。即ち、プリンタドライバがプリントチケットをサポートするならば、DEVMODEをプリントチケットに変換し、プリントチケットに対し個々の情報を適用し、プリントチケットからDEVMODEに変換してもよい。
SC907において、ジョブ管理サービス403は、ジョブ管理DB404に保存しているDEVMODEをSC906で変更したDEVMODEを使って更新する。SC908において、ジョブ管理サービス403は、SC906で更新したDEVMODEからカラーモード、両面、ページ集約、部数、といった個々の情報を取り出す。個々の情報の取り出し方は、図8のSC807と同じである。SC909において、ジョブ管理サービス403は、スレッドの偽装を解除する。SC910において、ジョブ管理サービス403は、パネル・アプリケーション407へ図13(c)のようなXML形式で変更した印刷設定情報を返信する。SC911で処理を終了する。
[論理プリンタ作成処理]
図10は、図9のSC902で呼び出される論理プリンタ作成処理のフローチャートである。SC1000において、ジョブ管理サービス403の処理を開始する。SC1001において、ジョブ管理サービス403は、図1の複合機102のIPアドレスを取得する。この複合機102のIPアドレスは、パネル・アプリケーション407とのデータ送受信のコネクションが確立した際に入手しておく。SC1002において、ジョブ管理サービス403は、図1の複合機102のモデル名をサポートしたプリンタドライバがプリントサーバ101上にインストールされているかどうか判定する。プリンタドライバがインストールされていない場合、SC1003へ進み、ジョブ管理サービス403は、図1の複合機102のモデル名をサポートしたプリンタドライバをプリントサーバ101上にインストールする。そして、SC1004へ進む。一方、SC1002でプリンタドライバがインストール済みと判定された場合は、SC1004へ進む。なお、この段階でインストール済みとなったプリンタドライバは、図4のプリンタドライバ408に相当する。
SC1004において、ジョブ管理サービス403は、インストール済みのプリンタドライバから構成され、かつ、SC1001で得たIPアドレスを出力ポートとする論理プリンタがプリントサーバ101上に存在するかどうか判定する。存在しない場合、SC1005へ進む。SC1005にて、ジョブ管理サービス403は、インストール済みのプリンタドライバを使ってSC1001で得たIPアドレスを出力ポートとする論理プリンタを生成する。そして、SC1006へ進む。一方、SC1004で存在すると判定された場合は、SC1606へ進む。SC1006で処理を終了する。
[第4の制御処理]
図11は、本発明のプリントシステムにおける第4の制御処理手順の一例を示すフローチャートであり、図9のSE911で呼び出される印刷指示処理のフローチャートでもある。図4に示した4−1から4−4までの処理手順に対応する。なお、図11に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SE1100〜SE1107は、図4に示したパネル・アプリケーション407による印刷指示処理に対応する。これらフローチャートの処理は、図1に示した複合機102のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC1100〜SC1109は、図4に示したジョブ管理サービス403による印刷処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、パネル・アプリケーション407による印刷指示処理を説明する。SE1100において、パネル・アプリケーション407の処理を開始する。SE1101において、パネル・アプリケーション407は、ジョブ管理サービス403へ印刷指示要求コマンドと選択済みの印刷ジョブのGUIDと複合機102のモデル名を送信する。SE1102において、パネル・アプリケーション407は、ジョブ管理サービス403から印刷実行結果(成否)を受信する。SE1103において、パネル・アプリケーション407は、受信した情報に基づき、印刷実行に成功したかどうかを判定する。失敗した場合は、SE1104へ進み、パネル・アプリケーション407は、エラー表示画面(図17(c))を操作部308の表示部に表示するように制御する。そしてSE1107へ進む。一方、SE1103において、印刷実行に成功したと判定した場合は、SE1105へ進む。
SE1105において、パネル・アプリケーション407は、図17(a)のプリント後文書消去チェックボックス1435がチェックされていたかどうかを判定する。プリント後に削除する指示があった場合、SE1106へ進み、パネル・アプリケーション407は、印刷ジョブを削除する。詳細は図12を用いて後述する。そしてSE1107に進む。SE1107で処理を終了する。
次にジョブ管理サービス403による印刷処理を説明する。SC1100において、ジョブ管理サービス403の処理を開始する。SC1101において、ジョブ管理サービス403は、パネル・アプリケーション407のSE1101から印刷指示コマンドと印刷対象の印刷ジョブのGUIDと複合機102のモデル名を受信する。SC1102において、ジョブ管理サービス403は、印刷実行変更のための論理プリンタを作成する。処理内容は、図9のSC902と同じである。詳細は図10で述べた通りである。SC1103において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC1101で得たGUIDと一致するレコードを探索する。SC1104において、ジョブ管理サービス403は、探索して得られたレコードからEMFSPOOLのファイル名とDEVMODEとユーザトークンとを取得する。
SC1105において、ジョブ管理サービス403は、SC1104で得たユーザトークンを使って、自身のスレッドを偽装する。スレッドを偽装している間、スレッドは図4のクライアント・アプリケーション400で印刷を実行したユーザのセキュリティコンテキストで実行される。SC1106において、ジョブ管理サービス403は、SC1102で得た論理プリンタに対し、SC1104で得たEMFSPOOL形式の印刷ジョブとDEVMODEをプリンタドライバ408に送信する。論理プリンタを構成するプリンタドライバ408は、ジョブ管理サービス403から受信したEMFSPOOL形式の印刷ジョブとDEVMODEに基づいてPDL印刷ジョブを生成し、複合機102にPDL印刷ジョブを送信する。SC1107において、ジョブ管理サービス403は、スレッドの偽装を解除する。SC1108において、ジョブ管理サービス403は、パネル・アプリケーション407へ印刷実行結果(成否)を返信する。SC1109で処理を終了する。
[第5の制御処理]
図12は、本発明のプリントシステムにおける第5の制御処理手順の一例を示すフローチャートであり、図4に示した5−1から5−4までの処理手順に対応する。なお、図12に示されたフローチャートにおいて、実線矢印は処理の流れを示し、破線矢印は装置間のデータの送受信を示している。
SE1200〜SE1203は、図4に示したパネル・アプリケーション407による印刷ジョブ削除指示処理に対応する。これらフローチャートの処理は、図1に示した複合機102のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SC1200〜SC1207は、図4に示したジョブ管理サービス403処理による印刷ジョブ削除処理に対応する。これらフローチャートの処理は、図1に示したプリントサーバ101のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
SD1200〜SD1204は、図4に示したアドレス管理サービス405による印刷ジョブ識別子登録解除処理に対応する。これらフローチャートの処理は、図1に示したアドレス管理サーバ103のCPUが外部メモリに格納されたプログラムをRAM上にロードして実行することにより実現される。
まず、パネル・アプリケーション407による印刷ジョブ削除指示処理を説明する。SE1200において、パネル・アプリケーション407の処理を開始する。なお、前述した通りSE1200の呼び出しは、図11のSE1106であるが、図16(c)の消去ボタン1421の押下をユーザから受け付けた場合も同様に当ステップを呼び出す。SE1201において、パネル・アプリケーション407は、削除対象の印刷ジョブのGUIDを取得し、SE1202において、ジョブ管理サービス403へ印刷ジョブ削除指示コマンドを送信する。このとき、パネル・アプリケーション407は、SE1201で取得したGUIDも併せて送信する。SE1203で処理を終了する。
次にジョブ管理サービス403による印刷ジョブ削除処理を説明する。SC1200において、ジョブ管理サービス403の処理を開始する。SC1201において、ジョブ管理サービス403は、パネル・アプリケーション407のSE1202から印刷ジョブ削除指示コマンドと削除対象の印刷ジョブのGUIDを受信する。SC1202において、ジョブ管理サービス403は、アドレス管理サービス405へ印刷ジョブ識別子登録解除コマンドとSC1201で得たGUIDを送信する。
SC1203において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC1201で得たGUIDと一致するレコードを探索する。SC1204において、ジョブ管理サービス403は、探索して得られたレコードからEMFSPOOLのファイル名を取得する。SC1205において、ジョブ管理サービス403は、取得したファイル名に基づいて、EMFSPOOLのファイルを削除する。SC1206において、ジョブ管理サービス403は、図4のジョブ管理DB404からSC1203で得たレコードを削除する。SC1207で処理を終了する。
次にアドレス管理サービス405による印刷ジョブ識別子登録解除処理を説明する。SD1200において、アドレス管理サービス405の処理を開始する。SD1201において、アドレス管理サービス405は、ジョブ管理サービス403のSC1202から印刷ジョブ識別子登録解除コマンドと対象の印刷ジョブ識別子であるGUIDを受信する。SD1202において、アドレス管理サービス405は、図4のアドレス管理DB406からSD1201で得たGUIDと一致するレコードを探索する。SD1203において、アドレス管理サービス405は、図4のジョブ管理DB404からSD1202で得たレコードを削除する。SD1204で処理を終了する。
以上により、ユーザが印刷装置からサーバ上に一時蓄積された印刷データに対して印刷要求を行う際に、蓄積されている文書のプレビュー画像を印刷装置上のパネルに表示可能となる。さらに、サーバ上で動作しているジョブ管理プログラムが中間形式の印刷データからプレビュー画像を生成するので、プレビュー表示の処理はPDLや機種に依存することなく、本機能を実現することができる。
また、プレビュー表示のためにサーバと印刷装置間を流れるデータはプレビュー表示に必要な小さな画像データのみであるので、通信にかかる負荷を抑えることが可能である。さらに、印刷装置上でプレビューを表示する処理は、サーバからプレビュー画像を受信して画面に表示するだけなので、印刷装置にかける負荷を抑えることができる。
<その他の実施形態>
また、本発明は、以下の処理を実行することによっても実現される。即ち、上述した実施形態の機能を実現するソフトウェア(プログラム)を、ネットワーク又は各種記憶媒体を介してシステム或いは装置に供給し、そのシステム或いは装置のコンピュータ(またはCPUやMPU等)がプログラムを読み出して実行する処理である。

Claims (11)

  1. 印刷装置に送信される前の形式である中間形式の印刷ジョブを記憶するプリントサーバと印刷装置とを含むプリントシステムであって、
    前記プリントサーバは、
    前記中間形式の印刷ジョブを記憶する記憶手段と、
    前記印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶手段に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成手段と、
    前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール手段と、
    前記インストール手段によるインストール処理の対象となった前記プリンタドライバを用いて、前記記憶手段に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成手段と、
    前記第1生成手段により生成されたプレビュー画像、または、前記第2生成手段により生成された前記印刷データを前記印刷装置に送信する送信手段と、
    を有し、
    更に、前記インストール手段は、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行し、
    前記印刷装置は、
    操作パネルを介して受け付けた指示に従って印刷ジョブを選択する選択手段と、
    前記選択手段により選択された印刷ジョブの前記プレビュー画像要求を前記プリントサーバへ送信するプレビュー要求送信手段と、
    前記プレビュー画像要求に従って前記プリントサーバが送信した前記プレビュー画像を受信し、表示する表示手段と、
    前記選択手段により選択された印刷ジョブの設定変更の要求を前記プリントサーバへ送信する変更要求送信手段と、
    前記選択手段により選択された印刷ジョブの前記印刷要求を前記プリントサーバへ送信する印刷要求送信手段と、
    前記印刷要求に従って前記プリントサーバが送信した前記印刷データを受信し、前記印刷データに基づく印刷処理を実行する印刷制御手段と、
    を有することを特徴とするプリントシステム。
  2. 記第2生成手段は、前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがすでにインストールされていた場合、当該プリンタドライバを用いて、前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成することを特徴とする請求項1に記載のプリントシステム。
  3. 前記印刷装置のプレビュー要求送信手段は、前記プレビュー画像要求としてプレビュー画像のデータ形式を含む前記プレビュー画像要求を前記プリントサーバへ送信し、
    前記プリントサーバの前記第1生成手段は、前記プレビュー画像要求に含まれるデータ形式のプレビュー画像を生成することを特徴とする請求項1に記載のプリントシステム。
  4. 前記中間形式とは、XPS(XML Paper Specification)、EMF(Enhanced Metafile)、PDF(Portable Document Format)のいずれかであることを特徴とする請求項1に記載のプリントシステム。
  5. 印刷装置の操作パネルを介して受け付けられた指示に従って印刷データを送信するプリントサーバであって、
    フォーマットに関して公開された中間形式の印刷ジョブを記憶する記憶手段と、
    前記印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶手段に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成手段と、
    前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール手段と、
    前記インストール手段によるインストール処理の対象となった前記プリンタドライバを用いて、前記記憶手段に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成手段と、
    前記第1生成手段により生成されたプレビュー画像、または、前記第2生成手段により生成された前記印刷データを前記印刷装置に送信する送信手段と、
    を有し、
    更に、前記インストール手段は、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行することを特徴とするプリントサーバ。
  6. 印刷装置に送信される前の形式である中間形式の印刷ジョブを記憶するプリントサーバと印刷装置とを含むプリントシステムにおける印刷方法であって、
    前記プリントサーバにおいて、
    前記中間形式の印刷ジョブを記憶部に記憶する記憶工程と、
    前記印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶部に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成工程と、
    前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール工程と、
    前記インストール工程においてインストール処理の対象となった前記プリンタドライバを用いて、前記記憶部に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成工程と、
    前記第1生成工程にて生成されたプレビュー画像、または、前記第2生成工程にて生成された前記印刷データを前記印刷装置に送信する送信工程と、
    を有し、
    更に、前記インストール工程において、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行し、
    前記印刷装置において、
    操作パネルを介して受け付けた指示に従って印刷ジョブを選択する選択工程と、
    前記選択工程にて選択された印刷ジョブの前記プレビュー画像要求を前記プリントサーバへ送信するプレビュー要求送信工程と、
    前記プレビュー画像要求に従って前記プリントサーバが送信した前記プレビュー画像を受信し、表示部に表示する表示工程と、
    前記選択工程にて選択された印刷ジョブの設定変更の要求を前記プリントサーバへ送信する変更要求送信工程と、
    前記選択工程にて選択された印刷ジョブの前記印刷要求を前記プリントサーバへ送信する印刷要求送信工程と、
    前記印刷要求に従って前記プリントサーバが送信した前記印刷データを受信し、前記印刷データに基づく印刷処理を実行する印刷制御工程と、
    を有することを特徴とする印刷方法。
  7. 記第2生成工程において、前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがすでにインストールされていた場合、当該プリンタドライバを用いて、前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成することを特徴とする請求項6に記載の印刷方法。
  8. 前記印刷装置のプレビュー要求送信工程において、前記プレビュー画像要求としてプレビュー画像のデータ形式を含む前記プレビュー画像要求を前記プリントサーバへ送信し、
    前記プリントサーバの前記第1生成工程において、前記プレビュー画像要求に含まれるデータ形式のプレビュー画像を生成することを特徴とする請求項6に記載の印刷方法。
  9. 前記中間形式とは、XPS(XML Paper Specification)、EMF(Enhanced Metafile)、PDF(Portable Document Format)のいずれかであることを特徴とする請求項6に記載の印刷方法。
  10. 印刷装置の操作パネルを介して受け付けられた指示に従って印刷データを送信するプリントサーバの制御方法であって、
    フォーマットに関して公開された中間形式の印刷ジョブを記憶部に記憶する記憶工程と、
    前記印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶部に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成工程と、
    前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール工程と、
    前記インストール工程にてインストール処理の対象となった前記プリンタドライバを用いて、前記記憶部に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成工程と、
    前記第1生成工程にて生成されたプレビュー画像、または、前記第2生成工程にて生成された前記印刷データを前記印刷装置に送信する送信工程と、
    を有し、
    更に、前記インストール工程において、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行することを特徴とする制御方法。
  11. コンピューターを、
    フォーマットに関して公開された中間形式の印刷ジョブを記憶する記憶手段、
    印刷装置から前記印刷ジョブに対するプレビュー画像要求を受信した場合、前記記憶手段に記憶された前記中間形式の印刷ジョブからプレビュー画像を生成する第1生成手段、
    前記印刷装置から前記印刷ジョブに対する印刷要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するインストール手段
    前記インストール手段によるインストール処理の対象となった前記プリンタドライバを用いて、前記記憶手段に記憶された前記中間形式の印刷ジョブから前記印刷装置が解釈可能な印刷データを生成する第2生成手段、
    前記第1生成手段により生成されたプレビュー画像、または、前記第2生成手段により生成された前記印刷データを前記印刷装置に送信する送信手段
    として機能させ
    更に、前記インストール手段は、前記印刷装置から前記印刷ジョブに対して行われた設定変更に従う要求を受信した際に、前記印刷装置に対応するプリンタドライバがインストールされていなかった場合、前記印刷装置に対応するプリンタドライバのインストール処理を実行するためのプログラム。
JP2010222435A 2010-09-30 2010-09-30 プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム Expired - Fee Related JP5763904B2 (ja)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2010222435A JP5763904B2 (ja) 2010-09-30 2010-09-30 プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム
US13/224,916 US8630010B2 (en) 2010-09-30 2011-09-02 Printing system, printing method, print server, control method, and computer-readable medium for performing pull print control
CN201110295314.5A CN102446076B (zh) 2010-09-30 2011-09-27 打印系统、打印方法、打印服务器及控制方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2010222435A JP5763904B2 (ja) 2010-09-30 2010-09-30 プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム

Publications (3)

Publication Number Publication Date
JP2012078998A JP2012078998A (ja) 2012-04-19
JP2012078998A5 JP2012078998A5 (ja) 2013-11-14
JP5763904B2 true JP5763904B2 (ja) 2015-08-12

Family

ID=45889583

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2010222435A Expired - Fee Related JP5763904B2 (ja) 2010-09-30 2010-09-30 プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム

Country Status (3)

Country Link
US (1) US8630010B2 (ja)
JP (1) JP5763904B2 (ja)
CN (1) CN102446076B (ja)

Families Citing this family (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8953181B2 (en) * 2010-04-20 2015-02-10 Ricoh Company, Ltd. Virtual print job preview and validation
JP2012186543A (ja) * 2011-03-03 2012-09-27 Ricoh Co Ltd 画像読取装置および画像読取装置の制御プログラム
JP5835964B2 (ja) * 2011-06-27 2015-12-24 キヤノン株式会社 画像処理装置、画像形成システムおよび画像出力方法
JP2013056472A (ja) * 2011-09-08 2013-03-28 Canon Inc 画像形成装置及びその制御方法、並びにプログラム、記録媒体
EP2774029A4 (en) * 2011-10-31 2016-01-13 Hewlett Packard Development Co PRESENTATION OF PERMITS FOR THE PRESENTATION OF CONTENT
JP2013126754A (ja) * 2011-11-16 2013-06-27 Canon Inc プリントシステム、画像形成装置、プリントサーバおよびその制御方法、並びにプログラム
JP5929374B2 (ja) * 2012-03-19 2016-06-08 ブラザー工業株式会社 プログラムおよび情報処理装置
US9462080B2 (en) 2012-04-27 2016-10-04 Hewlett-Packard Development Company, L.P. Management service to manage a file
US8941868B2 (en) * 2012-08-17 2015-01-27 Vistaprint Schweiz Gmbh System and method for processing multiple mailing services orders of varying quantities and address lists
JP5700014B2 (ja) * 2012-09-26 2015-04-15 コニカミノルタ株式会社 印刷システム、印刷制御プログラム、および記録媒体
US8924443B2 (en) * 2012-10-05 2014-12-30 Gary Robin Maze Document management systems and methods
JP6064592B2 (ja) * 2012-12-27 2017-01-25 株式会社リコー 印刷システム、印刷方法、画像形成装置及び制御デバイス
JP6065758B2 (ja) * 2013-06-17 2017-01-25 富士ゼロックス株式会社 印刷システム
JP6303312B2 (ja) * 2013-07-26 2018-04-04 株式会社リコー サービス提供システム及び画像提供方法
US9025192B1 (en) 2014-07-25 2015-05-05 Aol Inc. Systems and methods for dynamic mobile printing based on scheduled events
JP2016062214A (ja) * 2014-09-17 2016-04-25 株式会社リコー 出力システム、端末装置及びプログラム
CN105446669A (zh) * 2014-09-29 2016-03-30 王韧 基于虚拟打印机的医疗数据采集传输方法及其系统
JP2016126604A (ja) * 2015-01-06 2016-07-11 株式会社リコー 端末装置、プログラム、情報処理システム及び出力方法
JP6736306B2 (ja) 2016-02-19 2020-08-05 キヤノン株式会社 印刷システム、画像形成装置、印刷システムの制御方法、画像形成装置の制御方法、及びプログラム
JP6773139B2 (ja) * 2017-02-01 2020-10-21 京セラドキュメントソリューションズ株式会社 サーバー装置及び情報処理システム
JP6658654B2 (ja) * 2017-03-31 2020-03-04 京セラドキュメントソリューションズ株式会社 画像形成システム、サーバー、画像形成装置、及び画像形成方法
WO2019134161A1 (zh) * 2018-01-08 2019-07-11 彩亿印刷有限公司 打印输出管理系统及打印输出的操作方法
CN113608708B (zh) * 2021-10-11 2022-02-01 高德品创(山东)科技有限公司 基于gdi框架的打印预览方法及打印预览装置

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2000242463A (ja) * 1999-02-24 2000-09-08 Nec Corp 印刷システム
JP4345248B2 (ja) * 2001-07-25 2009-10-14 コニカミノルタビジネステクノロジーズ株式会社 印刷データ処理装置、印刷装置、印刷データ処理方法、及び、印刷データ処理プログラム
US7325235B2 (en) 2001-10-23 2008-01-29 Canon Kabushiki Kaisha Data processing apparatus, data processing method, program, and storage medium
JP4045799B2 (ja) * 2001-12-28 2008-02-13 コニカミノルタビジネステクノロジーズ株式会社 プリントシステム
US7365872B2 (en) * 2003-01-03 2008-04-29 Microsoft Corporation Client computer system, method and computer readable medium comprising executable instructions for rendering printable documents in a native printer language on the network
JP4485293B2 (ja) * 2003-09-08 2010-06-16 株式会社リコー 情報処理装置、クライアント端末、画像形成装置、データ加工方法およびその方法をコンピュータに実行させるプログラム
US20050213115A1 (en) * 2004-03-29 2005-09-29 Bruce Johnson Print job system and method
JP4033857B2 (ja) 2004-09-03 2008-01-16 キヤノンマーケティングジャパン株式会社 プリントシステムおよび印刷管理サーバおよび印刷方法および印刷管理方法およびプログラム
JP4520340B2 (ja) * 2005-03-17 2010-08-04 株式会社リコー 印刷制御装置、印刷制御装置の制御方法、印刷制御プログラム及び記録媒体
JP4623469B2 (ja) * 2005-12-27 2011-02-02 キヤノンマーケティングジャパン株式会社 プリントサーバおよびプリントシステムおよびプリント方法およびプログラムおよび記録媒体
JP4274259B2 (ja) * 2007-02-28 2009-06-03 コニカミノルタビジネステクノロジーズ株式会社 プッシュ型プル印刷システム、プル印刷方法及び画像形成装置
JP2009193163A (ja) * 2008-02-12 2009-08-27 Ricoh Co Ltd 画像形成システム、管理装置、通信制御装置、画像形成方法、及び画像形成プログラム
JP5072676B2 (ja) * 2008-03-21 2012-11-14 キヤノン株式会社 情報処理装置、情報処理方法及び印刷システム
JP4650850B2 (ja) * 2008-06-30 2011-03-16 キヤノンマーケティングジャパン株式会社 サーバ装置およびプリンタ設定方法およびプログラムおよび記録媒体
JP2010020545A (ja) * 2008-07-10 2010-01-28 Fuji Xerox Co Ltd 情報処理機器、画像形成装置、画像形成システム、画像処理プログラム
KR20100039138A (ko) * 2008-10-07 2010-04-15 삼성전자주식회사 화상형성장치 및 화상형성장치의 워밍업 방법
JP2010170234A (ja) * 2009-01-20 2010-08-05 Kyocera Mita Corp 画像形成システム、サーバ装置および画像形成装置

Also Published As

Publication number Publication date
US20120081741A1 (en) 2012-04-05
CN102446076B (zh) 2014-11-05
CN102446076A (zh) 2012-05-09
JP2012078998A (ja) 2012-04-19
US8630010B2 (en) 2014-01-14

Similar Documents

Publication Publication Date Title
JP5763904B2 (ja) プリントシステム、印刷方法、プリントサーバおよびその制御方法、並びにプログラム
JP5854654B2 (ja) プリントシステム、印刷方法、プリントサーバ、制御方法、及びプログラム
JP5680926B2 (ja) プリントシステム、印刷方法、プリントサーバ及びその制御方法、並びにプログラム
JP5719198B2 (ja) プリントシステム、情報処理装置、制御方法、およびプログラム
US9258437B2 (en) Printing system, control method, and computer-readable medium for controlling printing of data stored in a print server
US8970865B2 (en) Printing control device, storage medium storing printing control program, and printing control method
JP5677047B2 (ja) 印刷システム、情報処理装置、印刷方法、及び、プログラム
US8582162B2 (en) Information processing apparatus, output method, and storage medium
US8773699B2 (en) Information processing apparatus, printing system, and method for controlling the same
US8941867B2 (en) Printing system, server apparatus, information processing method, and storage medium
JP2007179197A (ja) プリントシステムおよびプリントサーバおよび印刷管理サーバおよび印刷装置およびプリント方法およびプログラムおよび記録媒体
JP2007286831A (ja) プリントシステムおよび印刷管理サーバおよび印刷装置および印刷管理サーバの制御方法および印刷装置の制御方法およびプログラムおよび記憶媒体
JP2012221198A (ja) プリントシステム
JP2012181695A (ja) 情報処理装置、プリントシステム、制御方法、及び、プログラム
JP2011015104A (ja) 画像形成装置とその処理方法およびプログラム
JP2018106612A (ja) 印刷管理システム、印刷管理システムの制御方法及びプログラム
JP5764924B2 (ja) 情報処理装置、情報処理装置の制御方法、プログラム、記憶媒体
JP2003037700A (ja) 画像出力装置、画像出力システム、画像出力装置の制御方法、制御プログラムを提供する媒体、及び制御プログラム
JP2009223382A (ja) 画像形成装置、印刷ドライバ
JPWO2013108377A1 (ja) デバイス、情報処理装置、情報処理システム、制御方法、及びプログラム

Legal Events

Date Code Title Description
A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130927

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20130927

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20140319

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140421

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140612

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20141117

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150108

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20150515

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20150612

R151 Written notification of patent or utility model registration

Ref document number: 5763904

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151

LAPS Cancellation because of no payment of annual fees