JP2019074906A - プログラム - Google Patents

プログラム Download PDF

Info

Publication number
JP2019074906A
JP2019074906A JP2017200310A JP2017200310A JP2019074906A JP 2019074906 A JP2019074906 A JP 2019074906A JP 2017200310 A JP2017200310 A JP 2017200310A JP 2017200310 A JP2017200310 A JP 2017200310A JP 2019074906 A JP2019074906 A JP 2019074906A
Authority
JP
Japan
Prior art keywords
driver
print
information indicating
function
application
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.)
Granted
Application number
JP2017200310A
Other languages
English (en)
Other versions
JP6983614B2 (ja
Inventor
敬二 川嵜
Keiji Kawasaki
敬二 川嵜
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 JP2017200310A priority Critical patent/JP6983614B2/ja
Priority to EP18198389.1A priority patent/EP3471389A3/en
Priority to CN202210630153.9A priority patent/CN114860177A/zh
Priority to CN201811176363.5A priority patent/CN109669645B/zh
Priority to US16/158,178 priority patent/US10747481B2/en
Priority to KR1020180120839A priority patent/KR20190042456A/ko
Publication of JP2019074906A publication Critical patent/JP2019074906A/ja
Priority to US16/926,523 priority patent/US11662963B2/en
Priority to KR1020210146002A priority patent/KR102461063B1/ko
Priority to JP2021189031A priority patent/JP7263491B2/ja
Application granted granted Critical
Publication of JP6983614B2 publication Critical patent/JP6983614B2/ja
Priority to JP2023063875A priority patent/JP2023080177A/ja
Priority to US18/304,209 priority patent/US20230251804A1/en
Priority to JP2024015794A priority patent/JP2024055888A/ja
Priority to JP2024015796A priority patent/JP2024055890A/ja
Priority to JP2024015797A priority patent/JP2024055891A/ja
Priority to JP2024015795A priority patent/JP2024055889A/ja
Priority to JP2024109883A priority patent/JP2024147624A/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • 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/1224Client or server resources management
    • G06F3/1228Printing driverless or using generic drivers
    • 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/1224Client or server resources management
    • G06F3/1225Software update, e.g. print driver, modules, plug-ins, fonts
    • 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/1205Improving or facilitating administration, e.g. print management resulting in increased flexibility in print job configuration, e.g. job settings, print requirements, job tickets
    • 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/1208Improving or facilitating administration, e.g. print management resulting in improved quality of the output result, e.g. print layout, colours, workflows, print preview
    • 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
    • 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/1254Automatic configuration, e.g. by driver
    • 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/1275Print workflow management, e.g. defining or changing a workflow, cross publishing
    • G06F3/1276Print workflow management, e.g. defining or changing a workflow, cross publishing within a printer driver, e.g. driver resides either on a server or on a client
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00204Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a digital computer or a digital computer system, e.g. an internet server
    • H04N1/00209Transmitting or receiving image data, e.g. facsimile data, via a computer, e.g. using e-mail, a computer network, the internet, I-fax
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00352Input means
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00408Display of information to the user, e.g. menus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00408Display of information to the user, e.g. menus
    • H04N1/0044Display of information to the user, e.g. menus for image preview or review, e.g. to help the user position a sheet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00408Display of information to the user, e.g. menus
    • H04N1/00466Display of information to the user, e.g. menus displaying finishing information, e.g. position of punch holes or staple or orientation references
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00408Display of information to the user, e.g. menus
    • H04N1/00472Display of information to the user, e.g. menus using a pop-up window
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00474Output means outputting a plurality of functional options, e.g. scan, copy or print
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00405Output means
    • H04N1/00482Output means outputting a plurality of job set-up options, e.g. number of copies, paper size or resolution
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/0035User-machine interface; Control console
    • H04N1/00501Tailoring a user interface [UI] to specific requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/333Mode signalling or mode changing; Handshaking therefor
    • H04N1/33307Mode signalling or mode changing; Handshaking therefor prior to start of transmission, input or output of the picture signal only
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0077Types of the still picture apparatus
    • H04N2201/0093Facsimile machine

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Quality & Reliability (AREA)
  • Computing Systems (AREA)
  • Accessory Devices And Overall Control Thereof (AREA)
  • Facsimiles In General (AREA)
  • Stored Programmes (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

【課題】 利用されるドライバに応じて、適切な機能を提供すること目的とする。【解決手段】 GUIを提供することが可能なGUIアプリケーションのプログラムであって、描画アプリケーションにより生成された描画データを取得するステップと、所定のデバイスにより前記描画データに基づく所定の処理が行われる際の設定を示す情報を含むデータと、前記ドライバの能力を示す情報を含むデータと、のうち少なくともいずれかを取得するステップと、前記設定を示す情報を含むデータと前記ドライバの能力を示す情報を含むデータとのうち少なくともいずれかにおいて、第1情報が含まれているか判定するステップと、第1表示アイテムを提供するステップと、をコンピュータに実行させ、前記第1情報が含まれているか否かに応じて、前記第1表示アイテムを提供するか否かが変わる。【選択図】 図6

Description

本発明は、プログラムに関する。特に、GUIを提供するアプリケーションのプログラムに関する。
印刷装置の制御用ソフトウェアとしてホストコンピュータにインストールされたプリンタドライバを利用し、ホストコンピュータに接続された印刷装置に対して印刷を行う構成が一般に知られる。ホストコンピュータには、基本ソフトウェアであるオペレーティングシステム(OS)がインストールされており、プリンタドライバはそのOSの規定する仕様に従って構成され、OSから呼び出されて動作する。印刷装置を提供するベンダは、OSの仕様に適合するプリンタドライバを提供することにより、そのOSを用いてプリンタに印刷を指示する手段を提供することができる。OSとしてMicrosoft(登録商標)のWindows(登録商標)8より前のバージョンを利用する場合、プリンタドライバは、V3プリンタドライバと呼ばれるアーキテクチャで構成される。V3プリンタドライバは、ユーザからの印刷要求が発生したタイミングでグラフィカルユーザインタフェース(以下、「ユーザインタフェース」又は「GUI」とも呼ぶ)を表示し、何らかの操作をユーザに促すような機能を提供することができる。例えば、印刷要求が発生すると、V3プリンタドライバの構成物であるコンフィグレーションモジュールの規定のイベントが呼び出されるため、コンフィグレーションモジュールは、そのイベント処理の中でユーザインタフェースを表示することが可能である。
近年、Windows(登録商標)において、V4プリンタドライバと呼ばれる新しいアーキテクチャが登場した。V4プリンタドライバは、セキュリティ性が重視されているため、プリンタドライバそのもののカスタマイズ性は低下している。例えば、前述のコンフィグレーションモジュールはOSにより提供され、ベンダは、その動作をカスタマイズする設定ファイルやスクリプトファイルのみを提供可能である。このようなカスタマイズ性の低下を補うため、印刷装置を提供するベンダは、プリンタドライバの機能を補助するための専用のアプリケーションを提供することができる。このアプリケーションはWindows Store Device App(WSDA)と呼ばれる。印刷装置を提供するベンダは、WSDAを提供することで、特定のアプリケーションから印刷する際の印刷設定画面をカスタマイズすることができる(特許文献1)。
また、V4プリンタドライバは、1つのプリンタドライバで複数の印刷装置をサポートするクラスドライバとして構成可能である。近年、OSが複数のベンダの提供する印刷装置で共通して利用可能な標準的なクラスドライバを提供している。このような標準ドライバは、OSのパッケージの中に同梱されており、ホストコンピュータに任意の印刷装置を接続するだけで利用可能である。よって、印刷装置に適したプリンタドライバを別途インストールする必要が無く、利便性が高い。
特開2017−33052号公報
このように、V4プリンタドライバは、セキュリティ性や利便性が向上している一方で、GUIを提供する機能を有していない等、プリンタドライバそのもののカスタマイズ性は低下している。よって、特許文献1のように、WSDAを用いることにより、V4プリンタドライバのようにGUIを提供する機能を有していないドライバが用いられる場合でも、印刷設定画面等のGUIを提供することができる。しかしながら、従来のWSDAには、依然として機能制限があった。本発明は、このような課題に鑑み、利用されるドライバに応じて、適切な機能を提供すること目的とする。
上述のような課題を解決するため、本発明のプログラムの一態様は、GUI(Graphical User Interface)を提供する機能を有していないドライバが選択された場合にGUIを提供することが可能なGUIアプリケーションのプログラムであって、描画アプリケーションにより生成された描画データを取得するステップと、所定のデバイスにより前記描画データに基づく所定の処理が行われる際の設定を示す情報を含むデータと、前記ドライバの能力を示す情報を含むデータと、のうち少なくともいずれかを取得するステップと、前記設定を示す情報を含むデータと前記ドライバの能力を示す情報を含むデータとのうち少なくともいずれかにおいて、第1情報が含まれているか判定するステップと、第1表示アイテムを提供するステップと、をコンピュータに実行させ、前記第1情報が含まれているか否かに応じて、前記第1表示アイテムを提供するか否かが変わる。
本発明により、利用されるドライバに応じて、適切な機能を提供することが可能となる。

印刷システムのハードウェア構成を示すブロック図。 ドライバ印刷システムのブロック構成図。 Metadataの対応デバイス情報の記述例。 Metadataの印刷時起動アプリケーションの関連付け情報の記述例。 本印刷システムで構築される印刷環境を説明するためのブロック図。 印刷時起動アプリケーションのセットアップ処理のフローチャート。 印刷時起動アプリケーションのUI処理のフローチャート。 印刷時起動アプリケーションの編集及び終了処理のフローチャート。 FaxドライバのPrintCapabilitiesの例。 機種別プリンタドライバのPrintCapabilitiesの例。 共通ドライバのPrintCapabilitiesの例。 標準ドライバのPrintCapabilitiesの例。 機種別プリンタドライバのPrintTicketの例。 FaxドライバのPrintTicketの例。 印刷時起動アプリケーションのサポートする拡張機能の例。 Local Storageに格納される情報の例。 機種別プリンタドライバ接続時のWSDAのユーザインタフェースの模式図。 標準プリンタドライバ接続時のWSDAのユーザインタフェースの模式図。 Faxドライバ接続時の印刷時起動アプリケーションのユーザインタフェースの模式図。 標準プリンタドライバ接続時の印刷時起動アプリケーションのユーザインタフェースの模式図。 印機種別プリンタドライバ接続時の刷時起動アプリケーションのユーザインタフェースの模式図。 印刷指示を行う場合の画面を説明するための模式図。
本発明の実施形態では、GUIアプリケーションにより、ドライバに応じた適切な機能を提供するための例を説明する。このGUIアプリケーションは、V4プリンタドライバのようにGraphical User Interface(以下、「ユーザインタフェース」又は「GUI」とも呼ぶ)を提供する機能を有していないドライバが用いられる場合に起動し、GUIを提供する。
なお、V4プリンタドライバを拡張する従来のWindows Store Device App(WSDA)も、GUIを提供できたが、以下の機能制限があった。具体的には、ユーザ指示によって任意に起動されるものであるため、印刷等の要求時に常にユーザインタフェースを表示したいユースケースには不適合である。さらに、従来のWSDAは印刷設定を変更することを目的に構成されたアプリケーションであるため、印刷要求を発行した描画アプリケーションが生成する描画データ(紙面上に印刷を形成する元となる画像やテキスト情報等)にアクセスすることができない。よって、描画データを表示したり編集したりすることはできない。従って、従来のWSDAは、V4プリンタドライバでは、ユーザからの印刷要求が発生したタイミングで、ユーザインタフェースを表示し、ユーザ操作を受け付けて、それを印刷処理に反映させるような機能の提供は困難であった。
また、従来のWSDAは、接続されたプリンタドライバの能力を示す情報に従って、それを指定するためのユーザインタフェースを提供する。仮にWSDAがプリンタドライバの能力情報に含まれない機能指示を印刷設定に含めたとしても、プリンタドライバにとっては未知の情報であるため有効に機能しない。さらに、前述の通り、従来のWSDAは描画データにアクセスできないため、WSDA自身が機能指示を受けて描画データを編集することもできない。従って、前述のようなOSと共に提供されるクラスドライバに対して印刷装置を提供するベンダがWSDAを提供したとしても、ベンダが独自に機能を拡張することはできなかった。
本発明では、上記した機能制限を受けないアプリケーションを用い、ドライバに応じた適切な機能を提供することができる。以下、添付図面を参照して本発明の好適な実施の形態を詳しく説明する。尚、以下の実施の形態は特許請求の範囲に係る本発明を限定するものでなく、また本実施の形態で説明されている特徴の組み合わせの全てが本発明の解決手段に必須のものとは限らない。なお、同一の構成要素には同一の参照番号を付して、説明を省略する。
<<実施形態1>>
<印刷システムのハードウェア構成>
図1は、印刷システムのハードウェア構成を示すブロック図である。本図において、ホストコンピュータ101は、情報処理装置の一例であり、入力インタフェース110、CPU111、ROM112、RAM113、外部記憶装置114、出力インタフェース115、及び入出力インタフェース116を有する。また、入力インタフェース110には、キーボード118、ポインティングデバイス117などの入力デバイスが接続され、出力インタフェース115には、表示部119などの表示デバイスが接続されている。
ROM112には、初期化プログラムが格納され、外部記憶装置114には、アプリケーションプログラム群、オペレーティングシステム(OS)、プリンタドライバ、その他の各種のデータが格納されている。RAM113は、外部記憶装置114にストアされる各種のプログラムの実行の際のワークメモリ等として使用される。
なお、本実施形態では、CPU111が、ROM112に格納されたプログラムの手順に従って処理を行うことによって、ホストコンピュータ101における後述の機能及び後述するフローチャートに係る処理が実現される。デバイスである印刷装置102は、入出力インタフェース116を介して、ホストコンピュータ101と接続されている。ここでは、ホストコンピュータ101と印刷装置102が分かれて構成されているが、これらが一つの情報処理装置として構成されていても良い。
<ドライバ印刷システムのブロック構成>
図2は、ドライバ印刷システムのブロック構成図である。ここでは、OSとしてMicrosoft(登録商標)のWindows(登録商標)8以降のOSを搭載したホストコンピュータ101を用い、V4プリンタドライバと呼ばれるアーキテクチャで動作する印刷システムを前提として説明する。
ユーザがUWP(Universal Windows Platform)アプリケーション202から印刷を指示すると、OSの機能である不図示のMPD(Modern Print Dialog)により所定の画面が表示される。UWPアプリケーション202は、描画アプリケーションである。MPDにより提供される画面は、印刷結果を画面上で確認できる印刷プレビュー機能と、基本的な印刷設定をユーザが選択可能な機能と、を有する。図22に具体的な例を示す。図22(A)では、描画アプリケーションであるUWPアプリケーションが提供する画面2201において、印刷の指示がなされると、OSのMPDにより図22(B)に示す設定画面2202が表示される。この設定画面2202において、ユーザは、使用するドライバの選択を行うことができる。さらに、設定画面2202において、基本的な印刷設定を指示することもできる。
さらに、MPDは、ユーザからの指示を受け、詳細な印刷設定をユーザが選択可能なWindows Store Device Application(以後、WSDA)207を起動する。具体的には、図22(B)の設定画面2202において「その他の設定」ボタン2203が指定されると、図22(C)に示すWSDAが提供する詳細設定画面2204が表示される。この詳細設定画面2204でユーザは更に詳細な印刷設定を指示することができる。WSDA207は印刷装置を提供するベンダ(以後、プリンタベンダ)が提供するプリンタドライバ201の機能を拡張するためのアプリケーションである。なお、WSDAが提供する詳細設定画面2204内に表示されている原稿画像のように見える画像は、WSDAが元々備えているサンプル画像である。よって、UWPアプリケーションにより生成された描画データに基づくプレビュー画像ではなく、描画データが変わっても変化しないサンプル画像である。WSDA207は、MPDから印刷設定を示す情報を受け取り、ユーザ操作に応じてその設定情報を変更し、MPDに返却する。ここで、印刷設定を示す情報は、OSの定義する書式に基づきXML形式で記述されたものであり、PrintTicketと呼ばれるデータ内に含まれる。WSDA207はPrintTicketを参照及び変更することができるが、描画データ(紙面上に印刷を形成する元となる画像やテキスト情報等)を参照することはできない。また、WSDA207は、MPDが提供する印刷設定画面2202上でユーザがボタン2203を指示した場合にのみ起動されるものであって、印刷設定時に必ず起動されるわけではない。
なお、PrintTicketは、選択されたプリンタドライバ201のコンフィグレーションモジュール208によって生成される。WSDA207は、コンフィグレーションモジュール208を呼び出すことで、ユーザの指定を反映したPrintTicketを生成する。また、コンフィグレーションモジュール208は、選択されたプリンタドライバ201で設定可能な機能と選択項目をOSの定義する書式に基づきXML形式で記述したPrintCapabilitiesを生成する機能も有する。WSDA207や後述するPEX209は、このPrintCapabilitiesに記述された情報に基づきユーザインタフェースを提供する。また、後述する印刷時起動アプリケーション205は、OSの機能を介して、コンフィグレーションモジュール208が生成したPrintCapabilitiesを取得することができる。
なお、図2では、コンフィギュレーションモジュール208をプリンタドライバ201の機能として記載しているが、コンフィギュレーションモジュール208は元々OSの構成物である。ただし、V4プリンタドライバにおいては、ドライバ自体がコンフィグレーションモジュールを備えていないためOSの構成物であるコンフィグレーションモジュール208をドライバのコンフィグレーションモジュールとして利用する。プリンタベンダは、プリンタドライバ201に含まれる不図示のGPDやJava(登録商標)script Constraintによって、コンフィグレーションモジュール208の動作をカスタマイズできる。
図22で示した印刷設定の後に、OSのMPDが提供する設定画面2202において、「印刷」ボタンが指示されると、印刷要求がなされる。MPD上でユーザにより印刷が指示されると、MPDから要求を受け、UWPアプリケーション202は印刷に必要な印刷データを生成する。この印刷データは、XML Paper Specification(以後、XPS)という書式で記述されたXPS文書である。本実施形態の印刷データは、前述のPrintTicketと、描画アプリケーションにより生成された描画データと、を有する。
UWPアプリケーション202が生成したXPS文書は、OSのコンポーネントである印刷時起動アプリランチャー204に渡される。印刷時起動アプリランチャー204は、プリンタドライバ201に関連付けられた印刷時起動アプリケーション205が存在し、かつ起動するように構成されていると判断した場合、印刷時起動アプリケーション205を起動する。なお、該当する印刷時起動アプリケーション205が存在しない場合は、印刷時起動アプリランチャー204はXPS文書をスプールファイル206として格納する。
印刷時起動アプリケーション205は、WSDA207と同様、プリンタベンダが提供するプリンタドライバ201の機能を拡張するためのアプリケーションである。つまり、V4ドライバのようにGUIを提供する機能を有していないドライバが選択された場合に、OSの指示に基づき、GUIを提供することができるGUIアプリケーションである。なお、GUIを提供する機能を有しているV3ドライバが選択された場合は、OSは印刷時起動アプリランチャー204を起動せず、描画アプリケーションが生成したXPS文書をスプールファイル206として格納する。つまり、V3ドライバが選択された場合は、印刷時起動アプリケーション205は起動せず、GUIを提供することもない。。
なお、WSDA207と印刷時起動アプリケーション205は、どちらも、プリンタドライバ201の構成物の1つとして提供されるものではなく、単独のアプリケーションである。また、WSDA207と印刷時起動アプリケーション205とは、合わせて1つのアプリケーションとして構成可能であるが、便宜上、ここでは、従来のWSDAとの差異を説明するため、別々のアプリケーションとして説明する。
WSDA207と印刷時起動アプリケーション205は、通常、OSが、不図示のアプリケーション配布システム(Microsoft(登録商標)が管理するサーバ)からインターネットを経由して取得する。さらに、プリンタベンダが、事前にMicrosoft(登録商標)が管理するMetadata用サーバに、後述のMetadataを提供することで、適切なWSDA207及び印刷時起動アプリケーション205が自動的にインストールされる。具体的には、デバイスである印刷装置102が入出力インタフェース116に接続されると、Metadataに基づき、印刷装置102に関連付けられたWSDA207及び印刷時起動アプリケーション205が自動的にインストールされる。
印刷時起動アプリケーション205は、ユーザから操作指示を受け付けるユーザインタフェースを表示することができる。また、印刷データであるXPS文書を受け取り、XPS文書内のPrintTicket及び描画データを編集することができる。印刷時起動アプリケーション205が必要に応じて編集したXPS文書を出力すると、OSはそれをスプールファイル206として格納する。スプールファイル206が格納されると、フィルタパイプラインマネージャ210に処理が渡される。フィルタパイプラインマネージャ210は、複数のフィルタを通すことで印刷が行われる仕組みで、不図示のコンフィグレーションファイルでフィルタの数や順番が制御される。本実施形態におけるフィルタ群は、レイアウト処理部であるレイアウトフィルタ211と、印刷コマンド変換部である印刷コマンドフィルタ212とを含んで構成される。
レイアウトフィルタ211は、XPSスプールファイル206に格納されたXPS文書を入力とし、印刷設定情報に基づきページのレイアウト処理を行い、レイアウト済みのXPS文書を出力する機能を有する。レイアウト処理とは、例えば複数のページを一つの用紙面に印刷する割り付け印刷や、一つのページを複数の用紙面に印刷するポスター印刷を含む。
印刷コマンドフィルタ212は、レイアウトフィルタ211の出力を入力とし、印刷設定情報に従い、XPS文書を印刷装置102が解釈可能な印刷コマンドに変換し出力する機能を有する。印刷コマンドフィルタ212が入力のXPS文書を一度イメージデータに変換する場合、印刷コマンドフィルタ212は一般的にレンダフィルタと呼ばれる。レンダフィルタは、インクジェットプリンタに代表される廉価なラスタプリンタ用のプリンタドライバにおいて多く見られる。印刷コマンドフィルタ212がレンダフィルタとして動作する場合は、入力のXPS文書を一度イメージデータに変換する。その後、色空間の変換や二値化等の画像処理の過程を経て、ラスタプリンタが解釈可能な印刷コマンドに変換される。
ページプリンタに代表される高機能なプリンタにおいて、印刷装置102が解釈できる印刷コマンドの種類にXPSが含まれる場合、印刷コマンドフィルタ212は、入力のXPS文書を編集してXPS文書を出力する。印刷コマンドフィルタ212にて処理する必要がなければ、入力のXPS文書をそのまま出力しても良いし、若しくは、印刷コマンドフィルタ212はプリンタドライバ201に含められなくても良い。以上が、UWPアプリケーション202からの印刷の基本処理である。
Win32アプリケーション等の描画アプリケーションであるLegacyアプリケーション203は、印刷設定を設定するためにPrinter Extensions209(以後、PEX)を起動することができる。PEXは、コンフィグレーションモジュール208を経由して起動され、ユーザが印刷設定を指定可能なユーザインタフェースを提供することができる。PEX209は、プリンタドライバ201と共にドライバパッケージ内の構成物として提供しても良いし、別で配布しても良い。WSDA207同様、PEX209はPrintTicketを参照及び変更することができるが、描画データ(紙面上に印刷を形成する元となる画像やテキスト情報等)を参照することはできない。また、PEX209は、Legacyアプリケーション203上でユーザが指示した場合にのみ起動されるものであって、印刷時に必ず起動されるわけではない。Legacyアプリケーション203で印刷が指示されると、Legacyアプリケーション203は印刷データとしてXPS文書を生成する。以後の流れは、UWPアプリケーション202からの印刷時と同等であるため省略する。
なお、本構成におけるプリンタドライバ201は、Faxドライバとして機能しても良い。この場合、プリンタドライバ201は、印刷装置が解釈可能な印刷コマンドではなく、印刷装置にFax送信を要求するためのFaxコマンドを生成する。以降の説明においても、便宜上、Faxドライバの場合であっても、プリンタドライバ201として記載し、Fax指示の場合であっても、印刷指示として記載する場合もある。
<印刷装置と印刷時起動アプリケーションを関連付けるMetadata>
図3は、印刷装置102と印刷時起動アプリケーション205を関連付けるMetadata301において、対応デバイス情報を示す記述の一例である。Metadata301には、Metadata301を利用する印刷装置102の一覧を示すHardwareIDListタグ302が記述される。項目303は、MFP1_abcdというHardware IDを持つ印刷装置102がこのMetadataを利用することを示している。同様に、項目304は、MFP2_ijklというHardware IDを持つ印刷装置102がMetadata301を利用することを示している。このように、1つのMetadataに、そのMetadataを利用するデバイスを複数列挙することができる。Metadata301には、デバイスとして2つの印刷装置が指定されているが、1つであっても、3つ以上であっても構わない。なお、Hardware IDとは、印刷装置102から返却される、印刷装置102を一意に特定するための識別情報である。
図4は、デバイスである印刷装置102と、GUIアプリケーションである印刷時起動アプリケーション205と、を関連付けるMetadata301において、関連付ける印刷時起動アプリケーション205を示す記述の一例である。図4のMetadata内には、Metadata301が関連付ける印刷時起動アプリケーション205を示すDeviceCompanionApplicationsタグ401が記述されている。項目402は、12345678−abcd−efgh−ijkl−123456789012というプリンタベンダが提供する、1234abcd.MFPUtilityという印刷時起動アプリケーション205を、HardwareIDListタグ302に列挙された印刷装置102に関連付けることを示す。
ホストコンピュータ101に印刷装置102が接続されると、OSは所定のサーバ(Microsoft(登録商標)が管理するMetadata用サーバ)に登録されているMetadataを検索する。そして、HardwareIDListに、接続された印刷装置102の返却するHardware IDが記述されたMetadataを見つけると、それを印刷装置102の外部記憶装置114に保存する。さらに、OSは、保存したMetadataのDeviceCompanionApplicationタグ401に記述された印刷時起動アプリケーション205を不図示のアプリケーション配布システムから取得する。そして、外部記憶装置114に印刷時起動アプリケーション205をインストールし、印刷装置102と関連付ける。これにより、印刷装置102に対してプリンタドライバ201を経由して印刷要求が発生した際に、関連付けられている印刷時起動アプリケーション205が起動される。
このMetadataはプリンタベンダにより提供されるものである。プリンタベンダは、このMetadataを事前にMicrosoft(登録商標)が管理するMetadata用サーバに提供することにより、ユーザ環境にプリンタドライバ201がインストールされた際に、接続されたデバイスに最適な印刷時起動アプリケーション205を自動的にインストールするように制御することができる。なお、ユーザの指示により、1つのデバイスに対して複数のプリンタドライバ201がインストールされることもあり得る。
<Metadata301で構築される印刷環境>
図5は、Metadata301で構築される印刷環境の一例を示す図である。印刷装置102であるMFP501は、1つの装置中に、印刷機能部504と、受け付けた印刷要求をFaxとして送信するFax機能部505を有する。印刷装置部504は、MFP1_abcdというHardware IDを有する。Fax機能部505は、MFP1_efghというHardware IDを有する。Fax機能部505のHardware IDは、印刷装置部504と同じHardware IDとして、コマンドによって処理を切り替えるよう構成することもできる。
MFP501をホストコンピュータに接続すると、OSは、HardwareIDListタグにMFP1_abcdというHardware IDが記述されているMetadata301を取得する。
さらに、Metadata301に記述されているMFPUtility506という印刷時起動アプリケーション205を取得し、MFP501と関連付ける。なお、Fax機能部505は印刷装置部504と異なるHardware IDを有しているが、OSは、印刷装置102から取得した情報を元に、これら2つの処理部を同一のデバイス(コンポジットデバイス)として判断する。従って、Fax機能部505についても、印刷装置部504と同一のMetadata301並びにMFPUtility506が関連付けられる。なお、Metadata301のHardwareIDList302に、Fax機能部505のHardware IDであるMFP1_efghを記述するよう構成しても良い。
MFP501の印刷装置部504用にインストールされるプリンタドライバ201は複数種類存在しうる。つまり、1つのデバイスであるMFP501に対応するドライバとして、複数のドライバが存在しうる。機種別プリンタドライバ508は、プリンタベンダにより提供されるMFP501の印刷装置部504の専用プリンタドライバである。共通プリンタドライバ509は、プリンタベンダにより提供される、該プリンタベンダの複数種類の印刷装置102を処理可能な、共通プリンタドライバである。そして、複数ベンダにより提供される印刷装置に共通して利用可能なクラスドライバである標準プリンタドライバ510は、OSと共にOSのパッケージ内の機能の1つとして提供されるプリンタドライバである。標準プリンタドライバ510は、標準化された印刷方法を利用することで、幅広い印刷装置102を処理可能なプリンタドライバである。
このように、ある印刷装置102用に利用可能なプリンタドライバ201は複数存在し、利用されるプリンタドライバ201は、インターネット接続状態やOSの種類、利用環境等に応じて異なる。通常、OSは、プリンタドライバのバージョン情報等を参照して、利用可能なプリンタドライバ201のうち、もっとも機能が高く新しいプリンタドライバ201を自動的に選定しインストールする。なお、プリンタドライバ201には、Hardware IDや、Compatible IDと呼ばれる装置を特定するための情報が含まれている。ホストコンピュータ101に印刷装置102が接続されると、OSは印刷装置102からこれらのID情報を取得し、該当するIDを有するプリンタドライバ201を探索し、インストールする。
MFP501のFAX機能部505用には、MFP1_efghというHardware IDを含むFaxドライバ511がインストールされる。また、ホストコンピュータ101に、MFP2_ijklというHardware IDを持つMFP502が接続された場合、このMFP502にはMFPUtility506が関連付けられる。これは、図3の304に示されるように、Metadata301の対象とするHardwareIDListに、MFP2_ijklが含まれているためである。MFP3_mnopというHardware IDを持つMFP503に対しては、Metadata301とは異なる不図示のMetadataの指定に伴って、MFPUtility506とは異なる、MFPUtility507が関連付けられる。
以上のように、印刷装置102を提供するプリンタベンダは、Metadataを提供することで、それぞれの印刷装置102に対してどの印刷時起動アプリケーション205を提供するかを制御することができる。例えば、プリンタベンダは、複数の印刷装置102で共通して一つの印刷時起動アプリケーション205を提供することもできるし、それぞれ異なる印刷時起動アプリケーション205を提供することもできる。しかしながら、印刷装置102に関連付けられたプリンタドライバ201の種類に応じて、印刷時起動アプリケーション205を提供し分けることはできない。図5においては、MFP501で利用されるプリンタドライバ201はドライバ508からドライバ511の4種類存在するが、関連付けられる印刷時起動アプリケーション205は常に1種類である。
なお、WSDA207についても、印刷時起動アプリケーション205と同等の仕組みで印刷装置102やプリンタドライバ201と関連付けられる。従って、関連付けに関する制約等については、印刷時起動アプリケーション205と同等である。
<印刷時起動アプリケーションのセットアップ処理>
図6は、本印刷システムにおける印刷時起動アプリケーション205のセットアップ処理のうち主要な処理フローを示した図である。本処理フローは、例えば図5のMFPUtility506のような構成下にある印刷時起動アプリケーション205の処理の一例である。以降、印刷時起動アプリケーション205を、各処理の主体として説明することもあるが、実際には、対応するプログラムをCPU111が実行することで、対応する機能が実現されることになる。なお、全ての処理は必ずしも一つのプロセス上で逐次的に実行されるものではなく、一度OS側に処理が移り、再度OSから呼び出されるようなケースもあり得る。あくまで印刷時起動アプリケーション205の主要な処理を、便宜的にわかりやすく示したフローである。
印刷時起動アプリランチャー204は、印刷要求元の描画アプリケーションからXPS文書を受け取ると、印刷装置102に関連付けられた印刷時起動アプリケーション205の初期化処理を呼び出す。なお、前述の図22にて説明した印刷設定の後、OSが提供する設定画面2202において「印刷」ボタンが指示されると、印刷要求がなされ、描画アプリケーションからXPS文書が出力される。
印刷時起動アプリケーション205は、初期化処理において、図6に示されるセットアップ処理と、後述する図8に示される編集及び終了処理を、OSの規定するイベントハンドラとして登録する。印刷時起動アプリケーション205が初期化処理を終了すると、OSは、規定のイベントハンドラとして登録された印刷時起動アプリケーション205のセットアップ処理を実行する。図6はそのセットアップ処理を示すものである。
まず、印刷時起動アプリケーション205は、XPS文書中に格納されたPrintTicketを取得する(S601)。PrintTicketは、図2で説明したとおり、印刷設定を示す情報を含むデータであり、ユーザにより指示された印刷設定に基づき、コンフィグレーションモジュール208によって生成される。PrintTicketは、OSの所定のAPIを呼び出すことでXPS文書中から取得することができる。
次に、印刷時起動アプリケーション205は、プリンタドライバ201の能力を示す情報を含むデータであるPrintCapabilitiesを取得する。そして、その中の名前空間を確認することで、アプリケーションから印刷要求を受けたプリンタドライバ201の種別を判定する(S602)。PrintCapabilitiesの名前空間と判定方法の詳細については後述する。
なお、通常であれば、PrintTicketにもPrintCapabilitiesと同等の名前空間情報が格納されているため、S602の判定はPrintTicketを利用しても良い。PrintCapabilitiesの取得は時間を要するため、構成によってはPrintTicketを利用することにより処理時間を短縮することができる。また、プリンタドライバ201が、不図示のDriverPropertyBag等に判定のための情報を格納してもよい。印刷時起動アプリケーション205は、そのDriverPropertyBagに格納した情報を取得し判定に用いるよう構成しても良い。
S602の判定の結果、アプリケーションから印刷要求を受けたプリンタドライバ201がFaxドライバであった場合、印刷時起動アプリケーション205は、動作モードがFaxドライバモードであることを保存する(S603)。S603の処理、及び以降で説明する印刷時起動アプリケーション205の情報の保持は、一例として、OSにより提供されるLocal Storageを利用する。Local Storageに格納する情報の全体構成は後述する。同様に、印刷時起動アプリケーション205は、Local Storageに、UI表示が有効であることを保存する(S604)。
その後、OSの提供する規定のAPIを呼び出して、今回の印刷時起動アプリケーション205の実行に於いて、ユーザインタフェースを表示することを指示する(S605)。このAPIを実行することで、後述の図7で示す印刷時起動アプリケーション205のUI処理が呼び出され、印刷時起動アプリケーション205はユーザインタフェースを表示する。Faxドライバモード時の印刷時起動アプリケーション205のセットアップ処理は以上で終了である。
S602の判定の結果、アプリケーションから印刷要求を受けたプリンタドライバ201がFaxドライバではなかった場合、印刷時起動アプリケーション205は、動作モードがプリンタドライバモードであることを保存する(S606)。
次に、PrintTicketを参照し、印刷プレビュー起動指示が存在するかを確認する(S607)。PrintTicketの具体的な確認方法は、図13を用いて後述する。また、印刷プレビューの起動指示は、WSDA207及びPEX209から指定可能で、かつ印刷時起動アプリケーション205から参照可能な手段であれば、PrintTicket以外の方法により実現しても良い。例えば、プリンタドライバ201の設定情報の格納場所としてOSにより提供される、UserPropertyBag、あるいはQueuePropertyBagを利用するよう構成しても良い。なお、印刷プレビューとは、印刷設定とアプリケーションが生成した印刷データとを元に、紙面上に生成されることになる印刷結果のイメージを表示部119に表示することを指す。つまり、「印刷プレビュー起動指示がPrintTicketに存在する」ことは、印刷プレビュー画面の表示がユーザにより指示されたことを示す。ユーザは、印刷プレビュー画面を見ることで、所望の印刷結果が得られるかを印刷前に確認し、必要に応じて印刷設定の修正や特定ページの削除、印刷処理の中止を指示することができる。
S607で印刷プレビュー起動指示が存在しないと判断した場合、印刷時起動アプリケーション205は、S609に進む。S607で印刷プレビュー起動指示が存在すると判断した場合、印刷時起動アプリケーション205は、印刷プレビューが有効であることを保存する(S608)。
次に、S609で、印刷時起動アプリケーション205は、PropertyBagに機能拡張指示が存在するか否かを確認する。PropertyBagは、前述の通り、UserPropertyBagあるいはQueuePropertyBagを指す。この機能拡張は、例えばプリンタドライバが標準プリンタドライバ510のような基本的な機能しか有さない場合に、印刷時に指定可能な機能をプリンタベンダが拡張するためのものである。なお、標準プリンタドライバ510に対し、機能拡張を指示するような指定を含むPrintTicketを渡すと、その指定は標準プリンタドライバ510にとって未知の情報であるため、不正な指定として削除されてしまう。このようなケースに於いては、機能拡張指示をPropertyBagに格納することで、削除されずに維持される。一方、PrintTicketは、印刷データであるXPS文書に含まれ、印刷データ単位で保持される情報である。よって、複数の印刷要求が連続して生じた場合にも、印刷要求毎に印刷プレビューや機能拡張の有効、無効を、正確に切り替える事ができるというメリットがある。なお、印刷時起動アプリケーション205は、S609の処理をスキップし、拡張可能である場合は、常に機能拡張を有効化するように構成しても良い。
S609でPropertyBag内に機能拡張指示が存在しないと判断した場合、印刷時起動アプリケーション205は、S613に進む。S609でPropertyBagに機能拡張指示が存在すると判断した場合、印刷時起動アプリケーション205は、PrintCapabilitiesを取得する(S610)。S602で既にPrintCapabilitiesを取得している場合は、S610の処理はスキップする。
次に、印刷時起動アプリケーション205は、PrintCapabilitiesでサポートされていない所定機能が存在するか否かを判定する(S611)。所定機能とは、印刷時起動アプリケーション205が自身で編集能力を有し、拡張機能として印刷時起動アプリケーション205が提供可能な機能を指す。すなわち、印刷時起動アプリケーション205は、PrintCapabilities内に記載されていない機能であり、印刷時起動アプリケーション205が提供可能な機能が存在するかを判定する。これにより、プリンタドライバ201がサポートしておらず、自身が提供可能な機能が存在するか否かを判定する。この判定処理については図15を用いて詳細を後述する。
S611で該当機能が存在しないと判断した場合、印刷時起動アプリケーション205はS613に進む。S611で該当機能が存在すると判断した場合、印刷時起動アプリケーション205は、該当機能を拡張機能としてLocal Storageに保存する(S612)。
次に印刷時起動アプリケーション205は、印刷プレビューが有効、あるいは提供する拡張機能が存在するかを判断する(S613)。S613がYesの場合、印刷時起動アプリケーション205はS604に進み、ユーザインタフェースの表示を指示する。S614がNoの場合、印刷時起動アプリケーション205はセットアップ処理を終了する。
以上のように、印刷時起動アプリケーション205のセットアップ処理では、ユーザインタフェースの起動が必要か否かを判断し、必要な場合はそれを指示すると共に、その後の処理に必要な情報の格納を行う。
<PrintTicket、PrintCapabilitiesの構成例と関連処理>
図9から図12は、それぞれ異なる構成のプリンタドライバおよびFaxドライバのPrintCapabilitiesの例である。なお、これらのPrintCapabilitiesは、説明に必要な部分を中心に記述したものであり、一部省略されている。
図9は、Faxドライバ511のPrintCapabilitiesの例である。PrintCapabilitiesの先頭には、psf:PrintCapabilities要素があり、その属性として、そのPrintCapabilitiesで利用する名前空間が定義されている。通常、ここには、PrintSchemaと呼ばれるOS標準の定義を示す名前空間に加え、このプリンタドライバ201を提供するプリンタベンダが独自に定義した名前空間が列挙される。図9で示されるPrintCapabilitiesには、プリンタベンダが独自に定義した名前空間901が含まれる。
一方、図10は、機種別プリンタドライバ508のPrintCapabilitiesの一例である。図10で示されるPrintCapabilitiesには、プリンタベンダが独自で定義した名前空間1001が含まれる。また、図11は、共通ドライバ509のPrintCapabilitiesの一例を示し、図12は標準プリンタドライバ510のPrinntCapabilitiesの一例を示している。
名前空間は、選択可能な機能や選択項目、その定義を一意に定めるためのものであり、同じプリンタベンダが提供するプリンタドライバ201であっても、プリンタとFax等、機能集合が大きく異なる場合は、異なる値とすることが一般的である。これを利用して、S602は、名前空間に、図9の名前空間901内に示されるような、http://www.mfpvendor.com/ns/printschema/fax/v100というURLが含まれるか否か、という判定を行えばよい。
図13は、図10に示した機種別プリンタドライバ508のPrintCapabilities1000を元に生成される、PrintTicketの一例である。図13に示されるように、PrintTicketには、PrintCapabilitiesで定義された各機能の設定値が格納される。例えば、psk:PageMediaTypeというFeatureは、印刷に利用する用紙種類を示しており、図13のPrintTicketでは、psk:Plain、つまり普通紙が指定されている。S607の印刷プレビューの起動指示有無の判定処理は、ns0000:JobPreviewというFeatureの指定値が、ns0000:ONになっているか否かを判定する事になる。
次に、S611の判定処理について、図10から図12のPrintCapabilitiesと、図15を用いて詳細に説明する。図15は、印刷時起動アプリケーション205が拡張機能として提供可能な所定機能と、その選択項目の一覧を示す。ここでは、印刷時起動アプリケーション205は、複数ページを1ページに割り付けて印刷するページ割り付け機能と、印刷結果に指定されたスタンプを重ね合わせるスタンプ機能を有する。
印刷時起動アプリケーション205は、S611の判定処理において、PrintCapabilitiesを解析して、図15の“機能名”で示される機能が存在しているか否かを確認する。印刷対象が機種別プリンタドライバ508のPrintCapabilities1000であった場合、JobNUpAllDocumentsContiguouslyというFeatureとPageStampというFeatureが存在する。よって、S611の判定結果はNoとなる。
印刷対象が共通プリンタドライバ509のPrintCapabilities1100であった場合、JobNUpAllDocumentsContiguouslyというFeatureは存在するが、PageStampというFeatureは存在しない。よって、S611の判定結果はYesとなる。その時に印刷時起動アプリケーション205が拡張機能として提供するのは、PageStamp、つまりスタンプ機能となる。印刷対象が標準プリンタドライバ510のPrintCapabilities1200であった場合、JobNUpAllDocumentsContiguouslyというFeatureもPageStampというFeatureも存在しない。よって、S611の判定結果はYesとなる。その時に印刷時起動アプリケーション205が拡張機能として提供するのは、JobNUpAllDocumentsContiguouslyとPageStamp、つまり割り付け機能とスタンプ機能となる。
<WSDAの処理及びユーザインタフェース構成例>
図17は、ユーザにより機種別プリンタドライバ508が選択された場合にWSDA207により提供されるユーザインタフェースの一例を示す図である。この図17の画面は、WSDA207が提供する設定画面の一例であり、描画アプリケーションから印刷要求が行なわれる前に提供される画面である。機種別プリンタドライバ508は、1002に示されるように、JobPreviewというFeatureをサポートしており、これは印刷プレビュー機能を示している。WSDA207は、プリンタドライバ201から取得したPrintCapabilitiesを元にユーザインタフェースを構成するため、1002に基づいて、印刷プレビューの有効無効を切り替えるためのコントロールアイテム1701を表示する。WSDA207は、ユーザの指定に応じて、JobPreviewというFeatureのON、OFFをPrintTicketに格納する。印刷時起動アプリケーション205は、S607の処理でこの情報を参照して、印刷プレビューの起動指示があるか否かを判断する。
図18は、印刷先として標準プリンタドライバ510が選択されたときのWSDA207のユーザインタフェースの一例を示す図である。この図18の画面も、WSDA207が提供する設定画面の一例であり、描画アプリケーションから印刷要求が行なわれる前に提供される画面である。標準プリンタドライバ510は、JobPreviewというFeatureをサポートしていない。このような場合、WSDA207は、拡張機能を有効にするか否かを選択するためのコントロールアイテム1801を表示する。WSDA207は、ユーザがOKボタン1802を押下したタイミングで、コントロール1801に指定された値をPropertyBagに格納する。なお、WSDA207は、拡張機能に加えて、印刷プレビューの起動を指示するよう構成しても良い。この場合、拡張機能と印刷プレビューは、それぞれ異なるコントロールで指定可能であっても、一つのコントロールで同時に指定可能であっても良い。
なお、PEX209についても、WSDA207の上記処理と同等の処理によって、印刷時起動アプリケーション205の起動をコントロールするための手段を提供することができる。
<印刷時起動アプリケーションのUI処理>
S605のUIの表示指定が実行された場合、OSは、印刷時起動アプリケーション205のセットアップ処理が終了した後、印刷時起動アプリケーション205のUI処理を呼び出す。図7は、本印刷システムにおける印刷時起動アプリケーション205のUI処理のうち主要な処理フローを示した図である。本処理フローは、例えば図5のMFPUtility506のような構成下にある印刷時起動アプリケーション205の処理の一例である。以降、印刷時起動アプリケーション205を、各処理の主体として説明することもあるが、実際には、対応するプログラムをCPU111が実行することで、対応する機能が実現されることになる。なお、全ての処理は必ずしも一つのプロセス上で逐次的に実行されるものではなく、一度OS側に処理が移り、再度OSから呼び出されるようなケースもあり得る。あくまで印刷時起動アプリケーション205の主要な処理を、便宜的にわかりやすく示したフローである。なお、S605のUIの表示指定が実行されなかった場合、OSは、図7に示されるUI処理をスキップし、後述の編集及び終了処理を呼び出す。
まず、印刷時起動アプリケーション205は、S603やS606で保存した動作モードをLocal Storageから読み出し(S701)、Faxドライバモードであるか、プリンタドライバモードであるかを判断する(S702)。
動作モードがFaxドライバモードであった場合、印刷時起動アプリケーション205は、Faxドライバ用のユーザインタフェースを構成する(S703)。Faxドライバ用のユーザインタフェースは、送信先とFax番号をユーザが指定可能なコントロールアイテムを有する。Faxドライバ用のユーザインタフェースの詳細は図19を用いて後述する。
印刷時起動アプリケーション205は、ユーザから入力を受け付け(S704)、ユーザインタフェース上でFax送信が指示されると、ユーザの指定した送信先とFax番号をLocal Storageに保存する(S705)。
以上で印刷時起動アプリケーション205のFaxドライバモードの処理は終了である。このように、印刷時起動アプリケーション205は、Faxドライバモードでは、常に送信先とFax番号を指定可能な入力画面としてのユーザインタフェースを表示する(後述の図19参照)。Faxドライバにおいて、送信先とFax番号は、Faxを送信する上で必須の送信先情報である。仮にWSDA207やPEX209でユーザが送信先とFax番号を指定可能なように構成していても、これらのユーザインタフェースは、印刷時に必ず開かれるとは限らない。印刷時起動アプリケーション205で送信先とFax番号を指定可能にすることで、ユーザは、現在のFax送信処理の宛先を確実に入力することができる。また、ユーザの指示があった場合にのみ表示されるWSDA207やPEX209の画面でも、送信先とFax番号を指定可能に構成しても良い。こうすることで、何らかの理由で印刷時起動アプリケーション205が起動しないケースにおいても、送信先とFax番号を指定する手段を提供することができる。なお、WSDA207やPEX209でユーザが送信先とFax番号を指定可能なように構成した場合、印刷時起動アプリケーション205は、所定の場合のみUI表示指示を実行するようにしてもよい。すなわち、印刷時起動アプリケーション205は、PrintTicketに送信先とFax番号が含まれる場合はS605のUI表示指示を実行し、PrintTicketに送信先とFax番号が含まれない場合はS605のUI表示指示を実行しない。こうすることで、ユーザがWSDA207やPEX209で送信先とFax番号を指定し忘れた場合にのみ、印刷時起動アプリケーションが起動するよう構成することができる。
S702の判定で、動作モードがFaxドライバモードではなかった場合、印刷時起動アプリケーション205は、S612で保存した拡張機能を読み込む(S706)。
次に、印刷時起動アプリケーション205は、S608で保存した情報を参照し、印刷プレビューが有効か否かを判断する(S707)。印刷プレビューが有効でない場合、印刷時起動アプリケーション205は、S713のユーザインタフェース構成処理に進む。印刷プレビューが有効である場合、印刷時起動アプリケーション205は、PrintTicketを取得する(S708)。
さらに、印刷時起動アプリケーション205は、そのPrintTicketを元に、PrintCapabilitiesを取得する(S709)。なお、PrintCapabilitiesの取得には時間を要するため、図6のSetup処理で必要な情報をLocal Storageに保存しておき、S709ではそれを利用するように構成しても良い。
次に、印刷時起動アプリケーション205は、取得したPrintCapabilitiesを解析し、特定機能がサポートされているかを探索する。そして、見つかった機能とPrinTicketに指定されている設定値をドライバ機能としてLocal Storageに保存する(S710)。ここでは、一例として、印刷時起動アプリケーション205は、割り付け機能と用紙種類設定の2つを特定機能として探索する。探索処理は、PrintCapabilitiesに、規定の名前を持つFeatureが存在するか否かを判断することで実行される。なお、S612で保存した拡張機能が、ドライバが有していない機能を示していたのに対して、S710で保存するドライバ機能は、ドライバが有している機能である。従って、PrintTicketでこれらドライバ機能が有効化された場合、プリンタドライバ201は、その指定に応じた処理を正しく実行することができる。
次に、印刷時起動アプリケーション205は、OSの所定のAPIを利用してXPS文書を取得する(S711)。さらに、印刷時起動アプリケーション205は、そのXPS文書の内容を解析し、表示部119に表示する(S712)。この時、印刷時起動アプリケーション205は、PrintTicketに設定された設定値を印刷結果に反映することで、より正確な印刷プレビューを実現することができる。
印刷時起動アプリケーション205が受け取るXPS文書は、印刷要求元のアプリケーションが生成したものであって、プリンタドライバ201が処理する前のデータである。従って、例えばXPS文書中のPrintTicketで割り付け印刷が指定されていたとしても、印刷時起動アプリケーション205が受け取るXPS文書には、割り付け処理が施されていない。このようなケースを考慮し、印刷時起動アプリケーション205は、その後のドライバで実施されるのと同等のロジックで印刷設定を反映した印刷イメージを表示部119に表示する。印刷時起動アプリケーション205の表示するユーザインタフェース上で印刷設定が変更された場合、印刷時起動アプリケーション205は、変更を反映した印刷イメージを表示部119に再表示する。なお、標準プリンタドライバ510のように、プリンタベンダが提供していないプリンタドライバにおいては、どのようなロジックで印刷設定がXPS文書に反映されるかわからない。その場合は、印刷時起動アプリケーション205は、指定された機能の反映をスキップするか、独自のロジックで反映した上で、異なる可能性がある旨を合わせて表示部119に表示する。また、印刷時起動アプリケーション205がXPS文書の編集も含めて機能を提供する拡張機能に関しては、印刷時起動アプリケーション205は実際の編集と同じロジックで印刷設定を反映した印刷イメージを表示部119に表示すればよい。
次に、印刷時起動アプリケーション205は、S612で保存した拡張機能、及びS710で保存したドライバ機能を指定可能なコントロールを持つユーザインタフェースを構成する(S713)。S612で保存した拡張機能の選択肢として表示する項目は、図15の“オプション”の情報、つまり印刷時起動アプリケーション205がサポートする項目である。S710で保存したドライバ機能の選択肢として表示する項目は、PrintCapabilitiesの該当機能のOptionの一覧である。例えば、PrintCapabilities1000の情報を元に用紙種類を指定可能にする場合、psk:PageMediaTypeのサポートOption(psk:Plain、ns0000:PhotoPaper等)を全て選択肢として列挙する。なお、PrintCapabilities1000では省略されているが、各FeatureやOptionには、通常DisplayNameという要素が存在する。DisplayNameには、ローカライズ実施済みの適切な名称情報が格納されているので、印刷時起動アプリケーション205は、各ドライバ機能の選択肢として、DisplayNameの名称を表示する。
印刷時起動アプリケーション205は、ユーザから入力を受け付け(S714)、ユーザインタフェース上で印刷が指示されると、ユーザの指定した各機能の設定値をLocal Storageに保存する(S715)。以上で印刷時起動アプリケーション205のプリンタドライバモードの処理は終了である。
なお、S708からS710までの処理は、S707の判定で印刷プレビューが有効でなかった場合にも実行するように構成しても良い。これにより、印刷前に必ず確認が必要な重要な印刷設定について、印刷時起動アプリケーション205で再度確認を促し、必要であれば変更可能な手段をユーザに提供することができる。
図19は、印刷時起動アプリケーション205がFaxドライバモードで動作した場合に表示される入力画面としてのユーザインタフェースの一例を示す図である。表示アイテム1901は、ユーザが送信先を指定するためのコントロールアイテムである。表示アイテム1902は、ユーザがFax番号を入力するためのコントロールアイテムである。表示アイテム1903は、アドレス帳を起動するためのボタンである。このボタンを押下するとアドレス帳が起動され、アドレス帳上で宛先を選択することで、送信先とFax番号が自動入力される。表示アイテム1905はFax送信を開始するためのボタンである。送信先とFax番号が未入力の状態では、ユーザはこのボタンを押下することはできない。表示アイテム1906はキャンセルボタンで、ユーザがこのボタンを押下すると、その後のFax送信処理はキャンセルされる。
本構成により、印刷時起動アプリケーション205は、Faxドライバモードでは、常に送信先とFax番号を指定可能な入力画面としてのユーザインタフェースを表示することが可能となる。Faxドライバにおいて、送信先とFax番号は、Faxを送信する上で必須の情報である。印刷時起動アプリケーション205で送信先とFax番号を指定可能にすることで、ユーザは、現在のFax送信処理の宛先を確実に入力することができる。
図20は、標準プリンタドライバ510動作時に、印刷時起動アプリケーション205がプリンタドライバモードで動作した場合に表示される拡張機能を指定するためのユーザインタフェースの一例である。なお、図20では印刷プレビュー機能は有効にされていないものとする。標準プリンタドライバ510のPrintCapabilities1200では、割り付け印刷機能もスタンプ機能もサポートされていない。従って、印刷時起動アプリケーション205は、S611及びS612の処理で、拡張機能として、割り付け印刷機能、及びスタンプ機能の2つを保存する。その結果、これら2つの機能が拡張機能として提供される。表示アイテム2001は、割り付け印刷機能の設定を指定するためのコントロールアイテムである。表示アイテム2002は、スタンプ機能の設定を指定するためのコントロールアイテムである。表示アイテム2003は印刷を開始するためのボタンである。表示アイテム2004はキャンセルボタンで、ユーザがこのボタンを押下すると、その後の印刷処理はキャンセルされる。なお、動作ドライバが共通プリンタドライバ509であった場合は、拡張機能として、スタンプ機能のみが表示される。これは共通プリンタドライバ509のPrintCapabilities1100において、割り付け機能はサポートされているためである。
本構成により、標準プリンタドライバ510のように、OSと同様にMicrosoft(登録商標)によって提供されプリンタベンダが機能拡張できないドライバにおいて、印刷時起動アプリケーション205を利用することで、印刷機能の拡張を実現できる。また、動作するドライバの能力を示す情報を判断し、不足している機能のみが拡張機能として提供される。これにより、利用可能なプリンタドライバ201が複数種類存在するようなケースにおいて、それぞれのプリンタドライバ201に最適な拡張機能を提供することができる。また、印刷時にユーザインタフェースを表示して機能拡張するか否かはユーザがコントロールすることができる。これにより、都度ユーザインタフェースが表示されることが好ましくないユースケースにも対応することができる。
図21は、機種別プリンタドライバ508動作時に、印刷時起動アプリケーション205がプリンタドライバモードで動作した場合のユーザインタフェースの一例である。なお、印刷プレビュー機能は有効にされているものとする。表示アイテム2101は、印刷プレビュー上で表示するページを変更するためのコントロールアイテムである。ユーザは、このコントールアイテムを利用して表示ページを変更できるし、また、現在の印刷データと印刷設定で発生する印刷の総ページ数を確認することもできる。表示アイテム2102は、指定されているページの印刷結果のイメージを示す印刷プレビュー画面である。表示アイテム2103は、割り付け印刷機能を指定するためのコントロールアイテムである。表示アイテム2104は、用紙種類を指定するためのコントロールアイテムである。表示アイテム2013、2014で表示されているのは拡張機能ではなくドライバ機能なので、前述の通り、選択項目はプリンタドライバ201の機能に準ずる。表示アイテム2105は印刷を開始するためのボタンである。表示アイテム2106はキャンセルボタンで、ユーザがこのボタンを押下すると、その後の印刷処理はキャンセルされる。なお、図21では、ドライバ機能のみが表示されているが、図6と図7の処理の結果、ドライバ機能と拡張機能が共に有効化された場合、印刷時起動アプリケーション205は、その全ての機能について指定可能なコントロールを表示する。
本構成により、描画アプリケーションの生成したXPS文書とユーザにより指定された印刷設定を元に、印刷結果に近い印刷イメージを印刷前に表示する印刷プレビュー機能を実現できる。また、印刷結果や印刷ページ数を確認しながら、印刷設定を最終調整するための変更も可能となる。これらの機能により、ミスプリントを防ぐと共に、所望のページ数に印刷を収める等の最終調整手段を提供することが可能となる。
<印刷時起動アプリケーションの編集及び終了処理>
図7の印刷時起動アプリケーション205のUI処理が終了した後、OSは、図8の印刷時起動アプリケーション205の編集及び終了処理を呼び出す。なお、S605のUIの表示指定処理が実行されなかった場合は、OSは、図7の印刷時起動アプリケーション205のUI処理を呼び出すことなく、本処理を呼び出す。本処理フローは、例えば図5のMFPUtility506のような構成下にある印刷時起動アプリケーション205の処理の一例である。以降、印刷時起動アプリケーション205を、各処理の主体として説明することもあるが、実際には、対応するプログラムをCPU111が実行することで、対応する機能が実現されることになる。また、全ての処理は必ずしも一つのプロセス上で逐次的に実行されるものではなく、一度OS側に処理が移り、再度OSから呼び出されるようなケースもあり得る。あくまで印刷時起動アプリケーション205の主要な処理を、便宜的にわかりやすく示したフローである。
印刷時起動アプリケーション205は、Local StorageよりS603及びS606で保存した動作モード、及びS604で保存されたUI表示情報を読み込む(S801)。S802でUI表示がなかったと判断した場合、印刷時起動アプリケーション205は、OSのAPIを利用してXPS文書を取得し(S806)、そのまま何も改変することなく、XPS文書を出力する(S807)。このように、印刷時起動アプリケーション205は、XPS文書を変更しない場合も、XPS文書を一度全て取得し、出力する必要がある。ユーザインタフェースを表示しなかった場合の印刷時起動アプリケーション205の処理は、以上で終了である。このように、印刷時起動アプリケーション205は、ユーザインタフェースの表示が不要と判断した場合は、ユーザインタフェースを表示することなく処理を終了する。
S802でUI表示があったと判断した場合、印刷時起動アプリケーション205は、S801で読み込んだ情報を元に、動作モードがFaxドライバモードであったか否かを判断する(S808)。Faxドライバモードであると判断した場合、印刷時起動アプリケーション205は、S705で保存された送信先とFax番号をLocal Storageから取得する(S803)。次に、印刷時起動アプリケーション205は、OSのAPIを利用してPrintTicketを取得する(S804)。さらに、印刷時起動アプリケーション205は、S803で取得した送信先とFax番号をPrintTicketに格納する(S805)。
これらの情報を格納したPrintTicketの一例を図14に示す。ここでは、送信先はJobRecipientNameとして、Fax番号はJobFaxNumberとして格納されている。PrintTicketを編集後、印刷時起動アプリケーション205は、必要に応じてそのPrintTicketをXPS文書に格納した上で、XPS文書を出力し、処理を終了する。Faxドライバ511は、PrintTicketを参照して送信先とFax番号を取得し、指定されたFax番号にFax送信するためのジョブを印刷装置102に送信する。
S808で、動作モードがFaxドライバモードではないと判定した場合、印刷時起動アプリケーション205は、S710で提供する機能が決定される。そして、2104等でユーザに指定されたドライバ機能の設定値をLocal Storageから読み込む(S809)。次に、印刷時起動アプリケーション205は、ドライバ機能の設定値が初期状態から変更されたか否かを判断する(S810)。
S810でドライバ機能の設定値の変更が無いと判断した場合、印刷時起動アプリケーション205は、S813の処理に進む。S810でドライバ機能の設定値が変更されたと判断した場合、印刷時起動アプリケーション205は、PrintTicketを取得し(S811)、S809で取得したドライバ機能の設定値をPrintTicketに反映する(S812)。これらの処理を実現するための、Local Storageに格納する情報の構成や、PrintTicketへの反映方法については後述する。設定値が変更されたドライバ機能が複数存在する場合は、印刷時起動アプリケーション205は、全てのドライバ機能についてPrintTicketへの反映処理を行う。PrintTicketへの反映後、印刷時起動アプリケーション205は、XPS文書を取得する(S813)。
次に、印刷時起動アプリケーション205は、S612で提供機能が決定され、2002等からユーザにより指定された拡張機能の設定値をLocal Storageから読み込む(S814)。次に、印刷時起動アプリケーション205は、拡張機能の設定値が指定されたか否かを判断する(S815)。S815で拡張機能の設定値が指定されていない判断した場合、印刷時起動アプリケーション205は、XPS文書を出力し(S807)、処理を終了する。
S815で拡張機能の設定値が指定されたと判断した場合、印刷時起動アプリケーション205は、ユーザの指定した拡張機能とその設定値に従い、XPS文書内の描画データを編集する。例えば、2ページを1ページに割り付ける割り付け印刷機能が指定されていた場合を説明する。この場合、印刷時起動アプリケーション205は、XPS文書内の描画データにおけるページの概念であるFixedPageを2ページ分取得し、1ページのFixedPage上に縮小配置する。その上で、印刷時起動アプリケーション205は、元の2ページ分のFixedPageを描画データ内から削除し、新たに作成したFixedPageを描画データに追加する。このような処理を全てのページに対して繰り返し実行する。指定された拡張機能が複数存在する場合は、それらの指定全てを反映した描画データを生成する。最後に、印刷時起動アプリケーション205は、編集した描画データを含むXPS文書を出力し、処理を終了する。
以上のように、本構成における印刷時起動アプリケーション205は、プリンタドライバ201がサポートするドライバ機能の設定値が変更された場合は、その変更をPrintTicketに反映する。そして、XPS文書内の描画データの編集処理は、プリンタドライバ201に任せる。これにより、印刷時起動アプリケーション205は不要なXPS文書の編集処理を実施する必要が無く、高速な処理が可能である。加えて、プリンタドライバ201の機能を利用するため、WSDA207等から機能が指定された場合と、印刷時起動アプリケーション205から機能が指定された場合とで、完全に同一の結果を得ることができる。
一方、本構成における印刷時起動アプリケーション205は、プリンタドライバ201がサポートしない拡張機能については、印刷時起動アプリケーション205自身が、XPS文書内の描画データの編集を実行する。これにより、プリンタドライバ201がサポートしない機能をユーザに提供することができる。
図16は、Local Storageに格納される情報の一例を示した図である。格納情報は名称と値で構成される。この例では、印刷時起動アプリケーション205はプリンタドライバモードで動作し、拡張機能としてスタンプ機能を、ドライバ機能として割り付け印刷機能を、それぞれ提供したことを示している。S612の処理では、Local Storageには、拡張機能_PageStampという名称で、値が空の情報が追加される。
印刷時起動アプリケーション205のユーザインタフェース上でスタンプ機能が指定された場合、S715の処理によって、指定された値が拡張機能_PageStampの値として格納される。ここでは、ユーザによって “Confidential”という設定値に変更されている。ドライバ機能である割り付け印刷機能は、S710の処理によって、ドライバ機能_JobNUpAllDocumentsContiguouslyという名称で、値がPrintTicketに設定されている初期値の情報が追加される。印刷時起動アプリケーション205のユーザインタフェース上で割り付け印刷機能の指定値が変更された場合、S715の処理によって、変更された値が格納される。ここでは、ユーザによって “ns0000:PagesPerSheet_2”という設定値に変更されている。この名称は、プリンタドライバ201のPrintCapabilitiesに定義されているOption名である。以上ように、拡張機能かドライバ機能かは、Local Storageに格納されている情報の接頭辞によって判断することができる。
S810の処理では、印刷時起動アプリケーション205は、Local Storageに“ドライバ機能_”という接頭辞で始まるドライバ機能が存在するかを判定する。S812の処理では、印刷時起動アプリケーション205は、Local Storageに値として格納されたOption名を、そのままPrintTicketのOption名として反映する。S815の処理では、印刷時起動アプリケーション205は、Local Storageに“拡張機能_”という接頭辞で始まる拡張機能が存在するかを判定する。
以上のように、本実施形態では、ユーザの印刷指示後(つまり描画アプリケーションからXPS文書が出力された後)、印刷装置102による印刷動作の前に、印刷時起動アプリケーション205のユーザインタフェースを表示するよう構成することができる。さらに、印刷時起動アプリケーション205が、プリンタドライバ201の種類に関わらず、印刷装置102に対して一意に割り当てられるようなケースにおいて、プリンタドライバ201の種類に応じた最適な機能拡張を実現することができる。Faxドライバが接続されている場合、Fax送信に必須である送信先とFax番号を入力するための入力画面としてのユーザインタフェースを表示する。
プリンタドライバが接続されている場合は、ユーザの指定に応じて、印刷結果を事前に表示部119上で確認するための印刷プレビュー機能を実現することができる。さらに、接続されているプリンタドライバ201の能力を示す情報を基に機能を判定し、不足している機能を拡張機能として提供することができる。これによって、接続されたドライバが、OSと共にMicrosoft(登録商標)の提供する標準プリンタドライバであり、プリンタベンダが機能拡張できないようなケースでも、印刷時起動アプリケーション205を利用することで、プリンタベンダが独自の機能を拡張することができる。
なお、本実施形態では、Faxドライバモード、プリンタドライバモードの印刷プレビュー、及び機能拡張を1つのGUIアプリケーションである印刷時起動アプリケーション205で実現している。しかしながら、これら3つの機能は必ずしも組み合わせて実施する必要があるものではなく、3つの機能のうち1つ乃至は2つを有するよう印刷時起動アプリケーション205を構成することが可能であることは言うまでもない。
<実施形態2>
上述した実施形態は、以下の処理を実行することによっても実行される。すなわち、前述した実施形態の機能を実現するソフトウェアのプログラムコードを記録した記録媒体を、システムあるいは装置に供給する。そして、そのシステムあるいは装置のコンピュータ(またはCPUまたはMPU)が記録媒体に格納されたプログラムコードを読み出し実行する。これによって、上述した目的を達成することができる。この場合、記憶媒体から読み出されたプログラムコード自体が前述した実施形態の機能を実現することとなり、そのプログラムコードを記憶した記憶媒体は本発明を構成することになる。
プログラムコードを供給するための記憶媒体としては、例えば、フレキシブルディスク、ハードディスク、光ディスク、光磁気ディスク、CD−ROM、CD−R、磁気テープ、不揮発性のメモリカード、ROM、DVDなどを用いることができる。
また、コンピュータが読み出したプログラムコードを実行することにより、前述した実施例の機能が実現されるだけでない。そのプログラムコードの指示に基づき、コンピュータ上で稼動しているOSなどが実際の処理の一部または全部を行い、その処理によって前述した実施例の機能が実現される場合も含まれる。
さらに、記憶媒体から読み出されたプログラムコードが、コンピュータに挿入された機能拡張ボードやコンピュータに接続された機能拡張ユニットに備わるメモリに書きこまれてもよい。そして、そのプログラムコードの指示に基づき、その機能拡張ボードや機能拡張ユニットに備わるCPUなどが実際の処理の一部または全部を行ってもよい。その処理によって前述した実施形態の機能が実現される。
102 印刷装置
119 表示部
201 プリンタドライバ
202 UWPアプリケーション
203 Legacyアプリケーション
203 印刷時起動アプリランチャー
205 印刷時起動アプリケーション
206 スプールファイル
207 WSDA
208 コンフィグレーションモジュール
209 PrinterExtensions(PEX)
506 MFPUtility
508 機種別プリンタドライバ
509 共通プリンタドライバ
510 標準プリンタドライバ
511 Faxドライバ

Claims (25)

  1. GUI(Graphical User Interface)を提供する機能を有していないドライバが選択された場合にGUIを提供することが可能なGUIアプリケーションのプログラムであって、
    描画アプリケーションにより生成された描画データを取得するステップと、
    所定のデバイスにより前記描画データに基づく所定の処理が行われる際の設定を示す情報を含むデータと、前記ドライバの能力を示す情報を含むデータと、のうち少なくともいずれかを取得するステップと、
    前記設定を示す情報を含むデータと前記ドライバの能力を示す情報を含むデータとのうち少なくともいずれかにおいて、第1情報が含まれているか判定するステップと、
    第1表示アイテムを提供するステップと、
    をコンピュータに実行させ、
    前記第1情報が含まれているか否かに応じて、前記第1表示アイテムを提供するか否かが変わることを特徴とするプログラム。
  2. 前記設定を示す情報を含むデータと前記ドライバの能力を示す情報を含むデータとのうち少なくともいずれか一方に、前記第1情報として前記ドライバがFaxドライバであることを示す情報が含まれている場合は、前記第1表示アイテムとしてFax送信に必要な送信先情報をユーザに入力させるための入力画面を提供し、
    前記設定を示す情報を含むデータと前記ドライバの能力を示す情報を含むデータとのうち少なくともいずれか一方に、前記Faxドライバであることを示す情報が含まれていない場合は、前記入力画面を提供しないことを特徴とする請求項1に記載のプログラム。
  3. 前記設定を示す情報を含むデータは、前記描画アプリケーションから前記描画データと共に出力されるデータであり、
    前記入力画面において入力された送信先情報に基づき、前記設定を示す情報を含むデータを編集するステップをさらに実行させることを特徴とする請求項2に記載のプログラム。
  4. 前記ドライバの能力を示す情報を含むデータ内に、前記第1情報として前記GUIアプリケーションが提供できる所定の機能に関する情報が含まれていない場合、前記第1表示アイテムとして前記所定の機能を指定可能な表示アイテムを提供し、
    前記ドライバの能力を示す情報を含むデータ内に、前記所定の機能に関する情報が含まれている場合は、前記表示アイテムを提供しないことを特徴とする請求項1に記載のプログラム。
  5. 前記表示アイテムにおいて指定された情報に基づき、前記描画データを編集するステップをさらに実行させることを特徴とする請求項4に記載のプログラム。
  6. 前記設定を示す情報を含むデータに、前記第1情報として印刷プレビュー画面を表示することを示す情報が含まれている場合は、前記第1表示アイテムとして前記描画データに基づく印刷プレビュー画面を提供し、
    前記設定を示す情報を含むデータに、前記印刷プレビュー画面を表示することを示す情報が含まれていない場合は、前記印刷プレビュー画面を提供しないことを特徴とする請求項1に記載のプログラム。
  7. 前記印刷プレビュー画面において指示された情報に基づき、前記設定を示す情報を含むデータを編集するステップをさらに実行させることを特徴とする請求項6に記載のプログラム。
  8. 前記設定を示す情報を含むデータは、PrintTicketであることを特徴とする請求項1乃至7のいずれか1項に記載のプログラム。
  9. 前記設定を示す情報を含むデータは、PropertyBag内に含まれるデータであることを特徴とする請求項1乃至7のいずれか1項に記載のプログラム。
  10. GUI(Graphical User Interface)を提供する機能を有していないドライバが選択された場合にGUIを提供することが可能なGUIアプリケーションのプログラムであって、
    前記ドライバの種類に関する情報を取得するステップと、
    前記ドライバの種類に関する情報に基づき、前記ドライバがFaxドライバである場合に、Fax送信に必要な送信先情報をユーザに入力させるための入力画面を提供するステップと、
    をコンピュータに実行させるためのプログラム。
  11. 設定を示す情報を含むデータと、前記ドライバの能力を示す情報を含むデータと、のうち少なくともいずれか一方から前記ドライバの種類に関する情報を取得し、
    前記取得された前記ドライバの種類に関する情報に基づき、前記ドライバがFaxドライバか判定するステップをさらに実行させることを特徴とする請求項10に記載のプログラム。
  12. 前記入力画面において入力された送信先情報に基づき、前記設定を示す情報を含むデータを編集するステップをさらに実行させることを特徴とする請求項10又は11に記載のプログラム。
  13. GUI(Graphical User Interface)を提供する機能を有していないプリンタドライバが選択された場合にGUIを提供することが可能なGUIアプリケーションのプログラムであって、
    描画アプリケーションにより生成された描画データを取得するステップと、
    前記ドライバの能力を示す情報を含むデータを取得するステップと、
    前記ドライバの能力を示す情報を含むデータに基づき、前記ドライバの能力を示す情報に含まれていない機能であり且つ前記GUIアプリケーションが提供可能な機能である所定の機能の指定が可能な表示アイテムを提供するステップと、
    をコンピュータに実行させるためのプログラム。
  14. 前記ドライバの能力を示す情報を含むデータと、設定を示す情報を含むデータと、に基づき、前記設定を示す情報に、前記所定の機能が含まれているかを判定するステップをさらに備え、
    前記設定を示す情報に、前記所定の機能が含まれている場合、前記表示アイテムを提供することを特徴とする請求項13に記載のプログラム。
  15. 前記表示アイテムにおいて指定された情報に基づき、前記描画データを編集するステップをさらに実行させるための請求項13又は14に記載のプログラム。
  16. GUI(Graphical User Interface)を提供する機能を有していないプリンタドライバが選択された場合にGUIを提供することが可能なGUIアプリケーションのプログラムであって、
    描画アプリケーションにより生成された描画データを取得するステップと、
    印刷プレビュー画面を表示することが設定されているかを判定するステップと、
    前記印刷プレビュー画面を表示することが設定されている場合に、前記描画データに基づく印刷プレビュー画面を提供するステップと、
    をコンピュータに実行させるためのプログラム。
  17. 前記印刷プレビュー画面において指示された情報に基づき、前記アプリケーションから前記描画データと共に出力される、設定を示す情報を含むデータを編集するステップをさらに実行させることを特徴とする請求項15に記載のプログラム。
  18. 印刷要求に応じて前記描画アプリケーションから前記描画データが出力される前に表示される設定画面において、前記印刷プレビュー画面を表示することが指示され、
    印刷要求に応じて前記描画アプリケーションから前記描画データが出力された後に、前記印刷プレビュー画面が提供されることを特徴とする請求項16又は17に記載のプログラム。
  19. 前記GUIアプリケーションは、前記ドライバより前に描画データを取得することを特徴とする請求項1乃至18のいずれか1項に記載のプログラム。
  20. 前記ドライバのインストールに応じて、インターネットを介してOSによりMetadataが取得され、
    前記GUIアプリケーションは、前記取得されたMetadata内の記述に基づき、インターネットを介してアプリケーション配布システムから取得されることを特徴とする請求項1乃至19のいずれか1項に記載のプログラム。
  21. 前記GUIアプリケーションは、前記Metadata内に記述されたデバイスと関連付けられることを特徴とする請求項20に記載のプログラム。
  22. 前記GUIアプリケーションがインストールされた情報処理装置には、前記Metadataに記載されたデバイスに対応する複数のドライバのうち、少なくとも1つのドライバがインストールされていることを特徴とする請求項20又は21に記載のプログラム。
  23. 前記GUIを提供する機能を有していないドライバが選択された場合は、OSの指示に基づき前記GUIアプリケーションはGUIを提供し、前記GUIを提供する機能を有するドライバが選択された場合は、前記GUIアプリケーションは起動されないことを特徴とする請求項1乃至22のいずれか1項に記載のプログラム。
  24. 前記所定の機能は、前記スタンプ機能とページ割り付け機能のうち少なくともいずれかであることを特徴とする請求項4又は13に記載のプログラム。
  25. 前記GUIを提供する機能を有していないドライバは、V4プリンタドライバであることを特徴とする請求項1乃至24のいずれか1項に記載のプログラム。
JP2017200310A 2017-10-16 2017-10-16 プログラム Active JP6983614B2 (ja)

Priority Applications (16)

Application Number Priority Date Filing Date Title
JP2017200310A JP6983614B2 (ja) 2017-10-16 2017-10-16 プログラム
EP18198389.1A EP3471389A3 (en) 2017-10-16 2018-10-03 Program
CN202210630153.9A CN114860177A (zh) 2017-10-16 2018-10-10 控制方法
CN201811176363.5A CN109669645B (zh) 2017-10-16 2018-10-10 控制方法
US16/158,178 US10747481B2 (en) 2017-10-16 2018-10-11 Control method for acquiring data
KR1020180120839A KR20190042456A (ko) 2017-10-16 2018-10-11 제어 방법
US16/926,523 US11662963B2 (en) 2017-10-16 2020-07-10 Control method for acquiring data
KR1020210146002A KR102461063B1 (ko) 2017-10-16 2021-10-28 제어 방법
JP2021189031A JP7263491B2 (ja) 2017-10-16 2021-11-19 プログラムおよび情報処理装置
JP2023063875A JP2023080177A (ja) 2017-10-16 2023-04-11 プログラム、及び情報処理装置
US18/304,209 US20230251804A1 (en) 2017-10-16 2023-04-20 Control method
JP2024015794A JP2024055888A (ja) 2017-10-16 2024-02-05 サポートプログラム、印刷方法、情報処理装置
JP2024015796A JP2024055890A (ja) 2017-10-16 2024-02-05 サポートプログラム、印刷方法、及び情報処理装置
JP2024015797A JP2024055891A (ja) 2017-10-16 2024-02-05 サポートプログラム、印刷方法、情報処理装置
JP2024015795A JP2024055889A (ja) 2017-10-16 2024-02-05 サポートプログラム、情報処理装置、及び印刷方法
JP2024109883A JP2024147624A (ja) 2017-10-16 2024-07-08 アプリケーションプログラム、記憶媒体、及びアプリケーションプログラムの受信方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017200310A JP6983614B2 (ja) 2017-10-16 2017-10-16 プログラム

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2021189031A Division JP7263491B2 (ja) 2017-10-16 2021-11-19 プログラムおよび情報処理装置

Publications (2)

Publication Number Publication Date
JP2019074906A true JP2019074906A (ja) 2019-05-16
JP6983614B2 JP6983614B2 (ja) 2021-12-17

Family

ID=63762252

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017200310A Active JP6983614B2 (ja) 2017-10-16 2017-10-16 プログラム

Country Status (5)

Country Link
US (3) US10747481B2 (ja)
EP (1) EP3471389A3 (ja)
JP (1) JP6983614B2 (ja)
KR (2) KR20190042456A (ja)
CN (2) CN114860177A (ja)

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2021039613A (ja) * 2019-09-04 2021-03-11 キヤノン株式会社 アプリケーション及び情報処理装置
JP2021096605A (ja) * 2019-12-16 2021-06-24 キヤノン株式会社 プログラム、情報処理装置、および方法
EP3842917A1 (en) 2019-12-27 2021-06-30 Canon Kabushiki Kaisha Control method and information processing apparatus
EP4149102A1 (en) 2021-08-31 2023-03-15 Canon Kabushiki Kaisha Information processing apparatus, method of controlling information processing apparatus, and program
DE102023200419A1 (de) 2022-02-09 2023-08-10 Canon Kabushiki Kaisha Programm, informationsverarbeitungsvorrichtung und steuerverfahren
US11842091B2 (en) 2021-08-31 2023-12-12 Canon Kabushiki Kaisha Method of controlling information processing apparatus, editing intermediate data, and converting edited intermediate data into printing data
EP4312116A1 (en) 2022-07-26 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus and non-transitory computer-readable storage medium
EP4312117A1 (en) 2022-07-29 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus, information processing method, and storage medium
EP4312115A1 (en) 2022-07-26 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus, program, and computer-readable storage medium
JP7446726B2 (ja) 2019-07-02 2024-03-11 キヤノン株式会社 印刷装置、情報処理装置及びプログラム
US11954386B2 (en) 2021-09-13 2024-04-09 Canon Kabushiki Kaisha Information processing apparatus having enhanced printing functions, controlling method of information processing apparatus, and storage medium
EP4354273A1 (en) 2022-10-14 2024-04-17 Canon Kabushiki Kaisha Information processing apparatus, control method, and storage medium
JP7547418B2 (ja) 2022-07-29 2024-09-09 キヤノン株式会社 情報処理装置、情報処理方法およびプログラム

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20220236932A1 (en) * 2021-01-27 2022-07-28 Toshiba Tec Kabushiki Kaisha Information processing apparatus, information processing method, and storage medium
JP2024046140A (ja) * 2022-09-22 2024-04-03 キヤノン株式会社 情報処理装置、情報処理装置の制御方法、及びプログラム

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014209316A (ja) * 2013-03-27 2014-11-06 株式会社リコー 印刷制御プログラム、情報処理装置及び印刷システム
JP2016062405A (ja) * 2014-09-19 2016-04-25 コニカミノルタ株式会社 Uiプログラム、印刷制御装置及びその制御方法
JP2017068339A (ja) * 2015-09-28 2017-04-06 富士ゼロックス株式会社 印刷設定支援装置及びプログラム
JP2017068304A (ja) * 2015-09-28 2017-04-06 富士ゼロックス株式会社 情報処理装置およびプログラム
JP2017073836A (ja) * 2014-03-06 2017-04-13 キヤノン株式会社 方法、情報処理装置、およびプログラム

Family Cites Families (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7168003B2 (en) * 2002-08-07 2007-01-23 Hewlett-Packard Development Company, L.P. Method and apparatus for automating printer and printer driver diagnostics and repair
JP2004252665A (ja) * 2003-02-19 2004-09-09 Canon Inc 文書処理方法
KR100561405B1 (ko) 2003-11-05 2006-03-16 삼성전자주식회사 프린터 드라이버 및 사용자 인터페이스 구성 방법
JP4250569B2 (ja) * 2004-06-25 2009-04-08 キヤノン株式会社 印刷制御装置及び印刷制御方法
JP4618610B2 (ja) 2004-12-27 2011-01-26 キヤノンマーケティングジャパン株式会社 印刷制御装置、印刷制御方法、印刷制御プログラム
EP1821189B1 (en) * 2006-02-15 2014-07-23 Canon Kabushiki Kaisha Host apparatus and printing control method
JP2007272870A (ja) * 2006-03-10 2007-10-18 Ricoh Co Ltd 印刷制御装置、gui表示方法、プリンタドライバ及び記録媒体
JP4693664B2 (ja) * 2006-03-13 2011-06-01 キヤノン株式会社 プリンタ装置及びプログラムと印刷方法
CN101578583A (zh) * 2007-01-18 2009-11-11 三菱电机株式会社 应用程序设定终端、应用程序执行终端及设定信息管理服务器
JP5078686B2 (ja) * 2008-03-18 2012-11-21 キヤノン株式会社 印刷設定処理装置及び印刷設定処理方法
JP5264391B2 (ja) * 2008-09-30 2013-08-14 キヤノン株式会社 情報処理装置及びインストール方法
JP5729903B2 (ja) * 2009-12-17 2015-06-03 キヤノン株式会社 情報処理装置、その方法およびプログラム
JP5634132B2 (ja) * 2010-06-01 2014-12-03 キヤノン株式会社 情報処理システム、情報処理装置、それらの制御方法及びプログラム
JP5787606B2 (ja) * 2011-05-02 2015-09-30 キヤノン株式会社 情報処理装置、情報処理方法、及びプログラム
JP5230827B1 (ja) * 2012-01-25 2013-07-10 キヤノン株式会社 情報処理装置、その方法、及びプログラム
JP5995461B2 (ja) * 2012-02-24 2016-09-21 キヤノン株式会社 情報処理装置、制御方法、プログラム
JP5924992B2 (ja) 2012-03-09 2016-05-25 キヤノン株式会社 情報処理装置、情報処理方法とプログラム
JP6051722B2 (ja) * 2012-09-20 2016-12-27 ブラザー工業株式会社 プログラムおよび情報処理装置
JP2014109854A (ja) * 2012-11-30 2014-06-12 Canon Inc 情報処理装置および制御方法およびプログラム
JP2014222299A (ja) * 2013-05-14 2014-11-27 セイコーエプソン株式会社 画像処理装置、プログラム、情報記憶媒体および画像処理装置の製造方法
JP5825565B2 (ja) * 2013-11-07 2015-12-02 コニカミノルタ株式会社 プリンタドライバ及びプリンタドライバの印刷機能の追加方法
JP2015170295A (ja) * 2014-03-10 2015-09-28 キヤノン株式会社 画像形成出力の出力設定を行う情報処理装置およびその制御方法
JP2017033052A (ja) 2015-07-29 2017-02-09 キヤノン株式会社 画像形成装置における制御装置およびプログラム
JP6602188B2 (ja) * 2015-12-02 2019-11-06 キヤノン株式会社 情報処理装置及びその制御方法、並びにプログラム
JP6321842B2 (ja) 2017-02-23 2018-05-09 シャープ株式会社 データ処理方法およびプログラム

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014209316A (ja) * 2013-03-27 2014-11-06 株式会社リコー 印刷制御プログラム、情報処理装置及び印刷システム
JP2017073836A (ja) * 2014-03-06 2017-04-13 キヤノン株式会社 方法、情報処理装置、およびプログラム
JP2016062405A (ja) * 2014-09-19 2016-04-25 コニカミノルタ株式会社 Uiプログラム、印刷制御装置及びその制御方法
JP2017068339A (ja) * 2015-09-28 2017-04-06 富士ゼロックス株式会社 印刷設定支援装置及びプログラム
JP2017068304A (ja) * 2015-09-28 2017-04-06 富士ゼロックス株式会社 情報処理装置およびプログラム

Cited By (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP7446726B2 (ja) 2019-07-02 2024-03-11 キヤノン株式会社 印刷装置、情報処理装置及びプログラム
JP2021039613A (ja) * 2019-09-04 2021-03-11 キヤノン株式会社 アプリケーション及び情報処理装置
JP7387342B2 (ja) 2019-09-04 2023-11-28 キヤノン株式会社 アプリケーション、情報処理装置及び制御方法
JP7397652B2 (ja) 2019-12-16 2023-12-13 キヤノン株式会社 プログラム、情報処理装置、および方法
JP2021096605A (ja) * 2019-12-16 2021-06-24 キヤノン株式会社 プログラム、情報処理装置、および方法
EP3842917A1 (en) 2019-12-27 2021-06-30 Canon Kabushiki Kaisha Control method and information processing apparatus
US11635927B2 (en) 2019-12-27 2023-04-25 Canon Kabushiki Kaisha Control method and information processing apparatus for displaying information related to a function
EP4321984A2 (en) 2019-12-27 2024-02-14 Canon Kabushiki Kaisha Control method and information processing apparatus
EP4149102A1 (en) 2021-08-31 2023-03-15 Canon Kabushiki Kaisha Information processing apparatus, method of controlling information processing apparatus, and program
US11875066B2 (en) 2021-08-31 2024-01-16 Canon Kabushiki Kaisha Controlling an information processing apparatus to execute an extension application associated with printing data generation software
US12079524B2 (en) 2021-08-31 2024-09-03 Canon Kabushiki Kaisha Method of controlling information processing apparatus, editing intermediate data, and converting edited intermediate data into printing data
US12039207B2 (en) 2021-08-31 2024-07-16 Canon Kabushiki Kaisha Information processing apparatus, method of controlling information processing apparatus, and storage medium for processing flow of manual double-sided printing function
US11842091B2 (en) 2021-08-31 2023-12-12 Canon Kabushiki Kaisha Method of controlling information processing apparatus, editing intermediate data, and converting edited intermediate data into printing data
US11954386B2 (en) 2021-09-13 2024-04-09 Canon Kabushiki Kaisha Information processing apparatus having enhanced printing functions, controlling method of information processing apparatus, and storage medium
DE102023200419A1 (de) 2022-02-09 2023-08-10 Canon Kabushiki Kaisha Programm, informationsverarbeitungsvorrichtung und steuerverfahren
US12086486B2 (en) 2022-02-09 2024-09-10 Canon Kabushiki Kaisha Storage medium, information processing apparatus, and control method for providing status notification about a printing apparatus
EP4312115A1 (en) 2022-07-26 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus, program, and computer-readable storage medium
EP4312116A1 (en) 2022-07-26 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus and non-transitory computer-readable storage medium
US12118253B2 (en) 2022-07-26 2024-10-15 Canon Kabushiki Kaisha Information processing apparatus and non-transitory computer-readable storage medium for using an extension application for extending functionality in association with a standard application
EP4312117A1 (en) 2022-07-29 2024-01-31 Canon Kabushiki Kaisha Information processing apparatus, information processing method, and storage medium
JP7547418B2 (ja) 2022-07-29 2024-09-09 キヤノン株式会社 情報処理装置、情報処理方法およびプログラム
EP4354273A1 (en) 2022-10-14 2024-04-17 Canon Kabushiki Kaisha Information processing apparatus, control method, and storage medium

Also Published As

Publication number Publication date
CN114860177A (zh) 2022-08-05
JP6983614B2 (ja) 2021-12-17
US10747481B2 (en) 2020-08-18
US11662963B2 (en) 2023-05-30
KR20190042456A (ko) 2019-04-24
EP3471389A3 (en) 2019-06-19
US20230251804A1 (en) 2023-08-10
CN109669645A (zh) 2019-04-23
KR20210134876A (ko) 2021-11-11
CN109669645B (zh) 2022-06-10
EP3471389A2 (en) 2019-04-17
KR102461063B1 (ko) 2022-11-01
US20200341703A1 (en) 2020-10-29
US20190114119A1 (en) 2019-04-18

Similar Documents

Publication Publication Date Title
JP6983614B2 (ja) プログラム
US10949148B2 (en) Print processing system and control method
US20030084132A1 (en) Network system, information processing apparatus, information processing method, and control program
JP7500657B2 (ja) プログラム及び情報処理装置
KR20130094239A (ko) 정보처리장치, 정보처리방법 및 컴퓨터 판독 가능한 매체
CN101964855A (zh) 信息处理装置及信息处理方法
EP2388685B1 (en) Information processing apparatus and control method thereof, and storage medium
JP6857040B2 (ja) 情報処理装置及びプログラム
JP7230387B2 (ja) 情報処理装置及び情報処理プログラム
JP2007249931A (ja) 情報処理装置、印刷設定方法、記憶媒体、プログラム
JP2005258924A (ja) 情報処理装置及びその制御方法、及び画像形成システム
JP4336555B2 (ja) データ処理装置
EP1460531A2 (en) Printer information setting method, server and program
JP7263491B2 (ja) プログラムおよび情報処理装置
JP2009187131A (ja) 文書管理装置、文書管理方法、及びコンピュータプログラム
US9990168B2 (en) Recording medium, information processing apparatus, and information processing method
US20240338152A1 (en) Information processing apparatus and method of controlling the same, and storage medium storing print expansion program
US20240329890A1 (en) Information processing apparatus and method of controlling the same, and storage medium
JP2020088487A (ja) 情報処理装置とその制御方法、及びプログラム
JP6808520B2 (ja) 画像形成装置、画像形成装置の制御方法、およびプログラム
JP2020071693A (ja) 情報処理装置、及びその制御方法並びにプログラム
JP2019185627A (ja) 情報処理装置及び情報処理プログラム
JP2018129607A (ja) 画像形成装置、画像形成装置の制御方法、およびプログラム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20201012

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20210721

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210810

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20211005

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: 20211026

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20211124

R151 Written notification of patent or utility model registration

Ref document number: 6983614

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151