JP5739561B2 - 周辺装置、画像読取装置および画像読取システム - Google Patents

周辺装置、画像読取装置および画像読取システム Download PDF

Info

Publication number
JP5739561B2
JP5739561B2 JP2014073631A JP2014073631A JP5739561B2 JP 5739561 B2 JP5739561 B2 JP 5739561B2 JP 2014073631 A JP2014073631 A JP 2014073631A JP 2014073631 A JP2014073631 A JP 2014073631A JP 5739561 B2 JP5739561 B2 JP 5739561B2
Authority
JP
Japan
Prior art keywords
information processing
file
control
image reading
image
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.)
Active
Application number
JP2014073631A
Other languages
English (en)
Other versions
JP2014147103A (ja
Inventor
健人 落合
健人 落合
博一 檜口
博一 檜口
千紘 平沼
千紘 平沼
伊藤 清志
清志 伊藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Electronics Inc
Original Assignee
Canon Electronics 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 Electronics Inc filed Critical Canon Electronics Inc
Priority to JP2014073631A priority Critical patent/JP5739561B2/ja
Publication of JP2014147103A publication Critical patent/JP2014147103A/ja
Application granted granted Critical
Publication of JP5739561B2 publication Critical patent/JP5739561B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Facsimiles In General (AREA)

Description

本発明は、イメージスキャナ、プリンタまたは複合機などの周辺装置に関する。
イメージスキャナ、プリンタまたは複合機などの周辺装置は広く普及している。これらの周辺装置に接続するインターフェースとして、シリアルインタフェース、パラレルインタフェース、USB、IEEE1394、LANなどが知られている。
ところで、周辺装置をコンピュータ上で使用できるようにするためには、その周辺装置用のデバイスドライバやアプリケーションソフトウエアをインストールしなければならない(特許文献1)。
特開2004−334449号公報
しかし、デバイスドライバやアプリケーションソフトウエアをインストールすることが制限されているコンピュータが存在する。この制限はセキュリティ対策で課されることが多い。例えば、マイクロソフトウインドウズ(登録商標)等のオペレーティングシステム(OS)では、管理者権限を有しているユーザのみがデバイスドライバをインストールできる。したがって、一般ユーザはデバイスドライバやアプリケーションソフトウエアをインストールできないため、周辺装置を利用できなくなってしまう。このような状況は、外出先のコンピュータを使用する場合に度々発生することが予想される。
また、従来は、管理者権限を持つユーザであっても、画像読み取り装置を接続する前に、予め、デバイスドライバをインストールしておかなければならなかった。すなわち、従来は、デバイスドライバをコンピュータにインストールしていない状態で、周辺装置を利用することができなかった。
さらに、デバイスドライバは、一般に、CD−ROMにより頒布されている。よって、このCD−ROMを用意しなければ、デバイスドライバをインストールすることができなかった。例えば、CD−ROMを紛失してしまうと、デバイスドライバをインストールすることができなかった。インターネットを介してデバイスドライバを入手できるケースもあるが、そのためにインターネットに接続できる環境が必要である。また、デバイスドライバを提供しているWEBサイトのURLや、周辺装置の種類や名称を正確に把握して入力しなければならず、面倒であった。
本発明の目的は、デバイスドライバやソフトウエアをコンピュータにインストールすることなく、周辺装置を利用可能とすることである。また、いくつかの観点での本発明の他の目的は、デバイスドライバやソフトウエアをコンピュータにインストールすることなく、画像読取装置により比較的に大きな画像も読取可能とすることである。また、他のいくつかの観点での本発明の他の目的は、情報処理装置(PC)がデバイスドライバをインストール済みであるか否かに応じて、周辺装置の動作モードを選択する制御を可能とすることである。
本発明は、情報処理装置からの情報に基づいて所定の処理が実行される周辺装置に適用できる。そして、本発明の周辺装置は、所定の処理を制御するプログラムを記憶し、また周辺装置を制御するためのデータを記憶する記憶手段と、情報処理装置に対して記憶手段のプログラムを送信する通信手段と、情報処理装置のプログラムの実行において記憶手段に書き込まれた指示情報に基づいて周辺装置の動作を制御する制御手段とを備えていることを特徴としている。
本発明は、たとえば、
情報処理装置からの情報に基づいて所定の処理が実行される周辺装置であって、
前記所定の処理を制御するための制御プログラム、及び前記周辺装置を制御するための制御ファイルを記憶する記憶手段と、
前記情報処理装置の前記制御プログラムの実行において前記記憶手段内の前記制御ファイルに書き込まれた指示情報に基づいて前記周辺装置の動作を制御する制御手段とを備え、
前記記憶手段は、前記制御プログラムが記憶されている書き込み禁止又は書き込み不可能な第1メモリ領域と、前記情報処理装置から認識可能であって前記制御ファイルが記憶されている第2メモリ領域とを有し、
前記制御プログラムを前記第1メモリ領域から前記第2メモリ領域に格納又は複製して、前記情報処理装置が前記第2メモリ領域内の前記制御プログラムを実行して前記情報処理装置から前記制御ファイルに書き込まれる前記指示情報に基づいて前記制御手段が前記周辺装置の動作を制御することを特徴とする周辺装置を提供する。
本発明の第1の実施形態に係る、パーソナルコンピュータとして例示したコンピュータと画像読み取り装置としてのスキャナのソフトウエアブロック図である。 パーソナルコンピュータとして例示するコンピュータとスキャナのハードウエアブロック図である。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローのフローチャートである。 ドライブレターを割り当てられたディスクドライブ(スキャナ)をファイル管理ソフト(エクスプローラ)で開いた様子を示す図である。 キャプチャアプリケーション210が起動したときに表示されるユーザインターフェースの一例を示した図である。 本発明の第2の実施形態に係る、コンピュータと画像読み取り装置としてのスキャナのソフトウエアブロック図である。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローを示したフローチャートである。 CDドライブとして認識されているメモリ領域に対応したフォルダの一例を示した図である。 ディスクドライブとして認識されているメモリ領域に対応したフォルダの一例を示した図である。 第3の実施形態に係るソフトウエアブロック図である。 ユーザが、コンピュータ100にインストールしてあるキャプチャアプリケーション222を起動して、スキャナ装置106で画像読み取りを行うフローを示したフローチャートである。 第4の実施形態に係るソフトウエアブロック図である。 画像転送処理の一例を示したフローチャートである。 コンピュータ側の画像転送処理の一例を示したフローチャートである。 スキャナ装置側の画像転送処理の一例を示したフローチャートである。 周辺装置がマスストレージデバイスとして接続されるときの処理の一例を示したフローチャートである。 周辺装置がマスストレージデバイスとして接続されるときの処理の一例を示したフローチャートである。 周辺装置がスキャナデバイスとして接続されるときの処理の一例を示したフローチャートである。 周辺装置がスキャナデバイスとして接続されるときの処理の一例を示したフローチャートである。 コンピュータとスキャナ装置とのソフトウエアブロック図である。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローのフローチャートである。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローのフローチャートである。 ドライブレターを割り当てられたCDドライブ(スキャナ)をファイル管理ソフト(エクスプローラ)で開いた様子を示す図である。 管理者権限を持つユーザによって、すでに、任意のキャプチャアプリケーション222およびUSBスキャナドライバ102がインストールされているコンピュータ100のソフトウエアブロック図である。 コンピュータとスキャナ装置とのソフトウエアブロック図である。 コンピュータとスキャナ装置とのソフトウエアブロック図である。 第6の実施形態に係る画像読み取りを示したフローチャートである。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行う処理のフローチャートである。 コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行う処理を示したフローチャートである。 画像データの分割転送の一例として、コンピュータ側及びスキャナ装置側で実行される通信プロトコルを示したフローチャートである。 画像読取処理の一例を示すフローチャートである。 RAM124に確保されたバッファCの一例を示す図である。 、スキャンタスクの一例を示したフローチャートである。 画像転送タスクの一例を示したフローチャートである。 スキャンバッファの一例を示す図である。 キャンバッファの状態遷移の例を示した図である。
以下に本発明の一実施形態を示す。以下で説明される個別の実施形態は、本発明の上位概念、中位概念および下位概念など種々の概念を理解するために役立つであろう。また、本発明の技術的範囲は、特許請求の範囲によって確定されるのであって、以下の個別の実施形態によって限定されるわけではない。
[観点1]
情報処理装置からの情報に基づいて所定の処理が実行される周辺装置であって、前記所定の処理を制御するプログラムを記憶し、また前記周辺装置を制御するためのデータを記憶する記憶手段と、
前記情報処理装置に対して前記記憶手段の前記プログラムを送信する通信手段と、
前記情報処理装置の前記プログラムの実行において前記記憶手段に書き込まれた指示情報に基づいて前記周辺装置の動作を制御する制御手段と
を備えていることを特徴とする周辺装置。
観点1によれば、前記周辺装置を制御するためのプログラムを情報処理装置にインストールしていなくても周辺装置を情報処理装置から利用可能となる。そのため、プログラムを入手していないユーザであっても周辺装置を利用できるようになる。また、必要なソフトウエアが周辺装置に記憶されているため、CD−ROMの紛失による使用不可といった問題からも開放されよう。
[観点2]
前記記憶手段は前記プログラムを記憶するRAMを含むことを特徴とする観点1記載の周辺装置。
このように、観点2によれば、容易にアクセスできる周辺装置のRAMから制御プログラムを利用できるようになる。
[観点3]
前記記憶手段は、前記プログラムを記憶するROM又は不揮発性メモリを含み、前記RAMは前記指示情報を記憶し、前記制御手段は、前記周辺装置に前記情報処理装置が接続されると前記プログラムを前記RAMに記憶し、前記通信手段は、前記RAMから前記プログラムを前記情報処理装置に送信することを特徴とする観点2記載の周辺装置。
このように観点3によれば、プログラムをROMや不揮発性メモリに保持することで誤消去からの保護が容易となり、前記プログラムの実行による情報処理装置からの指示情報を、RAMを介して容易に受け取ることが可能となる。従来であれば何らかのデバイスドライバが制御コマンドなどを送信していたのに対して、観点3の周辺装置では制御コマンドなどが周辺装置のRAMに書き込まれるので、間接的に周辺装置を制御できるようになる。
[観点4]
制御手段は、前記記憶手段の前記RAMをUSBディスクドライブとして前記情報処理装置に認識させるための情報を前記通信手段により情報処理装置へ送信することを特徴とする観点2記載の周辺装置。
このように観点4によれば、RAMを読み書き可能なUSBディスクデバイスとして情報処理装置に認識させることで、周辺装置を例えば画像読み取り装置や印刷装置として認識させる必要がなくなる。よって、OSからデバイスドライバのインストールを要求されることもない。
[観点5]
前記周辺装置は外部記憶装置として動作する第1動作モードと、所定の処理を実行する処理装置として動作する第2動作モードとを有し、前記制御手段は前記第1動作モードと前記第2動作モードとのいずれか一方を選択する選択手段を備えていることを特徴とする観点2に記載の周辺装置。
このように観点5によれば、外部記憶装置として周辺装置を情報処理装置に認識させる動作モードと、周辺装置を画像読み取り装置や印刷装置として認識させるモードとを使い分けることができる。
[観点6]
前記選択手段は、前記周辺装置に設けられる手動スイッチにより前記第1動作モードまたは前記第2動作モードを切り替えるものであることを特徴とする観点5に記載の周辺装置。
このように観点6によれば、ユーザは簡単な手の操作でスイッチを切り替えて動作モードの選択を確定させてから周辺装置を使用することができる。
[観点7]
前記プログラムは、前記情報処理装置への前記周辺装置の接続に応じて、前記情報処理装置によって前記通信手段を介して前記記憶手段から前記情報処理装置にロードされることを特徴とする観点1ないし6のいずれかに記載の周辺装置。
このように観点7によれば、接続時に制御用のプログラムがロードされるので、ユーザがソフトウエアをロードする操作を行う手間を省略できる。
[観点8]
情報処理装置からの情報に基づいて所定の処理を実行する周辺装置であって、前記所定の処理を制御するプログラムを記憶する記憶手段と、前記プログラムを前記情報処理装置に送信する通信手段と、前記情報処理装置にロードされた前記プログラムに基づいて動作が制御される前記周辺装置の第1動作モードの制御と、前記プログラムとは異なるデバイスドライバにより動作が制御される前記周辺装置の第2動作モードの制御を行う制御手段とを備えることを特徴とする周辺装置。
このように、観点8によれば、プログラムを情報処理装置にインストールすることなく周辺装置を情報処理装置から利用可能となる。また、必要なプログラムが周辺装置に記憶されているため、CD−ROMの紛失による使用不可といった問題からも開放されよう。また、外部記憶装置として、内蔵のプログラムにより制御される第1動作モードと、通常のデバイスドライバに制御されて動作する第2動作モードとを有しているので、デバイスドライバの利用が可能か否かで、より良い制御モードを選択できる。
[観点9]
前記デバイスドライバが前記情報処理装置にインストール済みであるか否かを判定するための判定プログラムを前記記憶手段に記憶し、前記周辺装置が前記情報処理装置に接続されると、前記通信手段により前記判定プログラムを該情報処理装置へ送信し、前記情報処理装置で実行された前記判定プログラムの判定結果に応じて、前記制御手段は前記周辺装置の前記第1動作モードと、前記第2動作モードとを選択する制御を行うことを特徴とする観点8に記載の周辺装置。
このように観点9によれば、判定プログラムを周辺装置が備えておくことで、情報処理装置はこの判定プログラムにしたがって、デバイスドライバをインストール済みであるか否かを判定できる。その結果、周辺装置は、判定結果に応じて周辺装置の動作モードを制御することが可能となる。
[観点10]
前記制御手段は、
デフォルトの状態で前記周辺装置の動作モードを前記第1動作モードとし、
前記デバイスドライバがインストールされていることが前記判定プログラムによって判定されると、前記制御手段は前記周辺装置の動作モードを前記第2動作モードとする制御を行うことを特徴とする観点9に記載の周辺装置。
観点10によれば、デフォルトの状態では周辺装置は外部記憶装置として機能し、一方で、デバイスドライバがインストール済みであれば、周辺装置は外部記憶装置から画像処理装置へと切り替わることができる。なお、デバイスドライバがインストール済みである場合に、周辺装置が外部記憶装置と画像読取装置との双方として機能してもよい。これは、例えば、外部記憶装置と画像読取装置とがUSBの切り替え可能なインターフェースとして機能すれば実現可能である。
[観点11]
前記判定プログラムは、前記情報処理装置への前記周辺装置の接続に応じて、前記情報処理装置によって、前記通信手段を介して前記記憶手段から前記情報処理装置にロードされることを特徴とする観点9に記載の周辺装置。
このように、プログラムを自動的にロードされるファイルとして記憶しておけば、ユーザがプログラムをロードする操作を行う手間を省略できる。
[観点12]
プログラムはデバイスドライバであり、判定プログラムは、
デバイスドライバが情報処理装置にインストール済みである場合に、情報処理装置にインストールされているデバイスドライバのバージョンと、記憶手段に記憶されているデバイスドライバのバージョンとを比較する比較手段と、
記憶手段に記憶されているデバイスドライバのバージョンが情報処理装置にインストールされているデバイスドライバのバージョンよりも新しい場合に限り記憶手段に記憶されているデバイスドライバを情報処理装置にインストールするインストール手段と
して情報処理装置を機能させることを特徴とする観点9に記載の周辺装置。
観点12によれば、より新しいデバイスドライバを使用できるようになる。また、新しいデバイスドライバを古いデバイスドライバによって上書きしてしまうことを防止できるようになる。
[観点13]
判定プログラムは、
周辺装置の取り外しを指示されると、記憶手段から読み出されて情報処理装置へインストールされたデバイスドライバを情報処理装置からアンインストールするアンインストール手段
として情報処理装置を機能させることを特徴とする観点12に記載の周辺装置。
このように、画像読取装置やプリンタ等の利用が終了したときなどに、インストールしたデバイスドライバをコンピュータから削除することができる。そのため、コンピュータに使用済みの不要なファイルが残ることがないだろう。また、画像読み取りや印刷を行っていないとき、コンピュータのリソースをむだに消費することがなくなるであろう。
[観点14]
画像読み取り部を備え、情報処理装置からの情報に基づいて画像読取処理を実行する画像読取装置であって、
情報処理装置で実行され、前記画像読取装置を制御するプログラムを記憶した記憶手段と、前記プログラムを前記情報処理装置に送信する通信手段と、
画像読取装置を情報処理装置の外部記憶装置として該情報処理装置に認識させるための情報を出力する制御を行う制御手段とを有し、該制御手段は前記情報処理装置での前記プログラムの実行において
繰り返し発生するコマンドに従って、前記記憶手段から部分画像データを繰り返し出力する制御を行う
ことを特徴とする画像読取装置。
観点14によれば、画像読取装置を情報処理装置の外部記憶装置として情報処理装置に認識させることで、画像読取装置のデバイスドライバを情報処理装置にインストールする必要がない。また、画像の読取のためのコマンドを受け付けると部分画像データを制御ファイルに格納し、制御ファイルから読み出す操作に応じて出力することで、比較的に大きな画像も読取可能となる。
[観点15]
記憶手段からプログラムが読み出され情報処理装置で実行されると、プログラムは情報処理装置を、記憶手段から部分画像データを読み出し、読み出した複数の部分画像データを組み合わせ、画像データを完成させる処理手段として機能させることを特徴とする観点14に記載の画像読取装置。
このようにバッファから制御ファイルを通じて部分画像データを読み出して複数の部分画像データを組み合わせ、画像データを完成させる必要がある。そこで、記憶手段から読み出されて情報処理装置で実行されるプログラムにこの機能を持たせることにした。
[観点16]
プログラムを実行する情報処理装置によって記憶手段にコマンドが書き込まれてから、記憶手段への部分画像データの書き込みが完了するまで、情報処理装置による前記部分画像データの読み出し要求に応答しないことを特徴とする観点15に記載の画像読取装置。
部分画像データの書き込みが完了していないにもかかわらず、画像読取装置が情報処理装置からのファイルの読み出し要求に応答してしまうと、部分画像データを正確に転送できなくなるおそれがある。そこで、このような読み出し要求を無視することとした。
[観点17]
制御手段は、前記プログラムを実行している前記情報処理装置による前記部分画像データの読み出しの速度が、画像読取装置の画像読取動作の速度より遅い場合、該画像読取動作の中断と再開の制御を行うことを特徴とする観点15または16に記載の画像読取装置。
観点17によれば、例えば部分画像データの読み出しの速度が遅い安価な情報処理装置を用いる場合でも、本実施形態の画像読取装置を使用して安定した画像読取を行うことができる。
[観点18]
画像読み取り部と、情報処理装置で実行され画像読取装置を制御するプログラムを記憶した記憶手段と、前記プログラムを情報処理装置に送信する通信手段と、を備えた画像読取装置の制御方法であって、
画像読取装置を情報処理装置の外部記憶装置として該情報処理装置に認識させるための情報を出力する制御を行う工程と、前記情報処理装置での前記プログラムの実行において繰り返し発生するコマンドに従って、前記記憶手段から部分画像データを繰り返し出力する制御を行う工程と
を備えることを特徴とする画像読取装置の制御方法。
観点18によれば、画像読取装置を情報処理装置の外部記憶装置として情報処理装置に認識させることで、画像読取装置のデバイスドライバを情報処理装置にインストールする必要がない。また、画像の読取のためのコマンドを受け付けると部分画像データを制御ファイルに格納し、制御ファイルから読み出す情報処理装置の操作に応じて出力することで、比較的に大きな画像も読取可能となる。
<第1の実施形態>
図1は、本発明の第1の実施形態に係る、パーソナルコンピュータとして例示したコンピュータと画像読み取り装置としてのスキャナのソフトウエアブロック図である。
情報処理装置の一例であるコンピュータ100には、オペレーティングシステム101、ファイルシステム201、USBマスストレージドライバ202及びUSBインターフェースドライバ103がインストールされている。オペレーティングシステム101は、いわゆるOSのことであり、コンピュータ100の基本ソフトウエアである。ファイルシステム201は、ハードディスクドライブなどの記憶装置にファイルを格納するためのソフトウエアである。USBマスストレージドライバ202は、ハードディスクドライブ、CD−ROM、DVD−ROM、CD−R、DVD−R、USBメモリなどのマスストレージを制御するためのソフトウエアである。USBインターフェースドライバ103は、USBインターフェースに接続されたUSBデバイスを制御するためのソフトウエアである。なお、これらのソフトウエアはOSの一部であってもよい。
一方、周辺装置の一例であるスキャナ装置106には、コンピュータ100にスキャナ装置の制御を実行させるための制御プログラムを備えている。例えば、本実施形態では、キャプチャアプリケーション210、制御ファイル204、USBディスクドライブインターフェース205及びUSBマスストレージクラスインターフェース206が備えられている。本実施形態のキャプチャアプリケーション210は、ドライバプログラムを含み、コンピュータ100で実行されて画像を読み取るための制御を行うソフトウエアである。制御ファイル204は、キャプチャアプリケーション210を実行しているコンピュータ100からの制御コマンドなどが書き込まれるファイルである。USBディスクドライブインターフェース205は、スキャナ装置106に備えられているメモリ(RAM、フラッシュメモリ、EEPROMなど)をディスクドライブとして使用するためのソフトウエアである。USBマスストレージクラスインターフェース206は、USBディスクドライブインターフェース205を介してメモリをUSBマスストレージとして使用するためのソフトウエアである。
なお、市販のスキャナ装置は、これらのソフトウエアではなく、USBスキャナクラスインターフェースを備えている。そのため、パーソナルコンピュータは、キャプチャアプリケーションソフトウエアや専用のスキャナドライバを備える必要がある。本実施形態であれば、USBスキャナクラスインターフェースは必ずしも必要ではない。また、パーソナルコンピュータ側では、キャプチャアプリケーションソフトウエアや専用のスキャナドライバが必ずしも必要ではない。
図2は、パーソナルコンピュータとして例示するコンピュータとスキャナのハードウエアブロック図である。図2において、コンピュータ100は、CPU121、ROM123、RAM124、ハードディスクドライブ122、USBインターフェース104を備えている。USBインターフェース104は、USBケーブル105を介してスキャナ装置106と接続される。また、CPU121は、キーボード/マウス125とディスプレイ126とが接続されている。
コンピュータ100に電力が投入されると、CPU121は、ROM123からファームウエアを起動し、ハードディスクドライブ122からマイクロソフト(登録商標)ウインドウズ・オペレーティングシステム101を起動する。OSなどの必要なソフトウエアは、RAM124にロードされる。
一方、スキャナ装置106は、CPU110、ROM127、RAM203、画像読み取り部112、USBコントローラ128、USBインターフェース107を備えている。スキャナ装置106に電力が投入されると、CPU110は、ファームウエアをROM127から起動する。または不図示の不揮発性メモリから起動してもよい。
まず、コンピュータ100上のオペレーティングシステム101は、USBインターフェース104にUSBケーブル105を介して何らかの周辺デバイスが接続されると、周辺デバイスのインターフェースにアクセスし、周辺デバイスの種類を確定する。ここで、スキャナ装置106には、オペレーティングシステム101にマスストレージデバイスクラスとして認識される。マスストレージデバイスクラスデバイスを制御するためのUSBマスストレージドライバ202は、コンピュータに備えられており、新たにインストールする必要がないからである。それゆえ、本実施形態のスキャナ装置106は、USBマスストレージクラスインターフェース206を有している。
このように、マイクロソフト(登録商標)ウインドウズのオペレーティングシステム101は、標準で、マスストレージクラスのUSBデバイスをサポートしている。CPU121がマスストレージクラスのUSBデバイスにアクセスする際、オペレーティングシステム101がマスストレージクラスのUSBドライバ(USBマスストレージドライバ202)を含んでいるため、コンピュータ100への特別なデバイスドライバ等のインストールを必要としない。また、マスストレージクラスデバイスへの標準的なアクセスは、オペレーティングシステム101を使用して、管理者権限なしに実行されることが可能である。
よって、コンピュータ100にスキャナ装置106が接続されると、CPU121は、予めインストールされているUSBマスストレージドライバ202を起動する。また、スキャナ装置106が、USBマスストレージクラスインターフェース206を有しているため、コンピュータ100にスキャナ装置106を接続すると、CPU121及びオペレーティングシステム101は、スキャナ装置106をマスストレージデバイスとして認識する。さらに、CPU121及びオペレーティングシステム101は、スキャナ装置106のROM127やRAM203を外部記憶装置としてアクセスする。
この認識処理についてさらに詳細に説明する。コンピュータ100にスキャナ装置106が接続された場合、オペレーティングシステム101(CPU121)は、USBインターフェース104にて何らかの周辺デバイスの接続を検知し、USBケーブル105を介して、スキャナ装置106のUSBインターフェース107にアクセスする。スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からアクセスがあると、USBマスストレージクラスインターフェース206にアクセスさせる。オペレーティングシステム101は、スキャナ装置106のUSBマスストレージクラスインターフェース206にアクセスすることで、予めオペレーティングシステム101に含まれているUSBマスストレージドライバ202を利用して、USBインターフェースドライバ103とUSBインターフェース104からUSBケーブル105を介してスキャナ装置106にアクセス可能になる。
また、スキャナ装置106は、オペレーティングシステム101に、マスストレージクラスデバイスとして認識されている。そのため、コンピュータ100は、スキャナ装置106のUSBインターフェース107、USBマスストレージクラスインターフェース206、USBディスクドライブインターフェース205を介して、管理者権限の有無に依存しないアクセス方法でスキャナ装置106にアクセスできる。ただし、コンピュータ100は直接的に画像読み取り部112を制御することはできず、あくまで記憶装置としてスキャナ装置106にアクセスできるにすぎない。
また、スキャナ装置106には、キャプチャアプリケーション210と、スキャナ装置106を制御するための制御ファイル204とを予めROM127またはRAM203に保存してある。ROM127またはRAM203は、フラッシュメモリ、EEPROM、DRAMなどの組み合わせによって実現可能である。キャプチャアプリケーション210は、コンピュータ100からの指令のもとにスキャナ装置106で画像読み取りを行うためのソフトウエアであり、オペレーティングシステム101上で動作する
さらに、コンピュータ100は、ファイルシステム201に関連付けたファイルフォルダ内に、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210に対応するテーブルを形成する。
図3は、コンピュータ100からの指令のもとにキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローのフローチャートである。
コンピュータ100のCPU121は、スキャナ装置106が接続されたか否かを判断する(ステップS301)。CPU121は、周辺デバイス(スキャナ装置106)のインターフェースに接続する(ステップS302)。
CPU121は、周辺デバイスのインターフェースクラスの情報をスキャナ装置106から取得する(ステップS303)。この情報により接続された周辺装置の種類が認識できる。
上述したようにスキャナ装置106がUSBマスストレージインターフェースを有している。そのため、コンピュータ100にスキャナ装置106が接続されたとき、CPU121は、USBマスストレージデバイスが接続されたと認識する(ステップS304)。また、スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USBディスクドライブインターフェース205を有している。そのため、CPU121は、接続されたスキャナ装置106をディスクドライブとして認識する。
オペレーティングシステム101は、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210に対応するテーブルを、ファイルシステム201に関連付けたファイルフォルダ内に形成する。このことによりCPU121は、スキャナ装置106内に格納してある制御ファイル204とキャプチャアプリケーション210を、ドライブレターを割り当てたディスクドライブ上のファイルとして扱うことができる(ステップS305)。これは、スキャナ装置106が、OSによってドライブレターを割り当てたディスクドライブとして認識されているからである。
図4は、ドライブレターを割り当てられたディスクドライブ(スキャナ)をファイル管理ソフト(エクスプローラ)で開いた様子を示す図である。スキャナ装置106が内蔵するメモリは、フォルダ300に対応している。フォルダ300は、コンピュータ100に接続されたキーボード/マウス125を使用して開くことができる。フォルダ300には、キャプチャアプリケーション210(ファイル名:CaptureApplication.exe)と制御ファイル204(ファイル名:Control.dat)とが格納されている。
CPU121は、フォルダ300内のキャプチャアプリケーション210を起動するための指示が入力されたか否かを判定する(ステップS306)。この指示は、キーボード/マウス125からユーザによって入力されてもよいし、フォルダ300に格納されている不図示のautorun.inf等の自動実行情報ファイルによって指示されてもよい。例えば、マイクロソフト(登録商標)ウインドウズオペレーティングシステムにおいては、CDドライブ内にCD−ROMが挿入されると、オペレーティングシステムは「autorun.inf」と呼ばれる、CD−ROM上の自動実行情報ファイルを検出し、「autorun.inf」内で自動実行することが指定された実行ファイルを実行する。また、マイクロソフト(登録商標)ウインドウズオペレーティングシステムのあるバージョンにおいては、USBディスクドライブ内に、「autorun.inf」、という名称のファイルが存在すると、その内部に記述されたコマンドを自動実行する。すなわち、「autorun.inf」内に自動実行させたい実行ファイル名を記述しておけば、利用者にキーボード/マウス125を操作させることなく自動的に起動させることも可能である。よって、実行ファイルとして上述のCaptureApplication.exeがautorun.inf内で記述されていることになる。キャプチャアプリケーション210を起動するための指示が入力されると、CPU121は、スキャナ装置106からキャプチャアプリケーションをメモリ(RAM124)にロードして起動する(ステップS307)。このようにスキャナ装置106のUSBインターフェースは、コンピュータ100からのソフトウエアのロード動作に応じて、ソフトウエアを送信する通信手段の一例である。
なお、autorun.inf等の自動実行情報ファイルにCaptureApplication.exeとは異なる、例えば異なる機能のautorun.exe等のソフトウエアの名称を記述しておいてもよい。コンピュータ100のメモリ(RAM124)にロードされて起動されたautorun.exeまたはCaptureApplication.exeによれば、USBディスクドライブインターフェース205を介して接続され、ディスクドライブとして認識されたスキャナ装置106を、スキャナドライバのインストールなしに制御することが出来る。すなわちCaptureApplication.exeやautorun.exe等の制御ソフトウエアは、USBメモリとして認識されるRAM上のファイルの受け渡しで画像読取及び画像形成の少なくとも一方に関するコマンドの送出と、画像データのスキャナからの移動を可能とするドライバ機能を有するものとする。またはドライバ機能を有するDLL(Dynamic Link Library)モジュール等の他のプログラムとリンクして、USBメモリとして認識されるRAM上のファイルの受け渡しを行うことによって、画像読取や画像形成に関するコマンドの送出と、画像データのスキャナからの移動やプリンタへの移動を可能とするようにしてもよい。
なお、CaptureApplication.exeやautorun.exe等のソフトウエアが特定のDLLモジュール等にリンクする必要がある場合には、必要なDLLモジュール等をスキャナ装置106からコンピュータ100のメモリ(RAM124)にロードするようにしてもよい。
なお、自動実行情報ファイルはautorun.inf以外の名称であってもよい。また、マイクロソフト(登録商標)ウインドウズオペレーティングシステムにおいては、USBディスクドライブにおいても、電源投入時またはUSBコネクタが差し込まれたとき、CPU121は「autorun.inf」と呼ばれる、USBディスクドライブ上の自動実行情報ファイルを検出し、autorun.infの記述に従って、CaptureApplication.exe、autorun.exe等の起動を確認させるためのコンピュータ100のダイアログ画面を表示させて、ユーザの操作により起動可能な状態にすることができる。またオペレーティングシステム101の設定を変えれば、起動確認のダイアログ画面をコンピュータ100に表示させることなく、autorun.infの記述に従って、CaptureApplication.exe、autorun.exe等を起動させることもできる。
また、autorun.inf等の自動実行情報ファイルは、コンピュータウイルス等の悪意のプログラムや、悪意を持った人物による改ざんを防ぐために、周辺装置のメモリ領域のうち書き込み禁止にできる保護メモリ領域又は書き込み不可能なメモリ領域に記憶することが望ましい。ここで、本実施形態では、スキャナ装置106は、コンピュータ100の指示情報に基づいて制御される。詳細には、コンピュータ100からの指示情報は、コンピュータ100によるソフトウエアの実行により、スキャナ装置106の記憶手段に書き込まれる。そして、スキャナ装置106のCPU110は、記憶手段に書き込まれた指示情報に基づいてスキャナ装置106の動作を制御するようになっている。例えば、本実施形態では、コンピュータ100は、ディスプレイ126を接続しており、各種ユーザインターフェースをディスプレイ126に表示する。すなわち、コンピュータ100は、実際には、ソフトウエアの実行により、図5に示すようなユーザインターフェースを表示可能であり、ユーザは、このユーザインターフェースによりスキャナ装置106の制御条件を適宜指定できるようになっている。例えば、図5は、キャプチャアプリケーション210が起動したときに表示されるユーザインターフェースの一例を示した図である。図5に示すようなキャプチャアプリケーション210のインターフェースが表示されると、ユーザは、キーボード/マウス125を操作して、スキャン設定を実行する。例えば、読み取りモード(本実施形態では、白黒)、用紙サイズ(本実施形態では、A4)、解像度(本実施形態では、300dpi)、読み取り面(本実施形態では、両面)がキーボード/マウス125を使用して選択される。さらに、読み取った画像を保存するための画像ファイルのファイル名(本実施形態では、test1)もキーボード/マウス125を操作して入力される。最後に、スキャンボタン301がキーボード/マウス125を使用してクリックされる。
スキャンボタン301がキーボード/マウス125によりクリックされると、キャプチャアプリケーション210(CPU121)は、スキャン設定を受け付け、スキャナ装置106内の制御ファイル204にスキャン設定(指示情報)を書き込む。さらに、CPU121は、スキャン開始コマンドデータ(指示情報)も制御ファイル204に書き込む(ステップS308)。
スキャナ装置106のCPU110は、制御ファイル204を監視している。そうして、CPU110は、スキャン設定およびスキャン開始コマンドデータが制御ファイル204に書かれたことを検出すると、制御ファイル204を読み込んで、そこに書かれているスキャン設定にしたがって画像読み取り部112を制御し、スキャンを開始する。以上のように、情報処理装置が接続されて所定の処理が実行される本スキャナ装置は、スキャナ装置を利用可能とするプログラムを格納すると共にスキャナ装置を制御するための指示情報が書き込み可能なメモリと、情報処理装置に対してメモリからプログラムを送信する通信手段と、情報処理装置の前記プログラムの実行によりメモリに書き込まれた前記指示情報に基づいてスキャナ装置を制御する制御手段とを備えていることを特徴としている。
スキャナ装置106はスキャンを開始すると、画像読み取り部112で読み取った画像データをCPU110は制御ファイルに書き込む。この制御ファイルは、スキャン設定を可能としている制御ファイルと同一であってもよいし、異なってもよい。
コンピュータ100のCPU121は、画像データが制御ファイル204に書き込まれたか否かを監視する(ステップS309)。画像データが制御ファイル204に書き込まれたことを検出すると、制御ファイル204から画像データを読み出す(ステップS310)。CPU121は、指定された画像ファイル(本実施形態では、ファイル名「test1」)を作成し、ハードディスクドライブ122に記憶する(ステップ311)。本実施形態の周辺装置はプリンタや複合機等の画像形成機能を有する装置でもよい。CaptureApplication.exeやautorun.exe等の制御ソフトウエアは、USBメモリとして認識されるRAM上のファイルの受け渡しで画像読取及び画像形成の少なくとも一方に関するコマンドの送出と、画像データのスキャナからの移動やプリンタ等への移動を可能とするドライバ機能を有するものであってもよい。またはドライバ機能を有するDLL(Dynamic Link Library)モジュール等の他のプログラムとリンクして、USBメモリとして認識されるRAM上のファイルの受け渡しを行うことによって、画像読取や画像形成に関するコマンドの送出と、画像データのスキャナからの移動やプリンタ 等への移動を可能とするようにしてもよい。
以上説明したように、本実施形態によれば、コンピュータ100にデバイスドライバやアプリケーションなどのソフトウエアをインストールすることなく、スキャナ装置106で画像読み取りを行うことができるようになる。例えば、管理者権限がなくオペレーティングシステム101においてインストーラにログインできないユーザや、外出先のパーソナルコンピュータを使用するユーザであっても、容易に、画像読み取りを行うことができる
本実施形態ではUSBマスストレージクラスインターフェース206のUSBディスクドライブインターフェース205を介して読出し可能なRAM203等にCaptureApplication.exe210やautorun.infやautorun.exe等の制御用のソフトウエアが常時記憶されているようになっている。しかし、電源投入時や初期化時や所定のコマンドを受けたとき等に不図示のROM等に記憶されたファームウエア等の制御により、ROMや不揮発性メモリ等に記憶された情報に基づいてRAM203等に、USBマスストレージクラスインターフェースを介して読み出し可能なように、その都度autorun.infやCaptureApplication.exeやautorun.exe等を格納するようにしてもよい。もちろんROMや不揮発性メモリ等にautorun.infやCaptureApplication.exeやautorun.exe等がそのまま記憶されている場合は、RAM203等に複製するようにしてもよい。このようにROMや不揮発性メモリ等に記憶された情報に基づいてRAM203等に格納又は複製された制御用のソフトウエアは、コンピュータ100のメモリ(RAM124)にロードされ起動される。起動された制御用のソフトウエアは、制御ファイル204へのコマンド等の書き込みの制御や、画像データを制御ファイル204から読み出したり制御ファイル204へ書き込んだりする制御を実行する。
これらの制御用のソフトウエア(CaptureApplication.exe210等)はRAM203等から消去することも可能であり、USBマスストレージクラスインターフェースを介して読み書き可能なRAM203等の記憶容量を、他の目的に有効に活用することができる。また、万一コンピュータウイルス等の感染がこれらの制御用のソフトウエアに認められた場合は、これらの制御用のソフトウエアを消去することによって、感染の拡大を防ぐことができる。
なお、CaptureApplication.exeやautorun.exe等の制御用のソフトウエアは、コンピュータ100のメモリ(RAM124)にロードして起動することで使用可能となるものであり、インストールする必要がないソフトウエアであることが特徴である。また、本実施形態ではコンピュータ100によってスキャナ装置106のRAM203が1つのディスクドライブとしてドライブレターを割り当てられて認識される。不図示のROMや不揮発性メモリ等はコンピュータ100からは認識されないことが望ましい。このようにするとスキャナ装置106に対してドライブレターは1つだけ割り当てられるので、他の機器のために必要とされるドライブレターを浪費することがない。以上説明したように、本発明の第1の実施形態では、コンピュータ100にデバイスドライバやアプリケーションなどのソフトウエアをインストールすることなく、スキャナ装置106で画像読み取りを行うことができるようになる。例えば、管理者権限がなくオペレーティングシステム101においてインストーラにログインできないユーザや、外出先のパーソナルコンピュータを使用するユーザであっても、容易に、画像読み取りを行うことができる。
<第2の実施形態>
図6は、本発明の第2の実施形態に係る、コンピュータと画像読み取り装置としてのスキャナのソフトウエアブロック図である。すでに説明した箇所に同一の参照符号を付与することで説明を簡潔にする。
第1の実施形態で説明したUSBマスストレージクラスインターフェース206は、複数のUSBマスストレージサブクラスを有することが可能である。そこで、第2の実施形態では、USBディスクドライブインターフェース205とUSB CDドライブインターフェース208といった2つのサブクラスがスキャナ装置106に備えられている。コンピュータ100上のオペレーティングシステム101は、それぞれを論理的に別個のデバイスとしてアクセス可能である。すなわち、コンピュータ100のCPU121は、スキャナ装置106を2つの論理的に異なるディスクドライブとして認識し、ドライブレターをそれぞれに割り当てる。
より詳細に説明する。コンピュータ100にスキャナ装置106が接続されると、オペレーティングシステム101(CPU121)は、USBインターフェース104にて何らかの周辺デバイスの接続を検知する。そして、CPU121は、USBケーブル105を介して、スキャナ装置106のUSBインターフェース107にアクセスする。
スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からアクセスがあると、USBマスストレージクラスインターフェース206にアクセスさせる。このように、オペレーティングシステム101は、スキャナ装置106のUSBマスストレージクラスインターフェース206へアクセスする。これにより、CPU121は、予めオペレーティングシステム101に含まれているUSBマスストレージドライバ202を利用して、USBインターフェースドライバ103とUSBインターフェース104からUSBケーブル105を介してスキャナ装置106にアクセス可能になる。
また、スキャナ装置106は2つのUSBマスストレージサブクラスを有していることから、オペレーティングシステム101は2つのマスストレージクラスデバイスとしてスキャナ装置106を認識する。よって、コンピュータ100のCPU121は、スキャナ装置106のUSBインターフェース107、USBマスストレージクラスインターフェース206、USB CDドライブインターフェース208あるいはUSBディスクドライブインターフェース205を介して、管理者権限を持たないユーザが利用可能なアクセス方法によってスキャナ装置106にアクセスできる。
また、スキャナ装置106には、オートランファイル207と、キャプチャアプリケーション210と、制御ファイル204とが予め保存されている。オートランファイル207は、上述したautorun.infなどである。
なお、コンピュータ100のCPU121は、USB CDドライブインターフェース208を介して、制御ファイル204は、USBディスクドライブインターフェース205を介して、キャプチャアプリケーション210とオートランファイル207とにアクセスする。
上述したように、オペレーティングシステム101がマイクロソフト(登録商標)ウインドウズであれば、CDドライブ内にデータCDが挿入されると「autorun.inf」(オートランファイル207)の読出しを実行する。オートランファイル207は、USB CDドライブインターフェース208を介してアクセスされるため、自動的に読み出されて処理されることになる。
スキャナ装置106のCPU110は、コンピュータ100に接続した時点で、CDドライブ内にデータCDが挿入されていない状態であるとオペレーティングシステム101に仮想的に認識させる。次に、CPU110は、CDが挿入されたことをオペレーティングシステム101に仮想的に認識させることで、オートランファイル207が自動実行されるように制御する。
さらに、コンピュータ100は、スキャナ装置106に保存してある制御ファイル204とキャプチャアプリケーション210とオートランファイル207に対応するテーブルを、ファイルシステム201に関連付けられたフォルダ内に形成する。
図7は、コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローを示したフローチャートである。既に説明した箇所には同一の参照符号を付与することで、説明を簡潔にする。
ステップS301ないしステップS304が実行されると、コンピュータ100のCPU121は、マスストレージデバイスが接続された認識する。スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USB CDドライブインターフェース208とUSBディスクドライブインターフェース205を有している。そのため、コンピュータ100のCPU121は、接続されたスキャナ装置106をそれぞれ、CDドライブとディスクドライブとして認識する(ステップS705)。
上述のように、オペレーティングシステム101(CPU121)は、ファイルシステム201に関連付けられたファイルフォルダ内に、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210とオートランファイル207に対応するテーブルを形成する。そのため、CPU121は、スキャナ装置106内に保存してある制御ファイル204をディスクドライブ上のファイルとして認識する。また、CPU121は、キャプチャアプリケーション210とオートランファイル207をCDドライブ上のファイルとして認識する。
図8は、CDドライブとして認識されているメモリ領域に対応したフォルダの一例を示した図である。すなわち、スキャナ装置106のROMやRAMのうち、CDドライブとして認識されているメモリ領域がフォルダ302としてコンピュータ100には認識される。よって、フォルダ302に、キャプチャアプリケーション210とオートランファイル207が格納されているように見える。
図9は、ディスクドライブとして認識されているメモリ領域に対応したフォルダの一例を示した図である。スキャナ装置106のROMやRAMのうち、ディスクドライブとして認識されているメモリ領域がフォルダ303としてコンピュータ100には認識される。よって、フォルダ303に、制御ファイル204が格納されているように見える。
ユーザは、図8に示すようなフォルダ302と図9に示すようなフォルダ303をコンピュータ100に接続されたキーボード/マウス125を使用して開くことができる。
オペレーティングシステム101(CPU121)は、CDドライブ内にデータCDが挿入されたと判断すると、オートランファイル207を実行する(ステップS706)。オートランファイル207は、予め、キャプチャアプリケーション210を起動するように記述されている。そのため、CPU121は、オートランファイル207の記述を解釈して、キャプチャアプリケーション210を起動する(ステップS707)。ユーザの操作は不要であるため、ユーザには、キャプチャアプリケーション210が自動的に起動されたように見える。
なお、図8のようなCDドライブとして認識される領域を設けず、RAM124が図9のようなUSBディスクドライブとしてだけ認識されるようにしてもよい。その場合autorun.infとCaptureApplication.exe、autorun.exe等をUSBディスクドライブとして認識されているRAM124のメモリ領域に格納すればよい。必要があればそこにDLLモジュールも格納する。電源投入時またはUSBコネクタが差し込まれたとき、autorun.infの記述に従って、CaptureApplication.exe、autorun.exe等の起動を確認させるためのダイアログ画面をコンピュータ100に表示させて、ユーザの操作により起動可能な状態にすることができる。またオペレーティングシステム101の設定を変えれば、起動確認のダイアログ画面をコンピュータ100に表示させることなく、autorun.infの記述に従って、CaptureApplication.exe、autorun.exe等を起動させることもできる。
また、図8でCDドライブとして認識されると示した領域の代わりに、読取のみ可能なUSBディスクドライブとして認識される領域を設け、RAM124が複数個のUSBディスクドライブとしてコンピュータ100に認識されるようにしてもよい。その場合、autorun.infとCaptureApprlication.exe、autorun.exe等を、読取のみ可能なUSBディスクドライブとして認識されているRAM124のメモリ領域に格納することで、これらのファイルが悪意を持った人物に改ざんされることを防ぐこともできる。
その後、上述したステップS308ないしS311が実行される。
以上、2つの実施形態で説明したように、本実施形態では、コンピュータ100にデバイスドライバやアプリケーションなどのソフトウエアをインストールすることなく、スキャナ装置106で画像読み取りを行うことができるようになる。例えば、管理者権限がなくオペレーティングシステム101においてインストーラにログインできないユーザや、外出先のパーソナルコンピュータを使用するユーザであっても、容易に、画像読み取りを行うことができる。
なお、上記の第1及び第2の各実施形態においては、キャプチャアプリケーション210からスキャンを開始する例を説明した。しかし、スキャナ装置106上にスタートボタン等を配置し、スタートボタンを押下されたことをCPU110が検知すると、スキャンを開始してもよい。その際、キャプチャアプリケーション210(CPU121)は、スキャナ装置106のスタートボタンを、制御ファイル204を介して監視してもよい。この場合は、CPU110がスタートボタンを押下されたことを示す情報を制御ファイル204に書き込むことになる。
キャプチャアプリケーション210は、スキャナ装置106に制御ファイル204を介してスキャン開始を指示してもよいし、キャプチャアプリケーション210が、制御ファイル204に画像データが生成されたことを検知して、スキャンが開始されたと判断し、画像データを読み出して画像ファイルをハードディスクドライブに保存しても良い。
また、上記第1及び第2の実施形態においては、キャプチャアプリケーション210を起動し、ユーザインターフェースを表示しているが、スキャナ装置106を最初に接続した後は、マイクロソフト(登録商標)ウインドウズ等のオペレーティングシステム101に常駐してもよい。
また、上記第1及び第2の実施形態においては、キャプチャアプリケーション210には画像表示機能が無いが、キャプチャアプリケーション210が読み取られた画像の表示機能を備えていても良い。
また、上記第1及び第2の実施形態においては、RAM203の制御ファイル204にスキャン設定を書き込んでいるため、スキャン設定がスキャナ装置106に保存されない。しかし、スキャナ装置106内で、設定されたスキャン設定を不図示の不揮発メモリ等に記憶しておいても良い。また、オペレーティングシステム101のユーザ毎に、別々のスキャン設定を記憶しておいても良い。
また、上記第1及び第2の実施形態においては、マイクロソフト(登録商標)ウインドウズオペレーティングシステム上での動作を例にとって説明した。しかしこれは一例にすぎない。本発明は、アップル社のオペレーティングシステムやリナックスオペレーティングシステム等、その他のオペレーティングシステムにも適用できる技術思想だからである。
また、上記第1及び第2の実施形態においては、画像読み取り装置を例にとって説明したが、プリンタでもよく、画像読み取り機能と画像形成機能を併せ持つ複合機等でもよい。
なお、本発明の周辺装置が画像形成機能を有する場合は画像形成に関するコマンドの送出の機能と、画像形成に用いる画像データの送出の機能とを、autorun.exe等のソフトウエアは備えることになる。
<第3の実施形態>
第1の実施形態や第2の実施形態では、デバイスドライバのインストールが不要となる反面、常に、専用のキャプチャアプリケーションを使用する必要がある。一方で、デバイスドライバのインストールが許可されているコンピュータでは、普及した汎用のキャプチャアプリケーションを使用したいという要望も予想される。
そこで、本実施形態では、専用のデバイスドライバのインストールを必要とする制御モードと、上述した第1の実施形態又は第2の実施形態のように、専用のデバイスドライバ等のソフトウエアのインストールを必要としない制御モードとを備え、両者を切り替えることができる周辺装置について提案する。なお、後者のモード、すなわち、ソフトウエアのインストールを必要としない制御モードについては、上述した第1の実施形態又は第2の実施形態と同様である。以下、専用のデバイスドライバ等のソフトウエアのインストールを必要とする制御モードについて詳細に説明する。
図10は、第3の実施形態に係るソフトウエアブロック図である。既に説明した箇所には同一の参照符号が付与されている。図1と比較すると、汎用のキャプチャアプリケーション222と、USBスキャナドライバ102と、スイッチ220がコンピュータ100に追加されている。一方、スキャナ装置106には、USBスキャナクラスインターフェース108とスイッチ221とが追加されている。
コンピュータ100上のオペレーティングシステム101は、USBインターフェース104にUSBケーブル105を介して何らかの周辺デバイスが接続された場合、周辺デバイスのインターフェースにアクセスし、周辺デバイスの種類を確定する。ここで、スキャナ装置106には、オペレーティングシステム101にマスストレージデバイスクラスとして認識してもらうためのUSBマスストレージクラスインターフェース206と、スキャナデバイスクラスとして認識してもらうためにUSBスキャナクラスインターフェース108とを有している。
これらの2つの異なるクラスのインターフェースは、スイッチ221によって択一的に切り替えられる。なお、スイッチ221は、第3の制御モードとして、2つのクラスのインターフェースを同時に有効にするように切り替えてもよい。スイッチ221は、ソフトウエアで実現されてもよいし、電気的に切り替え可能な電子スイッチを用いてハードウエアによって実現されてよい。また、ソフトウエア及びハードウエアの両方も用いてスイッチ221が実現されてもよい。
具体的には、上記のハードウエアにより実現されるスイッチ221としては、例えば、ユーザが手で切り替え可能なスイッチ等が挙げられる。またはスイッチ221の切り替えのための電気信号を生成する他の手動スイッチを別途設けてもよい。これらの場合後述するような制御が可能なスイッチと異なり、CPU110の制御によるスイッチ221の切り替えができない。このようなとき表示LED等を設けCPU110からLED等の点灯を制御することによりユーザに手でスイッチ221等を切り替えさせるようにしてもよい。
なお、このような手で切り替え可能なスイッチ221又は他の手動スイッチを設けた場合は、スイッチの切り替え状態に応じてスキャナ装置106の不図示の操作ボタンを押した場合の動作を異ならせることができる。例えば、スイッチ221又は他の手動スイッチをUSBマスストレージクラスインターフェース206を認識可能とする側に切り替えておき、不図示のスキャン開始ボタンを押すと、USBの接続が遮断された状態への遷移と、その後再びUSBの接続が行なわれた状態への遷移とを擬似的に起こすこともできる。これらの遷移により、USBのコネクタに触れることなく、USBの抜き差しを行った場合に実行されるオートランプログラムの起動やオートランの確認ダイアログの表示を可能とし、画像読取を少ない操作で行うことができる。
また、このような手で切り替え可能なスイッチ221又は上述した他の手動スイッチをUSBスキャナクラスインターフェース108を認識させる側に切り替えておき、不図示のスキャン開始ボタンを押すと、所定のJOBをコンピュータ100上で動作させるための情報をコンピュータ100に送信したり、あるいは制御ファイルにJOBを起動させるための情報を書き込んだりするようにすることもできる。
一方、コンピュータ100上で動作するオペレーティングシステム101は、マスストレージクラスのUSBデバイスをサポートしている。オペレーティングシステム101がマスストレージクラスデバイスのデバイスドライバであるUSBマスストレージドライバ202を含んでいる。そのため、ユーザは、コンピュータ100への特別なデバイスドライバをインストールすることを要求されることはない。また、マスストレージクラスデバイスへの標準的なアクセスは、オペレーティングシステム101を通じて、管理者権限なしに、実行可能である。
よって、コンピュータ100にスキャナ装置106を接続したとき、予めインストールされているUSBマスストレージドライバ202が使用される。また、スキャナ装置106は、USBマスストレージクラスインターフェース206を有している。そのため、コンピュータ100にスキャナ装置106を接続すると、スキャナ装置106がマスストレージデバイスとしてオペレーティングシステム101に認識され、アクセスが可能となる。
なお、コンピュータ100内のスイッチ220を切り替えることで、USBマスストレージドライバ202以外のドライバへ接続を切り替えることができるものとする。スイッチ220は、ソフトウエアで実現されてもよいし、電気的に切り替え可能な電子スイッチを用いてハードウエアによって実現されてよい。また、ソフトウエア及びハードウエアの両方も用いてスイッチ220が実現されてもよい。
また、USBマスストレージクラスインターフェース206は、複数のUSBマスストレージサブクラスを有することが可能である。図6に示したように、2つのサブクラスを有するようにスキャナ装置106が変更されてもよい。
コンピュータ100に予めインストールされているキャプチャアプリケーション222は、スキャナ装置106で画像読み取りを行うためのソフトウエアである。USBスキャナドライバ102は、スキャナ装置106を、USBインターフェースを介して接続するためのデバイスドライバである。これは、標準でOSには用意されていない専用のデバイスドライバである。よって、USBスキャナクラスインターフェース108が有効に設定されているときは、USBスキャナドライバ102を通じて画像の読取が実行される。
本実施形態においては、管理者権限を有するユーザが、予めキャプチャアプリケーション222とUSBスキャナドライバ102をコンピュータ100へインストールしているものとする。USBマスストレージドライバ202とUSBスキャナドライバ102は、スイッチ220によって切り替えられる。もちろん、双方が同時に有効にされてもよい。
コンピュータ100にスキャナ装置106が接続された場合、オペレーティングシステム101は、USBインターフェース104にて何らかの周辺デバイスの接続を検知し、USBケーブル105を介して、スキャナ装置106のUSBインターフェース107にアクセスする。スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からアクセスがあると、切り替えスイッチ221をUSBマスストレージクラスインターフェース206に切り替え、USBマスストレージクラスインターフェース206にアクセスさせる。オペレーティングシステム101は、スキャナ装置106のUSBマスストレージクラスインターフェース206にアクセスすることで、切り替えスイッチ220を切り替えてUSBマスストレージドライバ202を有効にし、USBインターフェース104からUSBケーブル105を介してスキャナ装置106にアクセスする。
スキャナ装置106は、オペレーティングシステム101に、マスストレージクラスデバイスとして認識されている。そのため、コンピュータ100は、スキャナ装置106のUSBインターフェース107、USBマスストレージクラスインターフェース206、USBディスクドライブインターフェース205を介して、オペレーティングシステム101の管理者権限なしに実行できるアクセス方法でスキャナ装置106にアクセスができる。
スキャナ装置106には、コンピュータ100からスキャナ装置106で画像読み取りを行うためのオペレーティングシステム101上で動作するキャプチャアプリケーション210と、スキャナ装置106を制御するための制御ファイル204とを予め保存してある。
さらに、コンピュータ100は、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210に対応するテーブルを、ファイルシステム201に関連付けたファイルフォルダ内に形成する。これらのテーブルを形成することでスキャナ装置106内の制御ファイル204とキャプチャアプリケーション210は、例えばコンピュータ100の画面に表示されるようになる。本実施形態の説明では、スキャナ装置106内のキャプチャアプリケーション210を使用する動作モードの説明は省略する。
図11は、ユーザが、コンピュータ100にインストールしてあるキャプチャアプリケーション222を起動して、スキャナ装置106で画像読み取りを行うフローを示したフローチャートである。
コンピュータ100はスキャナ装置106が接続されたか否かを監視する(ステップS1101)。コンピュータ100はUSBマスストレージクラスインターフェースを有する装置としてスキャナ装置106を接続する(ステップS1102)。コンピュータ100は周辺デバイスのインターフェースクラス等の情報をスキャナ装置106から取得する(ステップS1103)。コンピュータ100は、取得した情報により、接続された周辺デバイスの種類を認識できる。
ところで、スキャナ装置106の切り替えスイッチ221は、通常、USBマスストレージインターフェースに切り替えられている。そのため、コンピュータ100はスキャナ装置106をUSBマスストレージデバイスと認識する(ステップS1104)。コンピュータ100は、切り替えスイッチ220をUSBマスストレージドライバ202に切り替え、接続されたスキャナ装置106をディスクドライブとしてファイルシステムに追加する(ステップS1105)。
このようにして、コンピュータ100は、マスストレージとしてスキャナ装置106を認識する。コンピュータ100は、キャプチャアプリケーション222の起動が指示されたか否かを判定する。(ステップS1106)。キャプチャアプリケーション222の起動が指示されると、コンピュータ100は、キャプチャアプリケーション222を起動する(S1107)。
コンピュータ100はスキャナ装置106がマスストレージデバイスとして認識されていることをファイルシステム201から検知する。そこで、コンピュータ100は、ファイルシステム201を経由してスキャナ装置106に対して、USBスキャナクラスインターフェース108で接続しなおすように指示を出す(ステップS1108)。スキャナ装置106は、USBスキャナクラスクラスへのインターフェースの切り替えの指示を受信した場合、一度、コンピュータ100への接続状態から切断状態に移行した後、再度、接続状態に移行する。
このとき、オペレーティングシステム101は、USBインターフェース104にて何らかの周辺デバイスの接続を検知する(ステップS1109)。スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からのアクセスがあると、切り替えスイッチ221をUSBスキャナクラスインターフェース108が有効となるように切り替え、コンピュータ100にUSBスキャナクラスインターフェース108へアクセスさせる(S1110)。これによりコンピュータ100は、装置のインターフェースクラスの情報等を取得する(ステップS1111)。取得した情報は、コンピュータ100がUSBスキャナクラスインターフェース108に接続したことを示している。よって、コンピュータ100は、接続された周辺デバイスがスキャナデバイスであると認識する(ステップS1112)。
次に、ユーザは、キャプチャアプリケーション222が起動されているため、ディスプレイ126にはユーザインターフェース画面が表示されている(図5)。本実施形態でのキャプチャアプリケーション222はキャプチャアプリケーション210と同一のユーザインターフェースを使用しているが、両者は異なってもよい。ユーザは、キャプチャアプリケーション222で、読み取りモード(本実施形態では、白黒)、用紙サイズ(本実施形態では、A4)、解像度(本実施形態では、300dpi)、読み取り面(本実施形態では、両面)を設定する。この設定には、キーボード/マウス125が使用される。また、画像ファイルのファイル名(本実施形態では、test1)もキーボード/マウス125を使用して入力される。最後に、スキャンボタン301がキーボード/マウス125によりクリックされる。
スキャンボタン301がクリックされると、キャプチャアプリケーション222(CPU121)は、USBスキャナドライバ102、USBインターフェースドライバ103及びUSBインターフェース104を介して、スキャナ装置106に、スキャン設定を送信するとともに、スキャン開始コマンドを送信する(ステップS1113)。(以下はスキャナクラスのため:受信receive)
スキャナ装置106は、USBインターフェース107からUSBスキャナクラスインターフェースを介して、スキャン設定およびスキャン開始コマンドデータを受信したことを検出する。スキャナ装置106は、受信したスキャン設定にしたがってスキャンを開始する。
コンピュータ100は、スキャナ装置106の画像読み取り部112が読み取った画像データを、USBスキャナクラスインターフェース108及びUSBインターフェース107を介して受信する(ステップS1114、S1115)。キャプチャアプリケーション222は、受信した画像データを結合し、指定されたファイル名(本実施形態では、test1)の画像ファイルとしてハードディスクドライブに保存する(ステップS1116)。
なお、コンピュータ100にUSBスキャナドライバ102をインストールできないときの動作は、第1及び第2の実施形態と変わらないため、説明を省略する。
<第4の実施形態>
図12は、第4の実施形態に係るソフトウエアブロック図である。図12と図10とを比較するとわかるように、スキャナ装置106のソフトウエア構成が第2の実施形態と第3の実施形態とを組み合わせたものとなっている。すなわち、インストールに関して制限のあるコンピュータにスキャナ装置106が接続されたときは、第2の実施形態で説明したようにコンピュータ及びスキャナ装置106が動作する。一方で、既にUSBスキャナドライバ102やキャプチャアプリケーション222がすでにインストールされているコンピュータでは、第3の実施形態で説明したようにコンピュータ及びスキャナ装置106が動作する。
[画像転送処理]
図13は、上記第2、第4実施形態での画像転送処理の一例を示したフローチャートである。スキャナ装置106のCPU110は、制御ファイル204にスキャン開始コマンドが書き込まれたか否かを確認する(ステップS1301)。スキャン開始コマンドが書き込まれたことを検知すると、CPU110は、画像読み取り部112を制御してスキャンを開始し、読み取った画像の画像データをCPU110が制御ファイル204に書き込む(ステップS1302)。CPU110は、1ページ分の画像データについて制御ファイル204への書き込みが終了したか否かを判定する(ステップS1303)。これが終了すると、CPU110は、コンピュータ100にリムーバブルメディアが交換された旨を、USBケーブル105を通じて通知する(S1304)。
オペレーティングシステム101は、リムーバブルメディアが交換された旨の通知を受信すると、リムーバブルメディアが交換されたと判断し、スキャナ装置106に記憶されている制御ファイル204に対応したファイルシステム201の管理テーブルを更新する。CPU121は、更新された管理テーブルを読み、制御ファイル204に画像データが書き込まれたことを認識する。
CPU121が実行しているキャプチャアプリケーション210は、書き込まれた画像データを制御ファイル204から抽出し、抽出した画像データを結合して1つの画像ファイルを生成し、指定されたファイル名(上記実施形態では、test1)を付与してハードディスクドライブに保存する。上述したようにリムーバブルメディアが交換されたと判断される状態にする方法の他に、画像データの格納の完了等をコンピュータに通知する方法は、下記のような例示する方法が可能である。
[画像転送処理の他の例]
図14は、上記第4実施形態でのコンピュータ側の画像転送処理の一例を示したフローチャートである。図15は、上記第4実施形態でのスキャナ装置側の画像転送処理の一例を示したフローチャートである。
上記実施形態のマスストレージクラスデバイスは、SCSIコマンド体系での送受信をサポートしている。つまり、コンピュータ100は、マスストレージデバイスに対して、SCSIコマンド体系で、コマンドを発行する。また、コンピュータ100のマイクロソフトウインドウズ(登録商標)オペレーティングシステム101は、マスストレージデバイスの接続があると、定期的に、Test Unit Readyコマンドを発行する。
コンピュータ100から、スキャナ装置106にスキャン開始指示を行うとき、まず、キャプチャアプリケーション210は、制御ファイル204にスキャン開始命令を書き込む。具体的には、マイクロソフトウインドウズ(登録商標)オペレーティングシステム101は、Writeコマンドを発行し、パラメータデータでスキャン開始命令を送信する(S1401、S1402、S1403)。
スキャナ装置106は、Writeコマンドのパラメータデータでスキャン開始命令を受信し、スキャンパラメータを制御ファイル204から読み出して受け付けると(S1501,S1502)、スキャンを開始し、画像読み取り部112で読み取った画像データを制御ファイル204に書き込む(S1503)。
このとき、スキャナ装置106は、画像読み取り中の画像データが制御ファイル204に書き込み中である場合、Test Unit Readyコマンドに対して、正常状態を示すGOODステータスを返す(S1504,S1505)。コンピュータ100は、定期的にTest Unit Readyコマンドを送信する(S1404)。
その後、スキャナは、画像データの制御ファイル204への書き込みが終了した場合(S1506)、Test Unit Readyコマンドに対して(S1507)、書き込み終了を通知するためにCHECK CONDITIONステータスを返す(S1508)。
コンピュータ100のオペレーティングシステム101はスキャナ装置106から、GOODステータスの代わりにCHECK CONDITIONステータスを受信すると(S1405)、スキャナ装置106の状態の詳細情報を取得するために、Request Senseコマンドを発行する(S1406)。
スキャナ装置106は、Request Senseコマンドを受信すると(S1509)、前回のコマンドであるTest Unit Readyコマンドに対して、CHECK CONDITIONステータスを返しているため、センスデータでMEDIUM NOT PRESENTセンスキーおよびセンスコード、または、MEDIUM MAY HAVE CHANGEDセンスキーおよびセンスコードを送信する(S1510)。
コンピュータ100のオペレーティングシステム101はスキャナ装置106から、センスデータとして、MEDIUM NOT PRESENTセンスキーおよびセンスコード、または、MEDIUM MAY HAVE CHANGEDセンスキーおよびセンスコードを受信すると(S1407)、マスストレージデバイスのリムーバブルメディアが排出されたものと判断する。さらに、コンピュータ100のオペレーティングシステム101は、マスストレージデバイスのリムーバブルメディアの挿入を待つために、定期的に、Test Unit Readyコマンドを発行する(S1408)。
スキャナ装置106は、CHECK CONDITIONステータスを返した後、次のTest Unit Readyコマンドを受信すると(S1511)、オペレーティングシステム101に対して、正常状態を示すGOODステータスを返す(S1512)。
コンピュータ100のオペレーティングシステム101はGOODステータスを受信すると(S1409)、マスストレージデバイスのリムーバブルメディアが挿入されたと判断する。オペレーティングシステム101は、スキャナ装置106内にある制御ファイル204に対応するファイルシステム201内の管理テーブルを更新し、更新された管理テーブルにより制御ファイル204に画像データが書き込まれたことをキャプチャアプリケーション210は認識する(S1410)。
以上により、キャプチャアプリケーション210は制御ファイル204から、書き込まれた画像データを読み出して指定された保存ファイル名(上記実施形態では、test1)で保存する。
なお、上記実施形態では、Test Unit Readyコマンドに対して、上述したようにCHECK CONDITIONステータスを返したが、コンピュータ100のオペレーティングシステム101が発行する他のコマンド(例えば、Mode SelectコマンドやStart−Stop Unitコマンド)に対して、CHECK CONDITIONステータスを返しても実現できる。
また、上記実施形態では、マスストレージデバイスのリムーバブルメディアの排出/挿入と認識させるための振る舞いをすることで、オペレーティングシステム101にファイルシステム201内の管理テーブルの更新を促せたが、USBバスのD+信号とD−信号をともに0にするよう制御してから、USBバスリセットステートに移行して、USBデバイスの仮想的な脱着が行われたという振る舞いをしても実現できる。
[デバイス認識処理]
コンピュータ100のオペレーティングシステム101は、USBデバイスの接続を検知すると、コントロール転送のセットアップステージにて、GET_DESCRIPTOR標準デバイスリクエストを発行する。
スキャナ装置106は、GET_DESCRIPTOR標準デバイスリクエストを受信すると、要求されたディスクリプタを返す。ディスクリプタは、デバイスの種類や特性や属性などの情報を表現するために使われ、フォーマットが定義されている。
コンピュータ100のオペレーティングシステム101は、スキャナ装置106から受信したGET_DESCRIPTOR標準デバイスリクエストのうち、標準デバイスディスクリプタ、標準構成(コンフィグレーション)ディスクリプタ、標準インターフェースディスクリプタによって、接続されたデバイスの種類や特性や属性などの情報を取得する。
[マスストレージデバイスとして接続される処理]
図16、図17は、周辺装置がマスストレージデバイスとして接続されるときの処理の一例を示したフローチャートである。図16はコンピュータ100における処理であり、図17は周辺装置における処理である。
図16によれば、コンピュータ100は、スキャナ装置106が接続されたか否かを監視する(ステップS1601)。コンピュータ100は、何等かの周辺装置が接続されたことを検出すると、周辺装置のインターフェースに接続する(ステップS1602)。コンピュータ100は、周辺装置へGET_DESCRIPTOR標準デバイスリクエストを発行する(ステップS1603)。このディスクリプタにより接続された周辺装置の種類が認識できる。
一方、図17によれば、スキャナ装置106は、コンピュータに接続されたと認識したときは(S1701)、デフォルトでUSBマスストレージインターフェースを選択するよう、切り替えスイッチ221をソフト的に切り替える。これによりスキャナ装置106はコンピュータ100に、USBマスストレージインターフェースへの接続を行わせる(ステップS1702)。よって、スキャナ装置106は、GET_DESCRIPTORを受信すると(S1703)、GET_DESCRIPTOR標準デバイスリクエストのうち、標準デバイスディスクリプタのデバイスクラスコードまたは標準インターフェースディスクリプタのインターフェースクラスコードにて、USBマスストレージクラスコードを送信する(ステップS1704)。
図16によれば、コンピュータ100のオペレーティングシステム101は、デバイスクラスコード、または、インターフェースクラスコードとして、USBマスストレージクラスコードを受信すると(ステップS1604)、USBマスストレージクラスコードに関連するUSBマスストレージドライバや、その他のクライアントドライバをRAM124上で起動することで、内部の切り替えスイッチ220を、USBマスストレージドライバ202にソフト的に切り替える(ステップS1605)。
スイッチ221はユーザが手で切り替え可能なスイッチでもよい。またはスイッチ221の切り替えのための電気信号を生成する他の手動スイッチを別途設けてもよい。これらの場合上記のようなCPU110の制御によるスイッチ221のソフト的な切り替えができない。このようなとき表示LED等を設け、CPU110からLED等の点灯を制御することによりユーザに手でスイッチ221を切り替えさせるようにしてもよい。
[スキャナデバイスへ切り替わる処理]
図18、図19は、周辺装置がスキャナデバイスとして接続されるときの処理の一例を示したフローチャートである。図18はコンピュータ100における処理であり、図19は周辺装置における処理である。
図19によれば、スキャナ装置106は、コンピュータによりインターフェースクラスの切り替えが指示された場合、USBバスのD+信号とD−信号をともに0にするよう制御してから、USBバスリセットステートに移行することで、一度、コンピュータ100から接続を切り離し(ステップS1901)、再度、接続状態となった振る舞いをする(ステップS1902)。
一方、図18によれば、コンピュータ100は、スキャナ装置106が接続されたか否かを監視する(ステップS1801)。コンピュータ100は、周辺装置のインターフェースに接続する(ステップS1802)。コンピュータ100は、周辺装置へGET_DESCRIPTOR標準デバイスリクエストを発行する(ステップS1803)。このディスクリプタにより接続された周辺装置の種類が認識できる。
再び図19によれば、スキャナ装置106は、切り替えスイッチ221をUSBスキャナインターフェースへとソフト的に切り替える(ステップS1903)。スキャナ装置106は、GET_DESCRIPTORを受信すると(S1904)、GET_DESCRIPTOR標準デバイスリクエストのうち、標準デバイスディスクリプタのデバイスクラスコード、または、標準インターフェースディスクリプタのインターフェースクラスコードにて、USBスキャナクラスコードを送信する(ステップS1905)。
コンピュータ100のオペレーティングシステム101は、デバイスクラスコード、または、インターフェースクラスコードとして、USBスキャナクラスコードを受信すると(ステップS1804)、USBスキャナクラスコードに関連するUSBスキャナドライバや、その他のクライアントドライバをRAM124上で起動することで、内部の切り替えスイッチ220を、USBスキャナドライバ102にソフト的に切り替える(ステップS1805)。
なお、上述した実施形態では、デバイスクラスコード、あるいは、インターフェースクラスコードで、USBスキャナクラスコードを送信したが、クラスなし(0)を送信し、デバイスディスクリプタのベンダIDとプロダクトIDから、予めコンピュータ100にインストールしてある定義ファイルを参照してクラスを確定しても良い。
上述した各実施形態においては、画像読み取り装置(スキャナ)を周辺装置の一例として説明した。しかし、本発明の周辺装置は、画像形成装置(プリンタ)であってもよいし、画像読み取り機能と画像形成機能を併せ持つ複合機等であってもよい。この場合、画像処理部は画像形成部に相当し、キャプチャアプリケーションは印刷アプリケーションに相当しよう。
具体的に、CPU121は、印刷アプリケーションにしたがって、周辺装置のメモリ(読み書き可能でドライブレターが割り当てられたディスクドライブとして認識される)の制御ファイル204に印刷ジョブのデータを書き込む。周辺装置のCPU110は、制御ファイル204を監視しており、印刷ジョブのデータが印刷アプリケーションによって書き込まれるとこれを読み出し、画像形成部(プリンタエンジン)に転送する。CPU110は、必要に応じて印刷ジョブのデータを変換(ラスタライズなど)してもよい。これによって、画像形成部が印刷処理を実行する。このように、周辺装置は、画像形成装置であってもよい。
なお、周辺装置のデバイスドライバがコンピュータにインストールされていない場合は、通常の制御方法では周辺装置で印刷を行うことができない。本実施形態では、CPU121は周辺装置の記憶手段から印刷アプリケーションを起動する。コンピュータのアプリケーションソフトウエア(ワードプロセッサや画像編集ソフトウエアなど)が印刷対象データを汎用形式のファイルとして出力すると、印刷アプリケーションによりCPU121は、汎用形式のファイルを印刷ジョブのデータに変換し、制御ファイル204へ書き込む。なお、汎用形式のファイルがそのまま周辺装置の記憶手段に書き込まれてもよい。これにより、周辺装置のデバイスドライバをインストールしなくても、周辺装置で印刷を実行できるようになる。
<第5の実施形態>
一般に、OSは、外部記憶装置のデバイスドライバをデフォルトで備えているが、画像処理装置のデバイスドライバをデフォルトで備えていないことがあり、画像処理装置を制御できない場合がある。
そこで、本発明は、このような課題および他の課題のうち、少なくとも1つを解決することを目的とする。例えば、本発明は、情報処理装置(PC)がデバイスドライバをインストール済みであるか否かに応じて、周辺装置の動作モードを切り換える制御を行うことを目的とする。なお、他の課題については明細書の全体を通して理解できよう。
図20は、コンピュータとスキャナ装置とのソフトウエアブロック図である。コンピュータ100は、例えば、なパーソナルコンピュータ(PC)などのホストコンピュータである。ここでは、情報処理装置の一例として、コンピュータ100について説明する。
コンピュータ100には、オペレーティングシステム101、ファイルシステム201、USBマスストレージドライバ202及びUSBインターフェースドライバ103がインストールされている。オペレーティングシステム101は、いわゆるOSのことであり、コンピュータ100の基本ソフトウエアである。ファイルシステム201は、ハードディスクドライブなどの記憶装置にファイルを格納するためのソフトウエアである。USBマスストレージドライバ202は、ハードディスクドライブ、CD−ROM、DVD−ROM、CD−R、DVD−R、DVD+R、CD−RW、DVD−RW、DVD+RW、DVD−RAM、BD−ROM、BD−R、BD−RE、USBメモリなどのマスストレージを制御するためのソフトウエアである。USBインターフェースドライバ103は、USBインターフェースに接続されたUSBデバイスを制御するためのソフトウエアである。なお、これらのソフトウエアはOSの一部であってもよい。
スイッチ220を切り替えることで、USBマスストレージドライバ202以外のデバイスドライバへ接続を切り替えることができるものとする。スイッチ220は、ソフトウエアで実現されてもよいし、電気的に切り替え可能な電子スイッチを用いてハードウエアによって実現されてよい。また、ソフトウエア及びハードウエアの両方も用いてスイッチ220が実現されてもよい。
一方、周辺装置の一例であるスキャナ装置106には、キャプチャアプリケーション210、制御ファイル204、USBディスクドライブインターフェース205及びUSBマスストレージクラスインターフェース206が備えられている。キャプチャアプリケーション210は、コンピュータ100で実行されて画像を読み取るための制御を行うソフトウエアである。制御ファイル204は、キャプチャアプリケーション210を実行しているコンピュータ100からアクセスされ制御コマンドなどがその中に書き込まれるファイルである。USBディスクドライブインターフェース205は、スキャナ装置106に備えられているメモリ(RAM、フラッシュメモリ、EEPROMなど)をディスクドライブとして使用するためのソフトウエアである。USBマスストレージクラスインターフェース206は、USBディスクドライブインターフェース205を介してメモリをUSBマスストレージとして使用するためのソフトウエアである。
スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USBディスクドライブインターフェース205だけでなく、USB CDドライブインターフェース208を備えている。USB CDドライブインターフェース208は、スキャナ装置106が備えているメモリの一部をCD−ROMドライブとしてコンピュータ100が利用するためのインターフェースである。このCD−ROMとして利用される不揮発性のメモリ領域には、オートランファイル207、判定アプリケーション224及びキャプチャアプリケーション210が記憶されている。
なお、USB CDドライブインターフェース208は、USB CD−ROMドライブインターフェース、USB CD−Rドライブインターフェース、USB CD−RWドライブインターフェースのいずれであってもよい。USB CD−Rドライブインターフェース、USB CD−RWドライブインターフェースは、スキャナ装置106が備えている読み書き可能なメモリの一部をあたかもCD−Rドライブ、CD−RWドライブ中のCD−Rディスク、CD−RWディスクであると見なしてコンピュータ100が利用することを可能とするためのインターフェースである。
オートランファイル207は、判定アプリケーション224をコンピュータ100で自動的に実行することを指示するための情報を含んでいる。オートランファイル207は、例えば、autorun.infである。オペレーティングシステム101がマイクロソフト(登録商標)ウインドウズであれば、CDドライブ内にデータCDが挿入されると「autorun.inf」を実行するようになっている。オートランファイル207は、USB CDドライブインターフェース208を介してアクセスされるため、自動的に起動されることになる。判定アプリケーション224は、コンピュータ100で実行されて画像処理部(例:USBスキャナクラスインターフェース108、画像読み取り部など)をコンピュータ100から制御するためのデバイスドライバがコンピュータ100にインストール済みであるか否かを判定するための判定プログラムである。
キャプチャアプリケーション210は、コンピュータ100で実行されて画像を読み取るための制御を行うソフトウエアである。キャプチャアプリケーション210は、デバイスドライバを備えていないPCや、デバイスドライバやアプリケーションのインストールを制限されているPCでの使用が有用である。なぜなら、キャプチャアプリケーション210は、PCにデバイスドライバや何らかのキャプチャアプリケーションをインストールすることなく、直接、スキャナ装置106を制御できるソフトウエアだからである。
スキャナ装置106は、USBスキャナクラスインターフェース108とスイッチ221とを備えている。判定アプリケーション224によって、デバイスドライバがコンピュータ100にインストールされていることが確認されると、スイッチ221は判定結果に基づいて、スキャナ装置106を外部記憶装置(USBマスストレージクラスインターフェース)から画像処理部(USBスキャナクラスインターフェース108)へと切り替えるよう制御される。なお、デバイスドライバがコンピュータ100にインストールされていないことが判定されると、スイッチ221は、スキャナ装置106を外部記憶装置(USBマスストレージクラスインターフェース)から画像処理部(USBスキャナクラスインターフェース108)へと切り替える制御はされない。すなわち、スキャナ装置106は、そのまま外部記憶装置としてコンピュータ100によって認識されたままとなる。
または、デバイスドライバがコンピュータ100にインストールされていないことが判定された際に、デフォルトモードで外部記憶装置(USBマスストレージクラスインターフェース)として認識された状態を、一旦解消した後、再度外部記憶装置(USBマスストレージクラスインターフェース)と認識させてもよい。
コンピュータとスキャナ装置とのハードウエアブロックに関してはすでに図2に示したとおりなので、ここでは説明を省略する。
ところで、本実施形態では、スキャナ装置106は外部記憶装置としてOSに認識されたままの状態で、画像を読み取ることができる。すなわち、キャプチャアプリケーション210をコンピュータ100のRAM124にロードして実行すると、CPU121は、キャプチャアプリケーション210にしたがって各種の制御命令を制御ファイル204に書き込む。スキャナ装置106のCPU110は、制御ファイル204への書き込みアクセスを監視し、制御ファイル204にコマンドが書き込まれると、そのコマンドを実行する。CPU110は、コマンドにしたがって読み取った画像の画像データを制御ファイル204に書き込む。CPU121は、キャプチャアプリケーション210にしたがって制御ファイル204から画像データを抽出し、画像データを結合して画像ファイルを作成する。すなわち、制御ファイル204を介在させることで、スキャナ装置106をUSBメモリ等としてOSに認識させたまま、画像を読み取ることが可能となる。
コンピュータ100上のオペレーティングシステム101は、USBインターフェース104にUSBケーブル105を介して何らかの装置が接続された場合、USBマスストレージクラスインターフェースを有する装置としてアクセスし、装置の種類を確定する。ここで、スキャナ装置106には、オペレーティングシステム101にマスストレージデバイスクラスとして認識してもらうためのUSBマスストレージクラスインターフェース206と、USBスキャナクラスデバイスとして認識してもらうためにUSBスキャナクラスインターフェース108とを有している。
このように、これらの2つのUSBクラスインターフェースは、スイッチ221によって択一的に切り替えられる。なお、スイッチ221は、第3の制御モードとして、2つのクラスのインターフェースを同時に有効にするように切り替えてもよい。スイッチ221は、ソフトウエアで実現されてもよいし、電気的に切り替え可能な電子スイッチを用いてハードウエアによって実現されてよい。また、ソフトウエア及びハードウエアの両方も用いてスイッチ221が実現されてもよい。
スキャナ装置106には、コンピュータ100からスキャナ装置106で画像読み取りを行うためのオペレーティングシステム101上で動作するキャプチャアプリケーション210と、キャプチャアプリケーション222およびUSBスキャナドライバ102がコンピュータ100に予めインストールされているかどうか判定する判定アプリケーション224が予め保存してある。また、スキャナ装置106をコンピュータ100に接続した際に自動実行される、オートランファイル207、スキャナ装置106を制御するための制御ファイル204を予め保存してある。
なお、キャプチャアプリケーション210と判定アプリケーション224とオートランファイル207は、USB CDドライブインターフェース208を介して、制御ファイル204は、USBディスクドライブインターフェース205を介して、コンピュータ100からアクセスできる。
上述したように、オペレーティングシステム101は、CDドライブ内にデータCDが挿入された場合、「autorun.inf」と呼ばれる、CD上のファイルを検出して自動実行する機能を備えている。オートランファイル207は、USB CDドライブインターフェース208を介してアクセスされるため、仮想的にCDが装着されたものとコンピュータ100に認識させることが必要となる。仮想的にデータCDが装着されたことを示す信号をCPU110は、USBインターフェース107を介してコンピュータ100へ出力する。すなわち、CPU110は、コンピュータ100に接続した時点では、CDドライブ内にデータCDが挿入されていない状態であるとコンピュータ100に仮想的に認識させ、直後に、CDが装着されたと仮想的に認識させることで、オートランファイル207が自動実行されるような制御を行うものとする。これにより、オペレーティングシステム101及びCPU121は、データCDが装着されたことを検知し、autorun.infを読み出して解析し、判定アプリケーションを読み出して起動する。
さらに、コンピュータ100は、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210と判定アプリケーション224とオートランファイル207とに対応するテーブルを、ファイルシステム201に関連付けたファイルフォルダ内に形成する。
図21、図22は、コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行うフローのフローチャートである。
コンピュータ100のCPU121は、周辺装置(スキャナ装置106)が接続されたか否かを監視する(ステップS2101)。コンピュータ100のCPU121は、USBマスストレージクラスインターフェースを有する装置としてスキャナ装置106を接続する(ステップS2102)。コンピュータ100は、インターフェースクラス等の情報を周辺装置(スキャナ装置106)から取得する(ステップS2103)。CPU121は、この情報に基づいて、接続された周辺デバイスの種類を認識できる。
周辺デバイスの種類を認識した段階では、スキャナ装置106の切り替えスイッチ221は、USBマスストレージクラスインターフェース206に切り替えられている。そのため、コンピュータ100のCPU121は、スキャナ装置106をUSBマスストレージデバイスと認識する(ステップS2104)。
コンピュータ100のCPU121は、内部の切り替えスイッチ220をUSBマスストレージドライバ202に切り替える(S2105)。スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USB CDドライブインターフェース208とUSBディスクドライブインターフェース205を有している。そのため、オペレーティングシステム101及びCPU121は、接続されたスキャナ装置106をCDドライブとディスクドライブとしてファイルシステムに追加する(ステップS2106)。
オペレーティングシステム101は、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210と判定アプリケーション224とオートランファイル207に対応するテーブルを、ファイルシステム201に関連付けたファイルフォルダ内に形成する。このことによりCPU121は、スキャナ装置106内に格納してある制御ファイル204を、ドライブレター(例:D)を割り当てたディスクドライブ上のファイルとして認識する。また、CPU121は、キャプチャアプリケーション210と判定アプリケーション224とオートランファイル207とを、ドライブレター(例:E)を割り当てたCDドライブ上のファイルとして扱うことができる。
図23は、ドライブレターを割り当てられたCDドライブ(スキャナ)をファイル管理ソフト(エクスプローラ)で開いた様子を示す図である。スキャナ装置106が提供しコンピュータ100からのアクセスが可能なメモリ領域は、フォルダ302に対応している。フォルダ302は、コンピュータ100に接続されたキーボード/マウス125を使用して開くことができる。フォルダ302には、キャプチャアプリケーション210(ファイル名:CaptureApplication.exe)と、判定アプリケーション224(ファイル名:Judge.exe)と、オートランファイル207(ファイル名:Autorun.inf)とが格納されている。
なお、すでに図9に示したように、スキャナ装置106が提供するメモリ領域は、フォルダ303に対応している。フォルダ303はコンピュータ100から読み書き可能なフォルダであり、制御ファイル204(ファイル名:Control.dat)を格納している。
次に、オペレーティングシステム101(CPU121)は、CDドライブ内にデータCDが挿入されたと判定し、スキャナ装置106内にあるオートランファイル(自動実行情報ファイル)207をRAM124にロードして自動的にその内容を調べる処理を起動する(S2107)。オートランファイル207には、判定アプリケーション224を起動するよう記載されている。よって、オペレーティングシステム101は、スキャナ装置106内にある判定アプリケーション224をRAM124に読み込み自動的に起動する(S2108)。なお、判定アプリケーション224は、スキャナ装置106に対応したデバイスドライバ(USBスキャナドライバ102)と、任意のキャプチャアプリケーション(画像編集ソフトウエアなど)との両方がインストール済みであるか否かを判定する(S2109)。これは、どちらか1つでも欠けていれば、画像の読み取りを実行できないからである。なお、簡易的な読取に限ればスキャナドライバだけでも読み取り可能な場合もあり、このような場合はスキャナドライバのインストールの判定だけを行ってもよい。
判定アプリケーション224が、任意のキャプチャアプリケーションおよびUSBスキャナドライバ102の少なくとも一方がインストールされていないと判定すると、判定アプリケーション224は、キャプチャアプリケーション210を起動するための動作を行う(S2110)。すなわち、オペレーティングシステム101及びCPU121は、スキャナ装置106内にあるキャプチャアプリケーション210をRAM124にロードして起動する。CPU121は、スキャナ装置106を外部記憶装置として認識されているため、キャプチャアプリケーション210を直接起動することができる。
コンピュータ100には、ディスプレイ126が接続されており、各種ユーザインターフェースの表示ができる。キャプチャアプリケーション210が起動したときに表示されるユーザインターフェースの一例は、図5に示した通りである。キャプチャアプリケーション210のユーザインターフェースが表示されると、ユーザは、キーボード/マウス125を操作して、スキャン設定を実行する。最後に、スキャンボタン301がキーボード/マウス125を使用してクリックされる。
スキャンボタン301がキーボード/マウス125によりクリックされると、キャプチャアプリケーション210(CPU121)は、スキャン設定を受け付け、スキャナ装置106内の制御ファイル204にスキャン設定を書き込む。さらに、CPU121は、スキャン開始コマンドデータも制御ファイル204に書き込む(ステップS2111)。
スキャナ装置106のCPU110は、制御ファイル204を監視している。そうして、CPU110は、スキャン設定およびスキャン開始コマンドデータが制御ファイル204に書かれたことを検出すると、制御ファイル204を読み込んで、そこに書かれているスキャン設定にしたがって画像読み取り部112を制御し、スキャンを開始する。
スキャナ装置106はスキャンを開始すると、画像読み取り部112で読み取った画像を制御ファイルに書き込む。この制御ファイルは、スキャン設定を可能としている制御ファイルと同一であってもよいし、異なってもよい。
コンピュータ100のCPU121は、画像データが制御ファイル204に書き込まれたか否かを監視する(ステップS2112)。画像データが制御ファイル204に書き込まれたことを検出すると、制御ファイル204から画像データを読み出す(ステップS2113)。CPU121は、指定された画像ファイル(本実施形態では、ファイル名「test1」)を作成し、ハードディスクドライブ122に記憶する(ステップS2114)。
図24は、管理者権限を持つユーザによって、すでに、任意のキャプチャアプリケーション222およびUSBスキャナドライバ102がインストールされているコンピュータ100のソフトウエアブロック図である。
一般に、オペレーティングシステム101には、スキャナ装置106で画像読み取りを行うためのキャプチャアプリケーション222と、スキャナ装置106をUSBで接続するためのUSBスキャナドライバ102とが標準で用意されていない。そのため、一般には、USBスキャナドライバ102と、このUSBスキャナドライバ102を介してスキャナ装置106から画像を入力するためのキャプチャアプリケーション222とをコンピュータ100へインストールする必要がある。
ところが、管理者権限を持たないユーザは、コンピュータ100へキャプチャアプリケーション222やUSBスキャナドライバ102をインストールできないことがある。よって、これらがインストールの制限でインストールされていないときは、ステップS2110ないしS2114が実行される。
一方、管理者権限を有するユーザが、予めコンピュータ100へこれらのソフトウエアをインストールしていることもある。すなわち、この場合は、ステップS2109において、インストール済みと判定され、図22に示したステップS2201に進む。なお、USBマスストレージドライバ202とUSBスキャナドライバ102は、スイッチ220によって択一的に切り替えられる(選択される)ものとする。
図22を参照して具体的な動作について説明する。スキャナ装置106はデフォルトの状態でマスストレージデバイスとして認識されている。キャプチャアプリケーション222およびUSBスキャナドライバ102がインストールされていると判定すると、判定アプリケーション224(CPU121)は、スキャナ装置106に対して、USBスキャナクラスインターフェース108で接続しなおすように指示を送信する(ステップS2201)。スキャナ装置106のCPU110は、インターフェースのクラスの切り替えの指示を受信すると、一度、コンピュータ100への接続状態から切断状態に移行した後、再度、接続状態に移行する。
このとき、オペレーティングシステム101(CPU121)は、USBインターフェース104にて何らかの周辺デバイスの接続を検知する(ステップS2202)。CPU121は、USBマスストレージクラスインターフェースを有する装置としてスキャナ装置106を接続する(S2203)。スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からのアクセスがあると、切り替えスイッチ221を、USBマスストレージクラスインターフェース206からUSBスキャナクラスインターフェース108に切り替える。コンピュータ100にUSBスキャナクラスインターフェース108にアクセスさせる。これによりコンピュータ100は、周辺装置のインターフェースクラス等の情報を取得し(ステップS2204)、接続された周辺デバイスがスキャナデバイスであると認識することができる(ステップS2205)。
一方、CPU121は、判定プログラム(判定アプリケーション)にしたがってスイッチ220を操作し、USBインターフェースドライバ103の接続先をUSBマスストレージドライバ202からUSBスキャナドライバ102へ切り替える(S2206)。
CPU121は、ユーザによる起動指示を受け付け、コンピュータ100にインストールされているキャプチャアプリケーション222を起動する(ステップS2207、S2208)。なお、コンピュータ100には、ディスプレイ126が接続されており、各種ユーザインターフェースの表示ができるものとする。キャプチャアプリケーション222は、図5に示したようなユーザインターフェースであってもよいし、異なるユーザインターフェースであってもよい。ここでは、説明の簡略化のために同一とする。
ユーザは、キャプチャアプリケーション222で、読み取りモード(本実施形態では、白黒)、用紙サイズ(本実施形態では、A4)、解像度(本実施形態では、300dpi)、読み取り面(本実施形態では、両面)をキーボード/マウス125を使用して選択し、保存ファイル名(本実施形態では、test1)をキーボード/マウス125を使用して入力して、スキャンボタン301をキーボード/マウス125でキーの押下あるいはクリックする。
スキャンボタン301がキーボード/マウス125でキーの押下あるいはクリックされると、キャプチャアプリケーション222(CPU121)は、USBスキャナドライバ102からUSBインターフェースドライバ103とUSBインターフェース104を介して、スキャナ装置106へスキャン設定を送信し、さらにスキャン開始コマンドを送信する(ステップS2209)。
スキャナ装置106は、USBインターフェース107からUSBスキャナクラスインターフェースを介して、スキャン設定およびスキャン開始コマンドデータを受信したことを検出すると、設定されたスキャン設定でスキャンを開始する。CPU110は、画像読み取り部112が読み取った画像データをUSBスキャナクラスインターフェース108から送信する。
コンピュータ100のCPU121は、スキャナ装置106が送信する画像データを、USBインターフェース107を介して受信する(ステップS2210、S2211)。キャプチャアプリケーション222(CPU121)は、受信した画像データから、指定されたファイル名(本実施形態では、test1)を付与した画像ファイルを生成して保存する(ステップS2212)。
以上説明したように、本実施形態によれば、スキャナドライバがインストール済みであれば周辺装置を画像処理装置として情報処理装置に認識させ、スキャナドライバがインストールされてないければ周辺装置を情報処理装置により読み書き可能である外部記憶装置として情報処理装置に認識させる。なお、上述したように、画像を読み取るために必要となる複数のソフトウエア(キャプチャアプリケーション及びドライバ)のうち少なくとも1つが未インストールであれば、周辺装置を外部記憶装置として情報処理装置に認識させてもよい。この場合は、スキャナ装置106などの周辺装置を外部記憶装置として使用できるようになる。もちろん、スキャナドライバなど画像を読み取るために必要となるすべての制御用プログラムがインストールされていれば、情報処理装置は、スキャナ装置106をスキャナ装置として認識する。
また、判定プログラム(判定アプリケーション)は自動実行形式のファイルであるため、ユーザは起動を指示する手間を省ける。
なお、本実施形態では、デバイスドライバなど必要な制御用プログラムがインストールされていなければ、スキャナ装置106が記憶しているキャプチャアプリケーション210を起動することで、画像を読み取ることが可能となる。例えば、スキャナドライバなどをインストールするには、オペレーティングシステム101の管理者権限がユーザに要求されることがある。例えば、外出先のPCを利用する際にこのような状況が発生するだろう。本実施形態であれば、スキャナドライバなどのインストールが不要となるため、管理者権限でログインできない制限ユーザや一般ユーザであっても、画像の読み取りを実行できる。
もちろん、管理者権限を持つユーザが、すでに、キャプチャアプリケーション222およびUSBスキャナドライバ102をインストールしているコンピュータ100においては、汎用のキャプチャアプリケーションを利用して本実施形態のスキャナ装置で画像読み取りを行うことができる。
また、スキャナ装置106は、コンピュータ100に接続した際にデフォルトでマスストレージデバイスとして認識される。よって、デバイスドライバがインストールされないことが原因でオペレーティングシステム101が不明なデバイスと認識することを回避できる。オペレーティングシステム101等のドライバインストールウイザードが起動したりすることも回避できる。
なお、本実施形態においては、キャプチャアプリケーション210からスキャンを開始する例を説明した。しかし、スキャナ装置106上にスタートボタン等を配置し、スタートボタンを押下されたことをCPU110が検知すると、スキャンを開始してもよい。その際、キャプチャアプリケーション210(CPU121)は、スキャナ装置106のスタートボタンを、制御ファイル204を介して監視してもよい。この場合は、CPU110がスタートボタンを押下されたことを制御ファイル204に書き込むことになる。
キャプチャアプリケーション210は、スキャナ装置106に制御ファイル204を介してスキャン開始を指示してもよいし、キャプチャアプリケーション210が、制御ファイル204に画像データが生成されたことを検知して、スキャンが開始されたと判断し、画像ファイルをハードディスクドライブに保存しても良い。
また、本実施形態においては、スキャナ装置106の接続時にキャプチャアプリケーション210を起動し、ユーザインターフェースを表示しているが、スキャナ装置106の最初の接続時に、オペレーティングシステム101に常駐してもよい。
また、本実施形態においては、キャプチャアプリケーション210には画像表示機能が無いが、キャプチャアプリケーション210が画像表示機能を備えていても良い。
なお、USB CDドライブインターフェースを持たない場合は、USBディスクドライブインターフェースを介して読み書き可能な領域として認識される領域に、自動実行情報ファイルや判定アプリケーションを格納してもよい。このようにすれば自動実行情報ファイルの記述内容に従って判定アプリケーションの自動起動が可能となる。
<第6の実施形態>
図25は、コンピュータとスキャナ装置とのソフトウエアブロック図である。図1などと共通する部分には、同一の参照番号が付与されている。とりわけ、スキャナ装置106では、キャプチャアプリケーション210、制御ファイル204及びUSBディスクドライブインターフェース205が削除され、代わりに、インストーラ225が採用されている。インストーラ225は、スキャナドライバなど画像を読み取るために必要な制御用プログラムをコンピュータ100へインストールするためのソフトウエアである。必要な制御用プログラムは、例えば、上述したキャプチャアプリケーション222およびUSBスキャナドライバ102である。判定アプリケーション224にしたがってCPU121は、これらの制御用プログラムがインストールされているか否かを判定し、未インストールであればスキャナ装置106からこれらの制御用プログラムをコンピュータ100に送信し、インストールする。CPU121は、インストーラ225と判定アプリケーション224とオートランファイル207とへUSB CDドライブインターフェース208を介してアクセスできる。オートランファイル207は、例えば、autorun.infであり、CPU121に判定アプリケーション224を自動起動させる。判定アプリケーション224は、CPU121にインストーラ225を起動させる。
図26は、コンピュータとスキャナ装置とのソフトウエアブロック図である。図26では、キャプチャアプリケーション222とUSBスキャナドライバ102とがコンピュータ100にインストールされている状態を示している。この場合は、CPU121がスイッチ220をUSBマスストレージドライバ202からUSBスキャナドライバ102へ切り替えるものとする。この切り替えは、判定アプリケーション224の判定結果に依存して実行される。
図27は、第6の実施形態に係る画像読み取りを示したフローチャートである。なお、図21と共通する処理には同一の参照符号を付与することで説明を簡潔にする。ステップS2101ないしステップS2108が実行され、CPU121は、判定アプリケーション224を起動する。
CPU121は、判定アプリケーション224にしたがって、キャプチャアプリケーション222およびUSBスキャナドライバ102がインストールされているか否かを判定する(S2109)。CPU121は、所定のファイル名のファイルを検索したり、レジストリの内容を解析したりすることで、これらのソフトウエアがインストール済みであるか否かを判定する。未インストールであれば、ステップS2710に進み。インストール済みであれば、図22に示したステップS22201に進む。
CPU121は、判定アプリケーション224にしたがって、インストーラ225を起動する(S2710)。インストーラ225は、コンピュータ100に、キャプチャアプリケーション222およびUSBスキャナドライバ102をインストールする(S2711)。インストーラ225には、圧縮された状態でキャプチャアプリケーション222およびUSBスキャナドライバ102を内包している。インストールが完了すると、コンピュータ100の内部状態は、図26に示した通りとなる。その後、図22に示したステップS2201に進む。
なお、キャプチャアプリケーション222およびUSBスキャナドライバ102のうち一部のソフトウエアがコンピュータ100内にインストールされていることがある。この場合、CPU121は、不足しているソフトウエアのみをインストールすることが作業の短縮化の観点から好適であろう。もちろん、インストール済みのソフトウエアを上書きしてインストールしてもよい。
以上説明したように、第6の実施形態によれば、画像を読み取るために必要なソフトウエアがインストールされていなければ、スキャナ装置106からこれらをインストールすることができる。よって、これらのソフトウエアを記憶した専用のCD−ROMを紛失した場合や、元々専用のCD−ROMを製品パッケージに同梱していない場合であっても、スキャナ装置106を使用することが可能となる。また、WEBサイトにこれらのソフトウエアを探しに行く手間も省けるであろう。
上述した第5、第6の実施形態においては、画像読み取り装置を周辺装置の一例として説明した。しかし、本発明の周辺装置は、画像形成装置(プリンタ)であってもよいし、画像読み取り機能と画像形成機能を併せ持つ複合機等であってもよい。この場合、画像処理部は画像形成部に相当し、キャプチャアプリケーションは印刷アプリケーションに相当しよう。
具体的に、CPU121は、印刷アプリケーションにしたがって、周辺装置のメモリ(読み書き可能でドライブレターが割り当てられたディスクドライブ)の制御ファイル204に印刷ジョブのデータを書き込む。周辺装置のCPU110は、制御ファイル204を監視しており、印刷ジョブのデータが書き込まれるとこれを読み出し、画像形成部(プリンタエンジン)に転送する。CPU110は、必要に応じて印刷ジョブのデータを変換(ラスタライズなど)してもよい。これによって、画像形成部が印刷処理を実行する。このように、周辺装置は、画像形成装置であってもよい。
なお、周辺装置のデバイスドライバがコンピュータにインストールされていない場合は、市販の周辺装置では印刷を行うことができない。本実施形態では、CPU121は周辺装置の記憶手段から印刷アプリケーションを起動する。コンピュータのアプリケーションソフトウエア(ワードプロセッサや画像編集ソフトウエアなど)が印刷対象データを汎用形式のファイルとして出力すると、起動された印刷アプリケーションにより、CPU121は、汎用形式のファイルを印刷ジョブのデータに変換し、制御ファイル204へ書き込む。なお、汎用形式のファイルがそのまま周辺装置の記憶手段に書き込まれてもよい。これにより、周辺装置のデバイスドライバをインストールしなくても、周辺装置で印刷を実行できるようになる。
ところで、スキャナ装置106からキャプチャアプリケーション222およびUSBスキャナドライバ102をコンピュータ100にインストールしたときは、これらをCPU121が強制的にアンインストール(削除)してもよい。例えば、スキャナ装置106とコンピュータ100との接続が切断されるなど、周辺装置の取り外しを指示された時点で、CPU121は、キャプチャアプリケーション222およびUSBスキャナドライバ102を削除する。あるいは、ユーザのスキャン作業が終了したら、CPU121は、これらを削除しても良い。この場合、判定アプリケーション224は常駐しており、CPU121は判定アプリケーション224にしたがってスキャナ装置106が取り外されたか否かや、キャプチャアプリケーション222が終了したか否かを監視する。
また、キャプチャアプリケーション222およびUSBスキャナドライバ102がコンピュータ100内にインストールされている場合に、CPU121は、スキャナ装置106内に保持されさているソフトウエアモジュール類のバージョンとインストール済みのフトウエアモジュール類のバージョンとを比較してもよい。そして、スキャナ装置106に記憶されているフトウエアモジュール類のバージョンが相対的に新しい場合に限り、これらをコンピュータ100にインストールしてもよい。
また、本実施形態においては、RAM203の制御ファイル204にスキャン設定を書き込んでいるため、設定が保存されない。しかし、スキャナ装置106内で、設定されたスキャン設定を不図示の不揮発メモリ等に記憶しておいても良い。また、その設定は、オペレーティングシステム101のユーザ毎に、記憶しておいても良い。
また、上記2つの実施形態においては、マイクロソフト(登録商標)ウインドウズオペレーティングシステム上での動作を例にとって説明した。しかしこれは一例にすぎない。本発明は、アップル社のオペレーティングシステムやリナックスオペレーティングシステム等、その他のオペレーティングシステムにも適用できる技術思想だからである。
なお、上述した実施形態では、コンピュータ100のオペレーティングシステム101によりautorun.infに記述されたソフトウエアを実行させるために読み書き可能な外部記憶装置として認識させる際に、CD−RドライブやCD−RWドライブとして認識させる技術を用いたが、DVD−RW等の規格のDVDドライブやブルーレイ規格のドライブとして認識されるようにしても良い。
<第7の実施形態>
上述したいくつかの実施形態は、デバイスドライバやソフトウエアをコンピュータにインストールすることなく、画像読取装置を利用可能とする発明であった。すなわち、画像読取装置を外部記憶装置として情報処理装置に認識させ、この外部記憶装置に画像ファイルを書き込み、情報処理装置がこの画像ファイルを読み出す。これは、情報処理装置を制御するオペレーティングシステム(OS)は、画像読取装置のデバイスドライバを有していないが、外部記憶装置のデバイスドライバであれば有している性質を利用した発明である。
しかし、画像ファイルのサイズによって、画像読取装置が備える記憶装置に例えば1ページの画像ファイルの全体を格納できないことが予想される。この場合、画像読取装置は、極めて小さな画像ファイルしか情報処理装置に転送できなくなってしまう。すなわち、画像読取装置の能力を十分に生かしきれないおそれがある。
そこで、第7の実施形態は、例えば、画像読取装置のデバイスドライバをコンピュータにインストールすることなく、画像読取装置により比較的に大きな画像も読取可能とすることを目的とする。
第7の実施形態に係る、汎用情報処理装置として例示したコンピュータと、画像読取装置としてのスキャナとのソフトウエアブロックは、図1に記載した通りである。これらのハードウエアブロックは、図2に記載した通りである。
図2によれば、スキャナ装置106は、CPU110、ROM127(ソフトウエア記憶手段)、RAM203(ファイル記憶手段)、画像読み取り部112、USBコントローラ128、USBインターフェース107を備えている。スキャナ装置106に電力が投入されると、CPU110は、ファームウエアをROM127から読み出して起動する。とりわけ、ROM127は、画像読取装置を使用するために情報処理装置で実行されるソフトウエアを記憶したソフトウエア記憶手段の一例である。また、RAM203は制御ファイル等を記憶するファイル記憶手段の一例である。なお、ROM127やRAM203は、フラッシュメモリやEEPROMなどの不揮発性メモリによって実現されてもよい。また、1つの不揮発性メモリによってROM127とRAM203が実現されてもよい。なお、RAM203には、画像読み取り部によって取得された画像データを一時的に格納するためのバッファ領域が確保される。
コンピュータ100にスキャナ装置106が接続されると、CPU121は、予めインストールされている標準のUSBマスストレージドライバ202を起動する。また、スキャナ装置106は、USBマスストレージクラスインターフェース206を有している。そのため、コンピュータ100にスキャナ装置106を接続すると、USBマスストレージクラスインターフェース206は、自己がUSBマスストレージクラスインターフェースであることを示す識別情報を送信する。よって、CPU121及びオペレーティングシステム101は、スキャナ装置106をマスストレージデバイスとして認識する。さらに、CPU121及びオペレーティングシステム101は、スキャナ装置106のROM127やRAM203を外部記憶装置としてアクセスする。すなわち、スキャナ装置106は、よく知られたUSBメモリと同等の動作をすることになる。オペレーティングシステム101は、使用されていないドライブレター(D:やE:など)をスキャナ装置106に割り当てることで、スキャナ装置106はドライブの1つとなる。
図28は、コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行う処理のフローチャートである。
コンピュータ100のCPU121は、スキャナ装置106が接続されたか否かを監視する(ステップS2801)。CPU121は、USBマスストレージクラスインターフェースを有する装置としてスキャナ装置106を接続する(ステップS2802)。
CPU121は、インターフェースクラス等の情報をスキャナ装置106から取得する(ステップS2803)。この情報により接続された周辺装置の種類が認識できる。
上述したようにスキャナ装置106は、USBマスストレージインターフェースを有している。そのため、コンピュータ100にスキャナ装置106が接続されたとき、CPU121は、USBマスストレージデバイスが接続されたと認識する(ステップS2804)。また、スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USBディスクドライブインターフェース205を有している。そのため、CPU121は、接続されたスキャナ装置106をディスクドライブとして認識する。このように、USBマスストレージクラスインターフェース206は、画像読取装置を情報処理装置の外部記憶装置として情報処理装置に認識させるための認識制御手段の一例である。
オペレーティングシステム101は、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210に対応するテーブルを、ファイルシステム201に関連付けたファイルフォルダ内に形成する。このことによりCPU121は、スキャナ装置106内に格納してある制御ファイル204とキャプチャアプリケーション210を、ドライブレターを割り当てたディスクドライブ上のファイルとして扱うことができる(ステップS2805)。これは、スキャナ装置106が、OSによってドライブレターを割り当てたディスクドライブとして認識されているからである。
ドライブレターを割り当てられたディスクドライブ(スキャナ)をファイル管理ソフト(エクスプローラ)で開いた様子は、すでに図4に示したとおりである。
CPU121は、フォルダ300内のキャプチャアプリケーション210を起動するための指示が入力されたか否かを監視する(ステップS2806)。この指示は、キーボード/マウス125から入力されてもよいし、フォルダ300に格納されている不図示のautorun.infによって指示されてもよい。例えば、マイクロソフト(登録商標)ウインドウズオペレーティングシステムにおいては、CDドライブ内にCD−ROMが挿入されると、「autorun.inf」と呼ばれる、CD−ROM上のファイルを検出し、「autorun.inf」内で自動実行することが指定されたコマンドを実行する。また、マイクロソフト(登録商標)ウインドウズオペレーティングシステムのあるバージョンにおいては、USBディスクドライブ内に「autorun.inf」という名称のファイルが存在すると、オペレーティングシステムはその内部に記述されたコマンドを自動実行する。すなわち、「autorun.inf」内に自動実行させたい実行ファイル名を記述しておけば、利用者にキーボード/マウス125を操作させることなく自動的にコンピュータ100に実行ファイルを起動させることも可能である。よって、コマンドファイルとして上述のCaptureApplication.exeがautorun.inf内で記述されていることになる。キャプチャアプリケーション210を起動するための指示が入力されると、CPU121は、スキャナ装置106のROM127に記憶されているキャプチャアプリケーション210を読み出し、RAM124にロードして起動する(ステップS2807)。このように、外部記憶装置として認識された画像読取装置のソフトウエア記憶手段からソフトウエアが情報処理装置によって実行される。
上記autorun.inf内で記述されている、実行が指定されたコマンドファイルはCaptureApplication.exeよりも簡単な機能のautorun.exe等のプログラムであってもよい。また、コマンドファイルとして記述されたプログラムは、メモリ上のファイルの受け渡しで画像読取を可能とするドライバプログラムの機能を、少なくとも含んでいればよい。
コンピュータ100は、ディスプレイ126を接続しており、各種ユーザインターフェースをディスプレイ126に表示する。キャプチャアプリケーション210が起動したときに表示されるユーザインターフェースの一例は、すでに図5に示した通りである。
図5に示したスキャンボタン301がキーボード/マウス125によりクリックされたと判断すると(ステップS2807a)、キャプチャアプリケーション210(CPU121)は、スキャン設定を受け付け、スキャナ装置106内の制御ファイル204にスキャン設定を書き込むことでスキャナ装置106へ送信が行われる。さらに、CPU121は、スキャン開始コマンドも制御ファイル204に書き込む(ステップS2808)。なお、スキャン設定は、スキャン開始コマンドに添付されて転送されるデータであってもよい。
スキャナ装置106のCPU110は、制御ファイル204が更新されたか否かを監視している。制御ファイル204が更新されると、CPU110は、制御ファイル204を解析し、制御ファイル204に含まれているコマンドを実行する。例えば、CPU110は、スキャン設定およびスキャン開始コマンドなどが制御ファイル204に書かれたことを検出すると、制御ファイル204に書かれているスキャン設定にしたがって画像読み取り部112を制御し、スキャンを開始する。このように、CPU110は、ファイル記憶手段に書き込まれた制御ファイルを解析し、制御ファイルに含まれているコマンドを実行する実行手段の一例である。
スキャナ装置106のCPU110は、上記のように制御ファイル204に含まれているコマンドを実行するとともに、コマンドを受け付けたことを示すレスポンス情報を制御ファイル204または他の特定のファイルに書き込むようにしてもよい。このようにすることで、制御ファイル204または上述した他の特定のファイル等の定期的なポーリングを行っているコンピュータ100へのレスポンス情報の送信と等価な働きを実行することができる。
スキャナ装置106はスキャンを開始すると、画像読み取り部112で読み取った画像データを制御ファイルに書き込む。この制御ファイルは、スキャン設定やコマンドが書き込まれている制御ファイル204と同一であってもよいし、異なってもよい。ここでは、説明の便宜上、両者は同一であるものとする。又は制御ファイルではなく画像データを転送するための他のファイルを別途用意してもよい。なお、レスポンス情報や画像データを制御ファイル204または他の特定のファイルに書き込んでいる間は、この制御ファイル204または当該特定のファイルの読出しはブロックされる。
コンピュータ100のCPU121は、画像データが制御ファイル204に書き込まれたか否かを監視する(ステップS2809)。画像データが制御ファイル204に書き込まれたことを検出すると、制御ファイル204から画像データを読み出す(ステップS2810)。CPU121は、指定された画像ファイル(本実施形態では、ファイル名「test1」)を作成し、ハードディスクドライブ122に記憶する(ステップS2811)。
ところで、1枚の画像あたりのデータサイズが、RAM203に確保しているバッファのサイズよりも大きいことがある。これは、原稿のサイズが大きかったり、画像圧縮率が小さかったりすると、発生しやすい。なお、バッファは、RAM203以外の不図示のメモリに確保されてもよい。
そこで、本実施形態では、CPU110は、バッファの記憶可能容量を超える画像データについて、この画像データのサイズより小さなサイズの部分画像データごとに、読取と制御ファイル204への格納とを実行する。このように、部分画像データは、例えば1ページの画像の全体を表す全体画像データに対する部分的な画像データである。
CPU110は、原稿から読み取った部分画像データによってバッファが満杯になると、その旨を示すステータスデータを制御ファイル204に書き込む。また、CPU110は、部分画像データを制御ファイル204に保存する。このように、CPU110は、バッファに格納された部分画像データを制御ファイルに保存する保存手段の一例である。
コンピュータ100のCPU121は、制御ファイル204の一部を読み出し、満杯になったことを示すステータスデータが格納されているか否かを判定する。満杯になったことを示すステータスデータが格納されていれば、部分画像データの転送が可能となったことを意味する。よって、CPU121は、制御ファイル204から部分画像データを読み出し、RAM124に格納するとともに、制御ファイル204から部分画像データを削除する。このように、ステータスデータを中に含む制御ファイルは、部分画像データの転送が可能となったことを通知するための通知手段の一例である。なお、通知手段は、制御ソフトウエアを実行する情報処理装置によって制御ファイルにコマンドが書き込まれてから、実行手段によって制御ファイル又は他のファイルへ部分画像データの書き込みが完了するまで、情報処理装置による制御ファイル又は他のファイルの読み出し要求に応答しないようにしてもよい。この場合、情報処理装置は、画像読み取り装置が制御ファイル等の読取に応答したことをもって、部分画像データの転送が可能となったことを認識すると同時に、部分画像データの読み出しを実行し完了する。
スキャナ装置106のCPU110は、制御ファイル204から部分画像データが削除されると、中断されていた画像の読取を再開する。CPU110は、原稿から読み取った新たな部分画像データによってバッファが満杯になると、その旨を示すステータスデータを制御ファイル204に書き込む。これらの動作は、1枚の原稿についての画像の読取が完了するまで、繰り返し実行される。1枚の原稿についての画像の読取が完了すると、CPU110は、画像読取の完了を示すステータスデータを制御ファイル204に書き込む。
コンピュータ100のCPU121は、制御ファイル204を読み出し、読取完了を示すステータスデータが格納されているか否かを判定する。読取完了を示すステータスデータが格納されていれば、CPU121は、RAM124に格納して置いた一連の部分画像データを合成して、1枚相当の画像データを作成する。なお、CPU121の動作は、スキャナ装置106に保存されているキャプチャアプリケーション210を、コンピュータ100のCPU121で実行することによって実現されている。一方、スキャナ装置106のCPU110の動作は、ファームウエアによって実現されている。
<第8の実施形態>
第8の実施形態に係る、コンピュータと画像読取装置としてのスキャナのソフトウエアブロックは、図6に示した通りである。
第7の実施形態で説明したUSBマスストレージクラスインターフェース206は、複数のUSBマスストレージサブクラスを有することが可能である。そこで、第8の実施形態では、USBディスクドライブインターフェース205とUSB CDドライブインターフェース208といった2つのサブクラスがスキャナ装置106に備えられている。コンピュータ100上のオペレーティングシステム101は、論理的にそれぞれを別デバイスとしてアクセス可能である。すなわち、コンピュータ100のCPU121は、スキャナ装置106を2つのディスクドライブとして認識し、ドライブレターをそれぞれに割り当てる。
より詳細に説明する。コンピュータ100にスキャナ装置106が接続されると、オペレーティングシステム101(CPU121)は、USBインターフェース104にて何らかの周辺デバイスの接続を検知する。そして、CPU121は、USBケーブル105を介して、スキャナ装置106のUSBインターフェース107にアクセスする。
スキャナ装置106のCPU110は、USBインターフェース107にコンピュータ100からアクセスがあると、USBマスストレージクラスインターフェース206にアクセスさせる。このように、オペレーティングシステム101は、スキャナ装置106のUSBマスストレージクラスインターフェース206へアクセスする。これにより、CPU121は、予めオペレーティングシステム101に含まれているUSBマスストレージドライバ202を利用して、USBインターフェースドライバ103とUSBインターフェース104からUSBケーブル105を介してスキャナ装置106にアクセス可能になる。
また、スキャナ装置106は2つのUSBマスストレージサブクラスを有していることから、オペレーティングシステム101は2つのマスストレージクラスデバイスとしてスキャナ装置106を認識する。よって、コンピュータ100のCPU121は、スキャナ装置106のUSBインターフェース107、USBマスストレージクラスインターフェース206、USB CDドライブインターフェース208あるいはUSBディスクドライブインターフェース205を介して、管理者権限を必要としないアクセス方法でスキャナ装置106にアクセスできる。
また、スキャナ装置106には、オートランファイル207と、キャプチャアプリケーション210と、制御ファイル204とが予め保存されている。オートランファイル207は、上述したautorun.infなどである。
なお、コンピュータ100のCPU121は、USB CDドライブインターフェース208を介して、制御ファイル204は、USBディスクドライブインターフェース205を介して、キャプチャアプリケーション210とオートランファイル207とにアクセスする。
上述したように、オペレーティングシステム101がマイクロソフト(登録商標)ウインドウズであれば、CDドライブ内にデータCDが挿入されると「autorun.inf」を実行する。オートランファイル207は、USB CDドライブインターフェース208を介してアクセスされるため、自動的に起動されることになる。
スキャナ装置106のCPU110は、コンピュータ100に接続した時点で、CDドライブ内にデータCDが挿入されていない状態であるとオペレーティングシステム101に仮想的に認識させる。次に、CPU110は、CDが挿入されたことをオペレーティングシステム101に仮想的に認識させることで、オートランファイル207が自動実行されるように制御する。
さらに、コンピュータ100は、スキャナ装置106に保存してある制御ファイル204とキャプチャアプリケーション210とオートランファイル207に対応するテーブルを、ファイルシステム201に関連付けられたフォルダ内に形成する。
図29は、コンピュータ100からキャプチャアプリケーション210を利用してスキャナ装置106で画像読み取りを行う処理を示したフローチャートである。既に説明した箇所には同一の参照符号を付与することで、説明を簡潔にする。
ステップS2801ないしステップS2804が実行されると、コンピュータ100のCPU121は、マスストレージデバイスが接続された認識する。スキャナ装置106は、USBマスストレージクラスインターフェース206のサブクラスとして、USB CDドライブインターフェース208とUSBディスクドライブインターフェース205を有している。そのため、コンピュータ100のCPU121は、接続されたスキャナ装置106をそれぞれ、CDドライブとディスクドライブとして認識する(ステップS2905)。なお、USBマスストレージクラスインターフェース206は、サブクラスとして、USB CDドライブインターフェース208とUSBディスクドライブインターフェース205を有していることを示す情報をコンピュータ100に通知する。この通知は、USBインターフェースドライバ103を経由してオペレーティングシステム101に伝達される。
オペレーティングシステム101(CPU121)は、ファイルシステム201に関連付けられたファイルフォルダ内に、スキャナ装置106内に保存してある制御ファイル204とキャプチャアプリケーション210とオートランファイル207に対応するテーブルを形成する。そのため、CPU121は、スキャナ装置106内に保存してある制御ファイル204をディスクドライブ上のファイルとして認識する。また、CPU121は、キャプチャアプリケーション210とオートランファイル207をCDドライブ上のファイルとして認識する。
CDドライブとして認識されているメモリ領域に対応したフォルダの一例は、すでに図8に示した通りである。すなわち、スキャナ装置106のROMやRAMのうち、CDドライブとして認識されているメモリ領域がフォルダ302としてコンピュータ100には認識される。よって、フォルダ302に、キャプチャアプリケーション210とオートランファイル207が格納されているように見える。
ディスクドライブとして認識されているメモリ領域に対応したフォルダの一例は、すでに図9に示した通りである。スキャナ装置106のROMやRAMのうち、ディスクドライブとして認識されているメモリ領域がフォルダ303としてコンピュータ100には認識される。よって、フォルダ303に、制御ファイル204が格納されているように見える。
ユーザは、コンピュータ100に接続されたキーボード/マウス125を使用して、図8に示すようなフォルダ302と図9に示すようなフォルダ303を開くことができる。
オペレーティングシステム101(CPU121)は、CDドライブ内にデータCDが挿入されたと判断すると、オートランファイル207を実行する(ステップS2906)。オートランファイル207は、予め、キャプチャアプリケーション210を起動するように記述されている。そのため、CPU121は、オートランファイル207の記述を解釈して、キャプチャアプリケーション210を起動する(ステップS2907)。ユーザの関与は不要であるため、ユーザには、キャプチャアプリケーション210が自動的に起動されたように見える。
その後、上述したステップS2807aないしS2811が実行される。
以上、第7及び第8の実施形態で説明したように、本発明では、コンピュータ100にデバイスドライバやアプリケーションなどのソフトウエアをインストールすることなく、スキャナ装置106で画像読み取りを行うことができるようになる。例えば、管理者権限でオペレーティングシステム101にログインできないユーザや、外出先のパーソナルコンピュータを使用するユーザであっても、容易に、画像読み取りを行うことができる。
なお、上記の第7及び第8の実施形態においては、キャプチャアプリケーション210からスキャンを開始する例を説明した。しかし、スキャナ装置106上にスタートボタン等を配置し、スタートボタンを押下されたことをCPU110が検知すると、スキャンを開始してもよい。その際、キャプチャアプリケーション210(CPU121)は、スキャナ装置106のスタートボタンを、制御ファイル204を介して監視してもよい。この場合は、CPU110がスタートボタンを押下されたことを制御ファイル204に書き込むことになる。
キャプチャアプリケーション210は、スキャナ装置106に制御ファイル204を介してスキャン開始を指示してもよいし、キャプチャアプリケーション210が、制御ファイル204に画像データが生成されたことを検知して、スキャンが開始されたと判断し、画像ファイルをハードディスクドライブに保存しても良い。
また、上記第7及び第8の実施形態においては、キャプチャアプリケーション210を起動し、ユーザインターフェースを表示しているが、スキャナ装置106の接続時に、マイクロソフト(登録商標)ウインドウズ等のオペレーティングシステム101に常駐してもよい。
また、上記第7及び第8の実施形態においては、キャプチャアプリケーション210には画像表示機能が無いが、キャプチャアプリケーション210が画像表示機能を備えていても良い。
また、上記第7及び第8の実施形態においては、RAM203の制御ファイル204にスキャン設定を書き込んでいるため、設定が保存されない。しかし、スキャナ装置106内で、設定されたスキャン設定を不図示の不揮発メモリ等に記憶しておいても良い。また、その設定は、オペレーティングシステム101のユーザ毎に、記憶しておいても良い。
また、上記第7及び第8の実施形態においては、マイクロソフト(登録商標)ウインドウズオペレーティングシステム上での動作を例にとって説明した。しかしこれは一例にすぎない。本発明は、アップル社のオペレーティングシステムやリナックスオペレーティングシステム等、その他のオペレーティングシステムにも適用できる技術思想だからである。
<第9の実施形態>
スキャナ装置では、コンピュータにインストールされたスキャナドライバにより直接的に制御されて画像の読取を実行する。そのため、スキャナ装置から逐次画像データがコンピュータに転送されることになる。しかし、本実施形態のスキャナ装置では、スキャナドライバを介さずにマスストレージドライバを介して画像データを転送するため、スキャナ装置が有しているバッファのサイズが画像データのサイズを制限することになる。
そこで、本実施形態では、スキャナ装置106のバッファのサイズよりも大きな画像データを分割して格納する方法について詳細に説明する。すなわち、上述したステップS2808ないしS2811に関して、より詳細に説明する。
[コマンドの送出/受け付け]
図30は、画像データの分割転送の一例として、コンピュータ側及びスキャナ装置側で実行される通信プロトコルを示したフローチャートである。以下で説明するコンピュータ側の処理は、スキャナ装置106側に記憶されたキャプチャアプリケーション210をコンピュータ100のCPU121が実行することによってCPU121が行うものとする。すなわち、ソフトウエア上の主体は、キャプチャアプリケーション210であり、ハードウエア上の主体はCPU121である。なお、コンピュータ100のCPU121は、キャプチャアプリケーション210にしたがってRAM124にバッファAを確保しておくものとする。一方、以下で説明するスキャナ装置側の処理は、ファームウエアにしたがってCPU110が実行するものとする。すなわち、ソフトウエア上の主体は、ファームウエアであり、ハードウエア上の主体はCPU110である。なお、スキャナ装置106のCPU110は、ファームウエアにしたがってRAM203にバッファBを確保しておくものとする。
ステップS3001で、コンピュータ100のCPU121は、キャプチャアプリケーション210にしたがって、バッファAに制御コマンドを書き込む。制御コマンドは、例えば、SCSIコマンドのフォーマットにしたがって独自に定義したデータ列である。制御コマンドとして、例えば、画像取得のために必要なスキャン解像度等を設定するSet Windowコマンドや、画像取得の開始を指示するScanコマンド、画像データを読み込むときに使用するRead Imageコマンド等を予め定義しておく。予め定義された制御コマンドとその意味との関係を示す制御コマンド定義情報は、キャプチャアプリケーション210およびスキャナ装置106の双方に保持されているものとする。制御コマンド定義情報には、各コマンドを識別するための固有のコマンドデータ列と、コマンドデータ列の長さを示す整数値と、コマンドにデータを添付して転送を行う必要性を示す真偽値と、データ転送の方向(スキャナ装置106からキャプチャアプリケーション210へ転送するものか、あるいはその逆か)を示す情報とを含む。
ステップS3002で、CPU121は、制御コマンドにデータを添付して送信する必要があるか否かを判定する。CPU121は、バッファAに書き込まれた制御コマンドをキーとしてコマンド定義情報を検索し、抽出した真偽値からデータを添付すべきか否かを判定する。データを添付すべき制御コマンドであれば、ステップS3003に進む。一方、データを添付すべき制御コマンドでなければ、ステップS3004に進む。
ステップS3003で、CPU121は、既にステップS3001で書き込まれている制御コマンドに続けてデータをバッファAに追記する。
ステップS3004で、CPU121は、スキャナ装置106に記憶されている制御ファイル204にバッファAの内容を書き込む。なお、本実施形態では、キャプチャアプリケーション210から制御ファイル204に対して読み書きを開始するときに、マイクロソフトウインドウズ(登録商標)によるファイルキャッシュ機能が働くと正常に通信を行うことができないおそれがある。そこで、CPU121は、ファイルキャッシュ機能を停止する。
スキャナ装置106は、ステップS3004によって制御ファイル204が更新されるまで監視しつつ待機している。ステップS3050で、スキャナ装置106のCPU110は、制御ファイル204が更新されたか否かを監視する。制御ファイル204の更新の検知方法は、例えば、CPU110は、スキャナ装置106のRAM203に保持しているファイルシステムのアドレステーブルから制御ファイル204が存在しているセクタアドレスを参照する。CPU110は、コンピュータ100からこのセクタアドレスに対するデータ書き込みが行われ、その終了を検知したとき、制御ファイル204が更新されたと判定する。他の例としては、CPU110が、制御ファイル204を一定周期で読み込み、制御ファイル204の内容、サイズ、日付等に変化があったときに、制御ファイル204が更新されたと判定する。制御ファイルの更新検知処理は、キャプチャアプリケーション210による制御ファイル204への書き込み及び読み出し処理と重複しないように、排他制御される。
ステップS3051で、CPU110は、制御ファイル204の先頭から、各制御コマンドに対応したサイズだけコマンドデータ列を読み出す。CPU110は、コマンド定義情報を参照し、制御ファイル204に書かれている制御コマンドの長さを取得して、コマンドデータ列を読み出す。
ステップS3052で、CPU110は、制御ファイル204を解析し、受け付けた制御コマンドにデータが添付されているか否かを判定する。データが添付されていなければ、ステップS3054に進む。データが添付されていれば、ステップS3053に進む。
ステップS3053で、CPU110は、制御コマンドの後端部分から添付データを読み込む。読み出す添付データの長さは、前述のコマンド定義情報を参照して取得する。
ステップS3054で、スキャナ装置106は、制御ファイル204から抽出した制御コマンドを実行する。例えば、制御コマンドが前述のSet Windowコマンドであった場合、CPU110は、スキャナ装置106のRAM203にスキャン設定を保持するための領域を確保し、そこに受信した添付データを元にスキャン設定を書き込む。例えば、制御コマンドがScanコマンドであった場合、CPU110は、RAM203内部でスキャン設定を保持している領域を参照して画像読み取り部112等を制御し、取得した画像データをRAM203に別途確保したスキャンバッファに保存する。
ステップS3055で、CPU110は、制御ファイル204から抽出した制御コマンドが添付データの送信の必要なコマンドであるか否かを判別する。この判別は制御コマンド定義情報を参照して実行される。データの送信が必要なコマンドであった場合、ステップS3056に進む。データの送信が必要でないコマンドであった場合、ステップS3057に進む。
ステップS3056で、CPU110は、抽出したコマンドに対応したステータスデータとともに、当該コマンドに対応したデータをバッファBに書き込む。例えば、制御コマンドが、Read Imageコマンドであった場合、CPU110は、画像読み取り部112等を制御して取得した画像データのうち、キャプチャアプリケーション210が指定したサイズだけ抽出し、その画像データをバッファBに書き込む。その後、ステップS3058に進む。
ステップS3057で、CPU110は、抽出したコマンドに対応したステータス情報をバッファBに書き込む。その後、ステップS3058に進む。ステータス情報は、受信した制御コマンドの実行状態を表す情報である。ステータス情報には、例えば、制御コマンドに対応する処理が正常に行われたことを表すGOOD STATUSや、スキャナ装置106が他の処理を実行中であり、コマンドを受け付けることができないことを表すBUSYなどがある。もし、ステップS3056で、バッファBに添付データが書き込まれた場合についても同様のステータス情報を、CPU110は、この添付データの末尾等に追加する。
CPU110は、キャプチャアプリケーション210に送信すべきデータのバッファBへの書き込みが完了すると、ステップS3058で、制御ファイル204にバッファBの内容を書き込む。なお、スキャナ装置106による制御ファイル204へのデータ書き込み処理は、キャプチャアプリケーション210による制御ファイル204への書き込み及び読み出し処理と重複しないように、排他制御される。このとき制御ファイル204内の制御コマンドは変更しないものとするが、変更してもよい。
スキャナ装置106は、ステップS3058の処理が終了したら、ステップS3050に戻る。
ステップS3005で、コンピュータのCPU121は、制御ファイル204を監視しつつ、制御ファイル204が更新されるまで待機する。制御ファイルの監視および更新の検知方法は、例えば、制御ファイル204のうち、添付データ以外の部分の内容を一定周期で繰り返し読み込み、RAM124に保存されている制御ファイルの内容と比較する。現在の制御ファイルと、前回の制御ファイルとが不一致であれば、CPU121は、制御ファイル204が更新されたと判定する。また、例えば、他の通知用ファイルを読み込んで、その内容により制御ファイル204の更新を判定するようにしてもよい。また、例えば、スキャナ装置106は、ステップS3050で制御コマンドの更新を検知してから、ステップS3058で制御ファイル204を更新するまでの間に、コンピュータのCPU121が制御ファイル204を読み込もうとしたときには、その処理をブロックし、応答を返さないようにUSBディスクドライブインターフェース205を制御してもよい。この場合、コンピュータのCPU121は、制御ファイル204に対して読み込み処理を実行し、その処理が終了したことを検知すると、制御ファイル204が更新されたと判定する。更新が判定され読み込まれた制御ファイル204の内容は、RAM124に保持される。
また、コマンドを受け付けたことを示すレスポンス情報を制御ファイル204または他の特定のファイルに書き込む場合も、制御ファイル204を更新するまでの間に、コンピュータのCPU121が制御ファイル204または他の特定のファイルを読み込もうとしたときには、読み込み動作をブロックし、応答を返さないようにする。
ステップS3006で、CPU121は、ステップS3004で送信のために制御ファイル204に書き込んだ制御コマンド又は、S3005で制御ファイル204から読み込んだ制御コマンドが添付データの受け取りを必要とするものであるか否かを判別する。この判別は、ステップS3002と同様、前述のコマンド定義情報を参照することで実行される。送信又は、読み込まれた制御コマンドが添付データを受け取るべきものであった場合、ステップS3007に進む。添付データを受け取るべきものでなければ、ステップS3008に進む。
ステップS3007で、CPU121は、制御ファイル204から添付データを読み込む。
ステップS3008で、CPU121は、制御ファイル204からステータス情報を読み込む。添付データが存在する場合は、添付データの後端からステータス情報が抽出される。一方、添付データが存在しない場合には、制御ファイル204の先頭からステータス情報が読み込まれる。
ステップS3009で、CPU121は、ステータス情報から、次に行うべき動作を決定して実行する。例えば、ステータス情報がGOOD STATUSであったなら、CPU121は、引き続き次のコマンドの送出/受け付けを実行する。一方、ステータス情報がBUSY等の異常を示すものであった場合、CPU121は、その要因を取得するコマンドを新たに発行する(ステップS3001)。CPU121は、このコマンドに応答してスキャナ装置106が制御ファイル204に書き込んだ詳細情報を読み出す(S3007、S3008)。CPU121は、この詳細情報にしたがって、ディスプレイ126に要因を通知するためのダイアログボックスを表示する。
[画像読取処理]
図31は、画像読取処理の一例を示すフローチャートである。ここでは、ステップS2810に示した画像データ転送方法(キャプチャアプリケーション210の動作)について説明する。なお、通信プロトコルは、図30に示した通りである。
ステップS3100で、CPU121は、キャプチャアプリケーション210にしたがって、スキャナ装置106に画像取得動作の開始を指示するScanコマンドを発行する。なお、コマンドの発行処理は、ステップS2808やステップS3001などに関して説明した通りである。CPU121は、変数RcvSizeと、変数ImgSizeを初期化する。変数RcvSizeは、スキャナ装置106からこれまでに受信したデータのサイズを表す変数であり、初期化によって0にクリアされる。変数ImgSizeは、受信すべき全画像データのサイズを表す変数であり、ユーザ設定値から算出された画像データサイズが初期化によって代入される。一方、スキャナ装置106のCPU110は、制御ファイル204を通じてScanコマンドを受け付けると、画像読み取り部112を制御して画像読取を開始する。CPU110は、取得した画像データをRAM203に一時的に蓄積する。なお、RAM203の記憶容量には制限があるため、ここでは、受信すべき全画像データのうち一部の画像データのみがRAM203に格納されるものとする。
ステップS3101で、CPU121は、Read Imageコマンドを発行する。スキャナ装置106のCPU110は、制御ファイル204を通じてRead Imageコマンドを受け付けると、RAM203に蓄積されている画像データを、図30の通信プロトコルにしたがって、コンピュータ100が読み出せるように、制御ファイル204に格納する。1つのRead Imageコマンドあたりでコンピュータ100が読み出す画像データのサイズは、例えば、キャプチャアプリケーション210の内部で定数TransSizeとして予め定義されている。定数TransSizeは、予めRAM203の記憶容量よりも小さな値に設定されることになる。CPU121は、Read Imageコマンドのコマンド列に定数TransSizeの値を添付し、スキャナ装置106の制御ファイル204に書き込むことでコマンドの転送を実行する。スキャナ装置106のCPU110は、受け付けたRead Imageコマンドを解析し、コマンド列中に含まれている定数TransSizeに応じたサイズの画像データを、図30の通信プロトコルにしたがって制御ファイル204に書き込む。画像データの書き込みが完了すると、CPU121(キャプチャアプリケーション210)は、制御ファイル204から画像データを読み出し可能となる。CPU121は、前述の通信プロトコルにしたがって制御ファイル204を読み出す。ここで読み出される画像データのサイズは、定数TransSizeにより示されたサイズである。
ステップS3102で、CPU121は、制御ファイル204を通じて受信した画像データをRAM124に確保されたバッファCに書き込む。
図32は、RAM124に確保されたバッファCの一例を示す図である。バッファCの先頭アドレスから変数RcvSize分だけ進んだアドレスから、CPU121は、画像データを書き込む。
例えば、1つ目のReadImageコマンドを発行したときには、まだ画像データを全く受信していないため、変数RcvSizeは0である。1つ目の画像データ1201は、アドレスaを先頭アドレスとしてバッファCに書き込まれる。1つ目の画像データ1202は、アドレスbを先頭アドレスとして書き込まれる。ここで、b=a+TransSizeである。
ステップS3103で、CPU121は、定数TransSizeを、変数RcvSizeに加算する(ステップS3103)。ちなみに、転送回数をnとすれば、RcvSize = n × TransSizeという式が成り立つ。また、ImgSizeをTransSizeで除算して得られる商の値は、総転送回数を示すことになる。
ステップS3104で、CPU121は、1枚の原稿についてすべての画像データの転送が完了したか否かを判定する。具体的に、CPU121は、取得すべき全画像サイズImgSizeと、変数RcvSizeの値を比較し、RcvSizeの値がImgSize以上となったか否かを判定する。ImgSizeがRcvSize未満であれば、まだ、転送は完了していないため、次の画像データをスキャナ装置106の制御ファイル204から読み出すべく、ステップS3101に戻り、ReadImageコマンドを発行する。ImgSizeがRcvSize以上となると、転送が完了したため、ステップS3105に進む。
このように、ステップS3101からステップS3104までの各処理を繰り返し実行することで、大サイズの原稿画像であっても部分画像データに分割して読み出すことができる。
ステップS3105で、CPU121は、バッファCに格納されているすべての部分画像データを結合することで、1枚の原稿画像についての画像ファイルを生成する。
なお、スキャナ装置106から受信した画像データが、画像読み取り部に固有の形式となっている場合もある。この場合、コンピュータ100上のさまざまなアプリケーションで扱いやすくするため、CPU121は、画像データの変換処理を実行してもよい。例えば、受信した画像データをフルカラーBMPファイルとして保存するためには、CPU121は、バッファCに蓄えられた各画像データの色深度を24Bitに変換し、画像ファイルの先頭にビットマップヘッダを付加すればよい。なお、CPU121は、予め図5のユーザインターフェースを通じてユーザにより設定されたファイル名を、完成した画像ファイルに付与し、ハードディスクドライブ122に保存する。
次に、スキャナ装置106の動作について説明する。
図33は、スキャンタスクの一例を示したフローチャートである。図34は、画像転送タスクの一例を示したフローチャートである。制御ファイル204から読み出した制御コマンドが、Scanコマンドであれば、スキャナ装置106では、スキャンタスクと画像転送タスクとが並行して実行される。なお、図中のN、Mは、フラグを識別するための整数型の変数である。
スキャナ装置106のCPU110は、画像読み取り部112が取得した画像データを一時的に保持するための記憶領域である複数のスキャンバッファをRAM203に確保する。各スキャンバッファのサイズは、定数TransSizeに相当する。
図35は、スキャンバッファの一例を示す図である。この図では、2つのスキャンバッファ(0)とスキャンバッファ(1)とが存在する。フラグ(0)は、スキャンバッファ(0)の状態を表す。フラグ(1)は、スキャンバッファ(1)の状態を表す。これらのフラグも2つのスキャンバッファと同時にRAM203の内部に確保される。
はじめに図33を参照してスキャンタスクについて説明する。
ステップS3300で、CPU110は、整数N、スキャンタスクに関する2つのフラグを初期化する。具体的には、Nには0が設定され、スキャンバッファ(0)に対応するフラグ(0)及びスキャンバッファ(1)に対応するフラグ(1)には「空」が設定される。「空」は、フラグ(N)に対応するスキャンバッファに未処理の画像データがないことを表す値である。
ステップS3301で、CPU110は、スキャンバッファ(N)の状態を監視し、スキャンバッファ(N)が空いた状態になるまで待機する(ステップS3301)。すなわち、CPU110は、フラグ(N)の値を参照し、スキャンバッファ(N)が空いたか否かを判定する。スキャンバッファ(N)が空いた状態になると、ステップS3302に進む。
ステップS3302で、CPU110は、フラグ(N)の値を、「取得中」に設定する。「取得中」は、スキャンタスクがフラグ(N)に対応するスキャンバッファに画像データを取得中であることを表す値である。
ステップS3303で、CPU110は、原稿の読取を開始するよう画像読み取り部112に指示し、原稿の走査を開始する。画像読み取り部112は、原稿から読み取った画像データをスキャンバッファ(N)に書き込む。
ステップS3304で、スキャンバッファ(N)への画像データの格納が完了したことを画像読み取り部112が通知すると、CPU110は、フラグ(N)の値を、「取得済」に設定する。「取得済」は、スキャンタスクがフラグ(N)に対応するスキャンバッファに画像データを取得し終えたことを表す値である。
ステップS3305で、CPU110は、スキャンバッファの切り替え処理を実行する。例えば、CPU110は、次のスキャンバッファを識別するための整数Nを、(N+1)%2を演算することで決定する。%は剰余を求める演算記号とし、(N+1)%2は(N+1)を2で割ったときのあまりを求める演算式とする。例えば、現在のスキャンバッファがスキャンバッファ(0)であれば、次はスキャンバッファ(1)となる。(0+1)%2=1。よって、CPU110は、Nを1に変更する。逆に、現在のスキャンバッファがスキャンバッファ(1)であれば、次はスキャンバッファ(0)となる。(1+1)%2=0。よって、CPU110は、Nを0に変更する。
ステップS3306で、CPU110は、画像読み取りの終了がコンピュータ100から指示されているか又は、画像読み取りを終了すべき状態か判定する。例えば、原稿の走査が終了したとき、キャプチャアプリケーション210から原稿取得終了を示すコマンドが発行されたとき、あるいは原稿台に原稿を搭載したスキャナにおいて原稿のジャムが発生したときなどに、画像の読み取りを終了する。ここで、画像の読み取りが終了でなければ、スキャンタスクはステップS3301に戻って、画像の読み取りを継続する。画像の読み取りの終了と判断した場合は、スキャナ装置106のスキャンタスクは処理を終了する。
次に、図34を参照して画像転送タスクについて説明する。
ステップS3400で、CPU110は、フラグを識別するための整数Mを初期化する。具体的には、Mには0が設定される。
ステップS3401で、CPU110は、画像データの取得を指示するReadImageコマンドがコンピュータ100により制御ファイル204に書き込まれたか否かを判定する。ReadImageコマンドの読み出しに成功するまでCPU110は待機する。ReadImageコマンドを受け付けると、ステップS3402に進む。
ステップS3402で、CPU110は、RAM203からフラグ(M)の値を読み出し、その値が「取得済」か否かを判定する。フラグ(M)の値が「取得済」になるまで、CPU110は待機する。フラグ(M)の値が「取得済」になると、画像転送タスクはステップS3403に進む。
ステップS3403で、CPU110は、フラグ(M)の値を、「送信中」に設定する。「送信中」は、フラグ(M)に対応するスキャンバッファに保存された画像データを、キャプチャアプリケーション210が読み出し可能であることを表す値である。
ステップS3404で、CPU110は、スキャンバッファ(M)に含まれるデータを、ReadImageコマンドに対応する処理によって作成された部分画像データとして、キャプチャアプリケーション210が読み出し可能な状態にする。すなわちステップS3404の送信の処理とは、CPU110が、制御ファイル204に画像データを書き込むことを意味する。このように制御ファイル204に書き込まれた部分画像データは、制御ファイル204を監視しているコンピュータ100により、そのつど読み出される。すなわち制御ファイル204を介して画像データの読み出しの指示を受け付けるごとに、制御ファイル204に書き込まれた部分画像データのデータ量を1回の送信データ量としてコンピュータ100への画像データの送信が実行される。また、図31からわかるように、コンピュータ100の受信した部分画像データの合計サイズ(RcvSize)がImgSizeになるまでコンピュータ100はReadImageコマンドを繰り返し発行する。こうして部分画像データはコンピュータ100に繰り返し送信される。なお、1つの部分画像データを送信している間に、下位レベルの通信で例えばUSBディスクドライブの512セクタを単位として、画像データの送信を複数回行う場合もある。すなわち本発明での部分画像データを単位とする画像データの分割送信は、上述した下位レベルの通信での例えば所定数のセクタを単位とする画像データの複数回の送信を意味するものではない。
ステップS3405で、CPU110は、フラグ(M)の値を、「空」に設定する。
ステップS3406で、CPU110は、スキャンバッファの切り替え処理を実行する。例えば、CPU110は、次のスキャンバッファを識別するための整数Mを、(M+1)%2を演算することで決定する。例えば、現在のスキャンバッファがスキャンバッファ(0)であれば、次はスキャンバッファ(1)となる。(0+1)%2=1。よって、CPU110は、Mを1に変更する。逆に、現在のスキャンバッファがスキャンバッファ(1)であれば、次はスキャンバッファ(0)となる。(1+1)%2=0。よって、CPU110は、Mを0に変更する。
ステップS3407で、CPU110は、画像読み取り終了がコンピュータ100から指示されているか否か又は、画像読み取りを終了すべき状態かを判定する。(ステップS3407)。判定条件は、前述のスキャンタスクのステップS3306と同様である。画像読み取りが終了でなければ、画像転送タスクはステップS3401に戻って、画像転送処理を継続する。画像読み取りの終了と判断した場合、スキャナ装置106の画像転送タスクは終了する。
図36は、スキャンバッファの状態遷移の例を示した図である。A1からA7は、画像転送タスクにおける転送速度が、スキャンタスクの画像読み取り速度よりも速い場合の一例である。B1からB7は、画像転送タスクの転送速度が、スキャンタスクの画像読み取り速度よりも遅い場合の一例である。
キャプチャアプリケーション210(CPU121)がScanコマンドを発行すると、スキャンタスク(CPU110)は、ステップS3300〜S3302を順に実行する。そして、スキャンタスクは、ステップS3303で画像読み取り及び画像データのスキャンバッファ(0)への格納を開始する。このとき、すでにReadImageコマンドが発行されていたとすると、画像転送タスク(CPU110)は、ステップS3400、S3401を順に実行し、ステップ1402に進む。画像転送タスクは、ステップS3402でフラグ(0)の値が画像取得終了を表す値に変化するまで待機する(A1、B1)。
次に、スキャンタスクがステップS3303、S3304を終了すると、画像転送タスクは、ステップS3402を抜け、ステップS3403、S3404に示したスキャンバッファ(0)の内容を制御ファイル204に書き込んで、画像データがコンピュータ100により読み出し可能な状態にする(A2、B2)。そして、画像読取終了の指示がなかった場合、スキャンタスクはS3305、S3306、S3301、S3302を順に実行し、画像読み取り及び画像データのスキャンバッファ(1)への格納動作を継続する(A3、B3)。
画像転送タスクにより画像データが制御ファイル204に書き込まれ、かつ制御ファイル204から画像データが、コンピュータ100のキャプチャアプリケーション210により読み込まれる処理の速度等である、画像転送タスクの転送速度が、スキャンタスクの画像読み取り速度よりも速い場合、次のような動作になる。すなわち、スキャンタスクがスキャンバッファ(1)に対して画像データの書き込みを終了する前に、画像転送タスクがスキャンバッファ(0)から制御ファイル204に書き込んだ画像データがコンピュータ100により読み出されて転送し終えることとなる(A4)。画像転送タスクは、スキャンバッファ(0)の画像転送が終了すると、ステップS3405、S3406、S3407、S3401を順に実行する。そしてキャプチャアプリケーション210から2回目のReadImageコマンドが発行されると、画像転送タスクは、ステップS3401の待機状態を抜け、ステップS3402でフラグ(1)の値を参照する。このとき、スキャンタスクによるスキャンバッファ(1)への画像データの格納が終了していなかった場合、画像転送タスクは、これが終了するまで待機する(A5)。スキャンタスクがスキャンバッファ(1)に対する格納動作を終了すると(A6)、画像転送タスクは、S3402の待機状態を抜けて、スキャンバッファ(1)の内容を制御ファイル204に書き込む。すなわち、コンピュータ100のキャプチャアプリケーション210により読み出し可能なように、制御ファイル204に画像データを格納することで、キャプチャアプリケーション210に対して転送する(A7)。
この例のように画像転送タスクの転送速度がスキャンタスクの画像読み取り速度よりも速い場合、上述のフローチャートに従った処理を実装すると、スキャンタスクは画像転送タスクの進捗に応じて適宜待機することになる。スキャナ装置106の画像取得処理速度よりもキャプチャアプリケーション210による画像読み出し動作の速度が上回っていたとしても、スキャナ装置106は、TransSizeごとに原稿の画像データを分割し、滞りなく転送することができる。
逆に、画像転送タスクの転送速度がスキャンタスクの画像読み取り速度よりも遅いこともある。この場合、例えば、キャプチャアプリケーション210の画像データ読み取りが遅いため、画像転送タスクによるスキャンバッファ(0)から制御ファイル204への画像データの格納が終了する前に、スキャンタスクはスキャンバッファ(1)に対する取得した画像データの書き込みを完了することがある(B4)。このとき、スキャンタスクは、ステップS3304、S3305、S3306を順に実行したあと、S3301でフラグ(0)の値を参照し、スキャンバッファ(0)へ画像データの取得を開始しようとする。しかし、この段階ではまだスキャンバッファ(0)から制御ファイル204への画像データの格納が終了していない。よって、スキャンタスクは、スキャンバッファ(0)の画像データの制御ファイル204への格納が終了するまで待機する(B5)。スキャンタスクは、画像データ取得の停止とともに、原稿の走査を一時停止する。その後、画像転送タスクによってスキャンバッファ(0)の画像データの制御ファイル204への格納動作が終了すると(B6)、スキャンタスクは、ステップS3301の待機状態を抜けて、原稿の走査を再開するとともに、画像データをスキャンバッファ(0)に書き込み始める(B7)。
この例のように、画像データのコンピュータ100への転送速度がスキャンタスクの画像読み取り速度よりも遅い場合であっても、上述したフローチャートに従った処理を実装すると、スキャンタスクは、画像転送タスクによる画像転送処理の進捗に併せて、適宜待機することができる。このため、スキャナ装置106の画像取得処理速度よりもコンピュータ100のキャプチャアプリケーション210による画像読み込み動作速度が下回っていたとしても、スキャナ装置106は、原稿の画像データをTransSizeごとに分割し、キャプチャアプリケーション210へ転送することができる。
以上の実施形態により、キャプチャアプリケーション210が制御ファイル204にReadImageコマンドを複数回書き込むことによって、スキャナ装置106は、RAM203の容量を超える大きな原稿画像データを、キャプチャアプリケーションへ転送することができる。
以上説明した第7ないし第9の各実施形態によれば、画像読取装置を情報処理装置の外部記憶装置(例:USBマスストレージクラス)として情報処理装置に認識させることで、画像読取装置のデバイスドライバを情報処理装置にインストールする必要がない。また、小サイズの部分画像データを取得して制御ファイルに格納して読み出し可能な状態にすることで、比較的に大きな画像も読取可能となる。
とりわけ、画像データをより小さな複数の部分画像データごとに読取と転送とを実行することで、バッファのサイズが小さくても大きな画像を転送できるようになる。なお、1枚の原稿の画像データを格納可能な大きなバッファを有する画像読取装置にも、本発明の部分画像データの送信は有効に適用できる。なぜならば、バッファに1枚の原稿の画像データが格納された後に画像データの転送を開始する場合よりも、部分画像データが格納されるごとに送信を行う場合のほうが、画像読取処理のスピードが速くなるためである。
また、制御ファイルを通じて部分データを転送することで、画像読取装置を外部記憶装置として認識させたまま、画像の読み取りを実現できる。
通常、制御ファイルを通じて部分データを転送するには、制御ファイルに部分データが書き込まれたことを情報処理装置に通知する必要がある。定期的に制御ファイルを監視する方法もあるが、監視周期がながければ、遅延が多くなり、監視周期が短すぎれば無駄に情報処理装置の演算能力を消費することになる。そこで、画像読み取り装置は、制御ファイルに部分画像の読み込みを指示するコマンドが書き込まれたことを検知してから、制御ファイルに部分画像データの書き込みが完了するまでの間、情報処理装置が制御ファイルを読み込もうとしたときには、その処理をブロックし、応答を返さないようにUSBインターフェースを制御してもよい。具体的には、画像読み取り装置が制御ファイルに部分画像データを書き込んでいる最中に、情報処理装置のUSBマスストレージドライバから制御ファイルの読み出しを行うコマンドを受信したら、そのデータステージの転送要求に対してNAKパケットを返すようにする。この場合、情報処理装置は、制御ファイルに対して部分画像の読み込みを指示するコマンドを書き込んだ直後から、制御ファイルの読み出しを繰り返し実行し、その処理が終了したことを検知すればよい。このとき情報処理装置は、制御ファイルの読み取り終了を検知することによって制御ファイルが更新されたと認識すると同時に、部分画像データの取得が完了することになる。あるいは、画像読取装置が制御ファイルに部分画像データが書き込まれたことを制御ファイルとは別のファイル又は別の通知手段で情報処理装置に通知するようにしてもよい。具体的には、情報処理装置からTest Unit Readyコマンド、Mode Selectコマンド、または、Start−Stop Unitコマンドを受信すると、画像読取装置は、CHECK CONDITION ステータスを返信すればよい。これにより、ファイルテーブルが参照され、制御ファイルの更新が認識されることになる。
また、USBバスのD+信号とD−信号とをともにゼロに変更することでUSBバスリセットステートに移行してもよい。この場合も、同様に、ファイルテーブルが参照され、制御ファイルの更新が認識されることになる。
<第10の実施形態>
本実施形態の周辺装置である画像処理装置(例:スキャナ、プリンタ及び複合機など)は、画像処理装置(スキャナ、プリンタ及び複合機など)として情報処理装置(PC)に認識させた状態で、情報処理装置にインストールされているドライバから指示を受けて動作する動作モードと、画像処理装置を外部記憶装置として情報処理装置に認識させて、画像データの受け渡しを行う動作モードとを備えている。このような画像処理装置を、どちらのモードで使用するかユーザが簡単に設定可能とすることが望ましい。
そこで、本実施形態の周辺装置である画像処理装置はユーザが手で切り替え可能な手動スイッチを有し、手動スイッチの切り替えに応じて画像処理装置の動作モードが切り替わるようになっている。それとともに、上記のどちらのモードで画像処理装置が動作しているかを情報処理装置において認識可能とするために、情報処理装置に送信する情報の切り替えを、ユーザの手による操作によるスイッチの切り替えに応じて行うようにした。
本実施形態は、例えば図10の等のスキャナ装置106においてソフト的に切り替えが行われるスイッチ221を、ユーザが手の操作で切り替え可能な手動スイッチに置き換えた場合に相当する。または、電気的に制御されるスイッチ221の切り替え状態を制御するための他の手動スイッチを、図10等の装置に追加して設けてもよい。このようにすれば、ユーザがスイッチを手で切り替える簡単な操作だけで、希望する動作モードでスキャナ装置106を動作させることができる。実際の動作モードの切り替えは手動スイッチの切り替え後の電源再投入時やリセット時やUSBケーブルの抜き差しが行われたときに行うようにすることが好適である。
上記手動スイッチを設けた本実施形態において、例えばスキャナ装置106に設けられた不図示のスタートボタン等の操作を行ったとき、手動スイッチの切り替え状態がどうなっているかに応じて、スキャナ装置106の動作を異ならせることが好適である。
例えば、スキャナ装置106を外部記憶装置としてパーソナルコンピュータ100に認識させて画像データの受け渡しを行う動作モードとなるように、手動スイッチの切り替えを行った状態で、パーソナルコンピュータ100に接続されたまま不図示のスタートボタン等の操作を行ったとする。このときに、スキャナ装置106は一旦擬似的にUSB接続が切断された状態に遷移し、その後再度USB接続が行われた状態に遷移する。
USBコネクタに触れることなくこのようなUSBインターフェースの切断と再接続を擬似的に行わせることで、画像処理装置を制御するソフトウエアの再立ち上げができる。例えば、画像処理装置を外部記憶装置として認識した状態で画像読取や画像形成を行った後、一旦情報処理装置(パーソナルコンピュータ)においてキャプチャアプリケーション210等の実行を終了すると、情報処理装置のメモリに画像処理装置(スキャナ装置106)からロードされていたキャプチャアプリケーション210は情報処理装置のメモリから消去される。再度、キャプチャアプリケーション210を起動したい場合に、USBコネクタの抜き差しを行うことは面倒であり、本実施形態では不図示のスタートボタン等(画像処理装置に設けたもの)の操作を行うだけでよい。このようにしてUSBコネクタの抜き差しに伴うキャプチャアプリケーション210の起動又は起動確認ダイアログの表示が可能である。
また、外部記憶装置を取り外す際の決められた操作をユーザが行って、外部記憶装置を安全に取り外し可能な状態となった場合等においても、上記のようなUSBコネクタの擬似的な抜き差しをワンタッチで行わせると効果的である。このようにすると、再度外部記憶装置として情報処理装置に認識させることができる。更にUSBの接続に伴って何らかのオートランプログラムの自動起動を行うような設定がされている場合は、上記スタートボタン等の操作でオートランプログラムを起動できる。
一方、画像処理装置か画像読取装置として情報処理装置に認識されて、情報処理装置からスキャナドライバを用いて制御される動作モードとなるように、手動スイッチの切り替えを行ったとする。このようにしてから不図示のスタートボタン等の操作を行ったとき、情報処理装置にスタートボタン等の操作が行われたことを示す情報を引き渡す。
ところで、画像読取装置を使用して原稿のスキャンを行う場合に、一連のスキャン動作のスキャン条件や、スキャン動作により読み取られた画像データに対して行う画像処理等の内容等を登録した、1つ又は複数のジョブを予め作成しておくことが一般に行われる。
情報処理装置では、画像読取装置からスタートボタン等の操作が行われたことを示す情報を受け取ったとき、ジョブとして登録された一連のスキャン動作等を実行するようにできる。もちろん、ジョブ機能がない場合やジョブが登録されていない場合は、画像読取装置からスタートボタン等の操作が行われたことを示す情報を受け取ったとき、現在の設定やデフォルトの設定に従ってスキャン動作を行ってもよい。なお、登録されているジョブの情報を情報処理装置のHDD等に記憶しておくことが好適であるが、画像読取装置が有する不揮発性メモリ等に記憶してもよい。
以上のようにすることで、画像処理装置の本体の操作ボタンを押す等の簡単な操作で、手動スイッチの切り替え状態に応じて異なる動作を行い画像処理装置の操作が簡単になる。なお、手動スイッチの切り替え後に実際に動作モードが切り替わるタイミングは、電源切断後の再投入時や、USBコネクタの実際の抜き差し時や、不図示のスタートボタン等の操作時の、いずれであっても又はこれら全てであっても本発明に含まれる。
以上説明した各実施形態の任意の構成要素を他の実施形態に追加してもよく、これもまた本発明に含まれる。また、本発明の構成の一部又は全てを1個又は複数個のCPUで実行されるソフトウエアで実現してもよい。
<他の実施形態>
なお、周辺装置からソフトウエアをコンピュータにインストールできるようにしつつ、インストール回数を管理できるようにしてもよい。周辺装置に備えられた記憶手段は、外部周辺機器としての機能を情報処理装置が制御するために使用する制御ソフトウエアモジュールを記憶するとともに、外部記憶装置としても機能する。転送手段は、記憶手段に記憶されている制御ソフトウエアモジュールと同一バージョンの制御ソフトウエアモジュールまたはより新しいバージョンの制御ソフトウエアモジュールのいずれもが情報処理装置にインストールされていないときに、記憶手段に記憶されている制御ソフトウエアモジュールを情報処理装置にインストールするために転送する。管理手段は、制御ソフトウエアモジュールをいずれかの情報処理装置にインストールした回数を管理する。
スキャナ装置106のROMには、判定アプリケーション224と、オートランファイル(自動実行情報ファイル)207が予め保存されている。判定アプリケーションは、パーソナルコンピュータ100のCPU121によって実行され、パーソナルコンピュータ100にUSBスキャナドライバ102がインストールされているかどうかを判断する。オートランファイルは、スキャナ装置106をパーソナルコンピュータ100に接続した際に判定アプリケーションをCPU121に自動実行させるための記述を備えている。
すなわち、CPU121は、オートランファイルの記述内容にしたがって、判定アプリケーション224を起動する。オートランファイルは、記憶手段のうちCDドライブとして認識される記憶領域に記憶されている。よって、判定アプリケーションは、記憶手段のうちCDドライブとして認識される記憶領域に記憶されているAutorun.inf(自動実行情報ファイル)によって自動的に起動されるように記述されているコンピュータプログラムの一例である。判定アプリケーションは、画像読み取りに必要となる制御ソフトウエアモジュールがインストール済みであるかどうかを判定し、インストール済みでなければ、上述した各種のソフトウエアをインストールする。
CPU121は、USBスキャナドライバがインストールされているかどうかを判断する。インストールされているかは、例えば、レジストリを参照することにより判断できる。SBスキャナドライバがインストールされていなければ、CPU121は、インストーラにしたがって、パーソナルコンピュータ100にキャプチャアプリケーションおよびUSBスキャナドライバをスキャナ装置106から読み出してインストールする。
キャプチャアプリケーションおよびUSBスキャナドライバは、CPU110、USBコントローラ128及びUSBインターフェース107によって、ROM127から読み出されて、パーソナルコンピュータ100へと転送される。よって、CPU110、USBコントローラ128及びUSBインターフェース107は、記憶手段に記憶されている制御ソフトウエアモジュールと同一またはより新しいバージョンの制御ソフトウエアモジュールのいずれもが情報処理装置にインストールされていないときに、記憶手段に記憶されている制御ソフトウエアモジュールを情報処理装置にインストールするために転送する転送手段の一例といえよう。
CPU121は、インストール回数カウンタのカウント値を1つ増やす。なお、インストール回数カウンタで残数をカウントしている場合は、残数を1つ減数する。インストール回数カウンタは、例えば、CPU121からアクセス可能な、スキャナ装置106に設けられた不揮発性の記憶領域(SRAMやEEPROMなど)に記憶されたファイルである。また、CPU121は、制御ソフトウエアモジュールをいずれかの情報処理装置にインストールした回数を計数して不揮発性の記憶領域に書き込む回数書き込み手段の一例である。
ところで、最新のドライバでは機能が向上していることが多いため、より最新のドライバがインストールされることが望ましい。そこで、CPU121は、パーソナルコンピュータ100内にインストールされているUSBスキャナドライバのバージョンとスキャナ装置106内にあるUSBスキャナドライバのバージョンとを比較し、前者が後者よりも古いか否かを判定する。古ければ、CPU121は、スキャナ装置106内にあるUSBスキャナドライバをパーソナルコンピュータ100内にインストールする。
ところで、周辺装置からソフトウエアをコンピュータにインストールできるようにしつつ、周辺装置に記憶されているソフトウエアを更新できるようにすれば便利であろう。この課題を解決するために、周辺装置は、情報処理装置の外部記憶装置としての機能と該情報処理装置の外部周辺機器としての機能とを備えている。周辺装置は、外部周辺機器としての機能を情報処理装置が制御するために使用する制御ソフトウエアモジュールを記憶するとともに、外部記憶装置として記憶領域を該情報処理装置に提供する記憶手段と、記憶手段に記憶されている制御ソフトウエアモジュールよりも新しいバージョンの制御ソフトウエアモジュールが情報処理装置に記憶されているときに、情報処理装置から送信される該新しいバージョンの制御ソフトウエアモジュールを受信して、記憶手段に書き込む書き込み手段とを含む。
判定アプリケーション224は、記憶手段に記憶されている制御ソフトウエアモジュールのバージョンと、情報処理装置にインストールされている制御ソフトウエアモジュールのバージョンとを比較する比較手段の一例である。なお、判定アプリケーション224は、制御ソフトウエアモジュールのインストールを制御するコンピュータプログラムの一例である。また、判定アプリケーション224やインストーラ225は、周辺装置を外部記憶装置として認識しているパーソナルコンピュータ(情報処理装置)によって記憶手段から読み出されてRAM124等にロードされ実行されるコンピュータプログラムである。
CPU121は、判定アプリケーション224にしたがって、パーソナルコンピュータに記憶されているUSBスキャナドライバ102のバージョンと、スキャナ装置106に記憶されているUSBスキャナドライバ226のバージョンとを比較し、USBスキャナドライバ102がより新しいか否かを判定する。パーソナルコンピュータにインストールされているUSBスキャナドライバ102がスキャナ装置106に記憶されているUSBスキャナドライバ226より新しければ、CPU121は、判定アプリケーション224にしたがって、パーソナルコンピュータ100のハードディスクドライブ122からUSBスキャナドライバ102を読み出し、スキャナ装置106のROM127に上書きするために転送する。このようにROM127はフラッシュメモリ等を用いて、書き換え可能な構成になっている。スキャナ装置106のCPU110は、USBインターフェース107を介して受信したUSBスキャナドライバ102をROM127に書き込む。このように、CPU110は、記憶手段に記憶されている制御ソフトウエアモジュールよりも新しいバージョンの制御ソフトウエアモジュールが情報処理装置に記憶されているときに、情報処理装置から送信される新しいバージョンの制御ソフトウエアモジュールを受信して、記憶手段に書き込む書き込み手段の一例である。自動更新の対象となる複数の制御ソフトウエアモジュールが存在する場合、ROM127に記憶されたものよりバージョンアップされていると判断された制御ソフトウエアモジュールのみがパーソナルコンピュータ100からスキャナ装置106に送信されてくるので、ROM127に上書きされることになる。すなわち、キャプチャアプリケーションのみが更新されることもあるし、ドライバのみが更新されることもある。なお、CDドライブインタフェースが有効となった状態でソフトウエアの更新ができない場合、CPU121及びCPU110は、CDドライブインタフェースからUSBメモリなどの書き込み可能なマスストレージインターフェースに切り替えることになろう。また、ソフトウエアの更新を可能とするために、読み取り専用のCDドライブとして認識されるのではなく、CD−RやCD−RWドライブ等の読み書き可能なディスク装置に、CD−RやCD−RW等の読み書き可能なディスクが装填されているものとして認識されるように構成しても良い。
なお、USB CDドライブインターフェースを持たない場合は、USBディスクドライブインターフェースを介して読み書き可能な領域として認識される領域に、自動実行情報ファイルや判定アプリケーションを格納してもよい。このようにすれば自動実行情報ファイルの記述内容に従って判定アプリケーションの自動起動が可能となる。
例えば、パーソナルコンピュータ100にインストールされているUSBスキャナドライバ102のバージョンが1.0.5で、スキャナ装置106に記憶されているUSBスキャナドライバ226のバージョンが1.0.4であったと仮定する。この場合は、CPU121は、スキャナ装置106に記憶されている古いUSBスキャナドライバ226をUSBスキャナドライバ102によって上書きする。
さらに、パーソナルコンピュータ側により新しいバージョンのソフトウエアが存在するときは、CPU121は、それを周辺装置に書き込む。よって、インストールされるために周辺装置に格納されているソフトウエアをより新しいものに維持することが可能となる。
上記の実施形態では、USBスキャナドライバのインストールとその更新について説明したが、キャプチャアプリケーションなどの他のソフトに本発明を適用してもよい。
ところで、画像読取装置のデバイスドライバをコンピュータにインストールすることなく画像の読取を実現しつつ、画像読取装置の個別の設定データを持ち運び可能としてもよい。この課題を解決するために、画像読取装置は、画像読取装置を使用するために情報処理装置で実行されるソフトウエアを記憶したソフトウエア記憶手段と、画像読取装置に接続される情報処理装置ごとまたは情報処理装置を使用するユーザごとに、画像の読み取りに適用されるパラメータファイル記憶手段とを備える。ソフトウエアは、情報処理装置に対応したパラメータをファイル記憶手段から読み出してパラメータに応じたコマンドを画像読取装置に送信するコマンド送信手段として、情報処理装置を機能させる。
本発明の画像読取装置は、画像読取装置を使用するために情報処理装置で実行されるソフトウエアを記憶したソフトウエア記憶手段と、画像読取装置に接続される情報処理装置ごとまたは情報処理装置を使用するユーザごとに画像の読み取りに適用されるパラメータファイル記憶手段とを備える。上記ソフトウエアは、情報処理装置に対応したパラメータをファイル記憶手段から読み出してパラメータに応じたコマンドを画像読取装置に送信するコマンド送信手段として、情報処理装置を機能させる。
画像読取装置を使用するユーザごとや画像読取装置が接続されるコンピュータごとの個別の設定データを持ち運び可能となるため、ユーザの設定負担が軽減される。また、本実施形態では、コンピュータごとの設定パラメータおよびユーザごとの設定パラメータの少なくとも一方をスキャナ装置106の内部に格納することを特徴としている。
本実施形態で、ROM127は、不揮発性のメモリであり、コンピュータ100によって情報を書き込むことが可能なメモリである。ROM127には、少なくとも、キャプチャアプリケーション210と設定ファイル212が記憶される。よって、ROM127は、画像読取装置に接続される情報処理装置ごとおよび情報処理装置を使用するユーザごとの少なくとも一方の、画像の読み取りに適用されるパラメータを記憶するファイル記憶手段の一例である。
図5に示したスキャン設定の確認と変更のためのユーザインターフェースには、各種の設定項目に対して現在選択されている内容が表示される。とりわけ、キャプチャアプリケーションを起動した直後に選択されている設定項目の内容は、CPU121が設定ファイルから読み出した内容に基づいて選択したものである。これらの読取設定の内容は、CPU121が、コンピュータの識別情報やユーザの識別情報を認識し、それらの少なくとも一方に対応する読取設定内容を設定ファイル212から抽出して、ユーザインターフェースに表示させている。
[DefaultSetting]は、初期設定であることを示す。初期設定は、コンピュータやユーザを特定できないときに使用される設定である。そのため、ComuputerNameには、コンピュータに依存しないことを意味するNULLが設定されている。Modeは、白黒読み取りモードまたはカラー読み取りモードかを示す。PaperSizeは読み取りサイズを示す。Resolutionは、読取解像度を示している。ReadSideは、片面読取か両面読取かを示す。FileNameは、読み取った画像に付与されるファイル名称を示す。DisplayImageは、読み取った画像を表示するか否かを示す。
また、設定の変更が行われた場合は、スキャナ装置106に記憶された設定ファイルに設定の変更が反映される。よって、ユーザは、スキャナ装置106を接続するコンピュータが変更されても、そのコンピュータに適するであろう新しい設定内容を読み出して、使用することができる。
上述したように、スキャナ装置が接続されるコンピュータごとの設定を設定ファイルに格納してもよいが、このような設定は、ユーザごとに切り替えられてもよい。そこで、ユーザごとの設定を設定ファイルに格納することについて説明する。
なお、現在、コンピュータ100を使用しているユーザ名が既に登録されていて、かつパラメータを変更した場合、CPU121は、設定ファイル212内の設定セットを書き換える。一方、ユーザ名が設定ファイル212に登録されていない場合、CPU121は、このユーザ名に対応した設定セットを設定ファイル212に追加する。設定の変更が行われた場合は、スキャナ装置106に記憶された設定ファイルに設定の変更が反映される。よって、ユーザは、スキャナ装置106を接続するコンピュータが変更されても、ユーザの用途に適するであろう新しい設定内容を読み出して、使用することができる。上述した各実施形態の構成要素を他の実施形態に追加してもよく、本発明に含まれる。上述した各実施形態の周辺装置(画像読取装置を含む)において、周辺装置に記憶されたプログラムが情報処理装置にロードされて起動され、周辺装置が動作を開始する方式を、下記のように変形してもよい。(1):周辺装置を情報処理装置に接続すると、自動実行情報ファイル(例えばautorun.inf)とドライバプログラム(例えばCaptureApplication.exe)が情報処理装置にロードされて、自動的に周辺装置は動作を開始する。(2):周辺装置を情報処理装置に接続すると自動実行情報ファイルと、ドライバプログラムが情報処理装置にロードされ、情報処理装置又は周辺装置の操作部をユーザが操作すると周辺装置は動作を開始する。(3):周辺装置を情報処理装置に接続すると自動実行情報ファイルが情報処理装置にロードされ、情報処理装置又は周辺装置の操作部をユーザが操作するとドライバプログラムが情報処理装置にロードされ、周辺装置は動作を開始する。(4):周辺装置を情報処理装置に接続すると自動実行情報ファイルが情報処理装置にロードされ、情報処理装置又は周辺装置の操作部をユーザが操作するとドライバプログラムが情報処理装置にロードされ、さらにユーザ操作を行うと周辺装置は動作を開始する。(5):周辺装置を情報処理装置に接続し情報処理装置又は周辺装置の操作部をユーザが操作すると、自動実行情報ファイルと、ドライバプログラムが情報処理装置にロードされ、周辺装置は動作を開始する。(6):周辺装置を情報処理装置に接続し情報処理装置又は周辺装置の操作部をユーザが操作すると、自動実行情報ファイルが情報処理装置にロードされ、さらにユーザ操作を行うと、ドライバプログラムが情報処理装置にロードされ周辺装置は動作を開始する。

Claims (15)

  1. 情報処理装置からの情報に基づいて所定の処理が実行される周辺装置であって、
    前記所定の処理を制御するための制御プログラム、及び前記周辺装置を制御するための制御ファイルを記憶する記憶手段と、
    前記情報処理装置の前記制御プログラムの実行において前記記憶手段内の前記制御ファイルに書き込まれた指示情報に基づいて前記周辺装置の動作を制御する制御手段とを備え、
    前記記憶手段は、前記制御プログラムが記憶されている書き込み禁止又は書き込み不可能な第1メモリ領域と、前記情報処理装置から認識可能であって前記制御ファイルが記憶されている第2メモリ領域とを有し、
    前記制御プログラムを前記第1メモリ領域から前記第2メモリ領域に格納又は複製して、前記情報処理装置が前記第2メモリ領域内の前記制御プログラムを実行して前記情報処理装置から前記制御ファイルに書き込まれる前記指示情報に基づいて前記制御手段が前記周辺装置の動作を制御することを特徴とする周辺装置。
  2. 前記情報処理装置が前記周辺装置に接続されると、前記周辺装置をマスストレージデバイスとして認識し、前記情報処理装置から前記マスストレージデバイスへのアクセスは、管理者権限なしに実行されることを特徴とする請求項1に記載の周辺装置。
  3. 前記第2メモリ領域は、1つのディスクドライブとしてドライブレターを割り当てることにより前記情報処理装置から認識されることを特徴とする請求項1又は2に記載の周辺装置。
  4. 前記周辺装置の前記記憶手段内に記憶されている前記制御プログラムよりも新しいバージョンの制御プログラムが前記情報処理装置に記憶されている場合には、前記情報処理装置から送信される前記新しいバージョンの制御プログラムを受信して、前記記憶手段に書き込むことを特徴とする請求項1乃至3のいずれか1項に記載の周辺装置。
  5. 前記所定の処理として画像を読み取る画像読取部を更に備え、
    前記記憶手段には、前記画像読取部で読み取った画像データを一時的に記憶するバッファ領域が形成され、
    前記情報処理装置は、前記バッファ領域から前記制御ファイルに書き込まれた画像データを、前記制御ファイルを介して取得することを特徴とする請求項1乃至4のいずれか1項に記載の周辺装置。
  6. 前記情報処理装置は、前記第2メモリ領域内から前記制御プログラムとともにDLLモジュールを前記情報処理装置のメモリにロードするようにしたことを特徴とする請求項1乃至5のいずれか1項に記載の周辺装置。
  7. 前記情報処理装置が前記制御プログラムを実行することによって前記情報処理装置に接続されたディスプレイにユーザインターフェースを表示し、前記ユーザインターフェースから前記周辺装置の制御条件がユーザにより指定されることで前記周辺装置を制御するための前記指示情報が前記制御ファイルに書き込まれることを特徴とする請求項1乃至6のいずれか1項に記載の周辺装置。
  8. 情報処理装置からの情報に基づいて画像を読み取る画像読取装置であって、
    画像の読取処理を制御するための制御プログラム、及び前記画像読取装置を制御するための制御ファイルを記憶する記憶手段と、
    前記情報処理装置の前記制御プログラムの実行において前記記憶手段内の前記制御ファイルに書き込まれた指示情報に基づいて前記画像読取装置の動作を制御する制御手段とを備え、
    前記記憶手段は、前記制御プログラムが記憶されている書き込み禁止又は書き込み不可能な第1メモリ領域と、前記情報処理装置から認識可能であって前記制御ファイルが記憶されている第2メモリ領域とを有し、
    前記制御プログラムを前記第1メモリ領域から前記第2メモリ領域に格納又は複製して、前記情報処理装置が前記第2メモリ領域内の前記制御プログラムを実行して前記情報処理装置から前記制御ファイルに書き込まれる前記指示情報に基づいて前記制御手段が前記画像読取装置の動作を制御することを特徴とする画像読取装置。
  9. 前記制御手段は、前記情報処理装置から前記制御ファイルに前記指示情報が書き込まれると、前記指示情報に従って画像を読み取るための画像読取部を制御し、画像の読取動作を開始することを特徴とする請求項8に記載の画像読取装置。
  10. 前記制御手段は、前記情報処理装置での前記制御プログラムの実行によって繰り返し発生する前記指示情報に従って、前記記憶手段に部分画像データを繰り返し記憶することを特徴とする請求項8又は9に記載の画像読取装置。
  11. 情報処理装置と、前記情報処理装置が接続された画像読取装置とを有する画像読取システムであって、
    前記画像読取装置は、
    画像の読取処理を制御する制御プログラム、及び前記画像読取装置を制御するための制御ファイルを記憶する記憶手段と、
    前記情報処理装置の前記制御プログラムの実行において前記記憶手段内の前記制御ファイルに書き込まれた指示情報に基づいて前記画像読取装置の動作を制御する制御手段とを備え、更に、前記記憶手段は、前記制御プログラムが記憶されている書き込み禁止又は書き込み不可能な第1メモリ領域と、前記情報処理装置から認識可能であって前記制御ファイルが記憶されている第2メモリ領域とを有し、前記情報処理装置が接続された状態で前記制御プログラムを前記第1メモリ領域から前記第2メモリ領域に格納又は複製し、
    前記情報処理装置は、前記画像読取装置の前記第2メモリ領域を外部記憶領域として認識した状態で前記第2メモリ領域内の前記制御プログラムを実行して前記指示情報を前記制御ファイルに書き込み、前記画像読取装置の前記制御手段は、前記情報処理装置によって前記制御ファイルに書き込まれた前記指示情報に基づいて前記画像読取装置の動作を制御することを特徴とする画像読取システム。
  12. 前記制御手段は、前記情報処理装置での前記制御プログラムの実行によって繰り返し発生する前記指示情報に従って、前記記憶手段に部分画像データを繰り返し記憶する一方で、
    前記情報処理装置は、前記記憶手段から前記部分画像データを読み出して結合することにより画像データを完成させることを特徴とする請求項11に記載の画像読取システム。
  13. 前記画像読取装置は、画像読取を実行するためのスタートボタンを有し、前記スタートボタンが押されたことを検知すると前記スタートボタンが押されたことを示す情報を前記制御ファイルに書き込み、
    前記情報処理装置は、前記制御ファイルを介して前記スタートボタンが押されたことを検知して、前記制御ファイルに対して画像読取開始のための前記指示情報を書き込み、
    前記画像読取装置は、前記制御ファイルから前記画像読取開始のための指示情報を検知して画像の読み取りを実行することを特徴とする請求項11又は12に記載の画像読取システム。
  14. 前記情報処理装置は、前記画像読取装置における前記記憶手段の前記第2メモリ領域内にあるテーブルの更新に基づいて前記制御ファイルに画像データが書き込まれたか否かを認識することを特徴とする請求項11乃至13のいずれか1項に記載の画像読取システム。
  15. 前記情報処理装置は、前記画像読取装置における前記記憶手段の前記第2メモリ領域内にある前記制御ファイルに画像データが書き込まれたか否かを監視し、前記制御ファイルに画像データが書き込まれたことを検知した場合、前記制御ファイルから画像データを読み出すことを特徴とする請求項11乃至13のいずれか1項に記載の画像読取システム。
JP2014073631A 2008-06-27 2014-03-31 周辺装置、画像読取装置および画像読取システム Active JP5739561B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2014073631A JP5739561B2 (ja) 2008-06-27 2014-03-31 周辺装置、画像読取装置および画像読取システム

Applications Claiming Priority (7)

Application Number Priority Date Filing Date Title
JP2008169262 2008-06-27
JP2008169262 2008-06-27
JP2008169263 2008-06-27
JP2008169263 2008-06-27
JP2008259957 2008-10-06
JP2008259957 2008-10-06
JP2014073631A JP5739561B2 (ja) 2008-06-27 2014-03-31 周辺装置、画像読取装置および画像読取システム

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2009143655A Division JP5513018B2 (ja) 2008-06-27 2009-06-16 周辺装置及び画像読取装置

Publications (2)

Publication Number Publication Date
JP2014147103A JP2014147103A (ja) 2014-08-14
JP5739561B2 true JP5739561B2 (ja) 2015-06-24

Family

ID=51426970

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2014073631A Active JP5739561B2 (ja) 2008-06-27 2014-03-31 周辺装置、画像読取装置および画像読取システム

Country Status (1)

Country Link
JP (1) JP5739561B2 (ja)

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH07271946A (ja) * 1994-03-28 1995-10-20 Toshiba Corp 画像情報処理装置
US5915106A (en) * 1997-03-20 1999-06-22 Ricoh Company, Ltd. Method and system for operating a scanner which emulates a disk drive
JP2001256170A (ja) * 2000-03-13 2001-09-21 Hitachi Ltd 周辺装置及びプリンタ
JP4238618B2 (ja) * 2003-03-28 2009-03-18 ブラザー工業株式会社 複合機

Also Published As

Publication number Publication date
JP2014147103A (ja) 2014-08-14

Similar Documents

Publication Publication Date Title
JP5513018B2 (ja) 周辺装置及び画像読取装置
EP1592221B1 (en) Peripherals of computer
JP7129842B2 (ja) システム、画像形成装置、及びその制御方法、並びにプログラム
US8312184B2 (en) Peripheral device usable without installing driver in computer beforehand
US9075627B2 (en) Server connected to image forming apparatus and client, client, and method of remotely installing driver of image forming apparatus
US7979600B2 (en) Multifunction peripheral and device control system
US20080055640A1 (en) Communication system and printer therefor
JP4926748B2 (ja) 情報処理装置及びその制御方法
US20080239383A1 (en) Data processor saving data indicating progress status of printing process retrievable by client
KR20110085986A (ko) 정보 처리 장치, 정보 처리 방법, 및 프로그램을 포함하는 저장 매체
EP2503466A2 (en) Peripheral device used while being connected to information processing apparatus
JP2004303216A (ja) 情報処理装置,画像形成装置,プログラム起動時のエラー処理方法および記録媒体
EP1542125B1 (en) Information processing apparatus, program recovery method, and recording medium storing a program for program recovery
JP5596376B2 (ja) 周辺装置
JP2009070230A (ja) 動作履歴情報記録装置、動作履歴情報記録装置の制御方法、制御プログラム及び記録媒体
JP5739561B2 (ja) 周辺装置、画像読取装置および画像読取システム
JP4676241B2 (ja) コンピュータの周辺装置
JP2006293638A (ja) 情報処理装置及び周辺装置
JP5869228B2 (ja) 周辺装置、画像読取装置および情報処理システム
US12032958B2 (en) Image forming device and program
JP5016133B2 (ja) 情報処理システムの制御方法
JP2010118003A (ja) 画像読取装置及びその制御方法
JP5161272B2 (ja) 周辺装置
JP2005189972A (ja) 画像処理装置
JP2010108426A (ja) 周辺装置

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20141226

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20150109

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150309

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20150423

R150 Certificate of patent or registration of utility model

Ref document number: 5739561

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250