JP2017123610A - Image formation device, image formation system, image formation method, and program - Google Patents

Image formation device, image formation system, image formation method, and program Download PDF

Info

Publication number
JP2017123610A
JP2017123610A JP2016002779A JP2016002779A JP2017123610A JP 2017123610 A JP2017123610 A JP 2017123610A JP 2016002779 A JP2016002779 A JP 2016002779A JP 2016002779 A JP2016002779 A JP 2016002779A JP 2017123610 A JP2017123610 A JP 2017123610A
Authority
JP
Japan
Prior art keywords
application
unit
operation unit
main body
workflow
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.)
Pending
Application number
JP2016002779A
Other languages
Japanese (ja)
Inventor
康人 中谷
Yasuto Nakatani
康人 中谷
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.)
Ricoh Co Ltd
Original Assignee
Ricoh Co Ltd
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 Ricoh Co Ltd filed Critical Ricoh Co Ltd
Priority to JP2016002779A priority Critical patent/JP2017123610A/en
Publication of JP2017123610A publication Critical patent/JP2017123610A/en
Pending legal-status Critical Current

Links

Images

Landscapes

  • Facsimiles In General (AREA)
  • Accessory Devices And Overall Control Thereof (AREA)

Abstract

PROBLEM TO BE SOLVED: To provide an image formation device capable of synchronizing an application activated on the operation unit side, with an application activated on the body side, when multiple processes registered in a work flow are executed in order, and to provide an image formation system, image formation method, and program.SOLUTION: An image formation device includes an operation unit receiving an operation, and a body unit operating in accordance with the operation received by the operation unit, where the operation unit has a first OS, and the body unit has a second OS. The operation unit includes an application cooperation part for executing the processing by activating the applications in order, based on the workflow, a synchronization processing part performing the processing for synchronizing a first application and a second application operating in the body unit, upon receiving an application activation request for requesting activation of the first application operating in the operation unit from the application cooperation part, and an application activation control unit for activating the first application, after the synchronization processing is performed in synchronization processing part.SELECTED DRAWING: Figure 3

Description

本発明は、画像形成装置、画像形成システム、画像形成方法およびプログラムに関する。   The present invention relates to an image forming apparatus, an image forming system, an image forming method, and a program.

スマートフォン等に用いられるOS(Operating System)では、アプリケーションが他のアプリケーションを呼び出すことで、複数のアプリケーションを連携したワークフローを実現する仕組みが知られている。また画像形成装置が有する操作部にOS(例えばAndroid OS)を搭載することで、従来の操作部に比べて容易に機能拡張を行えるものがある。以下、アプリケーションを「アプリ」とも表記する。   In an OS (Operating System) used for a smartphone or the like, a mechanism for realizing a workflow in which a plurality of applications are linked by an application calling another application is known. In addition, there is a type in which an OS (for example, Android OS) is installed in an operation unit included in the image forming apparatus, so that the function can be easily expanded as compared with a conventional operation unit. Hereinafter, the application is also referred to as “application”.

例えば、特許文献1には、ネットワークを介して提供されるサービスの柔軟性を向上させることができる情報処理装置が開示されている。特許文献1に記載の情報処理装置は、複数の処理を実行させる順序を決定し、決定した順序に従ってそれぞれの処理に関連付けられている処理装置に処理を実行させるものである。   For example, Patent Document 1 discloses an information processing apparatus that can improve the flexibility of a service provided via a network. The information processing apparatus described in Patent Document 1 determines an order in which a plurality of processes are executed, and causes a processing apparatus associated with each process to execute processes according to the determined order.

OSを搭載した画像形成装置の操作部においても、スマートフォン等と同様に、複数のアプリを連携したワークフローを実現することを考える。ワークフローに登録された複数の処理を順番に実行させる場合、操作部側のアプリを起動させる時には、操作部側のアプリに対応する本体部(コントローラ)側で起動させるアプリを起動させて、操作部側で起動させるアプリと本体部側で起動させるアプリとを同期させる必要がある。以下、本体部を「コントローラ」とも表記する。   In the operation unit of the image forming apparatus equipped with the OS, it is considered to realize a workflow in which a plurality of applications are linked in the same manner as a smartphone or the like. In order to execute a plurality of processes registered in the workflow in order, when starting an application on the operation unit side, start an application to be started on the main body (controller) side corresponding to the application on the operation unit side. It is necessary to synchronize the application activated on the side and the application activated on the main body side. Hereinafter, the main body is also referred to as a “controller”.

すなわち、同期とは、操作部側のアプリがコントローラ側のアプリの機能を使用する場合に、操作部側のアプリに対応するコントローラ側で使用する機能のコントローラ側のアプリを起動させる処理のことを示す。また、操作部側のアプリがコントローラ側のアプリの機能を使用しない場合には、コントローラ側ではホームアプリを起動させる処理のことを示す。なお、操作部側のアプリとは、操作部で動作中であり操作パネルに表示されているアプリのことを示し、コントローラ側のアプリとは、本体部で動作中のアプリのことを示す。   In other words, synchronization refers to the process of starting the controller-side application with the function used on the controller side corresponding to the operation-side application when the operation-side application uses the controller-side application function. Show. Further, when the application on the operation unit side does not use the function of the application on the controller side, the controller side indicates processing for starting the home application. The operation unit side application indicates an application that is operating on the operation unit and displayed on the operation panel, and the controller side application indicates an application that is operating on the main unit.

操作部側のアプリと、コントローラ側のアプリとを同期させる理由として、例えば、コントローラ側の画面を操作部側に表示させる場合に、操作部側のアプリと操作部側のアプリに対応するコントローラ側のアプリが同期していないと狙いと違う画面が表示されるためである。コントローラ側の画面を操作部に表示させる場合として、例えば、エラーが発生した時にユーザに通知する画面や、ストップキーを押下した時にジョブを停止させる画面等が挙げられる。   As a reason for synchronizing the operation unit side application with the controller side application, for example, when displaying the controller side screen on the operation unit side, the controller side corresponding to the operation unit side application and the operation unit side application This is because if the application is not synchronized, a different screen will be displayed. Examples of displaying the controller-side screen on the operation unit include a screen for notifying a user when an error occurs, and a screen for stopping a job when a stop key is pressed.

また、複数のアプリを連携したワークフローを実現する際に、ワークフローの処理を実行させるアプリが直接に操作部で起動させるアプリを呼び出すと、操作部側で起動させるアプリとコントローラ側で起動させるアプリとの同期がとれなくなる、という問題がある。   In addition, when realizing a workflow that links multiple applications, when an app that executes workflow processing calls an app that is activated directly on the operation unit, an application that is activated on the operation unit side and an application that is activated on the controller side There is a problem that it becomes impossible to synchronize.

しかしながら特許文献1に記載の情報処理装置では、ワークフローに登録された複数の処理を順番に実行させる場合、操作部側のアプリを起動させる時には、操作部側のアプリに対応する本体部(コントローラ)側で起動させるアプリを起動させて、操作部側で起動させるアプリと本体部側で起動させるアプリとを同期させる、という問題を解決することはできていない。   However, in the information processing apparatus described in Patent Document 1, when a plurality of processes registered in the workflow are executed in order, when the application on the operation unit side is activated, the main body unit (controller) corresponding to the application on the operation unit side However, it is not possible to solve the problem of synchronizing an application activated on the operation unit side and an application activated on the main body side by starting an application activated on the side.

本発明は、上記に鑑みてなされたものであって、ワークフローに登録された複数の処理を順番に実行させる場合、操作部側で起動させるアプリと、操作部側のアプリに対応する本体部側で起動させるアプリとを同期させることができる画像形成装置、画像形成システム、画像形成方法およびプログラムを提供することを目的とする。   The present invention has been made in view of the above, and in the case of sequentially executing a plurality of processes registered in a workflow, an application to be activated on the operation unit side, and a main body unit side corresponding to the application on the operation unit side An object of the present invention is to provide an image forming apparatus, an image forming system, an image forming method, and a program that can synchronize with an application that is activated in the above.

上述した課題を解決し、目的を達成するために、本発明の画像形成装置は、操作を受け付ける操作部と、前記操作部で受け付けた操作に応じて動作する本体部とを備え、前記操作部が第1のオペレーティングシステムを有し、前記本体部が第2のオペレーティングシステムを有した画像形成装置であって、前記操作部は、予め登録されたアプリケーションの実行順を示すワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行うアプリ連携部と、前記アプリ連携部から前記第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、前記第1のアプリケーションと、前記第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う同期処理部と、前記同期処理部での同期させる処理が行われた後に、前記第1のアプリケーションを起動させるアプリ起動制御部と、を備える、ことを特徴とする。   In order to solve the above-described problems and achieve the object, an image forming apparatus of the present invention includes an operation unit that receives an operation, and a main body unit that operates according to the operation received by the operation unit. Is an image forming apparatus having a first operating system, and the main body unit has a second operating system, and the operation unit sequentially operates based on a workflow indicating an execution order of applications registered in advance. When receiving an application activation request for starting the application and executing the process, and an application activation request for requesting activation of the first application operating on the first operating system from the application collaboration unit, A first application and a second application running on the second operating system; A synchronization processing unit for performing processing to synchronize, after the process of synchronizing with the synchronization processing unit is performed, and a application activation control unit activating the first application, and wherein the.

本発明によれば、操作部側で起動させるアプリと、操作部側のアプリに対応する本体部側で起動させるアプリとを同期させることができる、という効果を奏する。   According to the present invention, there is an effect that an application activated on the operation unit side and an application activated on the main body side corresponding to the operation unit side application can be synchronized.

図1は、本実施形態のMFPのハードウェア構成の一例を示す図である。FIG. 1 is a diagram illustrating an example of a hardware configuration of the MFP according to the present embodiment. 図2は、本実施形態のMFPのソフトウェア構成の一例を示す模式図である。FIG. 2 is a schematic diagram illustrating an example of the software configuration of the MFP according to the present embodiment. 図3は、本実施形態のMFPの機能構成の一例を示す図である。FIG. 3 is a diagram illustrating an example of a functional configuration of the MFP according to the present embodiment. 図4は、アプリ対応情報の一例について説明する図である。FIG. 4 is a diagram illustrating an example of the application correspondence information. 図5は、アプリを連携したワークフローの利用の概要について説明する図である。FIG. 5 is a diagram for explaining an outline of the use of a workflow in which applications are linked. 図6は、アプリを連携したワークフローの利用の概要について説明する図である。FIG. 6 is a diagram illustrating an outline of the use of a workflow that links applications. 図7は、ワークフロー作成画面表示のシーケンス図である。FIG. 7 is a sequence diagram of the workflow creation screen display. 図8は、各機能のメタデータの一例を示す図である。FIG. 8 is a diagram illustrating an example of metadata of each function. 図9は、操作部の複数の機能を利用するための操作受付画面(UI画面)を呼び出す初期画面(ホーム画面)の一例を示す図である。FIG. 9 is a diagram illustrating an example of an initial screen (home screen) for calling an operation reception screen (UI screen) for using a plurality of functions of the operation unit. 図10は、アプリ連携機能を利用するための操作受付画面(UI画面)の一例を示す図である。FIG. 10 is a diagram illustrating an example of an operation reception screen (UI screen) for using the application cooperation function. 図11は、ワークフロー作成画面(UI画面)の一例を示す図である。FIG. 11 is a diagram illustrating an example of a workflow creation screen (UI screen). 図12は、ワークフローのデータの一例を示す図である。FIG. 12 is a diagram illustrating an example of workflow data. 図13は、ワークフローを作成する際に組み合わせられる機能の一例を示す図である。FIG. 13 is a diagram illustrating an example of functions that are combined when creating a workflow. 図14は、ワークフローを作成する際に組み合わせられない機能の一例を示す図である。FIG. 14 is a diagram illustrating an example of functions that cannot be combined when creating a workflow. 図15は、ワークフローに登録する機能(アプリ)の組み合わせの一例を示す図である。FIG. 15 is a diagram illustrating an example of a combination of functions (applications) registered in a workflow. 図16は、ワークフロー登録のシーケンス図である。FIG. 16 is a sequence diagram of workflow registration. 図17は、ホーム画面に登録されたワークフローを示す図である。FIG. 17 is a diagram showing a workflow registered on the home screen. 図18は、ワークフローの処理の実行について説明するフローチャート図である。FIG. 18 is a flowchart illustrating the execution of workflow processing. 図19は、アプリ連携の操作受付画面の一例を示す図である。FIG. 19 is a diagram illustrating an example of an application cooperation operation reception screen. 図20は、コントローラ側のアプリ起動のシーケンス図である。FIG. 20 is a sequence diagram of application activation on the controller side. 図21は、コントローラ側のホームアプリ起動のシーケンス図である。FIG. 21 is a sequence diagram of home application activation on the controller side. 図22は、コントローラ側のアプリ起動が失敗した場合の処理の一例を示すシーケンス図である。FIG. 22 is a sequence diagram illustrating an example of processing in a case where application activation on the controller side fails. 図23は、実行する機能(アプリ)の間でのデータ受け渡し処理のシーケンス図である。FIG. 23 is a sequence diagram of data transfer processing between functions to be executed (applications).

以下、添付図面を参照しながら、本発明に係る画像形成装置、画像形成システム、画像形成方法およびプログラムの一実施形態を詳細に説明する。なお、以下の実施形態により本発明が限定されるものではない。また、各実施形態は、内容を矛盾させない範囲で、適宜組み合わせることができる。   Hereinafter, an embodiment of an image forming apparatus, an image forming system, an image forming method, and a program according to the present invention will be described in detail with reference to the accompanying drawings. In addition, this invention is not limited by the following embodiment. Moreover, each embodiment can be combined suitably as long as the content is not contradicted.

本実施形態の画像形成装置は、アプリケーションの実行順を示すワークフローに登録された順番にアプリケーションのアプリ起動要求を受け付けた場合、起動要求された操作部のアプリが本体部の機能(例えば、コピー、スキャナ、ファックス、プリンタ機能等)を使用するアプリの場合に、操作部のアプリに対応する本体部のアプリを起動させて、操作部で起動させるアプリと、本体部で起動させるアプリを対応させて同期させる処理を行う。本実施形態の画像形成装置では、同期処理部が操作部のアプリと、操作部のアプリに対応する本体部のアプリを同期させる処理を行うことで、操作部で起動するアプリと本体部で起動中のアプリを同期させる(揃える)ことができる。また、本実施形態の画像形成装置では、起動要求されたアプリの処理の実行が完了した後に、本体部でホームアプリを起動させる制御を行う。本体部でホームアプリを起動させることで、次に操作部で起動させるアプリと、本体部で起動させるアプリとの同期がとれなくなるという不具合が発生しない。すなわち、ワークフローの順番で複数のアプリを実行させた場合でも、操作部で起動させるアプリの切り換えと、切り換える操作部のアプリに対応する本体部で起動させるアプリへの切り換えを同期させることができる。本実施形態の画像形成装置によれば、ワークフローに登録された複数の処理を順番に実行させる場合でも、操作部側で起動させるアプリと、操作部側のアプリに対応する本体部側で起動させるアプリとを同期させることができる。なお、操作部側のアプリと本体部(コントローラ)側のアプリとの同期は操作部側のアプリがコントローラ側の機能(アプリ)を利用し始めるまでに完了する必要がある。   In the image forming apparatus according to the present embodiment, when the application activation request of the application is received in the order registered in the workflow indicating the execution order of the application, the application of the operation unit requested to activate the function (for example, copy, In the case of an application that uses a scanner, a fax machine, a printer function, etc.), the application of the main unit corresponding to the application of the operation unit is activated, and the application activated by the operation unit is associated with the application activated by the main unit. Process to synchronize. In the image forming apparatus according to the present embodiment, the synchronization processing unit performs processing for synchronizing the operation unit application and the main unit application corresponding to the operation unit application, thereby starting the operation unit and the main unit. You can synchronize (align) the apps inside. Further, in the image forming apparatus of the present embodiment, after the execution of the processing of the requested application is completed, control for starting the home application on the main body is performed. By starting the home application on the main unit, there is no problem that the application that is activated next on the operation unit and the application that is activated on the main unit cannot be synchronized. That is, even when a plurality of apps are executed in the order of the workflow, it is possible to synchronize the switching of the application to be activated by the operation unit and the switching to the application to be activated by the main body corresponding to the application of the operation unit to be switched. According to the image forming apparatus of the present embodiment, even when a plurality of processes registered in the workflow are executed in order, the application to be activated on the operation unit side and the main body unit corresponding to the application on the operation unit side are activated. You can synchronize with the app. The synchronization between the application on the operation unit side and the application on the main unit (controller) side needs to be completed before the application on the operation unit side starts using the function (application) on the controller side.

以下では、本実施形態の画像形成装置を、複合機(MFP:Multifunction Peripheral)に適用した場合を例に挙げて説明するが、これに限定されるものではない。なお、複合機とは、コピー機能、スキャナ機能、ファックス(FAX:Facsimile(ファクシミリ))機能、およびプリンタ機能のうち少なくとも2つの機能を有する装置である。   In the following, a case where the image forming apparatus according to the present embodiment is applied to a multifunction peripheral (MFP) will be described as an example, but the present invention is not limited to this. Note that a multifunction peripheral is a device having at least two functions among a copy function, a scanner function, a fax (FAX) function, and a printer function.

