JP2021124791A - 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム - Google Patents

情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム Download PDF

Info

Publication number
JP2021124791A
JP2021124791A JP2020015844A JP2020015844A JP2021124791A JP 2021124791 A JP2021124791 A JP 2021124791A JP 2020015844 A JP2020015844 A JP 2020015844A JP 2020015844 A JP2020015844 A JP 2020015844A JP 2021124791 A JP2021124791 A JP 2021124791A
Authority
JP
Japan
Prior art keywords
printer
application
information
print
server system
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
JP2020015844A
Other languages
English (en)
Other versions
JP7433940B2 (ja
JP2021124791A5 (ja
Inventor
弘和 三枝
Hirokazu Saegusa
弘和 三枝
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 JP2020015844A priority Critical patent/JP7433940B2/ja
Priority to KR1020210007180A priority patent/KR20210098335A/ko
Priority to EP21152625.6A priority patent/EP3859515A1/en
Priority to US17/157,334 priority patent/US20210240412A1/en
Publication of JP2021124791A publication Critical patent/JP2021124791A/ja
Publication of JP2021124791A5 publication Critical patent/JP2021124791A5/ja
Priority to JP2024009512A priority patent/JP2024045318A/ja
Application granted granted Critical
Publication of JP7433940B2 publication Critical patent/JP7433940B2/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/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/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1267Job repository, e.g. non-scheduled jobs, delay printing
    • 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/1204Improving or facilitating administration, e.g. print management resulting in reduced user or operator actions, e.g. presetting, automatic actions, using hardware token storing data
    • 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/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1224Client or server resources management
    • G06F3/1226Discovery of devices having required properties
    • 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/1229Printer resources management or printer maintenance, e.g. device status, power levels
    • G06F3/1231Device related settings, e.g. IP address, Name, Identification
    • 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/1229Printer resources management or printer maintenance, e.g. device status, power levels
    • G06F3/1232Transmitting printer device capabilities, e.g. upon request or periodically
    • 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/1257Configuration of print job parameters, e.g. using UI at the client by using pre-stored settings, e.g. job templates, presets, print styles
    • 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/1259Print job monitoring, e.g. job status
    • 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/1287Remote printer device, e.g. being remote from client or server via internet
    • 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols

Landscapes

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

Abstract

【課題】 本明細書に記載の発明は、ユーザーがクラウドプリントサービスに登録された印刷装置に対応するアプリケーションを探さずとも、当該アプリケーションをユーザーの使用する情報処理装置にインストールすることを目的とする。
【解決手段】 本明細書に記載の情報処理装置は、第1のサーバシステムに情報を登録する操作を受け付けた印刷装置が送信する登録要求を受信する前記第1のサーバシステムと通信することのできる情報処理装置であって、前記印刷装置の機種情報に対応するアプリケーション識別情報を特定する特定手段と、特定されたアプリケーション識別情報のアプリケーションを第3のサーバシステムから取得する取得手段と、取得された前記アプリケーションにより生成される印刷設定画面を表示する表示手段と、前記印刷設定画面を介して設定された印刷設定を前記第1のサーバシステムに送信する送信手段と、を有することを特徴とする。
【選択図】 図6

Description

情報処理装置および情報処理装置においてなされた印刷設定に基づく印刷を実行する印刷装置、および、当該情報処理装置の制御方法とプログラムに関するものである。
予め、ユーザーがクラウドプリントサービスに印刷装置の情報を登録しておき、印刷データをクラウドプリントサービス経由で印刷装置に送信して印刷する印刷システムが知られている。ユーザーは、PC等の情報処理装置からクラウドプリントサービスにアクセスし、クラウドプリントサービスに登録された印刷装置から印刷に使用する印刷装置を選択し、印刷データの印刷を指示する。
情報処理装置は、印刷ジョブを生成し、クラウドプリントサービス上の印刷キューに投入する。印刷装置は、クラウドプリントサービスにアクセスし、クラウドプリントサービス上に生成された印刷キューにスプールされた印刷ジョブを取得し、出力する(特許文献1)。
クラウドプリントサービスの代表例として、例えばGoogleCloudPrint(登録商標)(特許文献1)、MicrosoftHybridCloudPrint(登録商標)、uniFLOW Online(登録商標)などがある。
特開2013−238924号公報
クラウドプリントサービスを用いて印刷を行う際、ユーザーはクラウドプリントサービスが提供する印刷設定画面やOS等の標準的なソフトウェアが提供する印刷設定画面で印刷設定を行う。しかしながら、上記のようなクラウドプリントサービスやOSが提供する印刷設定画面では標準的な設定項目しか設定することができない。
印刷拡張アプリケーションを使って、クラウドプリントサービスやOSが提供する印刷設定画面を拡張し、標準的な項目以外の項目も設定をすることができるようにすることが考えられている。しかしながら、上記のアプリケーションを利用するためには、ユーザーが、アプリケーションを配布するサービスから、クラウドプリントサービスに登録したプリンターに対応するアプリケーションを探し、クライアント端末にインストールしなくてはならない。
本発明は、ユーザーがクラウドプリントサービスに登録された印刷装置に対応するアプリケーションを探さずとも、当該アプリケーションをユーザーの使用する情報処理装置にインストールすることを目的とする。
本明細書に記載の情報処理装置は、ユーザーによる第1のサーバシステムに情報を登録する操作を受け付けた印刷装置が送信する登録要求を受信する前記第1のサーバシステムと通信することのできる情報処理装置であって、前記印刷装置が前記第1のサーバシステムに送信した前記印刷装置の機種情報に対応するアプリケーション識別情報を特定する特定手段と、前記特定手段により特定されたアプリケーション識別情報のアプリケーションを第3のサーバシステムから取得する取得手段と、取得された前記アプリケーションにより生成される印刷設定画面を表示する表示手段と、前記印刷設定画面を介して設定された印刷設定を前記第1のサーバシステムに送信する送信手段と、を有することを特徴とする。
本発明により、ユーザーがクラウドプリントサービスに登録された印刷装置に対応するアプリケーションを探さずとも、当該アプリケーションをユーザーの使用する情報処理装置にインストールすることができる。
本実施形態において、クライアントコンピューター100におけるハードウェア構成の一例を示す図である。 本実施形態におけるネットワーク構成の一例を示す図である。 本実施形態におけるプリンタードライバー配布サービス300における機能ブロックの一例を示す図である。 本実施形態における印刷拡張アプリケーション配布サービス400における機能ブロックの一例を示す図である。 本実施形態におけるクラウドプリントサービス500における機能ブロックの一例を示す図である。 本実施形態において、クラウドプリントサービス500にプリンター200を登録するシーケンスの一例を示す図である。 本実施形態において、クラウドプリントサービス500が保持するプリンターの情報データベースの一例を示す図である。 本実施形態において、プリンタードライバー配布サービス300が保持するプリンターの情報データベースの一例を示す図である。 本実施形態において、印刷拡張アプリケーション配布サービス400が保持するプリンターの情報データベースの一例を示す図である。 本実施形態において、クライアントコンピューター100に印刷設定アプリケーション1052をインストールするシーケンスの一例を示す図である。 本実施形態において、クラウドプリントサービス500から受信した印刷可能ジョブリストを表示した操作パネルの一例を示す図である。 本実施形態において、印刷設定を変更するためのUIの一例を示す図である。 本実施形態において、プリンターの能力情報に基づき表示される印刷設定画面の一例を示す図である。 本実施形態において、拡張された印刷設定の一例を示す図である。 本実施形態において、クラウドプリントサービス500における印刷のフローチャートである。 本実施形態において、ドライバー拡張パッケージを更新する処理を示すシーケンスの一例である。 本実施形態において、クラウドプリントサービスがドライバー拡張パッケージを取得する処理を示すフローチャートである。 本実施形態において、印刷拡張アプリケーションをインストールする処理を示すフローチャートである。
図1は、本実施形態においてクラウドプリントサービスを利用するクライアントコンピューター(情報処理装置)のハードウェア構成図である。以下に詳細な説明を記載する。
CPU101は主記憶装置102のROM1021あるいはRAM1022あるいは補助記憶装置105に格納されたプログラムに従って装置全体の制御を行う。
RAM1022はCPU101が各種処理を行う際のワークエリアとしても使用される。補助記憶装置105はクラウドドライバー1050、オペレーションシステム(OS)1053やアプリケーション1051、印刷拡張アプリケーション1052等を記録する。以降の説明では、主記憶装置102と補助記憶装置105を合わせて記憶装置と記載する。
マウス・タッチパネルなどに代表されるポインティングデバイス109やキーボード108などの入力機器は、入力I/F103を通じてシステムバス107に接続され、ユーザーがコンピューターに対して各種指示を与えるためのデバイスである。
出力I/F104は、データを外部に出力するためのインターフェースであり、モニター110やパネル111のような出力機器に対してデータを出力する。また、クライアントコンピューター100は撮影機能を有しており、カメラ112が搭載されている。
クライアントコンピューター100は、通信I/F106を経由しネットワーク150を通じて図2にて後述するプリンター200や各システムと接続される。また、107は共通データシステムバスで、I/Fやモジュール間でデータのやり取りを行う。
図2は、本実施形態を示すネットワークの環境を簡略した印刷システムの概略図である。
ネットワーク150にはクライアントコンピューター100とプリンター200が接続されている。クライアントコンピューター100とプリンター200は同一イントラネットワークに接続され、通信可能な状態である。
また、別のイントラネット204にはプリンター201、プリンター202が接続されており、ネットワーク150はインターネット203を通じてイントラネット204に接続されている。インターネット203には、プリンタードライバー配布サービス300、印刷拡張アプリケーション配布サービス400、クラウドプリントサービス500が接続されている。
プリンタードライバー配布サービス300は、Webベースでプリンタードライバーをクライアントコンピューター100に配布するサービスを実行する1または複数台の情報処理装置で構成されるサーバシステムである。クライアントコンピューター100は、プリンター200をWSD(Web Services for Devices)やIPP(Internet Printing Protocol)などのプロトコルで探索する。クライアントコンピューター100は発見したプリンター200のプリンター識別情報や機種情報に基づくプリンタードライバーをプリンタードライバー配布サービス300から取得し、インストールする。プリンタードライバー配布サービス300に登録されているプリンタードライバーはプリンターベンダーによって更新される。クライアントコンピューター100は、バージョンの新しいプリンタードライバーを自動または手動でプリンタードライバー配布サービス300から取得し、インストールされているプリンタードライバーを更新する。
印刷拡張アプリケーション配布サービス400は、クライアントコンピューター100で実行されるアプリケーションを配布するサービスを実行する1または複数台の情報処理装置で構成されるサーバシステムである。印刷拡張アプリケーションとは、クラウドプリントサービスやOSが提供する印刷機能を拡張するためのアプリケーションである。クラウドプリントサービスやOSが提供する印刷機能ではいずれのベンダーのプリンターでも使用することのできる標準的な機能、たとえば、カラーモードや両面印刷等しか印刷設定を行うことができない。印刷拡張アプリケーションを利用することで、クラウドプリントサービスやOSの提供する印刷機能では設定することのできない印刷機能、例えば針なしステープルやポスター印刷、中綴じ製本などの機能を利用することができるようになる。
クライアントコンピューター100は、印刷拡張アプリケーションのインストールを要求するユーザー操作を受け付けた場合、印刷拡張アプリケーション配布サービス400にアクセスし、印刷拡張アプリケーションをインストールする。また、クライアントコンピューター100にインストールされたプリンタードライバーのInf(Information)ファイルにアプリケーション識別子が記述されている場合、印刷拡張アプリケーションのインストールが行われる。アプリケーション識別子は印刷拡張アプリケーション配布サービス400に登録されているアプリケーションのうち、クラウドプリントサービス500に登録されたプリンターに対応するアプリケーションを特定するためのアプリケーション識別情報である。クライアントコンピューター100は、印刷拡張アプリケーション配布サービス400にアクセスし、Infファイルに記述された識別子に対応する印刷拡張アプリケーションをインストールする。
クラウドプリントサービス500は、1台または複数台の情報処理装置からなるサーバシステムであるクラウド上に構築されるサービスである。本実施形態において、クラウドプリントサービス500は其々のイントラネットに対して接続が可能であり、インターネットを通じてクライアントコンピューター100およびプリンター200やプリンター201、プリンター202との接続が可能である。クラウドプリントサービス500は、ユーザーIDとPASSWORDを利用したアカウント管理がなされており、クライアントコンピューター100はユーザーが入力したアカウント情報を利用してクラウドプリントサービス500にアクセスする。
なお、本実施形態において、クライアントコンピューター100はクラウドプリントサービス500、印刷拡張アプリケーション配布サービス400のURLをあらかじめ記憶しているものとする。また、クラウドプリントサービス500は、プリンタードライバー配布サービス300のURLをあらかじめ記憶しているものとする。
図3Aは、プリンタードライバー配布サービス300の機能ブロックの一例を示した図である。プリンタードライバー配布サービス300は、図1に示す情報処理装置と同様の構成の1または複数台の情報処理装置で構成されるサーバシステムである。プリンタードライバー登録部301、プリンタードライバー応答部302は、プリンタードライバー配布サービス300を構成する情報処理装置のCPUがプログラムを実行することで実現される。
プリンタードライバー配布サービス300は、インターネットを通じたクラウド上に存在するサービスであり、外部サービスやクライアントコンピューター100にプリンタードライバーに関するパッケージの配布を可能とする。プリンタードライバーに関するパッケージとは、たとえば、プリンタードライバーやドライバー拡張パッケージなどである。
プリンタードライバー登録部301は、外部サービス及びクライアントコンピューター100からプリンタードライバーに関するパッケージの登録指示があった際に、アップロードされたパッケージをプリンタードライバーデータベース310に登録する。プリンタードライバー登録部301は、たとえば、プリンターベンダー等が配布するプリンタードライバーや、プリンタードライバーを拡張するためのドライバー拡張パッケージをプリンタードライバーデータベース310に登録する。
プリンタードライバー応答部302は、外部サービスやクライアントコンピューター100からプリンタードライバーや拡張パッケージに関する取得要求があった場合に、プリンタードライバーデータベース310から該当するパッケージを取得し、応答する。例えば、クライアントコンピューター100から、印刷キューが生成されたプリンター200に対応するプリンタードライバーの要求を受信したとする。プリンタードライバー応答部302は、プリンタードライバーデータベース310からプリンター200に対応するプリンタードライバーを読み出して、クライアントコンピューター100に送信する。プリンタードライバー応答部302は、クライアントコンピューター100から、インストールされているプリンタードライバーを拡張するためのドライバー拡張パッケージの取得要求を受信することもできる。その場合、プリンタードライバー応答部302は、プリンタードライバーデータベース310から要求されたプリンタードライバーに対応するドライバー拡張パッケージを読み出して、クライアントコンピューター100に送信する。
プリンタードライバーデータベース310には図5Bで後述するデータベースが記憶されている。プリンタードライバーデータベース310には様々なプリンターに対応するプリンタードライバーに加え、ドライバー拡張パッケージ303も記憶されている。
ドライバー拡張パッケージ303は、プリンタードライバー配布サービス300から配布されるパッケージの一例である。ドライバー拡張パッケージ303は、ドライバー情報部304とデバイス能力情報部305を持つ。ドライバー情報部304は、プリンターを識別するためのHWID、COID(Compatible ID)、当該パッケージがドライバー拡張パッケージであることを示す情報や、ドライバー拡張パッケージ303のバージョンなどの情報を持つ。デバイス能力情報部305は、対応するプリンター200のデバイス能力情報や禁則情報を持つ。デバイスの能力情報とは、たとえば、プリンター200がカラー印刷に対応しているか、両面印刷に対応しているか等の情報である。ドライバー拡張パッケージ303に含まれる能力情報は、上記の能力情報に加え、ベンダー特有の針なし綴じが可能か否か、中綴じ製本が可能であるか否か、複数種類の用紙を使って印刷する用紙混在印刷か可能であるか否かを含む。
図3Bは、印刷拡張アプリケーション配布サービス400の機能ブロックの一例を表した図である。アプリケーション登録部401、アプリケーション応答部402は、印刷拡張アプリケーション配布サービス400を構成する1または複数台の情報処理装置のCPUがプログラムを実行することで実現される。
印刷拡張アプリケーション配布サービス400は、インターネットを通じたクラウド上に存在するサービスであり、外部サービスやクライアントコンピューター100に印刷拡張アプリケーションの配布を可能とする。尚、印刷拡張アプリケーション配布サービス400は、印刷拡張アプリケーション1052に限らず、他のアプリケーションの配布が可能であっても構わない。
アプリケーション登録部401は、外部サービス及びクライアントコンピューター100から印刷拡張アプリケーション1052の登録指示があった際に、アップロードされたアプリケーションをアプリケーションデータベース410に登録する。
アプリケーション応答部402は、外部サービスやクライアントコンピューター100から印刷拡張アプリケーション1052の取得要求があった場合にアプリケーションデータベース410から該当するアプリケーションを取得し、要求元に送信する。
アプリケーションデータベース410は、ベンダー等が配布し、外部サービスやクライアントコンピューター100から登録要求を受信した印刷設定アプリケーションの情報が登録されるデータベースである。アプリケーションデータベース410に登録される情報の詳細は図5Cを用いて後述する。
本実施形態における印刷拡張アプリケーション1052は、設定ファイル部10521と実行ファイル部10522を持つ。設定ファイル部10521は、印刷拡張アプリケーション1052を識別するためのアプリケーション識別情報や、対応するプリンター200を識別するためのHWIDやCOIDなどの情報を持つ。実行ファイル部10522は、印刷拡張アプリケーション1052の実行ファイル部である。実行ファイル部10522は印刷設定UI(User Interface)や外部サービスからのプッシュ通知を受け取って、印刷設定画面を表示することが可能である。
図3Cは、本発明の実施形態を示すクラウドプリントサービス500の機能ブロック図である。それぞれの機能ブロックは、クラウドプリントサービス500を構成する1または複数台の情報処理装置のCPUがプログラムを実行することで実現される。
クラウドプリントサービス500は、インターネットを通じたクラウド上に存在するサービスであり、印刷に関連する機能を提供可能とする。本実施形態では、プリンター登録部501、印刷キュー生成部502、プリンターリスト生成部503、探索応答部504、プリンターデータベース510の機能を持つ。さらに、印刷ジョブ管理部505、印刷ジョブ生成部506、印刷ジョブ保存領域511の機能を持つ。また、これらの機能がクラウドプリントサービス500と連携する別のクラウドプリントサービスにあっても構わない。
以下、プリンター200をクラウドプリントサービス500に登録し、プリンター200を用いて印刷を行う場合を例に記載しているが、クラウドプリントサービス500と接続可能なプリンター201やプリンター202でも同様の処理で実現可能である。
プリンター登録部501は、プリンター200からプリンターの登録指示があった場合、印刷キュー生成部502を利用して印刷キューを生成させ、生成された印刷キューをプリンターデータベース510にプリンター識別情報と紐づけて登録する。このようにプリンターの印刷キューとプリンター識別情報とが紐づけて登録されていることを、プリンターが登録されていると記載する。ここで登録されたプリンターに対して、様々な属性が付加される場合がある。様々な属性とは、例えば、プリンターの所在地が該当する。
印刷キュー生成部502は、プリンター登録部501の制御に従い、クラウドプリントサービス500上の印刷キューを生成する。クライアントコンピューター100がクラウドプリントサービス500に印刷指示を送信すると、印刷キュー生成部502が生成した印刷キューに印刷ジョブが登録される。
プリンターリスト生成部503は、登録されたプリンターのリストを生成する。クライアントコンピューター100からクラウドプリントサービス500に登録されているプリンターのリストを要求された場合等にプリンターのリストを生成する。
探索応答部504は、クライアントコンピューター100からのクラウドプリントサービス500に対してプリンター探索に基づき、登録されているプリンターの情報をクライアントコンピューター100に応答する。探索応答部504は、探索結果をプリンターリスト生成部503に渡し、プリンターリストを生成させる。そして、プリンターリスト生成部503が生成したプリンターリストをクライアントコンピューター100に返す。
印刷ジョブ管理部505は、クライアントコンピューター100から画像データと印刷設定を受信したり、印刷ジョブ生成部506が生成した印刷ジョブをプリンター200に送信する。また、印刷ジョブ管理部505は、印刷ジョブ生成部506が生成した印刷ジョブを印刷ジョブ保存領域511に保存する。
プリンターデータベース510は、クラウドプリントサービス500に登録されているプリンターの情報を記憶するデータベースである。プリンターデータベース510に記憶される内容は、図5Aで後述する。
はじめに、プリンター200をクラウドプリントサービス500に登録する処理について説明する。
図4は、本発明の実施形態を示すプリンター200をクラウドプリントサービス500に登録する処理のシーケンス図である。本実施形態では、クライアントコンピューター100からプリンター200にアクセスし、プリンター200を操作することでクラウドプリントサービス500にプリンター200の登録要求を送信する。
プリンター200はクラウドプリント機能(クラウドプリントサービスから印刷ジョブを受信して印刷する機能)と、クライアントコンピューター100からプリンター200を操作するためのWebUI機能をサポートしている。WebUI機能とは、UIを生成してネットワーク上に公開する機能である。クライアントコンピューター100はクラウドプリントクライアント機能(クラウドプリントサービスにファイルを送信する機能)と、WebUIを操作するためのWebUIクライアント(例えば、Webブラウザー)をサポートしている。また、クラウドプリントサービス500はインターネット上のクラウドプリントサービスを表す。
ユーザーはまずクライアントコンピューター100のWebUIクライアントを利用して、プリンター200のWebUIを開き、当該WebUI上で、クラウドプリントサービスにプリンターを登録するためのボタンを選択する。当該選択がされると、S410において、クライアントコンピューター100は、クラウドプリントサービスへの登録要求をプリンター200に送信する。
S411において、プリンター200は、S410においてクラウドプリントサービスへの登録要求を受信すると、クラウドプリントサービス500にクラウドプリントサービスへの登録要求を送信する。このように、本実施形態では、クライアントコンピューター100のWebUIクライアントからクラウドプリントサービス500へのプリンター200の登録要求を送信している。プリンター200に付随した入力装置、例えばパネルから操作することで本要求を送信可能としてもよい。このときは、クライアントコンピューター100から要求を行わず、プリンター200がクラウドプリントサービス500にプリンターの登録要求を送信する。
S411において、クラウドプリントサービス500に送信されるクラウドプリントサービス登録要求には、プリンター200の情報が付随している。プリンター200の情報には、プリンター200の名称、プリンターの機種を識別する情報(HWID)、インクジェットプリンターやレーザープリンターなどのプリンターの種別を識別するためのCOIDが含まれる。さらに、プリンターの情報には、IPアドレス情報やIPPなどで標準化されている機能に関する能力情報ファイルが含まれる。
クラウドプリントサービス500は、S411において登録要求を受信すると、S412において、印刷キュー生成部502に、プリンター200に印刷ジョブを送信するための印刷キューを作成させる。プリンター登録部501は、プリンターデータベース510にプリンターの情報と能力情報を登録し、登録要求がなされたプリンターのレコードを生成する。さらに印刷キュー生成部502が印刷キューの生成を行う。この印刷キューは、受信したプリンター200の情報である、プリンターの名称(デバイス名)、プリンターの機種を識別するHWID、COIDや、プリンターのIPアドレスを利用して作成される。
次に、S413にて、クラウドプリントサービス500は、プリンタードライバー配布サービス300にドライバー拡張パッケージ303のダウンロード要求を送信する。これは、クラウドプリントサービス500に登録されたプリンターに対応するドライバー拡張パッケージ303を受信するための要求である。クラウドプリントサービス500は、ドライバー拡張パッケージ303ダウンロード要求とプリンター200のHWID、COIDをプリンタードライバー配布サービス300に送信する。
S414にて、プリンタードライバー配布サービス300は、受信したHWID及びCOIDに基づき、該当するドライバー拡張パッケージ303をクラウドプリントサービス500に送信する。プリンタードライバー配布サービス300は、プリンタードライバーデータベース310から、拡張フラグがTRUEのパッケージであって、受信したHWIDに一致するドライバー拡張パッケージを図5Bで示すプリンタードライバーデータベースから特定する。拡張フラグがTRUEであるが、受信したHWIDに一致するドライバー拡張パッケージが特定されない場合、プリンタードライバー配布サービス300は、拡張フラグがTRUEであって、受信したCOIDに一致するドライバー拡張パッケージを特定する。そして、プリンタードライバー配布サービス300は、クラウドプリントサービス500に特定されたプリンター拡張パッケージを送信する。なお、HWIDのみでドライバー拡張パッケージが特定可能である場合、S413において、HWIDのみをプリンタードライバー配布サービス300に送信するとしてもよい。
図5Bは、プリンタードライバー配布サービス300が保持するプリンタードライバーデータベース310の一例である。パッケージ名は、登録時にドライバー情報部304から取得したパッケージの名称を指す。HWIDはプリンター200の機種を識別する際に用いる識別情報(機種固有の識別情報)を指す。COIDは、当該ドライバーを使用するプリンターのカテゴリーを識別する識別情報である。パッケージは、ドライバー拡張パッケージ303を含むパッケージの名称を指す。パッケージは当該レコードに対応するドライバーまたはドライバー拡張パッケージを特定することのできる情報であればファイルパス等の情報であってもよい。拡張は、ドライバー拡張パッケージ303が拡張ファイルかどうかを示している。拡張が“FALSE”の場合、当該パッケージは拡張パッケージではなくプリンタードライバーである。一方で、拡張が“TRUE”の場合、当該パッケージはプリンタードライバーではなく、ドライバーを拡張するパッケージである。アプリケーション識別子は、当該プリンター拡張パッケージの記憶する能力情報を使って印刷設定画面を拡張する際に使用するアプリケーションの識別情報である。本実施形態では、プリンター拡張パッケージのみがアプリケーション識別子を有しているが、プリンタードライバーがアプリケーション識別子を有していてもよい。
なお、図5Bに示すプリンタードライバーデータベースはプリンタードライバー登録部301によって更新される。プリンタードライバー登録部301は、パッケージをプリンタードライバーデータベース310に登録する際に、ドライバー情報部304を解析する。プリンタードライバー登録部301は、パッケージ名、HWIDやCOID、ドライバー拡張パッケージであるかどうかの情報を取得し、ドライバー拡張パッケージ303と共にプリンタードライバーデータベース310に登録をする。
S415にて、クラウドプリントサービス500は、ダウンロードされたドライバー拡張パッケージ303のデバイス能力情報部305を解析し、印刷キューを拡張する。クラウドプリントサービス500は、ドライバー拡張パッケージ303のデバイス能力情報部305からプリンター200の能力情報を取得する。そして、クラウドプリントサービス500は、プリンターデータベース510のプリンター情報の印刷キューに対応するプリンターの能力情報を更新する。S415において、クラウドプリントサービス500は、印刷キューに対応づけられている能力情報をドライバー拡張パッケージから取得された能力情報で書き換える。なお、クラウドプリントサービス500が、ドライバー拡張パッケージから取得された能力情報のうち、印刷キューに対応づけられていない設定項目に関する能力情報を印刷キューに対応する能力情報に追加するとしてもよい。また、クラウドプリントサービス500が、プリンター200からプリンター200のハードウェア構成を示す情報を取得し、ドライバー拡張パッケージに含まれる能力情報とハードウェア構成情報から能力情報を決定するとしてもよい。また、クラウドプリントサービス500が、プリンター200からプリンター200のハードウェア構成を示す情報を取得し、ドライバー拡張パッケージに含まれる能力情報とハードウェア構成情報から能力情報を決定するとしてもよい。
上記の処理により、クラウドプリントサービス500に登録されたプリンター200に対してベンダー特有のデバイス能力情報で印刷キューが拡張される。そして、S416にて、拡張されたプリンター200の情報でプリンターデータベース510を更新する。上記の処理により、ドライバー拡張パッケージにより拡張された能力情報が印刷キューに対応する能力情報としてプリンターデータベース510に登録される。
図5Aは、クラウドプリントサービス500が保持するプリンターデータベース510の一例である。デバイス名は、登録時にプリンター200から取得したプリンターの名称(デバイス名)を指す。HWIDはプリンター200の機種を識別する際に用いる識別子(機種固有の識別子)を指す。COIDはプリンター200がインクジェットプリンターであるかレーザービームプリンターであるかなどプリンターのカテゴリーを識別するための識別情報である。IPアドレスは、接続先のプリンターのIPアドレスを指す。パッケージは、当該プリンターに対応する印刷キューの拡張に使われるドライバー拡張パッケージ303のパッケージ名を指す。なお、拡張されていない場合には、nullとなる。さらに、不図示であるが、デバイスの能力情報などがJSON(Javascript(登録商標) Object Notation)形式でデータベースに登録される。プリンターの能力情報がドライバー拡張パッケージにより拡張されている場合は、拡張後の能力情報が記憶されている。デバイスの能力情報が記憶される形式は、JSONに限らず他のデータフォーマットであっても構わない。また、図5Aがプリンターの情報と当該プリンターを使用することのできるユーザーの情報を対応づけて記憶するとしてもよい。
図9は、印刷キューに対応づけて記憶される能力情報の一例である。一例として、能力情報は、JSON形式になっており、各設定は機能を表している。また、各機能は配列形式で設定できる選択肢を持つ。
901はIPP等で定義された標準的な能力情報を示している。“Duplex”は、両面機能に関する設定項目であり、当該設定項目の選択肢として両面印刷を表す“Duplex”と片面印刷を表す“One−Sided”を持つことを示している。“Color”は、カラー印刷に関する設定項目であり、選択肢として白黒印刷を示す“Mono”とカラー印刷を示す“Color”を持つことを示している。“Orientation”は印刷に使用する用紙の向きに関する設定項目であり、選択肢として縦長方向を示す“Portrait”と横長方向を示す”Landscape“を持つことを示している。901に記載の能力情報は、プリンター200からクラウドプリントサービス500に提供することのできるIPP等で定義された標準的な設定項目、選択肢である。ドライバー拡張パッケージを用いてデバイスの能力情報を拡張することで、901に記載のIPP等で定義された標準的な設定項目であっても、ベンダー固有の選択肢を持つようにすることができる。たとえば、用紙の綴じに関する設定項目である”Staple“を拡張することで、標準的な選択肢である左上一か所綴じを示す”Staple left top“に加えて、中綴じを示す”Saddle Stitch“を設定することができるようになる。
902は、ドライバー拡張パッケージ303で拡張された能力情報であり、例えばベンダー固有の設定項目に関する能力情報である。機能がExtension_Setting1、Extension_Setting2となっており、その選択肢としてExntension_option1,Extension_option2となっている。Extension settingとしては、たとえば、針なし綴じに関する設定や、複数種類の用紙が一つのジョブに混在する用紙混在に関する設定などがある。用紙混在機能であれば、“Extension_Setting1”に用紙混在を示す文字列が入る。そして、“Exntension_option1”に例えばA3とA4の用紙を使用することを示す選択肢を示す文字列、“Exntension_option2”B4とB5の用紙を使用することを示す選択肢を示す文字列が入る。印刷拡張アプリケーションが図9に示すファイルを参照することで、ベンダー固有の設定項目を設定することのできる印刷設定画面の提供が可能となる。
ここで、説明を図4に戻す。S417において、クラウドプリントサービス500は、プリンターデータベース510への登録が完了すると、クラウドプリント登録用の登録URLを含むクラウドプリントサービス登録要求応答および登録URL提示要求をプリンター200に送信する。
S418において、プリンター200は、クラウドプリントサービス登録要求応答および登録URL提示要求を受信し、プリンター200は登録URL情報を出力する。S418において、プリンター200はモニター110にURLを表示する、もしくは登録URL情報が記載された紙を印刷し、ユーザーに登録URLを通知する。また、プリンター200がクライアントコンピューター100に対して、WebUI経由で登録URLを通知してもよい。
S419において、ユーザーは、プリンター200から提示された登録URLに位置するクラウドプリントサービス500にアクセスする。その際は、クラウドプリントサービス500にアクセス可能なクラウドアカウントにログインしている必要があるため、ユーザーIDとPASSWORDの入力が必要である。
クラウドプリントサービス500は、クラウドアカウントとプリンター情報を含む登録URLから、ユーザーとプリンター200を紐づける。紐づける方法として、例えば、プリンター情報とユーザートークンを紐づける方法がある。ただし、その方法に限定はしない。そして、S420にて、クラウドプリントサービス500は、クラウドプリントサービス500の情報を含めたユーザートークンをプリンター200に送信し、プリンター200のクラウドプリントサービス500への登録処理を終了する。プリンター200は、以降当該ユーザートークンを用いてクラウドプリントサービス500にアクセスする。
次に、クラウドプリントサービス500に登録されたプリンター200の印刷キューをクライアントコンピューター100に生成し、印刷拡張アプリケーションをインストールするときの処理を説明する。
図6は、本発明の実施形態を示すクライアントコンピューター100に印刷拡張アプリケーション1052をインストールする処理のシーケンス図である。
クライアントコンピューター100では、クラウドプリントを利用してプリンター200に出力する場合、クラウドプリントサービス500に対して印刷ジョブを送信する。そのため、クライアントコンピューター100に、クラウドプリントサービス500に対して印刷ジョブを送信する印刷キューを生成する必要がある。
本実施形態では、オペレーティングシステム1053が標準機能としてもつプリンター探索機能を利用して、クラウドプリントサービス500に登録されたプリンターの印刷キューを生成する。通常、プリンター探索を行う場合、同一イントラネット上にあるプリンターが対象となる。例えば、図2においてクライアントコンピューター100がプリンター探索を行うとプリンター200を見つけることはできるが、イントラネットを超えたプリンター201、プリンター202を見つけることはできない。本実施形態では、クライアントコンピューター100はクラウドプリントサービス500へのアクセスが可能である。クラウドプリントサービス500にプリンターが登録されている場合にはプリンター探索で、クラウドプリントサービス500に登録されているプリンターを見つけることができる。本実施形態では、前述したプリンター200に加え、プリンター201、プリンター202がクラウドプリントサービス500に登録されており、OSのプリンター探索機能でこれらのプリンターも見つけることができる。
クライアントコンピューター100は、前述したオペレーティングシステム1053の標準機能であるプリンター探索を行う(S610)。S610において、クライアントコンピューター100は、クライアントコンピューター100と同じイントラネット上にいるプリンターに加えて、クラウドプリントサービス500に登録されているプリンターを探索する。クライアントコンピューター100はクラウドプリントサービスにアクセスし、クラウドプリントサービス上に登録されているプリンター情報のリスト要求をクラウドプリントサービス500に送信する。
クラウドプリントサービス500の探索応答部504は、プリンター探索の情報を受信すると、クライアントコンピューター100に対して利用可能なプリンターを提示する。そのために、クラウドプリントサービス500は、クライアントコンピューター100からクラウドプリントサービス500にアクセスしているユーザーが使用することのできるプリンター情報を含むプリンターリストを生成する(S611)。このプリンター情報は、前述したプリンターの名称(デバイス名)、プリンターの機種を識別するHWID、プリンターのIPアドレスである。プリンター情報を含むプリンターリスト作成は、クラウドプリントサービス500のプリンターリスト生成部503がプリンターデータベース510の情報を利用して作成する。
クラウドプリントサービス500は、クライアントコンピューター100に対して、作成したプリンターリストを返答する(S612)。この際、クラウドプリントサービス500はプリンターリストに含まれるプリンター情報として図5Aに記載されているプリンター識別情報であるHWID、COID等の情報も付随して送信する。クライアントコンピューター100は、プリンターリストに基づきユーザーが利用可能なプリンターの選択画面をモニター110に表示させる。ユーザーは、提示されたプリンター一覧から使用したいプリンターを選択する。
クライアントコンピューター100のオペレーティングシステム1053が、クラウドプリントサービス500で利用されるクラウドドライバー1050をインストールし、選択されたプリンターの印刷キュー生成を行う(S613)。クライアントコンピューター100は、クラウドプリントサービス500からユーザーにより選択されたプリンターの情報を取得し、当該情報を使って印刷キューを生成する。クライアントコンピューター100は、クラウドプリントサービス500から取得したHWID、COID、IPアドレス、プリンターの能力情報に基づき印刷キューを生成する。なお、すでにクライアントコンピューター100にクラウドドライバー1050がインストールされている場合、クライアントコンピューター100はクラウドドライバー1050のインストールを行わない。クライアントコンピューター100はすでにインストールされているクラウドドライバーとクラウドプリントサービス500から取得したプリンターの情報を用いて、印刷キューを生成する。
クライアントコンピューター100のオペレーティングシステム1053は、印刷キューの生成に成功すると、プリンタードライバー配布サービス300に、ドライバー拡張パッケージ303のダウンロード要求を行う(S614)。クライアントコンピューター100は、クラウドプリントサービス500にHWID、COIDとドライバー拡張パッケージの取得要求を送信する。なお、クライアントコンピューター100は、HWIDとCOIDのいずれかのみをクラウドプリントサービス500に送信するとしてもよい。
プリンタードライバー配布サービス300は、ダウンロード要求を受信すると、クライアントコンピューター100に対してダウンロード処理を行う(S615)。プリンタードライバー配布サービス300は、プリンタードライバーデータベース310に登録されているドライバー拡張パッケージから受信したHWIDに一致するパッケージを特定し、クライアントコンピューター100に送信する。ドライバー拡張パッケージのうち受信したHWIDに一致するパッケージがない場合、プリンタードライバー配布サービス300は、受信したCOIDに一致するドライバー拡張パッケージを特定する。そして、プリンタードライバー配布サービス300は、特定したプリンター拡張パッケージをクライアントコンピューター100に送信する。
S616でクライアントコンピューター100のオペレーティングシステム1053は、ドライバー拡張パッケージ303のインストールを行い、前述のクラウドドライバー1050を基に生成された印刷キューの能力情報の拡張を行う(S616)。クライアントコンピューターは、印刷キューに対応する能力情報をプリンター拡張パッケージのデバイス能力情報で更新する。即ち、クラウドプリントサービス500に登録されたプリンター200に対してベンダー特有のデバイス能力で印刷キューを拡張する。クラウドプリントサービスからプリンター能力情報が取得されていない場合、ドライバー拡張パッケージに含まれる能力情報を印刷キューと対応づけることで印刷キューを拡張する。クラウドプリントサービス500から能力情報が取得されている場合、クラウドプリントサービス500から取得された能力情報をドライバー拡張パッケージに含まれる能力情報で上書きすることで印刷キューを拡張する。また、クラウドプリントサービス500から能力情報が取得されている場合に、ドライバー拡張パッケージに含まれる能力情報であって、クラウドプリントサービスから取得された能力情報に含まれていない能力情報を追加することで印刷キューを拡張してもよい。さらに、上記能力情報とプリンターのハードウェア構成情報に基づいて、プリンターが実行することのできる機能を能力情報として印刷キューに登録してもよい。
次に、クライアントコンピューター100は、印刷拡張アプリケーション配布サービス400に対して、ダウンロード要求を送信する(S617)。その際、オペレーティングシステム1053は、前述の印刷拡張アプリケーション1052の識別子情報を基に、対象のプリンターと紐づく印刷拡張アプリケーション1052のダウンロード要求を行う。本実施形態では、印刷拡張アプリケーション配布サービス400において、ドライバー拡張パッケージ303の印刷拡張アプリケーション1052の識別子情報と印刷拡張アプリケーション1052は1対1で紐づいている。
また、印刷拡張アプリケーション配布サービス400において、印刷拡張アプリケーション1052の識別子情報とプリンター情報に含まれるHWIDの紐づけ情報を記載したメタデータを保存しておいてもよい。その場合、そのメタデータを利用して、適切な印刷拡張アプリケーション1052をダウンロードする仕組みとなる。
印刷拡張アプリケーション配布サービス400は、ダウンロード要求を受信すると、クライアントコンピューター100に対してダウンロード処理を行う(S618)。アプリケーション応答部402は、クライアントコンピューター100から通知されたアプリケーション識別子に対応するアプリケーションを図5Cに示すアプリケーションデータベース410から特定する。アプリケーション応答部402は特定した印刷拡張アプリケーションをクライントコンピューターに送信する。クライアントコンピューター100は、印刷拡張アプリケーション1052のインストールを行う(S619)。
図5Cは、印刷拡張アプリケーション配布サービス400が保持するアプリケーションデータベース410の一例である。アプリケーション名は、印刷拡張アプリケーション1052を含む当該データベースに登録されたアプリケーションの名称である。アプリケーション識別子は、印刷拡張アプリケーション1052を含むアプリケーションを識別するための情報である。アプリパッケージは、印刷拡張アプリケーション1052を含むアプリケーションの記憶されたファイルパスである。アプリパッケージは登録されている印刷拡張アプリケーションのパッケージを特定することのできる情報であれば、アプリケーションの記憶されたフォルダ名等であってもよい。
アプリケーションデータベース410は、アプリケーション登録部401により更新される。アプリケーション登録部401は、設定ファイル部10521を解析し、アプリケーション名とアプリケーション識別子を取得する。アプリケーション登録部401は、印刷拡張アプリケーション1052と共にアプリケーションデータベース410に上記の情報を登録する。
インストール後、クライアントコンピューター100において印刷拡張アプリケーション1052は、プリンター200と1対1で紐づいている。従って、プリンター200において、プリンター200の機種情報や印刷設定情報を保持していることにより、ユーザーに対して適切な印刷設定UIを提示することが可能となる。もしくは、印刷拡張アプリケーション1052が、クラウドプリントサービス500と通信し、対象の機種情報や印刷設定情報を取得し、その情報を用いてUIを提供してもよい。ユーザーは、印刷拡張アプリケーション1052のインストールが完了すると、詳細な印刷設定変更が利用可能となる。
なお、本実施形態では、クライアントコンピューター100に印刷キューを生成した後、クライアントコンピューターがプリンタードライバー配布サービスにアクセスし、ドライバー拡張パッケージを取得した。クライアントコンピューター100がクラウドプリントサービス500から拡張後の印刷キューの情報を取得し、クライアントコンピューター上での印刷キューの拡張を行わないとしてもよい。この場合、クライアントコンピューター100はS614〜S616を省略する。また、クライアントコンピューター100がクラウドプリントサービス500から拡張後の印刷キューの情報を取得したうえで、S614〜S616に記載の処理を実行するとしてもよい。
次に、ユーザーがクライアントコンピューター100を操作し、クラウドプリントサービス500を介した印刷を行う場合について説明する。
ユーザーがクラウドプリントを利用する場合、クライアントコンピューター100のアプリケーション1051から印刷指示を行う。具体的な例として、アプリケーションのファイルメニューから“印刷”ボタンを選択する。アプリケーション1051は、ユーザーからの印刷指示に従って、オペレーティングシステム1053に対して図8Aに示す印刷コモンダイアログ(OSの提供する印刷設定画面)を表示するように指示を行う。オペレーティングシステム1053はアプリケーション1051から指示を受けて、印刷コモンダイアログを表示する。オペレーティングシステム1053が表示する印刷コモンダイアログは、クライアントコンピューター100に印刷キューが生成されているプリンターの一覧や、印刷するページの指定、部数の設定ができるようになっている。領域801には、クライアントコンピューター100に生成されている印刷キューの名称が表示されている。領域801には、クライアントコンピューター100とイントラネットで接続されるプリンターの印刷キューに加え、クラウドプリントサービス500を介して印刷に使用することのできるプリンターの印刷キューが表示される。印刷コモンダイアログでは、ユーザーはいずれのプリンターを使用する場合にも設定するようなページ指定や部数の設定を行うことしかできない。なお、図8Aに示すコモンダイアログで、IPP等の標準で定められている設定項目である両面印刷やカラーモードの設定が行えてもよい。
ユーザーが印刷コモンダイアログでは設定することのできない印刷設定を行うためには、ユーザーは印刷コモンダイアログから出力したいプリンターの印刷キューを選択し、同じ画面に表示している詳細設定ボタン(オブジェクト)800を選択する。ユーザーが“詳細設定”ボタンを選択すると、インストールされた印刷拡張アプリケーション1052が起動され、図8Bに示す印刷設定画面が表示される。印刷拡張アプリケーション1052が提供する印刷設定画面では、例えば、濃度や色味などの画像処理の設定やスタンプ合成の可否や、パンチ位置やステープル位置の設定など印刷コモンダイアログでは設定することのできない印刷設定を行うことができる。
ここで、図8Bを用いて、印刷拡張アプリケーション1052が提供する印刷設定画面について説明する。
ユーザーが印刷コモンダイアログの“詳細設定”ボタン800を選択すると、印刷拡張アプリケーション1052は、クラウドプリントサービス500に作成されたクライアントコンピューター100上の印刷キューに紐づく能力情報を取得する。
取得した能力情報を基に、実行ファイル部10522は図8Bに示す印刷設定画面を生成する。803は、印刷設定部であり、印刷キューの能力情報を基に印刷設定の変更を行うことができる。804は、拡張設定であり、ドライバー拡張パッケージ303で拡張された能力情報によって、生成された操作部である。805は、表示されている画面を切り替え、設定する項目を変更するための領域である。806は、確定ボタンであり、押下されることで設定情報を確定し、OS1053に確定した設定情報を渡す。
印刷コモンダイアログにて、ユーザーが“印刷”ボタン802を選択すると、画像データと印刷コモンダイアログで設定された印刷設定、印刷拡張アプリケーションで設定された印刷設定が印刷キューに送信される。領域801で設定されている印刷キューがクラウドプリントサービス500に登録されたプリンターの印刷キューである場合、クライアントコンピューター100は、クラウドプリントサービス500の当該印刷キュー宛てに画像データと印刷設定を送信する。
つぎに、ユーザーがプリンターを操作して印刷するときの処理について説明する。ユーザーがプリンター200にログインすると、プリンター200はクラウドプリントサービス500の印刷キューに登録された印刷ジョブの書誌情報の取得要求をクラウドプリントサービス500に送信する。ここで取得される書誌情報とは、画像データのファイル名はカラーモード印刷部数、印刷ジョブの生成日時など、プリンター200のUI表示に必要な情報である。
クラウドプリントサービス500は、印刷キューに記憶された印刷ジョブの書誌情報から印刷可能ジョブリストを生成する。そして、クラウドプリントサービス500は、プリンター200に生成した印刷可能ジョブリストを送信する。クラウドプリントサービス500が送付した印刷可能ジョブリストをプリンター200が受信すると、その印刷ジョブのリストが操作パネルに表示される。図7は、クラウドプリントサービス500から受信した印刷可能ジョブリストを表示した操作パネルの一例である。“aaa.doc”〜”jjj.pdf”はクラウドプリントサービスにある印刷ジョブである。ユーザーはその操作パネルから所望する印刷ジョブを選択しプリントボタン701を押下して印刷を実行する。印刷実行を受け付けたプリンター200は、クラウドプリントサービス500に対して印刷ジョブの取得要求を行う。なお、この取得要求には、取得したい印刷ジョブのID、即ち、印刷ジョブIDが含まれている。以下、図10に示す処理を実行することで印刷が実現される。
図10は、本実施形態を示すクラウドプリントサービス500にプリンター200から印刷ジョブの取得要求を受信した場合に、クラウドプリントサービス500が行う処理のフローチャート図である。特に明記しない場合、本処理はクラウドプリントサービス500の各処理部で行われる。まず、印刷ジョブ管理部505は、プリンター200から印刷ジョブ取得要求(出力対象の印刷ジョブの印刷ジョブIDを含む)を受信する(S1001)。
要求を受信した印刷ジョブ管理部505は、指定された印刷ジョブを印刷ジョブ保存領域511から特定する。印刷ジョブ管理部505は、特定された印刷ジョブを印刷ジョブ生成部506に渡し、出力先のプリンター200に適した印刷ジョブを生成する(S1002)。
印刷ジョブ管理部505は生成された印刷ジョブを印刷ジョブ生成部506から取得し、印刷要求元のプリンター200に印刷ジョブを送信する(S1003)。
本実施例では、ユーザーがプリンター200を操作し、選択した印刷ジョブをプリンター200がクラウドプリントサービス500から取得するとした。プリンター200が定期的にクラウドプリントサービス500にアクセスし、プリンター200の印刷キューと紐づいて管理される印刷ジョブをクラウドプリントサービス500から取得するとしてもよい。
以上の処理により、クラウドプリントサービス500に登録された印刷ジョブが実行される。
ここで、図4で示したクラウドプリントサービス500における印刷キューの拡張処理の詳細を説明する。
図12は、プリンター200をクラウドプリントサービス500に登録し、クラウドプリントサービスが印刷キューを拡張する処理を示すフローチャートである。図12に示す処理は、クラウドプリントサービス500を構成する1または複数の情報処理装置のCPUがプログラムを実行することで実現される。
プリンター登録部501は、プリンター200から登録要求を受信したか否かを判定する(S1201)。プリンター200から登録要求を受信した場合、プリンター登録部501は処理をS1202に進める。一方で、プリンター200から登録要求を受信していない場合、プリンター登録部501はS1201に記載の処理を続ける。
プリンター登録部501は、プリンターからメタ情報とデバイス能力情報を取得し、プリンターデータベース510に登録する(S1202)。メタ情報とは、プリンター200のHWIDやCOIDなどである。また、プリンター200から取得されるメタ情報には、プリンター200が提供するデバイス能力情報のファイルのバージョンが記憶されている。プリンター200から取得されるデバイス能力情報は、両面印刷の可・不可や、モノクロ印刷、カラー印刷の可・不可、印刷に用いられる用紙の向き等の情報であり、IPP等で標準化された能力情報である。プリンター登録部501は、取得したメタ情報、デバイス能力情報をプリンターデータベース510に登録する。さらにS1202において、クラウドプリントサービス500がプリンター200からプリンター200のハードウェア構成を受信するとしてもよい。
印刷キュー生成部502は、プリンター登録部501からメタ情報、デバイス能力情報を取得し、プリンター200の印刷キューを生成する(S1203)。
プリンター登録部501は、プリンタードライバー配布サービス300にドライバー拡張パッケージの取得要求を送信する(S1204)。プリンター登録部501は、ドライバー拡張パッケージの取得要求とともに、プリンター200から取得したメタ情報に含まれるHWID、COIDを送信する。なお、本実施形態ではHWID、COIDの両方をプリンタードライバー配布サービスに送信するとしたが、いずれか一方のみをプリンタードライバー配布サービスに送信するとしてもよい。
プリンター登録部501は、プリンタードライバー配布サービスから、ドライバー拡張パッケージを取得したか否かを判定する(S1205)。たとえば、クラウドプリントサービス500がプリンタードライバー配布サービス300から対応するドライバー拡張パッケージが存在しないことを示す応答を受信した場合、プリンター登録部501はドライバー拡張パッケージを取得していないと判定する。また、ドライバー拡張パッケージの取得要求を送信して、所定時間が経過してもドライバー拡張パッケージが取得されない場合、プリンター登録部501がドライバー拡張パッケージを取得していないと判定してもよい。プリンター登録部501がドライバー拡張パッケージを取得していない場合、プリンター登録部501は図12に記載のフローチャートを終了する。
プリンター登録部501がドライバー拡張パッケージを取得した場合、プリンター登録部501はS1206に記載の処理を実行する。
プリンター登録部501は、プリンタードライバー配布サービス300から取得されたドライバー拡張パッケージに含まれるデバイス能力情報ファイルが、プリンター200から取得されたデバイス能力情報ファイルよりも新しいか否かを判定する(S1206)。プリンター登録部501は、プリンタードライバー配布サービス300から取得したデバイス能力情報ファイルのバージョンと、プリンター200から取得されたデバイス能力情報ファイルのバージョンを比較する。プリンタードライバー配布サービス300から取得されたデバイス能力情報ファイルの方が、プリンター200から取得したデバイス能力情報よりも新しいファイルである場合、プリンター登録部501はS1207に記載の処理を実行する。なお、プリンタードライバー配布サービス300から取得されたデバイス能力情報ファイルが、プリンター200から取得されたデバイス能力情報ファイルよりも新しいか否かは、ファイルのバージョン以外のものによって判定されるとしてもよい。例えば、プリンター200から取得されたデバイス能力情報ファイルの生成日と、プリンタードライバー配布サービス300から取得されたデバイス能力情報ファイルの生成日を比較するとしてもよい。
プリンター登録部501は、プリンターデータベース510に登録されているデバイス能力情報をプリンタードライバー配布サービス300から取得したデバイス能力情報ファイルで更新する(S1207)。さらに、プリンター登録部501は、デバイス能力情報ファイルを印刷キュー生成部502にデバイス能力情報を送信し、印刷キューに対応するデバイス能力情報を更新する。プリンター登録部501は、プリンターデータベース510のデバイス能力情報をドライバー拡張パッケージに含まれるデバイス能力情報で上書きする。また、プリンター登録部501が、ドライバー拡張パッケージに含まれる能力情報のうちプリンターから取得したデバイス能力情報に含まれていない部分をデバイス能力情報に追加するとしてもよい。印刷キュー生成部502についても、印刷キューに紐づくデバイス能力情報をドライバー拡張パッケージに含まれる能力情報で上書きしてもよいし、デバイスから取得した能力情報に含まれていない能力情報を追加するとしてもよい。また、S1202において、プリンター200のハードウェア構成を受信している場合、ハードウェア構成を加味してプリンター200で実行することのできる機能を能力情報としてプリンターデータベースを更新してもよい。
図12のようにすることで、プリンターから取得された能力情報と、ドライバー拡張パッケージに含まれる能力情報のうち、新しい能力情報をクラウドプリントサービス500に登録することができる。なお、図12では、プリンター200から取得したデバイス能力情報とプリンタードライバー配布サービス300から取得した能力情報のうち新しい能力情報をクラウドプリントサービス500に登録するとした。必ず、プリンタードライバー配布サービス300から取得したドライバー拡張パッケージに含まれる能力情報をクラウドプリントサービス500に登録するとしてもよい。
次に、図6で示した、クライアントコンピューター100に印刷拡張アプリケーションをインストールする処理の詳細を説明する。
図13は、クライアントコンピューター100が印刷拡張アプリケーションをインストールする処理を示すフローチャートである。クライアントコンピューター100のCPUがプログラムを実行することで各処理が実現される。なお、図13に記載の処理はユーザーがクライアントコンピューター100を操作し、クライアントコンピューター100が利用することのできるプリンターの検索を開始される。
CPU101は、クラウドプリントサービス500に登録されているプリンターの情報のリストの取得要求をクラウドプリントサービス500に送信する(S1301)。CPU101は、あらかじめ登録されているクラウドプリントサービス500のURLにアクセスし、クライアントコンピューター100を使用するユーザーが利用することのできるプリンターの情報を取得する。なお、S1301においてクライアントコンピューター100はあらかじめ取得したアクセストークンを用いてクラウドプリントサービス500にアクセスする。アクセストークンがない場合、クライアントコンピューター100はクラウドプリントサービス500にログインするためにID、Passwordの入力を求める画面を表示させる。クライアントコンピューター100はユーザーが入力したID、Passwordを用いて認証を依頼し、アクセストークンを取得する。
CPU101は、クラウドプリントサービス500からプリンターのリストを受信したか否かを判定する(S1302)。プリンターのリストを取得することができなかった場合、CPU101は図13に記載の処理を終了する。プリンターのリストを取得することができた場合、CPU101はS1303に処理を進める。
CPU101は、受信したプリンターリストの情報を表示し、ユーザーによるプリンターの選択を受け付ける(S1303)。
CPU101は、選択されたプリンターのメタ情報および能力情報の取得要求をクラウドプリントサービスに送信する(S1304)。CPU101はクラウドプリントサービス500から選択したプリンターのメタ情報、能力情報を取得し、クライアントコンピューター100上に印刷キューを生成する。
CPU101は取得したメタ情報に含まれている、HWID、COID、ドライバー拡張パッケージの取得要求をプリンタードライバー配布サービス300に送信する(S1305)。そして、CPU101は送信したHWIDまたはCOIDに一致するドライバー拡張パッケージをプリンタードライバー配布サービス300から取得する。S1305において、HWIDまたはCOIDのいずれかのみをプリンタードライバー配布サービスに送信するとしてもよい。
CPU101は取得したドライバー拡張パッケージのドライバー情報部304に印刷拡張アプリケーションの識別情報であるアプリケーション識別子(アプリケーションID)が含まれているか否かを判定する(S1306)。アプリケーション識別子が含まれていない場合、CPU101は図13に記載の処理を終了する。
ドライバー拡張パッケージにアプリケーション識別子が含まれている場合、CPU101はクライアントコンピューター100に当該識別子のアプリケーションがインストールされているか否かを判定する(S1307)。クライアントコンピューター100にアプリケーションがインストールされている場合、CPU101はインストールされている印刷拡張アプリケーションが最新のものであるか否かを判定する(S1308)。S1308において、CPU101は印刷拡張アプリケーション配布サービス400にアクセスから配布されている印刷拡張アプリケーションのバージョン情報を取得し、すでにインストールされている印刷拡張アプリケーションのバージョンと比較する。インストールされているアプリケーションのバージョンが、配布されているアプリケーションと同じ場合、CPU101はインストールされているアプリケーションは最新であると判定し、図13に示す処理を終了する。インストールされているアプリケーションよりも配布されているアプリケーションのバージョンが新しい場合、CPU101はS1309に記載の処理を実行する。なお、本実施形態では、アプリケーションのバージョン情報に基づき、インストールされているアプリケーションが最新のものであるか否かを判定した。アプリケーションの配布開始日時に基づき、クライアントコンピューター100にインストールされているアプリケーションが最新のものであるか否かを判定するとしてもよい。
CPU101は印刷拡張アプリケーション配布サービスが配布するアプリケーションのインストールを行うか否かユーザーに問い合わせる(S1309)。印刷拡張アプリケーションのインストールを行なわない場合、CPU101は図13に記載の処理を終了する。インストールを行う場合、CPU101は印刷拡張アプリケーション配布サービス400からドライバー拡張パッケージに含まれているアプリケーション識別子のアプリケーションを取得し、クライアントコンピューター100にインストールする(S1310)。本実施例ではユーザーにアプリケーションのインストールを行うか否かを問い合わせた。S1309において、ユーザーへの問い合わせを行わずに、CPU101がS1310の処理を実行するとしてもよい。
なお、図13ではS1305において、クライアントコンピューター100がプリンタードライバー配布サービスからドライバー拡張パッケージを取得するとした。クライアントコンピューター100がクラウドプリントサービス100からドライバー拡張パッケージの情報を取得し、ドライバー拡張パッケージに基づきS1306以降の処理を行うとしてもよい。
図13に記載の処理を実行することで、標準的な印刷設定に加えて、ベンダー固有の印刷設定を行うことのできる印刷拡張アプリケーションをクライアントコンピューター100にインストールすることができる。
最後にプリンタードライバー配布サービス300のプリンタードライバーデータベースに登録されているドライバー拡張パッケージ303が更新された場合の処理について説明する。図11はプリンタードライバー配布サービス300に登録されているドライバー拡張パッケージが更新されたときの処理を示すシーケンス図である。
ベンダー等が配布したドライバー拡張パッケージがプリンタードライバー配布サービス300のプリンタードライバー登録部301によってプリンタードライバーデータベース310に登録されることで、ドライバー拡張パッケージ303が更新される。プリンタードライバー配布サービス300に登録されたドライバー拡張パッケージ303が更新された場合、クラウドプリントサービス500に登録されている印刷キューに対応するドライバー拡張パッケージも更新することが望ましい。そこで、以下の処理を行うことでクラウドプリントサービス500に登録されているドライバー拡張パッケージを更新する。
クライアントコンピューター100は、クラウドプリントサービス500にアクセスし、クラウドプリントサービス500にログイン要求を送信する(S1101)。ユーザーはクラウドプリントサービス500にアクセスし、ユーザーID、Passwordを入力し、クラウドプリントサービス500にログインする。クラウドプリントサービス500は入力されたユーザーID、Passwordに基づき、ユーザー認証を行う。
ユーザー認証に成功した場合、クラウドプリントサービス500は当該ユーザーに紐づくプリンター情報についてドライバー拡張パッケージ情報の取得要求をプリンタードライバー配布サービス300に送信する(S1102)。クラウドプリントサービス500は、プリンタードライバー配布サービス300にログインしたユーザーに紐づくプリンターのHWID、COIDを送信する。S1102において、クラウドプリントサービス500がHWID、COIDのいずれかを送信するとしてもよい。 プリンタードライバー配布サービス300は、クラウドプリントサービス500から受信したHWIDに紐づく、ドライバー拡張パッケージのパッケージ情報をクラウドプリントサービス500に送信する(S1103)。プリンタードライバー配布サービス300は、プリンタードライバーデータベース310に記憶されたドライバー拡張パッケージのパッケージ情報を送信する。ここで送信されるパッケージ情報とは、ドライバー拡張パッケージのバージョン情報や、最新の更新日時情報などである。
クラウドプリントサービス500は、受信したドライバー拡張パッケージのパッケージ情報と、印刷キューと対応づけて記憶したドライバー拡張パッケージ情報とを比較し、ドライバー拡張パッケージの更新が必要であるか判定する。クラウドプリントサービス500は、たとえば、プリンターデータベース510に登録されているドライバー拡張パッケージのバージョンと、プリンタードライバー配布サービスから受信したドライバー拡張パッケージのバージョン情報を比較する。プリンタードライバー配布サービス300から受信したバージョンの方が新しいバージョンを示す値である場合、S1104に後述する処理を実行する。クラウドプリントサービス500は、プリンタードライバー配布サービス300から受信したドライバー拡張パッケージの更新日時と、プリンターデータベース510に記憶しているドライバー拡張パッケージの更新日時とを比較するとしてもよい。プリンタードライバー配布サービス300から受信した更新日時の方が後の日時である場合、クラウドプリントサービス500は、S1104に記載の処理を実行する。なお、クラウドプリントサービス500にインストールされているドライバー拡張パッケージが最新のものである場合、S1104以降の処理は行われず、図11に示すシーケンスは終了する。
クラウドプリントサービス500は、更新が必要なドライバー拡張パッケージについて、更新を行うか否かユーザーに問い合わせる画面をクライアントコンピューター100に表示させる(S1104)。S1104では、たとえば、ドライバー拡張パッケージの更新が必要なプリンターの情報をリスト表示し、ドライバー拡張パッケージの更新を行うプリンターをユーザーに選択させる。
ユーザーがドライバー拡張パッケージの更新を要求した場合、クライアントコンピューター100は、ユーザーが指示したプリンターについてドライバー拡張パッケージの更新要求をクラウドプリントサービス500に送信する(S1105)。
クラウドプリントサービス500は、プリンタードライバー配布サービス300にドライバー拡張パッケージの取得要求を送信する(S1106)。S1106において、クラウドプリントサービス500はユーザーから更新が指示されたプリンターのHWID、COIDをプリンタードライバー配布サービス300に送信する。なおS1106において、クラウドプリントサービス500がHWID、COIDのいずれかのみをプリンタードライバー配布サービスに送信するとしてもよい。
プリンタードライバー配布サービス300は、指示されたHWIDに基づき特定されるドライバー拡張パッケージをクラウドプリントサービス500に送信する(S1107)。クラウドプリントサービス500は、あらかじめプリンター情報と対応づけて記憶していたドライバー拡張パッケージを受信したドライバー拡張パッケージで更新する。これにより、クラウドプリントサービス500に登録されているドライバー拡張パッケージをプリンタードライバー配布サービス300に登録された最新のものに更新することができる。なお、上記の例では、ユーザーによる更新指示に従って、ドライバー拡張パッケージの更新を行った。プリンタードライバー配布サービス300の配布するドライバー拡張パッケージが更新された場合に、ユーザーに問い合わせることなく、新しいドライバー拡張パッケージをクラウドプリントサービス500にインストールするとしてもよい。
クラウドプリントサービス500は、更新後のドライバー拡張パッケージをクライアントコンピューター100にもインストールする(S1108)。クライアントコンピューター100は、クラウドプリントサービス500から更新後のドライバー拡張パッケージを取得して、クライアントコンピューター100の記憶するドライバー拡張パッケージの情報を更新する。
なお、図11では、ユーザーがクラウドプリントサービスにログインしたS1102で、プリンタードライバー配布サービス300に登録されているドライバー拡張パッケージ情報の取得要求を行った。所定時間毎、または、決まった日時にクラウドプリントサービス500がプリンタードライバー配布サービス300にドライバー拡張パッケージ情報の取得要求を送信するとしてもよい。
また、図11ではユーザーがログインしたタイミングでS1102に記載の処理を実行するとした。クラウドプリントサービス500にログインしたユーザーがクラウドプリントサービス500でプリンター情報の管理を行う権限を有している場合にS1102以降の処理を実行するとしてもよい。
以上の処理を実行することで、クラウドプリントサービスやOSが提供する標準的な印刷設定画面では設定することのできない印刷設定を行うための印刷拡張アプリケーションをクライアントコンピューター100にインストールすることができる。また、ドライバー配布サービスから胚珠されたドライバー拡張パッケージに含まれるアプリケーション識別情報を使うことで、ユーザーが手動で印刷拡張アプリケーションを探さなくても、当該アプリケーションをインストールすることができる。
(その他の実施形態)
本発明は、以下の処理を実行することによっても実現される。即ち、上述した実施形態の機能を実現するソフトウェア(プログラム)をネットワーク又は各種記憶媒体を介してシステム或いは装置に供給し、そのシステム又は装置のコンピュータ(又はCPUやMPU等)がプログラムコードを読み出して実行する処理である。この場合、そのコンピュータプログラム、及び該コンピュータプログラムを記憶した記憶媒体は本発明を構成することになる。

Claims (12)

  1. ユーザーによる第1のサーバシステムに情報を登録する操作を受け付けた印刷装置が送信する登録要求を受信する前記第1のサーバシステムと通信することのできる情報処理装置であって、
    前記印刷装置が前記第1のサーバシステムに送信した前記印刷装置の機種情報に対応するアプリケーション識別情報を特定する特定手段と、
    前記特定手段により特定されたアプリケーション識別情報のアプリケーションを第3のサーバシステムから取得する取得手段と、
    取得された前記アプリケーションにより生成される印刷設定画面を表示する表示手段と、
    前記印刷設定画面を介して設定された印刷設定を前記第1のサーバシステムに送信する送信手段と、を有することを特徴とする情報処理装置。
  2. 前記第2のサーバシステムから前記機種情報に基づく情報を取得する取得手段をさらに有し、
    前記特定手段は、前記取得手段により取得された前記情報から前記アプリケーション識別情報を特定することを特徴とする請求項1に記載の情報処理装置。
  3. 前記第1のサーバシステムが前記機種情報に基づき前記第2のサーバシステムから取得した情報を、前記第1のサーバシステムから取得する取得手段をさらに有し、
    前記特定手段は、前記取得手段が取得した前記情報から、前記アプリケーション識別情報を特定することを特徴とする請求項1に記載の情報処理装置。
  4. 前記取得手段は、前記情報処理装置に特定された前記アプリケーション識別情報のアプリケーションが前記情報処理装置にインストールされている場合、すでにインストールされているアプリケーションと前記第3のサーバシステムに記憶されるアプリケーションとの比較に基づき、前記第3のサーバシステムに記憶されているアプリケーションを取得することを特徴とする請求項1乃至3のいずれか一項に記載の情報処理装置。
  5. 前記取得手段は、前記第3のサーバシステムに記憶されているアプリケーションが、前記情報処理装置にインストールされているアプリケーションよりも新しいアプリケーションであることに基づき、前記第3のサーバシステムに記憶されているアプリケーションを取得することを特徴とする請求項4に記載の情報処理装置。
  6. 前記アプリケーションが提供する印刷設定画面は、前記第1のサーバシステムにより提供される印刷設定画面では設定することのできない設定項目を表示することを特徴とする請求項1乃至5のいずれか一項に記載の情報処理装置。
  7. 前記アプリケーションは、前記第2のサーバシステムから取得された前記情報に基づき、印刷設定画面を表示することを特徴とする請求項1乃至6のいずれか一項に記載の情報処理装置。
  8. 前記印刷装置の機種情報と前記アプリケーション識別情報を対応づけて記憶する記憶手段と、
    ユーザーにより選択された印刷装置の機種情報と対応づけて前記記憶手段に記憶された前記アプリケーション識別情報で識別されるアプリケーションを起動させる制御手段と、をさらに有することを特徴とする請求項1乃至7のいずれか一項に記載の情報処理装置。
  9. ユーザーによる第1のサーバシステムへの登録指示を受け付けて、前記第1のサーバシステムに登録要求と機種情報を送信する送信手段と、
    前記第1のサーバシステムに送信した前記機種情報に対応するアプリケーション識別情報で識別されるアプリケーションであって、第2のサーバシステムから情報処理装置にダウンロードされた前記アプリケーションにより印刷設定された印刷データを前記第1のサーバシステムから受信する受信手段と、
    受信された前記印刷データに基づき印刷を実行する印刷手段と、を有することを特徴とする印刷装置。
  10. 前記アプリケーションは、前記情報処理装置のオペレーションシステムが提供する印刷設定画面では設定することのできない項目の印刷設定をすることのできるアプリケーションであることを特徴とする請求項9に記載の印刷装置。
  11. ユーザーによる第1のサーバシステムに情報を登録する操作を受け付けた印刷装置が送信する登録要求を受信する前記第1のサーバシステムと通信することのできる情報処理装置の制御工程であって、
    前記印刷装置が前記第1のサーバシステムに送信した前記印刷装置の機種情報に対応するアプリケーション識別情報を特定する特定工程と、
    前記特定工程において特定されたアプリケーション識別情報のアプリケーションを第3のサーバシステムから取得する取得工程と、
    取得された前記アプリケーションにより生成される印刷設定画面を表示手段に表示する表示工程と、
    前記印刷設定画面を介して設定された印刷設定を前記第1のサーバシステムに送信する送信工程と、を有することを特徴とする情報処理装置の制御方法。
  12. 請求項11に記載の情報処理装置の制御方法を実行するためのコンピュータプログラム。
JP2020015844A 2020-01-31 2020-01-31 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム Active JP7433940B2 (ja)

Priority Applications (5)

Application Number Priority Date Filing Date Title
JP2020015844A JP7433940B2 (ja) 2020-01-31 2020-01-31 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム
KR1020210007180A KR20210098335A (ko) 2020-01-31 2021-01-19 정보 처리 장치, 인쇄 장치, 정보 처리 장치를 제어하는 방법, 및 저장 매체
EP21152625.6A EP3859515A1 (en) 2020-01-31 2021-01-20 Information processing apparatus, printing apparatus, and method for controlling information processing apparatus, and storage medium
US17/157,334 US20210240412A1 (en) 2020-01-31 2021-01-25 Information processing apparatus, printing apparatus, and method for controlling information processing apparatus, and storage medium
JP2024009512A JP2024045318A (ja) 2020-01-31 2024-01-25 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2020015844A JP7433940B2 (ja) 2020-01-31 2020-01-31 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2024009512A Division JP2024045318A (ja) 2020-01-31 2024-01-25 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム

Publications (3)

Publication Number Publication Date
JP2021124791A true JP2021124791A (ja) 2021-08-30
JP2021124791A5 JP2021124791A5 (ja) 2023-01-30
JP7433940B2 JP7433940B2 (ja) 2024-02-20

Family

ID=74194613

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2020015844A Active JP7433940B2 (ja) 2020-01-31 2020-01-31 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム
JP2024009512A Pending JP2024045318A (ja) 2020-01-31 2024-01-25 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2024009512A Pending JP2024045318A (ja) 2020-01-31 2024-01-25 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム

Country Status (4)

Country Link
US (1) US20210240412A1 (ja)
EP (1) EP3859515A1 (ja)
JP (2) JP7433940B2 (ja)
KR (1) KR20210098335A (ja)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP4266166A1 (en) 2022-04-18 2023-10-25 Canon Kabushiki Kaisha Information processing apparatus, control method of information processing apparatus, and storage medium
EP4328735A1 (en) 2022-08-24 2024-02-28 Canon Kabushiki Kaisha Information processing apparatus, method for controlling information processing apparatus, and storage medium
EP4336338A1 (en) 2022-09-09 2024-03-13 Canon Kabushiki Kaisha Information processing apparatus, method for controlling information processing apparatus, and nonvolatile storage medium
DE102023209681A1 (de) 2022-10-21 2024-05-02 Canon Kabushiki Kaisha Informationsverarbeitungsvorrichtung, verfahren, programm und nichtflüchtiges computerlesbares speichermedium, das ein programm speichert

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP7447667B2 (ja) * 2020-05-01 2024-03-12 コニカミノルタ株式会社 ジョブデータを生成するためのプログラム、方法および装置
JP2023054486A (ja) * 2021-10-04 2023-04-14 セイコーエプソン株式会社 情報処理装置、インストール方法及びプログラム

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006155289A (ja) * 2004-11-30 2006-06-15 Canon Marketing Japan Inc 情報処理装置および印刷制御方法およびプリンタドライバプログラムおよび記録媒体
JP2011243067A (ja) * 2010-05-19 2011-12-01 Brother Ind Ltd 印刷制御装置,印刷制御システム,およびプリンタドライバ
JP2012160009A (ja) * 2011-01-31 2012-08-23 Canon Inc 印刷設定サーバ、印刷設定方法およびプログラム
JP2013025552A (ja) * 2011-07-21 2013-02-04 Canon Inc 情報処理装置、情報処理装置の制御方法およびコンピュータプログラム
JP2013101595A (ja) * 2011-10-14 2013-05-23 Canon Inc ネットワークシステム及びクライアント装置とその方法
US20200004473A1 (en) * 2018-06-29 2020-01-02 Canon Kabushiki Kaisha Information apparatus, controlling method for information apparatus, and storage medium
JP2020004254A (ja) * 2018-06-29 2020-01-09 キヤノン株式会社 情報処理装置、制御方法及びプログラム
JP2020013195A (ja) * 2018-07-13 2020-01-23 キヤノン株式会社 プリントサーバー、制御方法、およびそのプログラム

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007241990A (ja) * 2006-02-07 2007-09-20 Seiko Epson Corp ケーパビリティ情報取得システムおよびケーパビリティ情報取得プログラム、並びにケーパビリティ情報取得方法
US20070285704A1 (en) * 2006-06-09 2007-12-13 Yuwen Wu Automatic printer registration
JP5843691B2 (ja) 2012-05-11 2016-01-13 キヤノン株式会社 情報処理装置、印刷システム、情報処理装置の制御方法、およびコンピュータプログラム
JP2014032454A (ja) * 2012-08-01 2014-02-20 Seiko Epson Corp プリンターシステムおよびプリンター設定方法
JP7056286B2 (ja) * 2018-03-22 2022-04-19 富士フイルムビジネスイノベーション株式会社 画像形成装置
JP2019197246A (ja) * 2018-05-07 2019-11-14 Dgshape株式会社 デバイス管理装置
JP7301503B2 (ja) * 2018-06-29 2023-07-03 キヤノン株式会社 情報処理装置、情報処理装置の制御方法、プログラム及びアプリケーション

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006155289A (ja) * 2004-11-30 2006-06-15 Canon Marketing Japan Inc 情報処理装置および印刷制御方法およびプリンタドライバプログラムおよび記録媒体
JP2011243067A (ja) * 2010-05-19 2011-12-01 Brother Ind Ltd 印刷制御装置,印刷制御システム,およびプリンタドライバ
JP2012160009A (ja) * 2011-01-31 2012-08-23 Canon Inc 印刷設定サーバ、印刷設定方法およびプログラム
JP2013025552A (ja) * 2011-07-21 2013-02-04 Canon Inc 情報処理装置、情報処理装置の制御方法およびコンピュータプログラム
JP2013101595A (ja) * 2011-10-14 2013-05-23 Canon Inc ネットワークシステム及びクライアント装置とその方法
US20200004473A1 (en) * 2018-06-29 2020-01-02 Canon Kabushiki Kaisha Information apparatus, controlling method for information apparatus, and storage medium
JP2020004158A (ja) * 2018-06-29 2020-01-09 キヤノン株式会社 情報処理装置、情報処理装置の制御方法、及びプログラム
JP2020004254A (ja) * 2018-06-29 2020-01-09 キヤノン株式会社 情報処理装置、制御方法及びプログラム
JP2020013195A (ja) * 2018-07-13 2020-01-23 キヤノン株式会社 プリントサーバー、制御方法、およびそのプログラム

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP4266166A1 (en) 2022-04-18 2023-10-25 Canon Kabushiki Kaisha Information processing apparatus, control method of information processing apparatus, and storage medium
JP7487255B2 (ja) 2022-04-18 2024-05-20 キヤノン株式会社 情報処理装置、情報処理装置の制御方法ならびにプログラム
EP4328735A1 (en) 2022-08-24 2024-02-28 Canon Kabushiki Kaisha Information processing apparatus, method for controlling information processing apparatus, and storage medium
EP4336338A1 (en) 2022-09-09 2024-03-13 Canon Kabushiki Kaisha Information processing apparatus, method for controlling information processing apparatus, and nonvolatile storage medium
US12001734B2 (en) 2022-09-09 2024-06-04 Canon Kabushiki Kaisha Information processing apparatus, method for controlling information processing apparatus, and nonvolatile storage medium
DE102023209681A1 (de) 2022-10-21 2024-05-02 Canon Kabushiki Kaisha Informationsverarbeitungsvorrichtung, verfahren, programm und nichtflüchtiges computerlesbares speichermedium, das ein programm speichert

Also Published As

Publication number Publication date
JP7433940B2 (ja) 2024-02-20
US20210240412A1 (en) 2021-08-05
KR20210098335A (ko) 2021-08-10
EP3859515A1 (en) 2021-08-04
JP2024045318A (ja) 2024-04-02

Similar Documents

Publication Publication Date Title
JP7433940B2 (ja) 情報処理装置、印刷装置および当該情報処理装置の制御方法、プログラム
JP5441646B2 (ja) 印刷装置、印刷方法、及び印刷プログラム
JP7086754B2 (ja) 情報処理装置、情報処理装置の制御方法及びコンピュータプログラム
US8605316B2 (en) Information processing apparatus and control method thereof, and storage medium
JP7341647B2 (ja) 情報処理装置、制御方法及びプログラム
JP2023171389A (ja) 画像形成装置、制御方法、およびそのプログラム
US20140016152A1 (en) Image processing apparatus and method and non-transitory computer readable medium
US11842100B2 (en) Server system, information processing apparatus communicating with server system, control method, and computer-readable storage medium
JP2016177432A (ja) プログラム、情報処理装置、記憶媒体、画面作成方法
US20210240407A1 (en) Information processing apparatus, control method and program therefor, and server system capable of communicating with the information processing apparatus
JP2024020296A (ja) 印刷設定画面を提供するアプリケーション
JP2012121167A (ja) 印刷装置、印刷方法、及びプログラム
JP7410622B2 (ja) 情報処理装置、情報処理装置の制御方法ならびにプログラム、および当該情報処理装置と通信することのできるサーバシステム
JP7427459B2 (ja) サーバシステム、およびサーバシステムと通信する印刷装置
JP2022067915A (ja) サーバシステムおよびサーバシステムの制御方法
JP2022109051A (ja) サーバシステムおよびサーバシステムの制御方法
JP7328405B2 (ja) 情報処理装置、情報処理装置の制御方法及び印刷設定アプリケーション
US20230333786A1 (en) Information processing apparatus, control method therefor, and non-transitory computer-readable storage medium
US20230333793A1 (en) Information processing apparatus, control method for controlling information processing apparatus, and storage medium
JP7289715B2 (ja) 印刷サーバーシステム
JP2023158308A (ja) 情報処理装置、情報処理装置の制御方法ならびにプログラム
JP2023158307A (ja) 情報処理装置、情報処理装置の制御方法ならびにプログラム
CN115079961A (zh) 信息处理装置、控制方法和存储介质

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20230120

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20230120

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20230929

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20231010

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20231129

RD01 Notification of change of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7421

Effective date: 20231213

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20240207

R151 Written notification of patent or utility model registration

Ref document number: 7433940

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151