図1は、本実施形態のMFP1のハードウェア構成の一例を示す図である。図1に示すように、MFP1は、コピー機能、スキャナ機能、ファックス機能、プリンタ機能などの各種の機能を実現可能な本体部10と、ユーザの操作に応じた入力を受け付ける操作部20と、を備える。なお、操作部20は、画面を表示する表示部を有し、ユーザの操作を受け付ける。そして、本体部10は、操作部20で受け付けた操作に応じて動作する。なお、ユーザの操作を受け付けるとは、ユーザの操作に応じて入力される情報(画面の座標値を示す信号等を含む)を受け付けることを含む概念である。本体部10と操作部20は、専用の通信路300を介して相互に通信可能に接続されている。通信路300は、例えばUSB(Universal Serial Bus)規格のものを用いることもできるが、有線か無線かを問わず任意の規格のものであってよい。   FIG. 1 is a diagram illustrating an example of a hardware configuration of the MFP 1 according to the present embodiment. As illustrated in FIG. 1, the MFP 1 includes a main body unit 10 capable of realizing various functions such as a copy function, a scanner function, a fax function, and a printer function, and an operation unit 20 that receives an input corresponding to a user operation. Prepare. The operation unit 20 includes a display unit that displays a screen and accepts user operations. The main body 10 operates according to the operation received by the operation unit 20. Note that accepting a user operation is a concept including accepting information (including a signal indicating a coordinate value of a screen) input according to the user operation. The main unit 10 and the operation unit 20 are connected to each other via a dedicated communication path 300 so as to be able to communicate with each other. The communication path 300 may be, for example, a USB (Universal Serial Bus) standard, but may be of any standard regardless of whether it is wired or wireless.

なお、本体部10は、操作部20で受け付けた操作に応じた動作を行うことができる。また、本体部10は、クライアントPC(Personal Computer、パーソナルコンピュータ)などの外部装置とも通信可能であり、外部装置から受信した指示に応じた動作を行うこともできる。   The main body 10 can perform an operation according to the operation received by the operation unit 20. The main unit 10 can also communicate with an external device such as a client PC (Personal Computer), and can also perform an operation according to an instruction received from the external device.

まず、本体部10のハードウェア構成について説明する。図1に示すように、本体部10は、CPU11と、ROM12と、RAM13と、HDD(ハードディスクドライブ)14と、通信I/F(インタフェース)15と、接続I/F16と、プリントエンジン17とを備え、これらがシステムバス18を介して相互に接続されている。   First, the hardware configuration of the main body unit 10 will be described. As shown in FIG. 1, the main body 10 includes a CPU 11, a ROM 12, a RAM 13, an HDD (hard disk drive) 14, a communication I / F (interface) 15, a connection I / F 16, and a print engine 17. These are connected to each other via a system bus 18.

CPU11は、本体部10の動作を統括的に制御する。CPU11は、RAM13をワークエリア(作業領域)としてROM12またはHDD14などに格納されたプログラムを実行することで、本体部10全体の動作を制御し、上述したコピー機能、スキャナ機能、ファックス機能、プリンタ機能などの各種機能を実現する。   The CPU 11 comprehensively controls the operation of the main body unit 10. The CPU 11 controls the overall operation of the main unit 10 by executing a program stored in the ROM 12 or the HDD 14 using the RAM 13 as a work area (work area), and the above-described copy function, scanner function, fax function, and printer function. Various functions such as are realized.

通信I/F15は、ネットワーク30と接続するためのインタフェースである。また、通信I/F15は、PC(Personal Computer、パーソナルコンピュータ)などの外部装置からプリンタデータを受信可能に、ネットワーク30と接続している。   The communication I / F 15 is an interface for connecting to the network 30. The communication I / F 15 is connected to the network 30 so as to receive printer data from an external device such as a PC (Personal Computer).

接続I/F16は、通信路300を介して操作部20と通信するためのインタフェースである。   The connection I / F 16 is an interface for communicating with the operation unit 20 via the communication path 300.

プリントエンジン17は、印刷処理を実行するユニットであり、例えば白黒プロッタ、1ドラムカラープロッタ、4ドラムカラープロッタ等を含み、更にスキャナユニット、ファックスユニット等を含んでもよい。なお、プリントエンジン17には、プロッタなどのいわゆるエンジン部分に加えて、誤差拡散およびガンマ変換などの画像処理部分が含まれる。   The print engine 17 is a unit that executes a printing process, and includes, for example, a monochrome plotter, a 1-drum color plotter, a 4-drum color plotter, and the like, and may further include a scanner unit, a fax unit, and the like. The print engine 17 includes an image processing part such as error diffusion and gamma conversion in addition to a so-called engine part such as a plotter.

次に、操作部20のハードウェア構成について説明する。図1に示すように、操作部20は、CPU21と、ROM22と、RAM23と、フラッシュメモリ24と、通信I/F25と、接続I/F26と、操作パネル27と、外部接続I/F28と、を備え、これらがシステムバス29を介して相互に接続されている。   Next, the hardware configuration of the operation unit 20 will be described. As shown in FIG. 1, the operation unit 20 includes a CPU 21, a ROM 22, a RAM 23, a flash memory 24, a communication I / F 25, a connection I / F 26, an operation panel 27, an external connection I / F 28, These are connected to each other via a system bus 29.

CPU21は、操作部20の動作を統括的に制御する。CPU21は、RAM23をワークエリア(作業領域)としてROM22またはフラッシュメモリ24などに格納されたプログラムを実行することで、操作部20全体の動作を制御し、ユーザから受け付けた入力に応じた情報(画像)の表示などの後述する各種機能を実現する。   The CPU 21 comprehensively controls the operation of the operation unit 20. The CPU 21 uses the RAM 23 as a work area (work area) and executes a program stored in the ROM 22 or the flash memory 24 to control the operation of the entire operation unit 20 and information (image) according to the input received from the user. Various functions described later such as display of) are realized.

通信I/F25は、ネットワーク30と接続するためのインタフェースである。接続I/F26は、通信路300を介して本体部10と通信するためのインタフェースである。   The communication I / F 25 is an interface for connecting to the network 30. The connection I / F 26 is an interface for communicating with the main body 10 via the communication path 300.

操作パネル27は、ユーザの操作に応じた各種の入力を受け付けるとともに、各種の情報(例えば受け付けた入力に応じた情報、MFP1の動作状況を示す情報、設定状態などを示す情報など)を表示する。この例では、操作パネル27は、タッチパネル機能を搭載した液晶表示装置(LCD)で構成されるが、これに限られるものではない。例えばタッチパネル機能が搭載された有機EL表示装置で構成されてもよい。さらに、これに加えて又はこれに代えて、ハードウェアキー等の操作部やランプ等の表示部を設けることもできる。なお、操作パネル27は、この構成に限られるものではなく、画像を表示するとともに当該画像に応じた操作を受け付けるものであればよい。   Operation panel 27 accepts various inputs in accordance with user operations, and displays various types of information (for example, information in accordance with accepted inputs, information indicating the operation status of MFP 1, information indicating a setting state, and the like). . In this example, the operation panel 27 is configured by a liquid crystal display device (LCD) having a touch panel function, but is not limited thereto. For example, an organic EL display device equipped with a touch panel function may be used. Further, in addition to or instead of this, an operation unit such as a hardware key and a display unit such as a lamp may be provided. The operation panel 27 is not limited to this configuration, and may be any device that displays an image and receives an operation corresponding to the image.

外部接続I/F28は、ICカードリーダなどの周辺装置と接続するためのインタフェースである。   The external connection I / F 28 is an interface for connecting to a peripheral device such as an IC card reader.

次に、MFP1のソフトウェア構成について説明する。図2は、MFPのソフトウェア構成の一例を示す模式図である。図2に示すように、本体部10は、アプリ層101と、サービス層102と、OS層103とを有する。アプリ層101、サービス層102、及びOS層103の実体は、ROM12やHDD14などに格納されている各種ソフトウェアである。CPU11が、これらのソフトウェアを実行することにより、各種の機能が提供される。   Next, the software configuration of the MFP 1 will be described. FIG. 2 is a schematic diagram illustrating an example of the software configuration of the MFP. As shown in FIG. 2, the main body unit 10 includes an application layer 101, a service layer 102, and an OS layer 103. The entities of the application layer 101, the service layer 102, and the OS layer 103 are various types of software stored in the ROM 12, the HDD 14, and the like. Various functions are provided by the CPU 11 executing these software.

アプリ層101のソフトウェアは、ハードウェア資源を動作させて所定の機能を提供するためのソフトウェアであり、アプリケーションソフトウェア(以下の説明では、単に「アプリ」と称する場合がある)と言われる。例えばアプリとしては、コピー機能を提供するためのコピーアプリ、スキャナ機能を提供するためのスキャナアプリ、ファックス機能を提供するためのファックスアプリ、プリンタ機能を提供するためのプリンタアプリなどが挙げられる。   The software of the application layer 101 is software for operating a hardware resource to provide a predetermined function, and is referred to as application software (sometimes simply referred to as “application” in the following description). Examples of the application include a copy application for providing a copy function, a scanner application for providing a scanner function, a fax application for providing a fax function, and a printer application for providing a printer function.

サービス層102のソフトウェアは、アプリ層101とOS層103との間に介在し、アプリに対し、本体部10が備えるハードウェア資源を利用するためのインタフェースを提供するためのソフトウェアである。より具体的には、ハードウェア資源に対する動作要求の受付、動作要求の調停を行う機能を提供するためのソフトウェアである。サービス層102が受け付ける動作要求としては、スキャナによる読み取りやプリンタによる印字などの要求が考えられる。   The software of the service layer 102 is software that is interposed between the application layer 101 and the OS layer 103 and provides an interface for using hardware resources included in the main body unit 10 for the application. More specifically, it is software for providing a function of accepting an operation request for a hardware resource and arbitrating the operation request. The operation request received by the service layer 102 may be a request such as reading by a scanner or printing by a printer.

なお、サービス層102によるインタフェースの機能は、本体部10のアプリ層101だけではなく、操作部20のアプリ層201に対しても提供される。すなわち、操作部20のアプリ層201(アプリ)も、サービス層102のインタフェース機能を介して、本体部10のハードウェア資源(例えばプリントエンジン17)を利用した機能を実現することができる。   The interface function by the service layer 102 is provided not only to the application layer 101 of the main body unit 10 but also to the application layer 201 of the operation unit 20. That is, the application layer 201 (application) of the operation unit 20 can also realize a function using hardware resources (for example, the print engine 17) of the main body unit 10 through the interface function of the service layer 102.

OS層103のソフトウェアは、本体部10が備えるハードウェア資源を制御する基本機能を提供するための基本ソフトウェア(オペレーティングシステム)である。サービス層102のソフトウェアは、各種アプリからのハードウェア資源の利用要求を、OS層103が解釈可能なコマンドに変換してOS層103に渡す。そして、OS層103のソフトウェアによりコマンドが実行されることで、ハードウェア資源は、アプリの要求に従った動作を行う。   The software of the OS layer 103 is basic software (operating system) for providing a basic function for controlling hardware resources included in the main body unit 10. The software of the service layer 102 converts a hardware resource use request from various applications into a command interpretable by the OS layer 103 and passes the command to the OS layer 103. Then, when the command is executed by the software of the OS layer 103, the hardware resource performs an operation according to the request of the application.

同様に、操作部20は、アプリ層201と、サービス層202と、OS層203とを有する。操作部20が備えるアプリ層201、サービス層202、及びOS層203も、階層構造については本体部10側と同様である。ただし、アプリ層201のアプリにより提供される機能や、サービス層202が受け付け可能な動作要求の種類は、本体部10側とは異なる。アプリ層201のアプリは、操作部20が備えるハードウェア資源を動作させて所定の機能を提供するためのソフトウェアであってもよいが、主として本体部10が備える機能(コピー機能、スキャナ機能、ファックス機能、プリンタ機能)に関する操作や表示を行うためのUI(ユーザインタフェース)の機能を提供するためのソフトウェアである。   Similarly, the operation unit 20 includes an application layer 201, a service layer 202, and an OS layer 203. The application layer 201, the service layer 202, and the OS layer 203 included in the operation unit 20 are the same as the main body unit 10 in terms of the hierarchical structure. However, the functions provided by the applications in the application layer 201 and the types of operation requests that can be accepted by the service layer 202 are different from those on the main body 10 side. The application of the application layer 201 may be software for operating a hardware resource included in the operation unit 20 to provide a predetermined function, but mainly includes functions (copy function, scanner function, fax) included in the main body unit 10. This is software for providing a UI (user interface) function for performing operations and display related to functions and printer functions.

操作部20側のアプリ層201のアプリとしては、プリンタ機能に関する操作や表示を行うためのUIの機能を提供するためのプリンタアプリ、コピー機能に関する操作や表示を行うためのUIの機能を提供するためのコピーアプリ、ファックス機能に関する操作や表示を行うためのUIの機能を提供するためのファックスアプリなどが挙げられるが、これに限られるものではない。   As an application of the application layer 201 on the operation unit 20 side, a printer application for providing a UI function for performing an operation and display relating to a printer function, and a UI function for performing an operation and display relating to a copy function are provided. For example, a copy application for the user, a fax application for providing a UI function for performing an operation and display related to the fax function, and the like, but is not limited thereto.

なお、本実施形態では、機能の独立性を保つために、本体部10側のOS層103のソフトウェアと操作部20側のOS層203のソフトウェアは、別々の互いに独立したソフトウェアとなっている。つまり、本体部10と操作部20は、別々のオペレーティングシステムで互いに独立して動作する。例えば、本体部10側のOS層103のソフトウェア(第2のオペレーティングシステム)としてLinux(登録商標)を用い、操作部20側のOS層203のソフトウェア(第1のオペレーティングシステム)としてAndroid(登録商標)を用いることも可能である。また、本体部10、操作部20ともにAndroidを用いるといった、同種のOSを用いることも可能である。すなわち、第1のオペレーティングシステムと第2のオペレーティングシステムは、別々のOSを用いてもよいし、同じOSを用いてもよい。   In this embodiment, in order to maintain the independence of functions, the software of the OS layer 103 on the main body 10 side and the software of the OS layer 203 on the operation unit 20 are separate and independent software. That is, the main body unit 10 and the operation unit 20 operate independently of each other with different operating systems. For example, Linux (registered trademark) is used as software (second operating system) for the OS layer 103 on the main body 10 side, and Android (registered trademark) is used as software (first operating system) on the OS layer 203 on the operation unit 20 side. ) Can also be used. It is also possible to use the same type of OS such as Android for both the main body unit 10 and the operation unit 20. That is, the first operating system and the second operating system may use different OSs or the same OS.

以上のように、本実施形態のMFP1において、本体部10と操作部20は別々のオペレーティングシステムで動作するため、本体部10と操作部20との間の通信は、共通の装置内のプロセス間通信ではなく、異なる装置間の通信として行われる。操作部20が受け付けた情報(ユーザからの指示内容)を本体部10へ伝達する動作(コマンド通信)や、本体部10が操作部20へイベントを通知する動作などがこれに該当する。ここでは、操作部20が本体部10へコマンド通信を行うことにより、本体部10の機能を使用することができる。また、本体部10から操作部20に通知するイベントには、本体部10における動作の実行状況、本体部10側で設定された内容などが挙げられる。   As described above, in MFP 1 according to the present embodiment, main unit 10 and operation unit 20 operate on different operating systems, and therefore communication between main unit 10 and operation unit 20 is performed between processes in a common apparatus. This is not communication but communication between different devices. The operation (command communication) for transmitting information (instruction content from the user) received by the operation unit 20 to the main body unit 10, the operation for the main body unit 10 notifying the operation unit 20 of an event, and the like correspond to this. Here, the function of the main body 10 can be used when the operation unit 20 performs command communication to the main body 10. The event notified from the main unit 10 to the operation unit 20 includes the execution status of the operation in the main unit 10 and the contents set on the main unit 10 side.

また、本実施形態では、操作部20に対する電力供給は、本体部10から通信路300を経由して行われているので、操作部20の電源制御を、本体部10の電源制御とは別に(独立して)行うことができる。   In the present embodiment, since power is supplied to the operation unit 20 from the main unit 10 via the communication path 300, power control of the operation unit 20 is performed separately from power control of the main unit 10 ( Can be done independently).

なお、この例では、本体部10と操作部20は、通信路300を介して電気的かつ物理的に接続されているが、これに限ることはなく、操作部20は、本体部10から取り外し可能に設けられるようにしてもよい。この場合、本体部10及び操作部20に、例えば赤外線通信部、RF(Radio Frequency)通信部、ブルートゥース(登録商標)通信部などの近距離無線通信部を設ける。または、本体部10および操作部20に、Wi−Fi(登録商標)などの無線LAN通信機能を設け、図2に示すように無線LANアクセスポイント(無線LANAP)31及びネットワーク30を介して相互に通信可能としてもよい。LANは、「Local Area Network」の略記である。本体部10から操作部20を取り外し可能である場合、操作部20は、通信路300を介して本体部10から供給された電力を二次電池に蓄電しておき、本体部10から取り外された際に、二次電池に蓄電された電力を用いて動作して本体部10と通信を行う。   In this example, the main body unit 10 and the operation unit 20 are electrically and physically connected via the communication path 300, but the present invention is not limited to this, and the operation unit 20 is detached from the main body unit 10. It may be provided as possible. In this case, the main body unit 10 and the operation unit 20 are provided with short-range wireless communication units such as an infrared communication unit, an RF (Radio Frequency) communication unit, and a Bluetooth (registered trademark) communication unit. Alternatively, the main body unit 10 and the operation unit 20 are provided with a wireless LAN communication function such as Wi-Fi (registered trademark), and are mutually connected via a wireless LAN access point (wireless LANAP) 31 and a network 30 as shown in FIG. Communication may be possible. LAN is an abbreviation for “Local Area Network”. When the operation unit 20 can be detached from the main body unit 10, the operation unit 20 stores the electric power supplied from the main body unit 10 via the communication path 300 in the secondary battery and is removed from the main body unit 10. At this time, the power stored in the secondary battery is used to communicate with the main body 10.

次に、図3を用いて、本実施形態のMFP1の機能構成について説明する。図3は、MFPの機能構成の一例を示す図である。   Next, the functional configuration of the MFP 1 according to the present embodiment will be described with reference to FIG. FIG. 3 is a diagram illustrating an example of a functional configuration of the MFP.

まず、MFP1の本体部10側の機能について説明する。図3に示すように、本体部10は、CPU11がプログラムを実行することで実現される機能(モジュール)である通信部111と、起動制御部112と、記憶部113とを備える。上記各部の一部はCPU11がROM12又はHDD14からソフトウェア(プログラム)を読み出して実行することにより上記各部がRAM13上にロードされ、上記各部がRAM13上に生成されるソフトウェア(プログラム)であってもよい。また、上記各部の一部又は全部を、演算処理を行うプロセッサなどのハードウェア回路で置き換えてもよい。   First, functions on the main body 10 side of the MFP 1 will be described. As illustrated in FIG. 3, the main body unit 10 includes a communication unit 111 that is a function (module) realized by the CPU 11 executing a program, an activation control unit 112, and a storage unit 113. Some of the above-described units may be software (programs) that are loaded onto the RAM 13 by the CPU 11 reading and executing software (programs) from the ROM 12 or the HDD 14, and that the units are generated on the RAM 13. . In addition, a part or all of the above units may be replaced with a hardware circuit such as a processor that performs arithmetic processing.

通信部111は、CPU11によってROM12から読み出した命令を実行することにより実現される。通信部111は、専用の通信路300を経由して操作部20と接続し、操作部20との間でデータを送受信する。例えば、通信部111は、操作部20で受け付けた各種の操作入力を受信して、対応する各部に受け渡す。また、通信部111は、各種の情報(例えば受け付けた入力に応じた情報、MFP1の動作状況を示す情報、設定状態などを示す情報など)を操作部20に表示させるためのデータを送信する。   The communication unit 111 is realized by executing a command read from the ROM 12 by the CPU 11. The communication unit 111 is connected to the operation unit 20 via the dedicated communication path 300 and transmits / receives data to / from the operation unit 20. For example, the communication unit 111 receives various operation inputs received by the operation unit 20 and passes them to the corresponding units. The communication unit 111 also transmits data for causing the operation unit 20 to display various types of information (for example, information corresponding to the received input, information indicating the operation status of the MFP 1, information indicating a setting state, and the like).

また通信部111は、通信I/F15を介してネットワーク30を経由して、外部装置(クライアントPCなど)との間でデータを送受信して、対応する各部に受け渡す。例えば、通信部111は、外部装置から機能を実現するための指示やデータを受信して、対応する各部に受け渡す。   The communication unit 111 transmits / receives data to / from an external apparatus (client PC or the like) via the communication I / F 15 via the network 30 and transfers the data to corresponding units. For example, the communication unit 111 receives an instruction or data for realizing a function from an external device and passes it to each corresponding unit.

起動制御部112は、CPU11によってROM12から読み出した命令を実行することにより実現される。起動制御部112は、後述する操作部20のアプリ連携部217、アプリ起動制御部220、及び同期処理部221の制御の下で、アプリ連携部217からのアプリ起動要求に対応する操作部20で動作させる第1のアプリケーションを起動する前に、操作部20の第1のオペレーティングシステム上で動作する第1のアプリケーションに対して、本体部10の第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる制御を行う。すなわち、起動制御部112は、操作部20で起動させるアプリに対応する本体部10で起動させるアプリを起動させて同期させる処理を行う。本実施形態では、起動制御部112は、操作部20で起動させるアプリが本体部10の機能を使用するアプリであった場合に同期させる処理を行う。   The activation control unit 112 is realized by executing a command read from the ROM 12 by the CPU 11. The activation control unit 112 is an operation unit 20 corresponding to an application activation request from the application cooperation unit 217 under the control of an application cooperation unit 217, an application activation control unit 220, and a synchronization processing unit 221 of the operation unit 20 described later. Before starting the first application to be operated, the second application that operates on the second operating system of the main body unit 10 with respect to the first application that operates on the first operating system of the operation unit 20 Control to synchronize. That is, the activation control unit 112 performs processing for activating and synchronizing an application to be activated on the main body unit 10 corresponding to an application to be activated on the operation unit 20. In the present embodiment, the activation control unit 112 performs processing to be synchronized when the application activated by the operation unit 20 is an application that uses the function of the main body unit 10.

具体的には、予め登録されたアプリケーションの実行順を示すワークフローに基づいて、受け付けたアプリ起動要求に対応する操作部20で起動させる第1のアプリケーションが、例えば、本体部10の機能を使用する「コピー」アプリである場合、起動制御部112は、まず、アプリ連携部217の同期処理部221から、操作部20の「コピー」アプリに対応する本体部10のコピーアプリ(第2のアプリケーション)の起動要求を受け付けて、本体部10でコピーアプリを起動させる。そして、起動制御部112は、コピーアプリを起動させた後、コピーアプリの起動要求に対する応答であるコピーアプリ起動完了通知をアプリ連携部217の同期処理部221に対して送信する制御を行う。すなわち、起動制御部112は、操作部20のアプリ連携部217の同期処理部221の制御の下で、コピーアプリ(第2のアプリケーション)を起動させることで、操作部20のコピーアプリ(第1のアプリケーション)に対して本体部10のコピーアプリ(第2のアプリケーション)を同期させる制御を行う。これにより、操作部20のコピーアプリに対して本体部10のコピーアプリを同期させる処理を行っている。   Specifically, the first application that is activated by the operation unit 20 corresponding to the received application activation request uses, for example, the function of the main body unit 10 based on the workflow indicating the execution order of the applications registered in advance. In the case of a “copy” application, the activation control unit 112 first copies from the synchronization processing unit 221 of the application cooperation unit 217 to the copy application (second application) of the main body unit 10 corresponding to the “copy” application of the operation unit 20. In response to the activation request, the main body unit 10 activates the copy application. Then, after starting the copy application, the activation control unit 112 performs control to transmit a copy application activation completion notification, which is a response to the copy application activation request, to the synchronization processing unit 221 of the application cooperation unit 217. That is, the activation control unit 112 activates the copy application (second application) under the control of the synchronization processing unit 221 of the application cooperation unit 217 of the operation unit 20, thereby causing the copy application (first application) of the operation unit 20 to be activated. Control) to synchronize the copy application (second application) of the main unit 10 with the application. Thereby, the process which synchronizes the copy application of the main-body part 10 with the copy application of the operation part 20 is performed.

また、アプリ起動要求に対応する操作部20で起動させる第1のアプリケーションが、例えば、本体部10の機能を使用しない「メール」アプリである場合、起動制御部112は、まず、アプリ連携部217の同期処理部221から操作部20の「メール」アプリに対応する本体部10のホームアプリ(第2のアプリケーション)の起動要求を受け付けて、本体部10でホームアプリを起動させる。そして、起動制御部112は、ホームアプリを起動させた後、ホームアプリの起動要求に対する応答である、ホームアプリ起動完了通知をアプリ連携部217の同期処理部221に対して送信する制御を行う。すなわち、起動制御部112は、操作部20のアプリ連携部217の同期処理部221の制御の下で、ホームアプリ(第2のアプリケーション)を起動させることで、操作部20のホームアプリ(第1のアプリケーション)に対して本体部10のホームアプリ(第2のアプリケーション)を同期させる制御を行う。これにより、操作部20のホームアプリに対して本体部10のホームアプリを同期させる処理を行っている。なお、ホームアプリとは、操作部20の複数の機能を利用するための操作受付画面を呼び出す初期画面を起動させるアプリケーション(ホームアプリ)に対応する本体部10のアプリケーション(ホームアプリ)である。   In addition, when the first application activated by the operation unit 20 corresponding to the application activation request is, for example, a “mail” application that does not use the function of the main body unit 10, the activation control unit 112 first performs the application cooperation unit 217. In response to the activation request for the home application (second application) of the main body unit 10 corresponding to the “mail” application of the operation unit 20 from the synchronization processing unit 221, the home application is activated on the main body unit 10. Then, after starting the home application, the activation control unit 112 performs control to transmit a home application activation completion notification, which is a response to the activation request for the home application, to the synchronization processing unit 221 of the application cooperation unit 217. That is, the activation control unit 112 activates the home application (second application) under the control of the synchronization processing unit 221 of the application cooperation unit 217 of the operation unit 20, and thereby the home application (first application) of the operation unit 20. Control) to synchronize the home application (second application) of the main unit 10 with the application. Thereby, the process which synchronizes the home application of the main-body part 10 with respect to the home application of the operation part 20 is performed. The home application is an application (home application) of the main body unit 10 corresponding to an application (home application) that activates an initial screen that calls an operation reception screen for using a plurality of functions of the operation unit 20.

記憶部113は、ROM12またはHDD14に対応する。記憶部113は、各種のデータを記憶する。記憶部113は、例えば、本体部10で起動する各種のアプリケーションを記憶する。アプリケーションとして、例えば、レガシーコピー、レガシースキャナ、レガシーファックス、レガシープリンタ、ホームなどのアプリケーションを記憶する。   The storage unit 113 corresponds to the ROM 12 or the HDD 14. The storage unit 113 stores various data. The storage unit 113 stores, for example, various applications that are activated in the main body unit 10. For example, applications such as legacy copy, legacy scanner, legacy fax, legacy printer, and home are stored as applications.

また、記憶部113は、MFP1の識別情報(機種、機番、IDなど)を記憶する。   Further, the storage unit 113 stores identification information (model, machine number, ID, etc.) of the MFP 1.

次に、MFP1の操作部20側の機能について説明する。図3に示すように、操作部20は、CPU21がプログラムを実行することで実現される機能(モジュール)である通信部211と、入出力部212と、表示部213と、表示制御部214と、操作受付部215と、通知部216と、アプリ連携部217と、記憶部218とを備える。アプリ連携部217は、アプリ起動制御部220と、同期処理部221と、アプリ登録部222とを備える。上記各部の一部はCPU21がROM22又はフラッシュメモリ24からソフトウェア(プログラム)を読み出して実行することにより上記各部がRAM23上にロードされ、上記各部がRAM23上に生成されるソフトウェア(プログラム)であってもよい。また、上記各部の一部を、演算処理を行うプロセッサなどのハードウェア回路で置き換えてもよい。   Next, functions on the operation unit 20 side of the MFP 1 will be described. As illustrated in FIG. 3, the operation unit 20 includes a communication unit 211, an input / output unit 212, a display unit 213, and a display control unit 214 that are functions (modules) realized by the CPU 21 executing a program. , An operation receiving unit 215, a notification unit 216, an application cooperation unit 217, and a storage unit 218. The application cooperation unit 217 includes an application activation control unit 220, a synchronization processing unit 221, and an application registration unit 222. Some of the above-described units are software (programs) that are loaded onto the RAM 23 when the CPU 21 reads out and executes software (programs) from the ROM 22 or the flash memory 24, and are generated on the RAM 23. Also good. Further, a part of each of the above parts may be replaced with a hardware circuit such as a processor that performs arithmetic processing.

通信部211は、CPU21によってROM22から読み出した命令を実行することにより実現される。通信部211は、専用の通信路300を経由して本体部10と接続し、本体部10との間でデータを送受信する。例えば、通信部211は、操作部20で起動させるコピーアプリに対応するコピーアプリの起動要求を本体部10の起動制御部112に対して送信する。そして、通信部211は、コピーアプリの起動要求に対する応答である、コピーアプリ起動完了通知を受信する。   The communication unit 211 is realized by executing a command read from the ROM 22 by the CPU 21. The communication unit 211 is connected to the main unit 10 via the dedicated communication path 300 and transmits / receives data to / from the main unit 10. For example, the communication unit 211 transmits a copy application activation request corresponding to the copy application activated by the operation unit 20 to the activation control unit 112 of the main body unit 10. Then, the communication unit 211 receives a copy application activation completion notification, which is a response to the copy application activation request.

また、通信部211は、操作部20で起動させる、例えば、ホームアプリの起動要求を本体部10の起動制御部112に対して送信する。そして、通信部211は、ホームアプリの起動要求に対する応答である、ホームアプリ起動完了通知を受信する。   In addition, the communication unit 211 transmits, for example, a home application activation request to be activated by the operation unit 20 to the activation control unit 112 of the main body unit 10. Then, the communication unit 211 receives a home application activation completion notification, which is a response to the home application activation request.

また、通信部211は、例えば、操作部20で受け付けた各種の入力を本体部10に送信する。また、通信部211は、例えば、各種の情報(例えば受け付けた入力に応じた情報、MFP1の動作状況を示す情報、設定状態などを示す情報など)を操作部20に表示させるためのデータを受信して、対応する各部に受け渡す。   Further, the communication unit 211 transmits, for example, various inputs received by the operation unit 20 to the main body unit 10. Further, the communication unit 211 receives, for example, data for causing the operation unit 20 to display various types of information (for example, information corresponding to the received input, information indicating the operation status of the MFP 1, information indicating a setting state, etc.). To each corresponding part.

また、通信部211は、通信I/F25を介してネットワーク30を経由して、外部装置(クライアントPCなど)との間でデータを送受信して、対応する各部に受け渡す。具体的には、通信部211は、外部装置から機能を実現するための指示やデータを受信して、対応する各部に受け渡す。   In addition, the communication unit 211 transmits / receives data to / from an external device (client PC or the like) via the communication I / F 25 via the network 30 and transfers the data to corresponding units. Specifically, the communication unit 211 receives an instruction or data for realizing a function from an external device, and passes it to each corresponding unit.

入出力部212は、各種データの入出力を行う。例えば、入出力部212は、ネットワークに接続された外部装置(ストレージ)にデータの保存を行ったり、データの読み出しを行ったりする。また、入出力部212は、記憶装置にデータの入出力を行う。   The input / output unit 212 inputs and outputs various data. For example, the input / output unit 212 stores data in an external device (storage) connected to the network or reads out data. The input / output unit 212 inputs / outputs data to / from the storage device.

表示部213は、操作パネル27の表示画面に対応する。表示部213は、表示制御部214の制御の下で、例えば、利用者に対して情報を提供するための表示情報(画面)を表示する。また、表示部213は、例えば、常時表示される特定の機能を利用するための画面を表示する。   The display unit 213 corresponds to the display screen of the operation panel 27. The display unit 213 displays display information (screen) for providing information to the user, for example, under the control of the display control unit 214. The display unit 213 displays, for example, a screen for using a specific function that is always displayed.

また、表示部213は、例えば、後述するアプリ起動制御部220で起動されたアプリケーションの操作受付画面(UI(User Interface)画面)を表示する。また例えば、表示部213は、アプリケーションを実行する順番を受け付ける画面を表示する。また例えば、表示部213は、操作部20の複数の機能を利用するための操作受付画面を呼び出す初期画面(ホーム画面)を表示する(図9参照)。   Further, the display unit 213 displays, for example, an operation reception screen (UI (User Interface) screen) of an application activated by the application activation control unit 220 described later. Further, for example, the display unit 213 displays a screen for accepting the order of executing the applications. Further, for example, the display unit 213 displays an initial screen (home screen) for calling an operation reception screen for using a plurality of functions of the operation unit 20 (see FIG. 9).

表示制御部214は、CPU21によってROM22から読み出した命令を実行することにより実現される。表示制御部214は、CPU21で実行されるLauncherとして実現できる。Launcherはホーム画面を表示し、ユーザが操作部の各アプリを起動するUIを提供する。例えば、表示制御部214は、例えば、利用者に対して情報を提供するための表示情報(画面)を表示部213に表示させる制御を行う。また例えば、表示制御部214は、アプリ連携部217の制御の下、後述するアプリ登録部222でアプリケーションの登録を受け付ける場合に、最後に受け付けたアプリケーションを実行した後に実行可能なアプリケーションだけを表示部213に表示させる制御を行う。   The display control unit 214 is realized by executing a command read from the ROM 22 by the CPU 21. The display control unit 214 can be realized as a launcher executed by the CPU 21. The Launcher displays a home screen and provides a UI for the user to activate each application of the operation unit. For example, the display control unit 214 performs control to display display information (screen) for providing information to the user on the display unit 213, for example. Also, for example, when the application registration unit 222 receives an application registration under the control of the application cooperation unit 217, the display control unit 214 displays only the applications that can be executed after executing the last received application. Control to display on 213 is performed.

また、表示制御部214は、アプリ登録部222で、実行順にアプリケーションをワークフローに登録した後に、操作部20の複数の機能を利用するための操作受付画面(UI画面)を呼び出す初期画面(ホーム画面)に、ワークフローを呼び出すための画像を配置する制御を行う(図17参照)。本実施形態では、例えば、操作部20のアプリ層201に搭載されているアプリに対応するアイコンをホーム画面に表示させる制御を行う。   The display control unit 214 registers an application in the workflow in the execution order in the application registration unit 222 and then calls an initial screen (home screen) for calling an operation reception screen (UI screen) for using a plurality of functions of the operation unit 20. ) Is controlled to arrange an image for calling a workflow (see FIG. 17). In the present embodiment, for example, control is performed to display an icon corresponding to an application installed in the application layer 201 of the operation unit 20 on the home screen.

また、表示制御部214は、アプリ起動制御部220で起動されたアプリケーションの操作受付画面(UI画面)を表示部213に表示させる制御を行う。具体的には、表示制御部214は、後述するアプリ起動制御部220で起動されたアプリケーションが、例えば、「アプリ連携」アプリである場合、アプリ起動制御部220は、「アプリ連携」アプリを起動させる処理を行い、表示制御部214は、後述する図10及び図11に示すような「アプリ連携」アプリの操作受付画面を表示部213に表示させる制御を行う。つまり、アプリ起動制御部220が操作部20で「アプリ連携」アプリを起動させると、表示制御部214は、表示部213に「アプリ連携」アプリの操作受付画面を表示させる制御を行う。   In addition, the display control unit 214 performs control for causing the display unit 213 to display an operation reception screen (UI screen) of an application activated by the application activation control unit 220. Specifically, when the application activated by the application activation control unit 220 (to be described later) is an “application cooperation” application, for example, the application activation control unit 220 activates the “application cooperation” application. The display control unit 214 performs control for causing the display unit 213 to display an operation reception screen of an “application cooperation” application as illustrated in FIGS. That is, when the application activation control unit 220 activates the “application cooperation” application on the operation unit 20, the display control unit 214 performs control to display the operation reception screen of the “application cooperation” application on the display unit 213.

また例えば、表示制御部214は、記憶部218に記憶されたデータにアクセスするための識別情報(QRコード(登録商標))を表示部213に表示させる制御を行う。   Further, for example, the display control unit 214 performs control to display identification information (QR code (registered trademark)) for accessing data stored in the storage unit 218 on the display unit 213.

操作受付部215は、CPU21によってROM22から読み出した命令を実行することにより実現される。操作受付部215は、各種の入力を受け付ける。操作受付部215は、例えば、操作部20の表示部213に表示された操作受付画面に応じた操作入力を受け付ける。具体的には、操作受付部215は、タッチパネル機能が搭載された操作パネル27の画面(表示部213の画像が表示される面)に対するユーザのタッチ操作による入力を受け付ける。すなわち、操作部20のアプリの操作受付画面が表示されている状態において、何れかのアイコンのタッチ操作が行われたアイコンの操作入力を受け付ける。そして、操作受付部215は、受け付けた操作に対応する処理を通知部216を介して通知する。   The operation receiving unit 215 is realized by executing a command read from the ROM 22 by the CPU 21. The operation reception unit 215 receives various inputs. For example, the operation reception unit 215 receives an operation input corresponding to the operation reception screen displayed on the display unit 213 of the operation unit 20. Specifically, the operation accepting unit 215 accepts an input by a user's touch operation on the screen of the operation panel 27 equipped with the touch panel function (the surface on which the image of the display unit 213 is displayed). That is, in the state where the operation reception screen of the application of the operation unit 20 is displayed, an operation input of an icon in which a touch operation of any icon is performed is received. Then, the operation reception unit 215 notifies the process corresponding to the received operation via the notification unit 216.

また、操作受付部215は、表示部213に常時表示される特定の機能を利用するための画面(ファンクションキー(ソフトウェアキー))が押下された場合、当該画面(ファンクションキー(ソフトウェアキー))に対応付けられた特定の機能を利用するための第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を受け付ける。その後、操作受付部215は、受け付けた第1のアプリケーションの起動をアプリ起動制御部220に対して通知部216を介して通知する。具体的には、操作受付部215は、例えば、コピーアプリに対応付けられたファンクションキー(コピーキー231、図9参照)の画面が押下された場合、コピーアプリの起動を受け付ける。その後、操作受付部215は、コピーアプリ起動をアプリ起動制御部220に対して通知部216を介して通知する。   In addition, when a screen (function key (software key)) for using a specific function constantly displayed on the display unit 213 is pressed, the operation reception unit 215 displays the screen (function key (software key)). The activation of the first application operating on the first operating system for using the associated specific function is accepted. Thereafter, the operation reception unit 215 notifies the application activation control unit 220 of the activation of the received first application via the notification unit 216. Specifically, for example, when the screen of a function key (copy key 231, see FIG. 9) associated with a copy application is pressed, the operation reception unit 215 receives the activation of the copy application. Thereafter, the operation accepting unit 215 notifies the application activation control unit 220 of the copy application activation via the notification unit 216.

また、操作受付部215は、表示部213に常時表示される特定の機能を利用するための画面(ファンクションキー)のストップキー236(図9参照)が押下された場合、アプリケーションの停止を受け付ける。その後、操作受付部215は、アプリケーションのジョブを一時停止させるアプリ停止通知を本体部10の起動制御部112に対して通知部216を介して通知する。   The operation accepting unit 215 accepts the stop of the application when a stop key 236 (see FIG. 9) on a screen (function key) for using a specific function constantly displayed on the display unit 213 is pressed. Thereafter, the operation reception unit 215 notifies the activation control unit 112 of the main body unit 10 via the notification unit 216 of an application stop notification for temporarily stopping the application job.

通知部216は、CPU21によってROM22から読み出した命令を実行することにより実現される。通知部216は、操作部20の操作受付部215で受け付けた各種の操作に対応する処理を通知する。   The notification unit 216 is realized by executing a command read from the ROM 22 by the CPU 21. The notification unit 216 notifies processing corresponding to various operations received by the operation reception unit 215 of the operation unit 20.

例えば、通知部216は、操作部20の操作受付部215で受け付けた第1のアプリケーションの起動をアプリ起動制御部220に対して通知する。   For example, the notification unit 216 notifies the application activation control unit 220 of the activation of the first application received by the operation reception unit 215 of the operation unit 20.

また、例えば、通知部216は、操作部20の操作受付部215で受け付けたアプリケーションのジョブを一時停止させるアプリ停止通知を本体部10の起動制御部112に対して通知する。   Further, for example, the notification unit 216 notifies the activation control unit 112 of the main body unit 10 of an application stop notification for temporarily suspending the application job received by the operation reception unit 215 of the operation unit 20.

アプリ連携部217は、アプリ起動制御部220と、同期処理部221と、アプリ登録部222とを含む。アプリ連携部217、アプリ起動制御部220、同期処理部221、アプリ登録部222は、CPU21によってROM22から読み出した命令を実行することにより実現される。また、アプリ連携部217は、アプリ連携の仲介を行うモジュールと捉えることもできる。アプリ連携部217は、アプリ連携のためのアプリケーションを実行する順番を受け付けてワークフローを作成する。そして、ワークフローに登録された順番にアプリケーションの処理を実行させる制御を行う。アプリ連携部217は、アプリケーションの実行時には操作部20に表示されるアプリ(起動中のアプリ)切り替えと本体部(コントローラ)10で起動中のアプリ切り替えを制御して操作部20のアプリと、本体部10のアプリとの同期処理を行う。   The application cooperation unit 217 includes an application activation control unit 220, a synchronization processing unit 221, and an application registration unit 222. The application cooperation unit 217, the application activation control unit 220, the synchronization processing unit 221, and the application registration unit 222 are realized by executing instructions read from the ROM 22 by the CPU 21. In addition, the application cooperation unit 217 can be regarded as a module that mediates application cooperation. The application cooperation unit 217 accepts the order in which applications for application cooperation are executed and creates a workflow. Then, control is performed to execute application processing in the order registered in the workflow. The application cooperation unit 217 controls the switching of the application (active application) displayed on the operation unit 20 and the switching of the active application on the main unit (controller) 10 when executing the application, Synchronization processing with the application of the unit 10 is performed.

例えば、アプリ連携部217は、予め登録されたアプリケーションの実行順を示すワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行う。すなわち、アプリ連携部217は、ワークフローに登録された順番どおりに操作部20で実行するアプリの実行要求をアプリ起動制御部220に送信する。   For example, the application cooperation unit 217 performs control to activate applications in order and execute processing based on a workflow indicating the execution order of applications registered in advance. That is, the application cooperation unit 217 transmits an application execution request to be executed by the operation unit 20 to the application activation control unit 220 in the order registered in the workflow.

また、アプリ連携部217は、ワークフローに登録された順番にアプリケーションが処理したデータを、記憶部218に記憶させる制御を行う。   In addition, the application cooperation unit 217 performs control to store in the storage unit 218 data processed by the application in the order registered in the workflow.

また、アプリ連携部217は、ワークフローに登録された順番にアプリケーションが処理したデータに識別情報を付与して保持し、続けて起動される次の順番のアプリケーションに対して該データの識別情報を受け渡す。   In addition, the application cooperation unit 217 assigns and holds identification information to data processed by the application in the order registered in the workflow, and receives the identification information of the data for the next sequential application that is subsequently started. hand over.

次に、アプリ起動制御部220について説明する。アプリ起動制御部220は、アプリ連携部217からアプリケーションの実行順を示すワークフローに基づいて、順に第1のオペレーティングシステム上で動作するアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、起動させるアプリケーションのxmlコード内にコード含有アプリ対応情報が記述されているか否かを解析して、操作部20で起動させるアプリが本体部10の機能(アプリ)を使用するアプリであるか否かを判断し、本体部10の機能(アプリ)を使用するアプリである場合(アプリのxmlコード内にコード含有アプリ対応情報が記述されている場合)には同期処理部221に対して、操作部20で起動させるアプリに対応する本体部10で起動させるアプリを起動させて同期させる処理を要求する。すなわち、アプリ起動制御部220は、操作部20側で起動させるアプリに対応する本体部10側で起動させるアプリが、「ホームアプリ」でない場合に、同期処理部221に対して、操作部20で起動させるアプリに対応する本体部10で起動させるアプリを起動させて同期させる処理を要求する。   Next, the application activation control unit 220 will be described. When the application activation control unit 220 receives an application activation request that sequentially requests activation of an application that operates on the first operating system based on the workflow indicating the execution order of the applications from the application cooperation unit 217, the application activation control unit 220 activates the application Analyzing whether or not the code-containing application correspondence information is described in the xml code, it is determined whether or not the application activated by the operation unit 20 is an application that uses the function (application) of the main body unit 10. When the application uses the function (application) of the main unit 10 (when the code-containing application correspondence information is described in the xml code of the application), the operation unit 20 starts the synchronization processing unit 221. A process for starting and synchronizing an application to be started on the main body unit 10 corresponding to the application to be requested is requested. That is, when the application to be activated on the main body 10 side corresponding to the application to be activated on the operation unit 20 side is not the “home application”, the application activation control unit 220 performs the operation on the operation unit 20 with respect to the synchronization processing unit 221. A process for starting and synchronizing an application to be started in the main body unit 10 corresponding to the application to be started is requested.

次に、アプリ起動制御部220は、同期処理部221で操作部20の第1のアプリケーション(例えばスキャンアプリ)と、本体部10の第2のアプリケーション(例えばスキャンアプリ)を同期させる処理が行われた後に、アプリ連携部217から処理の実行を要求された操作部20で動作させる第1のアプリケーション(スキャンアプリ)を起動させる制御を行う。そして、アプリ起動制御部220は、処理の実行を要求された第1のアプリケーション(スキャンアプリ)の処理の実行が完了した後に、本体部10の起動制御部112に対して本体部10側でホームアプリを起動させる要求をする制御を行う。本体部10でホームアプリを起動させることで、次に操作部20側で起動させるアプリが、本体部10の機能(アプリ)を使用しないアプリであった場合、操作部20で起動させるアプリと、本体部10で起動させるアプリとの同期がとれないという不具合が発生しないことになる。   Next, the application activation control unit 220 performs a process of synchronizing the first application (for example, the scan application) of the operation unit 20 and the second application (for example, the scan application) of the main body unit 10 with the synchronization processing unit 221. After that, control is performed to activate the first application (scan application) that is operated by the operation unit 20 requested to execute the process from the application cooperation unit 217. Then, after the execution of the process of the first application (scan application) requested to execute the process is completed, the application activation control unit 220 sets the home on the main body unit 10 side with respect to the activation control unit 112 of the main body unit 10. Control to request to start the app. By starting the home application on the main body unit 10, if the next application to be started on the operation unit 20 side is an application that does not use the function (application) of the main body unit 10, There will be no inconvenience that the main unit 10 cannot synchronize with the application to be activated.

また、アプリ起動制御部220は、操作部20で起動させる第1のアプリケーション内に含まれる、当該アプリケーションごとに、本体部10で起動させるアプリケーションが対応付いたコード含有アプリ対応情報(アプリケーションのxmlコード内のコード含有アプリ対応情報)を解析(参照)して、操作部20で起動させるアプリケーションに対応する本体部10で起動させるアプリケーションを指定したアプリ起動要求を本体部10に対して送信する制御を行う。   In addition, the application activation control unit 220 includes, for each application, a code-containing application correspondence information (an xml code of an application) associated with an application activated by the main body unit 10 included in the first application activated by the operation unit 20. Control for transmitting an application activation request designating an application to be activated in the main body unit 10 corresponding to an application activated in the operation unit 20 to the main body unit 10. Do.

例えば、第1のアプリケーションがコピーアプリの場合には、コピーアプリのxmlコード内に「Copy」というコード含有アプリ対応情報(xmlコード)が記述されている。アプリ起動制御部220は、xmlコードを解析(参照)して「Copy」が記述されていれば本体部10のアプリ「コピー」を指定した情報と判断して、本体部10のアプリ「コピー」を指定したアプリ起動要求を本体部10に対して送信する。また、例えば、第1のアプリケーションがスキャナアプリの場合には、スキャナアプリのxmlコード内に「Scan」というコード含有アプリ対応情報(xmlコード)が記述されている。アプリ起動制御部220は、xmlコードを解析(参照)して「Scan」が記述されていれば本体部10のアプリ「スキャナ」を指定した情報と判断して、本体部10のアプリ「スキャナ」を指定したアプリ起動要求を本体部10に対して送信する。また、例えば、第1のアプリケーションがファックスアプリの場合には、ファックスアプリのxmlコード内に「Fax」というコード含有アプリ対応情報(xmlコード)が記述されている。アプリ起動制御部220は、xmlコードを解析(参照)して「Fax」が記述されていれば本体部10のアプリ「ファックス」を指定した情報と判断して、本体部10のアプリ「ファックス」を指定したアプリ起動要求を本体部10に対して送信する。また、例えば、第1のアプリケーションがホームアプリの場合には、ホームアプリのxmlコード内に「Home」というコード含有アプリ対応情報(xmlコード)が記述されている。アプリ起動制御部220は、xmlコードを解析(参照)して「Home」が記述されていれば本体部10のアプリ「ホーム」を指定した情報と判断して、本体部10のアプリ「ホーム」を指定したアプリ起動要求を本体部10に対して送信する。   For example, when the first application is a copy application, code-containing application correspondence information (xml code) “Copy” is described in the xml code of the copy application. The application activation control unit 220 analyzes (refers to) the xml code, and if “Copy” is described, the application activation control unit 220 determines that the application “copy” of the main unit 10 is specified, and determines that the application “copy” of the main unit 10 Is transmitted to the main body unit 10. For example, when the first application is a scanner application, code-containing application correspondence information (xml code) “Scan” is described in the xml code of the scanner application. The application activation control unit 220 analyzes (refers to) the xml code and, if “Scan” is described, determines that the application “scanner” of the main unit 10 is designated, and determines that the application “scanner” of the main unit 10 Is transmitted to the main body unit 10. For example, when the first application is a fax application, the code-containing application correspondence information (xml code) “Fax” is described in the xml code of the fax application. The application activation control unit 220 analyzes (refers to) the xml code, and if “Fax” is described, the application activation control unit 220 determines that the application “fax” of the main unit 10 is designated, and determines that the application “fax” of the main unit 10 Is transmitted to the main body unit 10. For example, when the first application is a home application, code-containing application correspondence information (xml code) “Home” is described in the xml code of the home application. The application activation control unit 220 analyzes (refers to) the xml code, and if “Home” is described, the application activation control unit 220 determines that the application “home” of the main unit 10 is specified, and determines that the application “home” of the main unit 10 Is transmitted to the main body unit 10.

また、例えば、第1のアプリケーションがメールアプリの場合には、本体部10の機能を利用しないので、メールアプリのxmlコード内にはコード含有アプリ対応情報が記述されていない。アプリ起動制御部220は、xmlコード内を解析(参照)してコード含有アプリ対応情報が記述されていない場合には本体部10の「ホーム」を指定した情報と判断して、本体部10の「ホーム」を指定したアプリ起動要求を本体部10に対して送信する。すなわち、アプリ起動制御部220は、アプリのxmlコード内にコード含有アプリ対応情報が記述されていない場合には、全て本体部10の「ホーム」を指定した情報と判断して、本体部10の「ホーム」を指定したアプリ起動要求を本体部10に対して送信する。   For example, when the first application is a mail application, the function of the main body unit 10 is not used, and therefore the code-containing application correspondence information is not described in the xml code of the mail application. The application activation control unit 220 analyzes (refers to) the inside of the xml code and determines that the “home” of the main body unit 10 is designated when the code-containing application correspondence information is not described. An application activation request designating “Home” is transmitted to the main unit 10. That is, when the code-containing application correspondence information is not described in the xml code of the application, the application activation control unit 220 determines that all of the information specifies the “home” of the main body unit 10, and An application activation request designating “Home” is transmitted to the main unit 10.

このように、アプリ起動制御部220は、ワークフローに基づいてアプリ連携部217から操作部20で第1のアプリケーションを起動させるアプリ起動要求を受け付けた場合、アプリのxmlコード内のコード含有アプリ対応情報(xmlコード)を解析(参照)して、本体部10で起動させるアプリケーションを指定したアプリ起動要求を本体部10に送信する。   As described above, when the application activation control unit 220 receives an application activation request for activating the first application with the operation unit 20 from the application cooperation unit 217 based on the workflow, the code-containing application correspondence information in the xml code of the application is received. (Xml code) is analyzed (referenced), and an application activation request specifying an application to be activated in the main body 10 is transmitted to the main body 10.

また、アプリ起動制御部220は、記憶部218に記憶された操作部20で起動させるアプリケーションごとに、本体部10で起動させるアプリケーションを対応付けたアプリ対応情報を参照して、操作部20で起動させるアプリケーションに対応する本体部10で起動させるアプリケーションを指定したアプリ起動要求を本体部10に対して送信する制御を行うようにしてもよい。すなわち、アプリ起動制御部220は、上述したように、コード含有アプリ対応情報(アプリケーションのxmlコード内のコード含有アプリ対応情報)を解析(参照)して本体部10で起動させるアプリケーションを指定するのではなく、予め記憶部218に記憶されているアプリ対応情報を直接参照して本体部10で起動させるアプリケーションを指定したアプリ起動要求を送信することができる。   Further, the application activation control unit 220 refers to application correspondence information in which an application to be activated by the main body unit 10 is associated with each application activated by the operation unit 20 stored in the storage unit 218, and is activated by the operation unit 20. Control for transmitting an application activation request designating an application to be activated in the main body unit 10 corresponding to the application to be performed may be performed. That is, as described above, the application activation control unit 220 analyzes (refers to) the code-containing application correspondence information (code-containing application correspondence information in the xml code of the application) and designates an application to be activated on the main body unit 10. Instead, an application activation request designating an application to be activated in the main body unit 10 by directly referring to the application correspondence information stored in the storage unit 218 in advance can be transmitted.

ここで、図4を用いて、アプリ対応情報について説明する。図4は、アプリ対応情報の一例について説明する図である。図4に示すように、アプリ対応情報は、操作部20で起動させるアプリケーションごとに、本体部10で起動させるアプリケーションが対応付いた情報である。   Here, the application correspondence information will be described with reference to FIG. FIG. 4 is a diagram illustrating an example of the application correspondence information. As shown in FIG. 4, the application correspondence information is information in which an application activated by the main body unit 10 is associated with each application activated by the operation unit 20.

例えば、操作部20のアプリ「コピー」には本体部10のアプリ「コピー」が対応付いている。また例えば、操作部20のアプリ「スキャン」には本体部10のアプリ「スキャン」が対応付いている。また例えば、操作部20のアプリ「ファックス」には本体部10のアプリ「ファックス」が対応付いている。また例えば、操作部20のアプリ「メール」には本体部10のアプリ「ホーム」が対応付いている。また例えば、操作部20のアプリ「データ入出力」には本体部10のアプリ「ホーム」が対応付いている。このように、アプリ対応情報は、操作部20のアプリに本体部10のアプリが対応付いた情報である。従って、アプリ起動制御部220は、操作部20で起動させるアプリケーションごとに、本体部10で起動させるアプリケーションを対応付けた、図4に示したようなアプリ対応情報を直接参照して、本体部10で起動させるアプリケーションを指定したアプリ起動要求を送信することができる。   For example, the application “copy” of the operation unit 20 is associated with the application “copy” of the main body unit 10. For example, the application “scan” of the operation unit 20 is associated with the application “scan” of the main body unit 10. Further, for example, the application “fax” of the operation unit 20 is associated with the application “fax” of the main body unit 10. Further, for example, the application “mail” of the operation unit 20 is associated with the application “home” of the main body unit 10. Further, for example, the application “data input / output” of the operation unit 20 is associated with the application “home” of the main body unit 10. As described above, the application correspondence information is information in which the application of the main body unit 10 is associated with the application of the operation unit 20. Therefore, the application activation control unit 220 directly refers to the application correspondence information as illustrated in FIG. 4 in which the application activated by the main body unit 10 is associated with each application activated by the operation unit 20, and the main body unit 10 An application activation request specifying an application to be activated can be transmitted.

図3に戻り説明を続ける。同期処理部221は、CPU21で実行されるSDKサービス、OCSとして実現できる。SDK(Software Development Kit)サービスはコントローラ側の起動アプリをコピー、スキャンなどホーム以外のアプリにする要求を行う。OCS(オペレーションコントロールサービス)はコントローラ側の起動アプリをホームにする要求を行う。   Returning to FIG. 3, the description will be continued. The synchronization processing unit 221 can be realized as an SDK service or OCS executed by the CPU 21. The SDK (Software Development Kit) service makes a request to make the application on the controller side other than the home, such as copying and scanning. The OCS (Operation Control Service) makes a request to make the startup application on the controller side home.

同期処理部221は、アプリ連携部217のアプリ起動制御部220から、操作部20で起動させるアプリに対応する本体部10で起動させるアプリを起動させて同期させる処理の要求を受け付けて、操作部20の第1のオペレーティングシステム上で動作する第1のアプリケーションに対して、本体部10の第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う。例えば、同期処理部221は、操作部20での画像を読み込む「スキャン」アプリ(第1のアプリケーション)と、操作部20の「スキャン」アプリに対応する本体部10での「スキャン」アプリ(第2のアプリケーション)とを同期させる処理を行う。   The synchronization processing unit 221 receives, from the application activation control unit 220 of the application cooperation unit 217, a request for processing to activate and synchronize an application activated on the main body unit 10 corresponding to an application activated on the operation unit 20, and the operation unit A process of synchronizing the second application operating on the second operating system of the main body unit 10 with the first application operating on the first 20 operating systems is performed. For example, the synchronization processing unit 221 includes a “scan” application (first application) for reading an image on the operation unit 20 and a “scan” application (first application) on the main body unit 10 corresponding to the “scan” application on the operation unit 20. 2 application) is synchronized.

また、同期処理部221は、特定のアプリケーションを起動する場合に、操作部20の第1のアプリケーション(例えばスキャンアプリ)と、本体部10の第2のアプリケーション(スキャンアプリ)を同期させる処理を行う。特定のアプリケーションは、本体部10の機能を使用するアプリケーションである。すなわち、同期処理部221は、操作部20のアプリケーションが本体部10の機能(アプリケーション)を使用する場合に、上記の同期処理を行う。本体部10の機能(アプリケーション)を使用するアプリケーションとは、例えば、コピーアプリ、スキャナアプリ、ファックスアプリ、プリンタアプリ等であるが、これに限ることはなく任意である。なお、本体部10の機能(アプリケーション)を使用しないアプリケーションとしては、例えば、メールアプリ、QRコード(登録商標)アプリ、入出力アプリ(Docs Connect)、ブラウザアプリ、ギャラリーアプリ等であるが、これに限ることはなく任意である。   Further, the synchronization processing unit 221 performs a process of synchronizing the first application (for example, a scan application) of the operation unit 20 and the second application (the scan application) of the main body unit 10 when starting a specific application. . The specific application is an application that uses the function of the main body unit 10. That is, the synchronization processing unit 221 performs the above-described synchronization processing when the application of the operation unit 20 uses the function (application) of the main body unit 10. Examples of the application that uses the function (application) of the main body unit 10 include a copy application, a scanner application, a fax application, and a printer application, but are not limited thereto and are arbitrary. Examples of applications that do not use the function (application) of the main unit 10 include a mail application, a QR code (registered trademark) application, an input / output application (Docs Connect), a browser application, and a gallery application. It is not limited and is optional.

アプリ登録部222は、操作部20の第1のオペレーティングシステム上で動作させるアプリケーションを、実行する順番で受け付けて、実行順に受け付けたアプリケーションをアプリケーションの実行順を示すワークフローに登録する。アプリ登録部222は、アプリを実行順に登録したワークフローに識別情報を付けて記憶部218の所定領域に記憶させる。なお、登録されたワークフローは、ネットワークに接続された外部装置等のデータベースに記憶させるようにしてもよい。   The application registration unit 222 receives the applications to be operated on the first operating system of the operation unit 20 in the order of execution, and registers the applications received in the execution order in the workflow indicating the execution order of the applications. The application registration unit 222 adds identification information to a workflow in which applications are registered in the execution order, and stores the identification information in a predetermined area of the storage unit 218. The registered workflow may be stored in a database such as an external device connected to the network.

記憶部218は、ROM22またはフラッシュメモリ24に対応する。記憶部218は、操作部20で起動させるアプリケーションごとに、本体部10で起動させるアプリケーションを対応付けたアプリ対応情報を記憶する。なお、アプリ対応情報は、操作部20に新たなアプリが追加された場合や対応情報が変更された場合には更新される。なお、アプリ対応情報は、上記の図4を用いて説明したとおりである。   The storage unit 218 corresponds to the ROM 22 or the flash memory 24. The storage unit 218 stores application correspondence information in which an application to be activated by the main body unit 10 is associated with each application to be activated by the operation unit 20. The application correspondence information is updated when a new application is added to the operation unit 20 or when the correspondence information is changed. The application correspondence information is as described with reference to FIG.

記憶部218は、各種のデータを記憶する。記憶部218は、例えば、操作部20で起動する各種のアプリケーションを記憶する。アプリケーションとして、例えば、かんたんコピー、かんたんスキャナ、かんたんファックス、プリンタ、ホーム、アプリ連携アプリ等のアプリケーションを記憶する。   The storage unit 218 stores various data. The storage unit 218 stores, for example, various applications that are activated by the operation unit 20. As an application, for example, an application such as an easy copy, an easy scanner, an easy fax, a printer, a home, and an application cooperation application is stored.

次に、アプリを連携したワークフローの利用の概要について説明する。図5および図6は、アプリを連携したワークフローの利用の概要について説明する図である。図5に示すように、まずユーザは、ワークフローの作成を行う。ユーザが、ホーム画面からアプリ連携アイコン245(図9)を選択してワークフロー作成画面を起動させる(図10)。アプリ連携部217は、各アプリが提供する機能のリストを取得し、ユーザに提示する。ユーザは提示された機能を組み合わせ、ワークフローを作成して登録する。   Next, an outline of the use of a workflow in which applications are linked will be described. FIG. 5 and FIG. 6 are diagrams for explaining an outline of the use of a workflow in which applications are linked. As shown in FIG. 5, the user first creates a workflow. The user selects the application cooperation icon 245 (FIG. 9) from the home screen and activates the workflow creation screen (FIG. 10). The application cooperation unit 217 acquires a list of functions provided by each application and presents it to the user. The user combines the presented functions to create and register a workflow.

次に図6に示すように、ユーザが、作成して登録したワークフローの実行を要求する。アプリ連携部217は、ワークフローに登録されたとおりの順序で各アプリが提供する機能を実行する。つまり、ワークフローの順番で操作部20のアプリを起動させて処理を実行させる。   Next, as shown in FIG. 6, the user requests execution of the created and registered workflow. The application cooperation unit 217 executes a function provided by each application in the order as registered in the workflow. In other words, the application of the operation unit 20 is activated in the workflow order to execute the process.

次にワークフロー作成画面表示の流れを説明する。図7は、ワークフロー作成画面表示のシーケンス図である。   Next, the flow of the workflow creation screen display will be described. FIG. 7 is a sequence diagram of the workflow creation screen display.

ユーザは、操作受付画面を呼び出すホーム画面(図9)で、アプリ連携アイコン245を選択し、アプリ連携アプリの操作受付画面(図10)でワークフロー作成アイコン251を押下する(ステップS1)。操作受付部215は、ワークフロー作成画面表示を受け付けて(ステップS2)、表示制御部214にワークフロー作成画面表示を通知する(ステップS3)。表示制御部214は、ワークフロー作成画面起動要求をアプリ連携部217に送信する(ステップS4)。アプリ連携部217は、ワークフロー作成画面起動要求を受け付けて(ステップS5)、ワークフローに組み込み可能な機能(アプリ)のリストを記憶部218(Android F/W)に取得しに行き(ステップS6)、記憶部218が保持している機能(アプリ)のリストを取得する(ステップS7)。アプリ連携部217は、機能(アプリ)のリストを用いてワークフロー作成画面を起動させる制御を行う(ステップS8)。アプリ連携部217は、ワークフロー作成画面表示の指示を表示制御部214に行い(ステップS9)、表示制御部214は、ワークフロー作成画面を表示する(ステップS10)。   The user selects the application cooperation icon 245 on the home screen that calls the operation reception screen (FIG. 9), and presses the workflow creation icon 251 on the operation reception screen (FIG. 10) of the application cooperation application (step S1). The operation reception unit 215 receives the workflow creation screen display (step S2), and notifies the display control unit 214 of the workflow creation screen display (step S3). The display control unit 214 transmits a workflow creation screen activation request to the application cooperation unit 217 (step S4). The application cooperation unit 217 receives the workflow creation screen activation request (step S5), goes to the storage unit 218 (Android F / W) to obtain a list of functions (applications) that can be incorporated into the workflow (step S6), A list of functions (applications) held by the storage unit 218 is acquired (step S7). The application cooperation unit 217 performs control to activate the workflow creation screen using the function (application) list (step S8). The application cooperation unit 217 instructs the display control unit 214 to display the workflow creation screen (step S9), and the display control unit 214 displays the workflow creation screen (step S10).

上記のアプリ連携部217が取得する機能(アプリ)のリストデータの実体は、実際にそれぞれの機能の処理を担うアプリ(例えばスキャンであれば操作部20のスキャンアプリ)のメタデータに記載されており、以下に示す情報を持っている。図8は、各機能のメタデータの一例を示す図である。図8に示すように、機能のメタデータは、項目と値が対応付いた情報である。図8の例では、名前は「任意の文字列」、入力データ形式は[「なし」もしくは「任意の文字列」もしくは「全て」もしくは「任意のファイル形式(例:PFD、PNG)」]、出力データ形式は[「なし」もしくは「任意の文字列」もしくは「全て」もしくは「任意のファイル形式(例:PFD、PNG)」]、使用するコントローラ側の機能は、[「なし」もしくは「コピー、スキャン等のコントローラ側のアプリ」]を示している。   The substance of the list data of the functions (applications) acquired by the application cooperation unit 217 is described in the metadata of the application actually responsible for the processing of each function (for example, the scan application of the operation unit 20 for scanning). And has the following information: FIG. 8 is a diagram illustrating an example of metadata of each function. As shown in FIG. 8, the function metadata is information in which items and values are associated with each other. In the example of FIG. 8, the name is “arbitrary character string”, the input data format is [“none” or “arbitrary character string” or “all” or “arbitrary file format (eg, PFD, PNG)”], The output data format is [“None”, “Any character string”, “All”, or “Any file format (eg PFD, PNG)”], and the function on the controller side is [None ”or“ Copy ” , An application on the controller side such as a scan "].

図9は、操作部の複数の機能を利用するための操作受付画面(UI画面)を呼び出す初期画面(ホーム画面)の一例を示す図である。   FIG. 9 is a diagram illustrating an example of an initial screen (home screen) for calling an operation reception screen (UI screen) for using a plurality of functions of the operation unit.

図9の例は、操作部20の複数の機能を利用するための操作受付画面(UI画面)を呼び出す初期画面(ホーム画面)の一例である。図9の例は、ホーム画面の一例であるため、表示部213の中央部分には、操作部20の複数の機能を利用するためのアイコン241〜247が表示されている。すなわち、コピーアイコン241、ファックスアイコン242、スキャンアイコン243、プリンタアイコン244、アプリ連携アイコン245、アプリBアイコン246、ブラウザアイコン247の各アプリを起動させるためのアイコン241〜247が表示されている。これらのアイコン241〜247が押下されることでアイコン241〜247に対応する各アプリが起動される。   The example of FIG. 9 is an example of an initial screen (home screen) that calls an operation reception screen (UI screen) for using a plurality of functions of the operation unit 20. The example of FIG. 9 is an example of the home screen, and icons 241 to 247 for using a plurality of functions of the operation unit 20 are displayed in the center portion of the display unit 213. That is, icons 241 to 247 for starting up the copy icon 241, the fax icon 242, the scan icon 243, the printer icon 244, the application cooperation icon 245, the application B icon 246, and the browser icon 247 are displayed. When these icons 241 to 247 are pressed, each application corresponding to the icons 241 to 247 is activated.

また、図9に示すように、バナー領域230には、常時表示される複数のファンクションキー(ソフトウェアキー)231〜238が表示されている。上側のバナー領域230には、コピーキー231、ファックスキー232、スキャナキー233、プリンタキー234、ブラウザキー235が並び、各ファンクションキー231〜235は、それぞれが対応するアプリを直接起動させるためのソフトウェアキーである。下側のバナー領域230には、表示中のアプリを停止させるストップキー236、ホーム画面を表示するためのホームキー237、MFP1の状態を確認するための状態確認キー238が表示されている。これらは、いずれもファンクションキー(ソフトウェアキー)である。   As shown in FIG. 9, the banner area 230 displays a plurality of function keys (software keys) 231 to 238 that are always displayed. In the upper banner area 230, a copy key 231, a fax key 232, a scanner key 233, a printer key 234, and a browser key 235 are arranged. Each function key 231 to 235 is software for directly starting the corresponding application. Key. In the lower banner area 230, a stop key 236 for stopping the displayed application, a home key 237 for displaying the home screen, and a status confirmation key 238 for confirming the status of the MFP 1 are displayed. These are all function keys (software keys).

図10は、図9において、ホーム画面のアプリ連携アイコン245が押下された場合に表示される、アプリ連携機能を利用するための操作受付画面(UI画面)の一例を示す図である。図10に示すように、操作受付画面には「ワークフロー作成」を行うためのアイコン251、「ワークフロー一覧」を表示するためのアイコン252、前の画面に「戻る」ためのアイコン253等が表示されている。   FIG. 10 is a diagram illustrating an example of an operation reception screen (UI screen) for using the application cooperation function displayed when the application cooperation icon 245 on the home screen is pressed in FIG. 9. As shown in FIG. 10, an icon 251 for performing “workflow creation”, an icon 252 for displaying “workflow list”, an icon 253 for “returning” to the previous screen, and the like are displayed on the operation reception screen. ing.

図11は、図10において、ワークフロー作成アイコン251が押下された場合に表示される、ワークフロー作成画面(UI画面)の一例を示す図である。図11に示すように、ワークフロー作成画面には、作成しているワークフローが表示される領域255と、ワークフローに追加可能な機能リストが表示される領域256と、登録名を入力する領域257とが表示されている。なお、本実施形態では、機能リストの「機能」とはその機能を実行(処理)できる「アプリ」のことを示す。   FIG. 11 is a diagram showing an example of a workflow creation screen (UI screen) displayed when the workflow creation icon 251 is pressed in FIG. As shown in FIG. 11, the workflow creation screen includes an area 255 for displaying the created workflow, an area 256 for displaying a list of functions that can be added to the workflow, and an area 257 for inputting a registered name. It is displayed. In the present embodiment, the “function” in the function list indicates an “application” that can execute (process) the function.

図11の例では、作成しているワークフローは「スキャン(カラー)」、「ネットワーク上のストレージに保存」を示し、上から順番に実行されることになる。領域256に表示される機能リストは、上記の図7のステップS7で取得した機能リストのうち、現在のワークフローに追加可能な機能(アプリ)が表示されている。すなわち、「ネットワーク上のストレージに保存」に続けて、追加可能な機能(アプリ)を表示(提示)するようになっている。図11の例では、「ネットワーク上のストレージに保存」に続けて、追加可能な機能(アプリ)リストとして、スキャンアプリ、入出力アプリ、メールアプリ、コピーアプリであることが示されている。   In the example of FIG. 11, the created workflow indicates “scan (color)” and “store in storage on the network”, and is executed in order from the top. The function list displayed in the area 256 displays functions (applications) that can be added to the current workflow among the function lists acquired in step S7 in FIG. That is, following “save in storage on the network”, functions (apps) that can be added are displayed (presented). In the example of FIG. 11, following “save in storage on the network”, the list of functions (apps) that can be added indicates a scan application, an input / output application, a mail application, and a copy application.

図11に示すワークフロー作成画面において、領域256に表示されている機能(アプル)をドラッグして、領域255の追加したい位置でドロップすることで、ワークフローに処理を追加することができる。ワークフローの作成が終了したら、領域257に登録名を入力して登録ボタンを押下すると、アプリ連携部217の記憶部218(データベース)にワークフローが登録される。   In the workflow creation screen shown in FIG. 11, by dragging the function (apple) displayed in the area 256 and dropping it at the position to be added in the area 255, it is possible to add processing to the workflow. When the creation of the workflow is completed, when a registration name is input in the area 257 and the registration button is pressed, the workflow is registered in the storage unit 218 (database) of the application cooperation unit 217.

図12は、ワークフローのデータの一例を示す図である。図12に示すように、ワークフローのデータは、実行順序と、起動情報と、名前と、入力データ形式と、出力データ形式と、使用するコントローラ側の機能とを対応付けた情報である。すなわち、実行順序と、機能を起動するための情報と、図8で示した機能のメタデータとを対応付けた情報である。機能を起動するための情報の一例としては、Android OSにおいて他のアプリを起動するための起動インテントのURI表現が挙げられる。   FIG. 12 is a diagram illustrating an example of workflow data. As shown in FIG. 12, the workflow data is information in which the execution order, the activation information, the name, the input data format, the output data format, and the function on the controller side to be used are associated with each other. That is, it is information in which the execution order, information for starting the function, and the metadata of the function shown in FIG. 8 are associated with each other. As an example of information for activating a function, there is a URI expression of an activation intent for activating another application in the Android OS.

ワークフローに追加可能な機能は、アプリ連携部217が、図8で示したデータのうち出力データ形式と入力データ形式が整合するか否かで判断する。図13は、ワークフローを作成する際に組み合わせられる機能の一例を示す図である。図13に示すように、機能Aの出力データ形式は「PNG」であり、機能Bの入力データ形式は「PNG」であるため出力データ形式と入力データ形式が整合する。よって、機能A(アプリ)に続けて機能B(アプリ)はワークフローに登録することが可能である。図14は、ワークフローを作成する際に組み合わせられない機能の一例を示す図である。図14に示すように、機能Aの出力データ形式は「PNG」であり、機能Bの入力データ形式は「PDF」であるため出力データ形式と入力データ形式が整合しない。よって、機能A(アプリ)に続けて機能B(アプリ)はワークフローに登録することができない。以上のように、図13及び図14の例では、ワークフローを作成する際に、最後に受け付けた機能(アプリ)に続けて、組み合わせられる機能(アプリ)の例と、組み合わせられない機能(アプリ)の例を示したものである。   Functions that can be added to the workflow are determined by the application cooperation unit 217 based on whether or not the output data format and the input data format of the data shown in FIG. FIG. 13 is a diagram illustrating an example of functions that are combined when creating a workflow. As shown in FIG. 13, since the output data format of function A is “PNG” and the input data format of function B is “PNG”, the output data format matches the input data format. Therefore, the function B (application) can be registered in the workflow after the function A (application). FIG. 14 is a diagram illustrating an example of functions that cannot be combined when creating a workflow. As shown in FIG. 14, the output data format of function A is “PNG” and the input data format of function B is “PDF”, so the output data format and the input data format do not match. Therefore, function B (application) cannot be registered in the workflow following function A (application). As described above, in the example of FIGS. 13 and 14, when creating a workflow, an example of a function (app) that can be combined with a function (app) that is combined last and a function (app) that cannot be combined. This is an example.

図15は、ワークフローに登録する機能(アプリ)の組み合わせの一例を示す図である。図15に示すように、ワークフローは、1つ目の機能(アプリ)で画像のスキャンを行い、2つ目の機能(アプリ)でネットワーク上のストレージ(サーバ装置)にスキャンした画像データを保存する。次に3つ目の機能(アプリ)で保存した画像データにアクセスするための識別情報(URI)をQRコード(登録商標)として表示部213に表示または印刷出力する。なお、3つ目の機能(アプリ)をメールアプリに置き換えれば、スキャンした画像データのURIをメールでユーザに送信することができる。このように、本実施形態のMFP1はユーザのニーズによって柔軟な処理を行うことが可能になる。   FIG. 15 is a diagram illustrating an example of a combination of functions (applications) registered in a workflow. As shown in FIG. 15, the workflow scans an image with the first function (application), and stores the scanned image data in a storage (server device) on the network with the second function (application). . Next, identification information (URI) for accessing the image data stored by the third function (application) is displayed or printed out as a QR code (registered trademark) on the display unit 213. If the third function (application) is replaced with a mail application, the URI of the scanned image data can be transmitted to the user by mail. As described above, the MFP 1 according to the present embodiment can perform flexible processing according to user needs.

次に、ワークフロー登録の流れを説明する。図16は、ワークフロー登録のシーケンス図である。まず、アプリ連携部217は、上述したようにワークフロー作成画面でワークフローを作成(ステップS21)したワークフローを記憶部218(データベース)に登録する(ステップS22)。アプリ連携部217は、登録したワークフローを起動するためのアイコンをホーム画面に登録する登録要求を表示制御部214に送信する(ステップS23)。表示制御部214では、登録名でワークフローの配置を行って、ホーム画面に登録する(ステップS24)。表示制御部214は、登録要求に対する応答としてアイコン登録完了通知をアプリ連携部217に送信する(ステップS25)。アプリ連携部217は、アイコン登録完了通知を受け付けて、ホーム画面表示要求を表示制御部214に送信する(ステップS26)。表示制御部214は、ホーム画面表示要求を受け付けて、ホーム画面を表示部213に表示させる制御を行う(ステップS27)。   Next, the flow of workflow registration will be described. FIG. 16 is a sequence diagram of workflow registration. First, the application cooperation unit 217 registers the workflow created on the workflow creation screen as described above (step S21) in the storage unit 218 (database) (step S22). The application cooperation unit 217 transmits a registration request for registering an icon for starting the registered workflow on the home screen to the display control unit 214 (step S23). The display control unit 214 arranges the workflow with the registered name and registers it on the home screen (step S24). The display control unit 214 transmits an icon registration completion notification to the application cooperation unit 217 as a response to the registration request (step S25). The application cooperation unit 217 receives the icon registration completion notification and transmits a home screen display request to the display control unit 214 (step S26). The display control unit 214 receives the home screen display request and performs control to display the home screen on the display unit 213 (step S27).

図17は、ホーム画面に登録されたワークフローを示す図である。図17に示すように、ホーム画面には、登録したワークフローを呼び出して実行させるためのワークフローA(登録名)アイコン248が追加されて配置されている。   FIG. 17 is a diagram showing a workflow registered on the home screen. As shown in FIG. 17, a workflow A (registered name) icon 248 for calling and executing a registered workflow is additionally arranged on the home screen.

次に、ワークフローの処理の実行について説明する。図18は、ワークフローの処理の実行について説明するフローチャート図である。まずユーザは、図17で示したワークフローAアイコン248を押下すると、図19に示すアプリ連携の操作受付画面(UI画面)が表示される。図19は、アプリ連携の操作受付画面の一例を示す図である。図19に示すように、操作受付画面には、登録名:ワークフローAと、ワークフローを「実行」するためのアイコン261、前の画面に「戻る」ためのアイコン262等が表示されている。実行アイコン261が押下されると、アプリ連携部217は、ワークフロー実行を受け付ける(ステップS31)。次にアプリ連携部217は、記憶部218に登録されたワークフローAの読み込みを処理する(ステップS32)。この際に読み込まれるデータは、図12で示した、実行順序と、機能を起動するための情報と、図8の機能のメタデータとを対応付けた対応情報である。次にアプリ連携部217は、読み込んだデータから実行する機能(アプリ)の読み出しを行う(ステップS33)。つまり、ワークフローの実行順番すべてのデータから順番ごとに実行する機能(アプリ)の読み出しを行う。   Next, execution of workflow processing will be described. FIG. 18 is a flowchart illustrating the execution of workflow processing. First, when the user presses the workflow A icon 248 shown in FIG. 17, an application cooperation operation reception screen (UI screen) shown in FIG. 19 is displayed. FIG. 19 is a diagram illustrating an example of an application cooperation operation reception screen. As shown in FIG. 19, on the operation reception screen, a registered name: workflow A, an icon 261 for “execution” of the workflow, an icon 262 for “return” to the previous screen, and the like are displayed. When the execution icon 261 is pressed, the application cooperation unit 217 accepts workflow execution (step S31). Next, the application cooperation unit 217 processes the reading of the workflow A registered in the storage unit 218 (step S32). The data read at this time is correspondence information in which the execution order, the information for starting the function, and the metadata of the function shown in FIG. 8 are associated with each other as shown in FIG. Next, the application cooperation unit 217 reads a function (application) to be executed from the read data (step S33). That is, the function (application) to be executed in order is read from all the data in the workflow execution order.

次にアプリ連携部217は、図12に示した対応情報から、実行する機能(アプリ)の「使用するコントローラ側の機能(アプリ)は「なし」か否かを判断する(ステップS34)。すなわち、ワークフローから読み込んだ図12の対応情報を参照し、例えば、実行順序1の機能(アプリ)に対応付いた、使用するコントローラ側の機能の項目を確認して、操作部20側のアプリは、本体部10側の機能(アプリ)を使用するアプリであるか否かを判断する(図12の例では、実行順序1のアプリはコントローラ側のスキャン機能を使用するアプリと判断する)。使用するコントローラ側の機能の項目が「なし」でない場合(ステップS34:No)、つまり、本体部10側の機能(アプリ)を使用する場合、同期処理部221は操作部20のアプリに対応するコントローラ側(本体部10)のアプリを起動する処理を行う(ステップS35)。すなわち、アプリ起動制御部220は、操作部20で起動させるアプリのxmlコード内のコード含有アプリ対応情報を解析して本体部10のアプリを指定した情報を取得し、同期処理部221に操作部20で起動させるアプリに対応する本体部10で起動させるアプリを起動させて同期させる処理の要求を行い、同期処理部221は、操作部20のアプリと、本体部10のアプリとを同期させる処理を行う。そして、ステップS36に移行する。   Next, the application cooperation unit 217 determines from the correspondence information illustrated in FIG. 12 whether the function (application) to be executed is “none of the functions (applications on the controller side to be used)” (step S34). That is, with reference to the correspondence information in FIG. 12 read from the workflow, for example, the function on the controller side to be used corresponding to the function (application) in the execution order 1 is confirmed. Then, it is determined whether or not the application uses the function (application) on the main body 10 side (in the example of FIG. 12, the application in the execution order 1 is determined to be an application that uses the scan function on the controller side). When the function item on the controller side to be used is not “none” (step S34: No), that is, when the function (application) on the main body unit 10 side is used, the synchronization processing unit 221 corresponds to the application of the operation unit 20. Processing for starting an application on the controller side (main body unit 10) is performed (step S35). That is, the application activation control unit 220 analyzes the code-containing application correspondence information in the xml code of the application activated by the operation unit 20, acquires information specifying the application of the main body unit 10, and sends the operation unit to the synchronization processing unit 221. A request for processing to activate and synchronize an application to be activated in the main body unit 10 corresponding to the application activated in 20 is performed, and the synchronization processing unit 221 synchronizes the application in the operation unit 20 and the application in the main body unit 10. I do. Then, the process proceeds to step S36.

「なし」であった場合(ステップS34:Yes)、つまり、本体部10側の機能(アプリ)を使用しない場合、アプリ起動制御部220は、アプリ連携部217から要求された操作部20で動作させる第1のアプリケーション(例えばスキャンアプリ)を起動させ(ステップS36)処理の実行をする制御を行う(ステップS37)。次にアプリ連携部217は、コントローラ側のアプリを起動していたか否かを判断する(ステップS38)。起動していた場合(ステップS38:Yes)、アプリ起動制御部220はコントローラ側のホームアプリを起動する処理の要求を本体部10の起動制御部112に送信する。起動制御部112はホームアプリの起動要求を受け付けて、ホームアプリを起動する(ステップS39)。   When it is “none” (step S34: Yes), that is, when the function (application) on the main body unit 10 side is not used, the application activation control unit 220 operates with the operation unit 20 requested by the application cooperation unit 217. A first application (for example, a scan application) to be activated is started (step S36), and control to execute the process is performed (step S37). Next, the application cooperation unit 217 determines whether or not the controller-side application has been activated (step S38). If activated (step S38: Yes), the application activation control unit 220 transmits a request for processing to activate the home application on the controller side to the activation control unit 112 of the main body unit 10. The activation control unit 112 accepts the activation request for the home application and activates the home application (step S39).

起動していない場合(ステップS38:No)、アプリ連携部217は、データに、次に実行する機能(アプリ)があるか否かを判断する(ステップS40)。次に実行する機能(アプリ)がある場合(ステップS40:Yes)、ステップS33に移行して処理を繰り返す。次に実行する機能(アプリ)がない場合(ステップS40:No)、処理を終了する。   If not activated (step S38: No), the application cooperation unit 217 determines whether or not the data has a function (application) to be executed next (step S40). When there is a function (application) to be executed next (step S40: Yes), the process proceeds to step S33 and the process is repeated. If there is no function (application) to be executed next (step S40: No), the process ends.

次に、上記のステップS35での処理について説明する。図20は、コントローラ側のアプリ起動のシーケンス図である。ステップS34で否定の判断がされる。つまり、実行する機能(アプリ)の「使用するコントローラ側の機能(アプリ)」がある場合である(ステップS51)。   Next, the process in step S35 will be described. FIG. 20 is a sequence diagram of application activation on the controller side. A negative determination is made in step S34. That is, there is a “function (application) on the controller side to be used” of the function (application) to be executed (step S51).

アプリ連携部217のアプリ起動制御部220は、操作部20のアプリに対応するコントローラ側でのアプリ起動要求を同期処理部221に送信する(ステップS52)。同期処理部221は、操作部20で起動するアプリに対応するコントローラ(本体部10)側で起動するアプリ起動要求を本体部10の起動制御部112に送信する(ステップS53)。起動制御部112は、アプリ起動要求に基づき、対応するアプリを起動する(ステップS54)。アプリを起動したら起動制御部112は、起動完了通知を同期処理部221に送信する(ステップS55)。同期処理部221は、起動完了通知を受け付けて、アプリ連携部217に起動完了通知を送信する(ステップS56)。   The application activation control unit 220 of the application cooperation unit 217 transmits an application activation request on the controller side corresponding to the application of the operation unit 20 to the synchronization processing unit 221 (step S52). The synchronization processing unit 221 transmits an application activation request activated on the controller (main body unit 10) side corresponding to the application activated by the operation unit 20 to the activation control unit 112 of the main body unit 10 (step S53). The activation control unit 112 activates the corresponding application based on the application activation request (step S54). When the application is activated, the activation control unit 112 transmits an activation completion notification to the synchronization processing unit 221 (step S55). The synchronization processing unit 221 receives the activation completion notification and transmits the activation completion notification to the application cooperation unit 217 (step S56).

次に、上記のステップS39での処理について説明する。図21は、コントローラ側のホームアプリ起動のシーケンス図である。ステップS38で肯定の判断がされる。つまり、コントローラ側のアプリを起動していた場合である(ステップS61)。アプリ連携部217のアプリ起動制御部220は、コントローラ側でのホームアプリ起動要求を同期処理部221に送信する(ステップS62)。同期処理部221は、コントローラ(本体部10)で起動するホームアプリ起動要求を本体部10の起動制御部112に送信する(ステップS63)。起動制御部112は、ホームアプリ起動要求に基づき、対応するホームアプリを起動する(ステップS64)。ホームアプリを起動したら起動制御部112は、起動完了通知を同期処理部221に送信する(ステップS65)。同期処理部221は、起動完了通知を受け付けて、アプリ連携部217に起動完了通知を送信する(ステップS66)。   Next, the process in step S39 will be described. FIG. 21 is a sequence diagram of home application activation on the controller side. A positive determination is made in step S38. That is, this is a case where an application on the controller side has been activated (step S61). The application activation control unit 220 of the application cooperation unit 217 transmits a home application activation request on the controller side to the synchronization processing unit 221 (step S62). The synchronization processing unit 221 transmits a home application activation request activated by the controller (main body unit 10) to the activation control unit 112 of the main body unit 10 (step S63). The activation control unit 112 activates the corresponding home application based on the home application activation request (step S64). When the home application is activated, the activation control unit 112 transmits an activation completion notification to the synchronization processing unit 221 (step S65). The synchronization processing unit 221 receives the activation completion notification and transmits the activation completion notification to the application cooperation unit 217 (step S66).

このように、以上で説明した図18、図20、図21で説明した処理フローによれば、アプリ連携部217からワークフローに登録された順番にアプリケーションのアプリ起動要求を受け付けた場合、起動要求された操作部20のアプリが本体部10の機能(アプリ)を使用するアプリの場合に、同期処理部221が操作部20のアプリと、操作部20のアプリに対応する本体部10のアプリを同期させる処理を行うことで、操作部20で起動するアプリと本体部10で起動中のアプリを同期させることができる。すなわち、本実施形態では、ワークフローの順番で複数のアプリを実行させた場合でも、操作部で起動させるアプリの切り換えと、切り換える操作部のアプリに対応する本体部で起動させるアプリへの切り換えを同期させることができる。   As described above, according to the processing flow described with reference to FIGS. 18, 20, and 21 described above, when application activation requests for applications are received from the application cooperation unit 217 in the order registered in the workflow, activation requests are issued. If the application of the operation unit 20 is an application that uses the function (application) of the main unit 10, the synchronization processing unit 221 synchronizes the application of the operation unit 20 with the application of the main unit 10 corresponding to the application of the operation unit 20. By performing the processing to be performed, the application activated by the operation unit 20 and the application activated by the main body unit 10 can be synchronized. That is, in the present embodiment, even when a plurality of apps are executed in the order of the workflow, the switching of the application to be activated by the operation unit is synchronized with the switching to the application to be activated by the main body corresponding to the application of the operation unit to be switched. Can be made.

次に、図20に示したコントローラ側のアプリ起動のシーケンス図において、ステップS54の対応するアプリを起動する処理が失敗した場合について説明する。図22は、コントローラ側のアプリ起動が失敗した場合の処理の一例を示すシーケンス図である。   Next, the case where the process of starting the corresponding application in step S54 in the sequence diagram for starting the application on the controller side shown in FIG. 20 fails will be described. FIG. 22 is a sequence diagram illustrating an example of processing in a case where application activation on the controller side fails.

まず実行する機能(アプリ)の「使用するコントローラ側の機能(アプリ)」がある場合である(ステップS71)。アプリ連携部217のアプリ起動制御部220は、操作部20のアプリに対応するコントローラ側でのアプリ起動要求を同期処理部221に送信する(ステップS72)。同期処理部221は、操作部20で起動するアプリに対応するコントローラ(本体部10)側で起動するアプリ起動要求を本体部10の起動制御部112に送信する(ステップS73)。起動制御部112は、アプリ起動要求に基づき、対応するアプリを起動する(ステップS74)。アプリの起動に失敗したら起動制御部112は、起動失敗通知を同期処理部221に送信する(ステップS75)。同期処理部221は、起動失敗通知を受け付けて、アプリ連携部217に起動失敗通知を送信する(ステップS76)。アプリ起動制御部220は、起動要求リトライのタイムアウトタイマを起動する(ステップS77)。その後、起動完了通知を受け付けるまで、又はタイムアウトタイマがタイムアウト(所定の時間が経過する)まで、同様の処理を繰り返す。   First, there is a case where there is a “function (application) on the controller side to be used” of the function (application) to be executed (step S71). The application activation control unit 220 of the application cooperation unit 217 transmits an application activation request on the controller side corresponding to the application of the operation unit 20 to the synchronization processing unit 221 (step S72). The synchronization processing unit 221 transmits an application activation request activated on the controller (main body unit 10) side corresponding to the application activated by the operation unit 20 to the activation control unit 112 of the main body unit 10 (step S73). The activation control unit 112 activates the corresponding application based on the application activation request (step S74). If the activation of the application fails, the activation control unit 112 transmits an activation failure notification to the synchronization processing unit 221 (step S75). The synchronization processing unit 221 receives the activation failure notification and transmits the activation failure notification to the application cooperation unit 217 (step S76). The application activation control unit 220 activates an activation request retry timeout timer (step S77). Thereafter, the same processing is repeated until the start completion notification is received or until the timeout timer times out (a predetermined time elapses).

すなわち、アプリ連携部217のアプリ起動制御部220は、操作部20のアプリに対応するコントローラ側でのアプリ起動要求を同期処理部221に送信する(ステップS78)。同期処理部221は、操作部20で起動するアプリに対応するコントローラ(本体部10)側で起動するアプリ起動要求を本体部10の起動制御部112に送信する(ステップS79)。起動制御部112は、アプリ起動要求に基づき、対応するアプリを起動する(ステップS80)。アプリの起動に失敗したら起動制御部112は、起動失敗通知を同期処理部221に送信する(ステップS81)。同期処理部221は、起動失敗通知を受け付けて、アプリ連携部217に起動失敗通知を送信する(ステップS82)。   That is, the application activation control unit 220 of the application cooperation unit 217 transmits an application activation request on the controller side corresponding to the application of the operation unit 20 to the synchronization processing unit 221 (step S78). The synchronization processing unit 221 transmits an application activation request activated on the controller (main body unit 10) side corresponding to the application activated by the operation unit 20 to the activation control unit 112 of the main body unit 10 (step S79). The activation control unit 112 activates the corresponding application based on the application activation request (step S80). If the activation of the application fails, the activation control unit 112 transmits an activation failure notification to the synchronization processing unit 221 (step S81). The synchronization processing unit 221 receives the activation failure notification and transmits the activation failure notification to the application cooperation unit 217 (step S82).

次に、アプリ連携部217は、タイムアウトになった場合(ステップS83)、表示制御部214にエラーメッセージを送信する(ステップS84)。表示制御部214は、エラーメッセージを受け付けて、表示部213にエラーメッセージ表示をする(ステップS85)。ユーザは、エラーメッセージを見て、エラー確認ボタンを押下する(ステップS86)。操作受付部215は、エラー確認を受け付けて、アプリ連携部217にエラー確認通知を送信する(ステップS87)。アプリ連携部217は、エラー確認通知を受け付けて、起動要求の終了処理を行う(ステップS88)。   Next, the application cooperation part 217 transmits an error message to the display control part 214, when time-out (step S83) (step S84). The display control unit 214 receives the error message and displays the error message on the display unit 213 (step S85). The user sees the error message and presses the error confirmation button (step S86). The operation accepting unit 215 accepts the error confirmation and transmits an error confirmation notification to the application cooperation unit 217 (step S87). The application cooperation unit 217 receives the error confirmation notification and performs a start request end process (step S88).

なお、図21に示したコントローラ側のホームアプリ起動のシーケンス図において、ステップS64のホームアプリを起動する処理が失敗した場合も上記の図22で説明した起動要求リトライの処理シーケンスを実行する。   In the sequence diagram for starting the home application on the controller side shown in FIG. 21, even when the process for starting the home application in step S64 fails, the processing sequence for the activation request retry described in FIG. 22 is executed.

次に、ワークフローに登録された実行順番で実行する機能(アプリ)の間でのデータ受け渡し処理について説明する。図23は、実行する機能(アプリ)の間でのデータ受け渡し処理のシーケンス図である。すなわち、アプリAに続いてアプリBを起動する場合である。   Next, data transfer processing between functions (applications) executed in the execution order registered in the workflow will be described. FIG. 23 is a sequence diagram of data transfer processing between functions to be executed (applications). That is, the application B is started after the application A.

まずアプリAは実行中の任意のタイミングでアプリ連携部217にデータを含むデータ保存依頼を送信する(ステップS101)。アプリ連携部217は受信したデータにデータを識別するID(データID)を付与して記憶部218に保存する(ステップS102)。アプリ連携部217は、データIDをアプリAに送信する(ステップS103)。アプリAは、実行終了時に、次のアプリBに送信する(受け渡したい)データのデータIDをアプリ連携部217に送信する(ステップS104)。アプリ連携部217は、受信したデータIDを保持する(ステップS105)。   First, the application A transmits a data storage request including data to the application cooperation unit 217 at an arbitrary timing during execution (step S101). The application cooperation unit 217 assigns an ID (data ID) for identifying the data to the received data and stores it in the storage unit 218 (step S102). The application cooperation unit 217 transmits the data ID to the application A (step S103). At the end of execution, the application A transmits the data ID of data to be transmitted (desired to be transferred) to the next application B to the application cooperation unit 217 (step S104). The application cooperation unit 217 holds the received data ID (step S105).

次に、アプリ連携部217は、アプリBの実行開始時に、アプリAから受信して保持しているデータIDをアプリBに送信する(ステップS106)。アプリBは、受信したデータIDを保持する(ステップS107)。アプリBは、任意のタイミングでデータIDを用いて、データの取得要求をアプリ連携部217に送信する(ステップS108)。アプリ連携部217は、受信したデータIDに紐付く記憶部218に保存されているデータをアプリBに送信する(ステップS109)。アプリBは、データを取得する(ステップS110)。アプリ連携部217は、ワークフローに登録されている全ての機能(アプリ)の処理の実行が完了した時に、記憶部218で保持しているデータを全て消去して処理を終了する(ステップS111)。   Next, the application cooperation unit 217 transmits the data ID received and held from the application A to the application B when the execution of the application B is started (step S106). The application B holds the received data ID (step S107). The application B transmits a data acquisition request to the application cooperation unit 217 using the data ID at an arbitrary timing (step S108). The application cooperation unit 217 transmits data stored in the storage unit 218 associated with the received data ID to the application B (step S109). The app B acquires data (step S110). When the execution of the processing of all functions (applications) registered in the workflow is completed, the application cooperation unit 217 deletes all data held in the storage unit 218 and ends the processing (step S111).

以上の処理方式を用いることにより、各アプリは統一的な方法で機能(アプリ)間でデータの送受信(受け渡し)ができるようになり、また、ワークフロー実行時のユーザのデータを消去することができる。   By using the above processing method, each application can send and receive (transfer) data between functions (applications) in a unified manner, and user data at the time of workflow execution can be deleted. .

以上説明したように、本実施形態によれば、アプリ連携部217からワークフローに登録された順番にアプリケーションのアプリ起動要求を受け付けた場合、起動要求された操作部20のアプリが本体部10の機能(アプリ)を使用するアプリの場合に、同期処理部221が操作部20のアプリと、操作部20のアプリに対応する本体部10のアプリを同期させる処理を行うことで、操作部20で起動するアプリと本体部10で起動中のアプリを同期させることができる、という有利な効果を達成できる。   As described above, according to the present embodiment, when application activation requests for applications are received from the application cooperation unit 217 in the order registered in the workflow, the application of the operation unit 20 requested to activate is a function of the main body unit 10. In the case of an application that uses (application), the synchronization processing unit 221 performs processing to synchronize the application of the operation unit 20 and the application of the main body unit 10 corresponding to the application of the operation unit 20, thereby starting the operation unit 20. The advantageous effect that the running application and the running application on the main unit 10 can be synchronized can be achieved.

以上、本発明に係る実施形態について説明したが、本発明は、上述の実施形態そのままに限定されるものではなく、実施段階ではその要旨を逸脱しない範囲で構成要素を変形して具体化できる。また、上述の実施形態に開示されている複数の構成要素の適宜な組み合わせにより、種々の発明を形成できる。例えば、実施形態に示される全構成要素から幾つかの構成要素を削除してもよい。さらに、異なる実施形態にわたる構成要素を適宜組み合わせてもよい。   Although the embodiments according to the present invention have been described above, the present invention is not limited to the above-described embodiments as they are, and can be embodied by modifying the constituent elements without departing from the scope of the invention in the implementation stage. Various inventions can be formed by appropriately combining a plurality of constituent elements disclosed in the above-described embodiments. For example, some components may be deleted from all the components shown in the embodiment. Furthermore, constituent elements over different embodiments may be appropriately combined.

また、上述した実施形態の画像形成装置1で実行されるソフトウェア(プログラム)は、インストール可能な形式または実行可能な形式のファイルでフロッピー(登録商標)ディスク、CD(Compact Disc)、CD−R(Compact Disc-Recordable)、CD−ROM(Compact Disc Read Only Memory)、DVD(Digital Versatile Disc)、SDメモリカード(SD memory card)、USBメモリ(Universal Serial Bus memory)等のコンピュータで読み取り可能な記録媒体に記録して提供するように構成してもよい。   The software (program) executed by the image forming apparatus 1 of the above-described embodiment is a file in an installable format or an executable format, and is a floppy (registered trademark) disk, CD (Compact Disc), CD-R ( Computer-readable recording media such as compact disc-recordable (CD), compact disc read only memory (CD-ROM), digital versatile disc (DVD), SD memory card, and universal serial bus memory (USB memory) You may comprise so that it may record and provide.

さらに、本実施形態の画像形成装置1で実行されるソフトウェア(プログラム)を、インターネット等のネットワークに接続されたコンピュータ上に格納し、ネットワーク経由でダウンロードさせることにより提供するように構成してもよい。また、本実施形態の画像形成装置1で実行されるソフトウェア(プログラム)をインターネット等のネットワーク経由で提供または配布するように構成してもよい。   Furthermore, the software (program) executed by the image forming apparatus 1 according to the present embodiment may be provided by being stored on a computer connected to a network such as the Internet and downloaded via the network. . The software (program) executed by the image forming apparatus 1 according to the present embodiment may be provided or distributed via a network such as the Internet.

本実施形態の画像形成装置1で実行されるソフトウェア(プログラム)は、上述した各機能部を含むモジュール構成となっており、これを実現するハードウェアとしてはCPU(プロセッサ)11及び21が上記ROM12及び22からソフトウェア(プログラム)を読み出して実行することにより上記各機能部を実現するプログラムの実行コードがRAM13及び23上にロードされ、上記各機能部がRAM13及び23上に生成されるようになっている。   The software (program) executed by the image forming apparatus 1 of the present embodiment has a module configuration including the above-described functional units. As hardware for realizing this, CPUs (processors) 11 and 21 are the ROM 12. The execution code of the program that realizes each function unit is loaded onto the RAMs 13 and 23 by reading out the software (program) from the program 22 and executing the program, and the function units are generated on the RAMs 13 and 23. ing.

なお、上記実施形態では、本発明の画像形成装置1を、コピー機能、プリンタ機能、スキャナ機能およびファクシミリ機能のうち少なくとも2つの機能を有する複合機に適用した例を挙げて説明したが、複写機、プリンタ、スキャナ装置、ファクシミリ装置等の画像形成装置であればいずれにも適用することができる。   In the above embodiment, the image forming apparatus 1 according to the present invention has been described by taking an example in which the image forming apparatus 1 is applied to a multifunction machine having at least two functions among a copy function, a printer function, a scanner function, and a facsimile function. The present invention can be applied to any image forming apparatus such as a printer, a scanner apparatus, and a facsimile apparatus.

本発明の範囲において、上記実施形態に対して多くの修正、変更が可能である。請求項に記載された発明の範囲において、上記実施形態として記載された形態以外の形態についても、本発明の実施の形態とすることが可能である。   Many modifications and changes can be made to the above embodiment within the scope of the present invention. Within the scope of the invention described in the claims, embodiments other than those described as the above-described embodiments can also be used as embodiments of the present invention.

コンピュータのアーキテクチャや演算処理に関した情報処理技術によって、従来のコンピュータを本明細書に記載の発明を実施するようプログラムすることにより、本発明を実施することが可能である。ソフトウェア技術の分野における知識を有した技術者であれば、本明細書の記載に基づいて、本発明を実施するようコンピュータをプログラムするためのソフトウェアを作成することが可能である。   It is possible to implement the present invention by programming a conventional computer to implement the invention described in this specification by information processing technology related to the computer architecture and arithmetic processing. An engineer with knowledge in the field of software technology can create software for programming a computer to implement the present invention based on the description herein.

さらに、本発明は、情報処理技術の分野における知識を有した技術者であれば、ASIC(Application Specific Integrated Circuits)や、従来の回路モジュールを接続して構成した装置によって実施することが可能である。実施形態に記載された各機能のそれぞれは、一又は複数の処理回路によって実現することが可能である。ここで、本明細書における「処理回路」とは、ソフトウェアによって各機能を実行するようプログラムされたプロセッサや、各機能を実行するよう設計されたASICや回路モジュールなどのハードウェアを含むものとする。   Furthermore, the present invention can be implemented by an ASIC (Application Specific Integrated Circuits) or an apparatus configured by connecting conventional circuit modules if it is an engineer who has knowledge in the field of information processing technology. . Each of the functions described in the embodiments can be realized by one or a plurality of processing circuits. Here, the “processing circuit” in this specification includes a processor programmed to execute each function by software, and hardware such as an ASIC and a circuit module designed to execute each function.

1 MFP(画像形成装置)
10 本体部
11 CPU
12 ROM
13 RAM
14 HDD
15 通信I/F
16 接続I/F
17 プリントエンジン(画像形成部)
18 システムバス
20 操作部
21 CPU
22 ROM
23 RAM
24 フラッシュメモリ
25 通信I/F
26 接続I/F
27 操作パネル
28 外部接続I/F
29 システムバス
30 ネットワーク
31 無線LANAP
101 アプリ層
102 サービス層
103 OS層
111 通信部
112 起動制御部
113 記憶部
201 アプリ層
202 サービス層
203 OS層
211 通信部
212 入出力部
213 表示部
214 表示制御部
215 操作受付部
216 通知部
217 アプリ連携部
218 記憶部
220 アプリ起動制御部
221 同期処理部
222 アプリ登録部
230 バナー領域
231 コピーキー
232 ファックスキー
233 スキャナキー
234 プリンタキー
235 ブラウザキー
236 ストップキー
237 ホームキー
238 状態確認キー
241 コピーアイコン
242 ファックスアイコン
243 スキャンアイコン
244 プリンタアイコン
245 アプリ連携アイコン
246 アプリBアイコン
247 ブラウザアイコン
248 ワークフローAアイコン
251 ワークフロー作成アイコン
252 ワークフロー一覧アイコン
253 戻るアイコン
255、256、257 領域
261 実行アイコン
262 戻るアイコン
300 通信路
1 MFP (image forming device)
10 Body 11 CPU
12 ROM
13 RAM
14 HDD
15 Communication I / F
16 Connection I / F
17 Print engine (image forming unit)
18 System bus 20 Operation unit 21 CPU
22 ROM
23 RAM
24 Flash memory 25 Communication I / F
26 Connection I / F
27 Operation panel 28 External connection I / F
29 System Bus 30 Network 31 Wireless LANAP
101 application layer 102 service layer 103 OS layer 111 communication unit 112 activation control unit 113 storage unit 201 application layer 202 service layer 203 OS layer 211 communication unit 212 input / output unit 213 display unit 214 display control unit 215 operation reception unit 216 notification unit 217 Application linkage unit 218 Storage unit 220 Application activation control unit 221 Synchronization processing unit 222 Application registration unit 230 Banner area 231 Copy key 232 Fax key 233 Scanner key 234 Printer key 235 Browser key 236 Stop key 237 Home key 238 Status confirmation key 241 Copy icon 242 Fax icon 243 Scan icon 244 Printer icon 245 Application link icon 246 Application B icon 247 Browser icon 248 Workflow A icon 251 Kufuro creation icon 252 workflow list icon 253 Back icon 255,256,257 area 261 execution icon 262 Back icon 300 communication channel

特開2014−95986号公報JP 2014-95986 A

Claims (13)

操作を受け付ける操作部と、前記操作部で受け付けた操作に応じて動作する本体部とを備え、前記操作部が第1のオペレーティングシステムを有し、前記本体部が第2のオペレーティングシステムを有した画像形成装置であって、
前記操作部は、
予め登録されたアプリケーションの実行順を示すワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行うアプリ連携部と、
前記アプリ連携部から前記第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、前記第1のアプリケーションと、前記第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う同期処理部と、
前記同期処理部での同期させる処理が行われた後に、前記第1のアプリケーションを起動させるアプリ起動制御部と、
を備える、
ことを特徴とする画像形成装置。
An operation unit that receives an operation; and a main body unit that operates according to an operation received by the operation unit, wherein the operation unit includes a first operating system, and the main body unit includes a second operating system. An image forming apparatus,
The operation unit is
Based on a workflow indicating the execution order of applications registered in advance, an application cooperation unit that performs control to start the applications in order and execute processing;
When an application activation request for requesting activation of a first application that operates on the first operating system is received from the application cooperation unit, the first application that operates on the first operating system and the second operating system A synchronization processing unit that performs processing for synchronizing the two applications;
An application activation control unit that activates the first application after the synchronization processing in the synchronization processing unit is performed;
Comprising
An image forming apparatus.
前記同期処理部は、特定のアプリケーションを起動する場合に、前記第1のアプリケーションと、前記第2のアプリケーションを同期させる処理を行う、
請求項1に記載の画像形成装置。
The synchronization processing unit performs a process of synchronizing the first application and the second application when starting a specific application.
The image forming apparatus according to claim 1.
前記特定のアプリケーションは、前記本体部の機能を使用するアプリケーションである、
請求項2に記載の画像形成装置。
The specific application is an application that uses the function of the main body.
The image forming apparatus according to claim 2.
前記第1のオペレーティングシステム上で動作させるアプリケーションを実行する順番で受け付けて、実行順に前記アプリケーションを前記ワークフローに登録するアプリ登録部を、さらに備える、
請求項1に記載の画像形成装置。
An application registration unit that accepts applications to be executed on the first operating system in the order of execution, and registers the applications in the workflow in the order of execution;
The image forming apparatus according to claim 1.
前記アプリケーションを実行する順番を受け付ける画面を表示する表示部を有し、
前記アプリ登録部で前記アプリケーションを受け付ける場合に、最後に受け付けた前記アプリケーションの後に、実行可能なアプリケーションだけを前記表示部に表示させる表示制御部を、さらに備える、
請求項4に記載の画像形成装置。
A display unit for displaying a screen for receiving an order of executing the applications;
When the application registration unit accepts the application, it further includes a display control unit that displays only executable applications on the display unit after the last received application.
The image forming apparatus according to claim 4.
前記表示制御部は、
前記アプリ登録部で、実行順に前記アプリケーションを前記ワークフローに登録した後に、前記操作部の複数の機能を利用するための操作受付画面を呼び出す初期画面に、前記ワークフローを呼び出すための画像を配置する、
請求項5に記載の画像形成装置。
The display control unit
In the application registration unit, after registering the applications in the workflow in the execution order, an image for calling the workflow is arranged on an initial screen for calling an operation reception screen for using a plurality of functions of the operation unit.
The image forming apparatus according to claim 5.
前記アプリ連携部は、
前記ワークフローに登録された順に前記アプリケーションが処理したデータを、記憶部に記憶させ、
前記表示制御部は、
前記記憶部に記憶された前記データにアクセスするための識別情報を前記表示部に表示させる、
請求項5に記載の画像形成装置。
The application cooperation unit
Store the data processed by the application in the order registered in the workflow in the storage unit,
The display control unit
Display identification information for accessing the data stored in the storage unit on the display unit,
The image forming apparatus according to claim 5.
前記同期処理部は、前記同期させる処理が完了できなかった場合に、所定の時間が経過するまでの間、前記同期させる処理を繰り返して行う、
請求項1に記載の画像形成装置。
The synchronization processing unit repeatedly performs the synchronization processing until a predetermined time elapses when the synchronization processing cannot be completed.
The image forming apparatus according to claim 1.
前記アプリ連携部は、前記ワークフローに登録された順に前記アプリケーションが処理したデータに識別情報を付与して保持し、続けて起動される次の順番のアプリケーションに対して該データの識別情報を受け渡す、
請求項1に記載の画像形成装置。
The application cooperation unit assigns and holds identification information to data processed by the application in the order registered in the workflow, and delivers the identification information of the data to the next sequential application that is subsequently started ,
The image forming apparatus according to claim 1.
前記同期させる処理は、前記操作部で起動させるアプリケーションを起動させる前に、前記操作部で起動させる該アプリケーションに対応する前記本体部で起動させるアプリケーションを起動させてから、前記操作部で起動させるアプリケーションを起動させて同期させる処理である、
請求項1に記載の画像形成装置。
The process to synchronize starts an application to be started on the main body corresponding to the application to be started on the operation unit before starting an application to be started on the operation unit, and then starts on the operation unit. Is the process of starting and synchronizing
The image forming apparatus according to claim 1.
前記画像形成装置に、アプリケーションの実行順を示すワークフローの情報を含むデータを送信するコンピュータにより実行可能なプログラムと、
操作を受け付ける操作部と、前記操作部で受け付けた操作に応じて動作する本体部とを備え、前記操作部が第1のオペレーティングシステムを有し、前記本体部が第2のオペレーティングシステムを有した画像形成装置とを含む画像形成システムであって、
受信した前記データに含まれるアプリケーションの実行順を示す前記ワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行うアプリ連携部と、
前記アプリ連携部から前記第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、前記第1のアプリケーションと、前記第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う同期処理部と、
前記同期処理部での同期させる処理が行われた後に、前記第1のアプリケーションを起動させるアプリ起動制御部と、を有する操作部を備える前記画像形成装置と、
を含む、
ことを特徴とする画像形成システム。
A program executable by a computer that transmits data including workflow information indicating an execution order of applications to the image forming apparatus;
An operation unit that receives an operation; and a main body unit that operates according to an operation received by the operation unit, wherein the operation unit includes a first operating system, and the main body unit includes a second operating system. An image forming system including an image forming apparatus,
Based on the workflow indicating the execution order of the applications included in the received data, an application cooperation unit that performs control to start the applications in order and execute processing;
When an application activation request for requesting activation of a first application that operates on the first operating system is received from the application cooperation unit, the first application that operates on the first operating system and the second operating system A synchronization processing unit that performs processing for synchronizing the two applications;
The image forming apparatus including an operation unit having an application activation control unit that activates the first application after the synchronization process in the synchronization processing unit is performed;
including,
An image forming system.
操作を受け付ける操作部と、前記操作部で受け付けた操作に応じて動作する本体部とを備え、前記操作部が第1のオペレーティングシステムを有し、前記本体部が第2のオペレーティングシステムを有した画像形成装置の画像形成方法であって、
予め登録されたアプリケーションの実行順を示すワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行うアプリ連携ステップと、
前記アプリ連携ステップから前記第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、前記第1のアプリケーションと、前記第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う同期処理ステップと、
前記同期処理ステップでの同期させる処理が行われた後に、前記第1のアプリケーションを起動させるアプリ起動制御ステップと、を含む、
ことを特徴とする画像形成方法。
An operation unit that receives an operation; and a main body unit that operates according to an operation received by the operation unit, wherein the operation unit includes a first operating system, and the main body unit includes a second operating system. An image forming method of an image forming apparatus,
Based on a workflow indicating the execution order of applications registered in advance, an application cooperation step for performing control to start the applications in order and execute processing;
When an application activation request for requesting activation of the first application that operates on the first operating system is received from the application cooperation step, the first application that operates on the first operating system and the second operating system. A synchronization processing step for performing processing for synchronizing the two applications;
An application activation control step of activating the first application after the process of synchronizing in the synchronization process step is performed,
An image forming method.
操作を受け付ける操作部と、前記操作部で受け付けた操作に応じて動作する本体部とを備え、前記操作部が第1のオペレーティングシステムを有し、前記本体部が第2のオペレーティングシステムを有した画像形成装置に、
予め登録されたアプリケーションの実行順を示すワークフローに基づいて、順にアプリケーションを起動させて処理を実行させる制御を行うアプリ連携ステップと、
前記アプリ連携ステップから前記第1のオペレーティングシステム上で動作する第1のアプリケーションの起動を要求するアプリ起動要求を受け付けた場合、前記第1のアプリケーションと、前記第2のオペレーティングシステム上で動作する第2のアプリケーションを同期させる処理を行う同期処理ステップと、
前記同期処理ステップでの同期させる処理が行われた後に、前記第1のアプリケーションを起動させるアプリ起動制御ステップと、
を実行させるためのプログラム。
An operation unit that receives an operation; and a main body unit that operates according to an operation received by the operation unit, wherein the operation unit includes a first operating system, and the main body unit includes a second operating system. In the image forming device,
Based on a workflow indicating the execution order of applications registered in advance, an application cooperation step for performing control to start the applications in order and execute processing;
When an application activation request for requesting activation of the first application that operates on the first operating system is received from the application cooperation step, the first application that operates on the first operating system and the second operating system. A synchronization processing step for performing processing for synchronizing the two applications;
An application activation control step of activating the first application after the process of synchronizing in the synchronization processing step is performed;
A program for running
JP2016002779A 2016-01-08 2016-01-08 Image formation device, image formation system, image formation method, and program Pending JP2017123610A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2016002779A JP2017123610A (en) 2016-01-08 2016-01-08 Image formation device, image formation system, image formation method, and program

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2016002779A JP2017123610A (en) 2016-01-08 2016-01-08 Image formation device, image formation system, image formation method, and program

Publications (1)

Publication Number Publication Date
JP2017123610A true JP2017123610A (en) 2017-07-13

Family

ID=59305852

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2016002779A Pending JP2017123610A (en) 2016-01-08 2016-01-08 Image formation device, image formation system, image formation method, and program

Country Status (1)

Country Link
JP (1) JP2017123610A (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6400248B1 (en) * 2017-03-03 2018-10-03 三菱電機株式会社 Data processing apparatus, data processing method, setting management apparatus, and data processing system
JP2019067118A (en) * 2017-09-29 2019-04-25 ブラザー工業株式会社 Computer program and workflow creating device
JP2020052701A (en) * 2018-09-26 2020-04-02 株式会社リコー Information processing system, service providing system and flow setting method
US11115556B2 (en) 2018-03-20 2021-09-07 Hewlett-Packard Development Company, L.P. Work form sharing

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6400248B1 (en) * 2017-03-03 2018-10-03 三菱電機株式会社 Data processing apparatus, data processing method, setting management apparatus, and data processing system
US10725794B2 (en) 2017-03-03 2020-07-28 Mitsubishi Electric Corporation Data processing device, data processing method, setting management device, and data processing system
JP2019067118A (en) * 2017-09-29 2019-04-25 ブラザー工業株式会社 Computer program and workflow creating device
US11115556B2 (en) 2018-03-20 2021-09-07 Hewlett-Packard Development Company, L.P. Work form sharing
JP2020052701A (en) * 2018-09-26 2020-04-02 株式会社リコー Information processing system, service providing system and flow setting method
JP7314491B2 (en) 2018-09-26 2023-07-26 株式会社リコー Information processing system, service providing system, flow setting method

Similar Documents

Publication Publication Date Title
US11210052B2 (en) Information processing apparatus controlling screen to be displayed
JP6424745B2 (en) Image forming apparatus, image forming method and program
JP6502637B2 (en) INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING APPARATUS, AND CONTROL METHOD AND PROGRAM THEREOF
JP6499423B2 (en) Information processing system, information processing apparatus, and control method and program thereof
JP6442976B2 (en) Image forming apparatus, browser control method, and program
JP2013161117A (en) Image formation apparatus, control method of image formation apparatus, and program
US10129426B2 (en) Image forming apparatus having display screen with position configurable icons, information processing method, and computer-readable recording medium
JP2016162044A (en) Image forming apparatus, server device, and communication system
JP6620530B2 (en) Information processing system, information processing apparatus, information processing method, and program
US9509872B2 (en) Image reading apparatus and non-transitory computer-readable medium having image reading program
US10587766B2 (en) Electronic device, screen display method, and computer program product for changing a display appearance of a screen based on a parameter received from an application
JP2016085659A (en) Information processing system, information processing apparatus, information processing method, and program
JP2017123610A (en) Image formation device, image formation system, image formation method, and program
JP2012226522A (en) Information processing apparatus and control method thereof
US11294608B2 (en) Server system and information processing apparatus
JP6123393B2 (en) Information processing system, information processing method, and program
JP6933020B2 (en) Image processing equipment, information processing systems, and methods
JP6485227B2 (en) Image forming apparatus, image forming system, image forming method, and program
US9794437B2 (en) Information processing apparatus, information processing system, and information processing method
JP2019164573A (en) Display input device, image forming device, screen display method, and program
JP6406060B2 (en) Image forming apparatus, server apparatus, portable terminal, and communication system
US11165925B2 (en) API for printing apparatus functions
JP7156446B2 (en) Server, system, control method and program
US10846035B2 (en) Method for controlling image forming apparatus and image forming apparatus using same
JP7346937B2 (en) Information processing device, information processing method, program, image forming system