This application is a National Stage application of International Application No. PCT/JP2006/310086, filed on May 16, 2006.
The present invention relates to an image processing apparatus, remote control method, and program and, more particularly, to an image processing apparatus which is connected to a network and has a communication means for communicating with an external apparatus, a remote control method applied to the image processing apparatus, and a program for causing a computer to execute the remote control method.
Recently, in the Internet Web technology field centered on information processing apparatuses, various versions of RSS used to syndicate the latest news, and XML applications such as Atom are becoming popular (see, e.g., the specifications of RSS 1.0 (RDF Site Summary) by the RSS DEV Working Group). In the proposal by the present invention, syndication means distributing and announcing update information/summary information.
In recent years, not only information processing apparatuses such as a general-purpose computer but also various embedded systems are connected to a network, and can be utilized or managed from a remote place via the network. The embedded system is a computer system which is embedded in an application specific apparatus, and comprises peripheral devices and applications specialized in specific purposes. For example, a printer, scanner, image communication apparatuses using a facsimile or E-mail protocol, and various image processing apparatuses such as a copying machine, document management system, digital camera, and projector are also connected to a network, and can be utilized or managed from a remote place via the network. For example, a printer and multi-functional peripheral available from CANON include Web servers, and incorporate a Web application “remote UI” for connecting the apparatus via a Web browser, and utilizing and managing the apparatus from a remote place.
Situations in which the administrator and user use or manage a plurality of apparatuses via a network are increasing. Also, situations in which the administrator and user use or manage an apparatus from various nodes on a network are increasing.
These days, embedded systems such as an image processing apparatus exploit an advanced, high-performance internal CPU and nonvolatile memory (hard disk or the like) to provide a larger number of more advanced functions. These functions are installed as embedded applications which are executed by the internal CPU, and the internal nonvolatile memory holds various settings and data necessary for the operation. Information accumulated in the apparatus is timely updated in accordance with an operation by the user or the operation of the apparatus.
Recently, there is known an image processing apparatus in which a function available by the user is added or deleted by installing or uninstalling an application or license. For example, CANON has commercialized MEAP® (Multi-functional Embedded Application Platform) which can dynamically add and delete an embedded application by embedding a Java® execution environment in a multi-functional peripheral.
Patent reference 1 discloses an image processing apparatus capable of acquiring, in the XML format, historical information of a font loaded into a printer.
However, the embedded system which is connected to a network and has a communication means for communicating with an external apparatus, especially the image processing apparatus cannot meet the following requirements.
(1) The administrator wants to centrally monitor a change in data (i.e., update information) accumulated in a plurality of apparatuses. The administrator wants to unitarily grasp update information of a plurality of apparatuses.
(2) The user wants to grasp a change, caused by another user, in data accumulated in an apparatus shared with another user. The user wants to unitarily grasp update information of a plurality of apparatuses.
(3) The administrator and user (to be simply referred to as the administrator hereinafter) want to grasp update information from anywhere (particularly including a remote place).
(4) The administrator wants to unitarily grasp update information of data in the apparatus together with update information of a Web site.
(5) The administrator wants to grasp update information in cooperation with a related Web page, Web application, and the like.
(6) The administrator wants to exploit update information in various ways. For example, similar to the concept of a semantic Web (technique proposed by Tim Berners-Lee in around 1998: a technique of adding semantics based on metadata, and causing a computer to determine information contents, which have been determined by the human eye), the administrator wants the apparatus to provide update information as an free-purpose knowledge representation, and wants to exploit the update information for various purposes.
(7) The administrator wants to finely control the contents and format of update information supplied from the apparatus.
(8) The administrator wants to flexibly customize update information supplied from the apparatus.
(9) The administrator wants to grasp especially a change in application embedded in the apparatus and a change in license which permits the use of the embedded application.
(10) The administrator wants to grasp especially update information of documents accumulated in the apparatus.
(11) The administrator wants to grasp especially update information of an address book accumulated in the apparatus.
(12) The administrator wants to grasp information obtained by statistically processing data accumulated in the apparatus.
(13) The administrator wants to grasp changes including not only addition and modification of data accumulated in the apparatus but also deletion of data from the apparatus.
(14) The administrator wants to grasp details of deleted data for a predetermined period even after deletion.
(15) When a change in data accumulated in the apparatus pertains to an image, the administrator wants to grasp the contents of the image as update information.
Patent reference 1 discloses that historical information of the font is described in XML, but does not disclose any configuration capable of universal access by a URI (Uniform Resource Identifier). Further, the above-mentioned requirements such as the type of update information in addition to the font, flexibility of the format, and cooperation with another Web resource cannot be satisfied.
The present invention has been made to overcome the conventional drawbacks, and has as its object to provide an image processing apparatus capable of solving the above problems and meeting the above requirements, a control method thereof, and a program.
To achieve the above object, the present invention comprises the following arrangement.
An image processing apparatus which is connected to a network and communicates with an external apparatus comprises
update information collection means for collecting information on update of data stored in the apparatus,
generation means for generating and saving syndication data which describes the update information collected by the update information collection means in a markup language, and
syndication data providing means for providing the syndication data in response to a request from the external apparatus.
A network apparatus which can communicate with an external apparatus on a network comprises
collection means for collecting update information representing that data stored in the network apparatus is updated,
generation means for generating data which describes the update information collected by the collection means in a format that can be reproduced by the external apparatus,
save means for saving the data generated by the generation means, and
data transmission means for transmitting data saved in the save means in response to a request from the external apparatus.
An image processing apparatus having a printing unit or an image reading unit comprises
collection means for collecting update data,
processing means for processing the collected update data, and
output means for outputting the update data processed by the processing means in a format of a markup language notation including a plurality of items.
A structure of syndication data in a markup language notation that is recorded on a computer-readable recording medium and represents update information available in an information processing apparatus or an image processing apparatus comprises
a declaration of version information of the markup language,
a declaration of version information of the syndication data,
an element which describes information on distribution, and
elements which list pieces of update information,
wherein the structure of the syndication data is distributed as update information of data stored in an image processing apparatus which is connected to a network, communicates with an external apparatus, and has a printing unit or an image reading unit.
The present invention exhibits the following effects. (1) The administrator can centrally monitor a change in data (i.e., update information) accumulated in a plurality of apparatuses. The administrator can unitarily grasp update information of a plurality of apparatuses. The present invention can also obtain any one of the following effects.
(2) The user can grasp a change, caused by another user, in data accumulated in an apparatus shared with another user. The user can unitarily grasp update information of a plurality of apparatuses.
(3) The administrator can grasp update information from anywhere (particularly including a remote place).
(4) The administrator can unitarily grasp update information of data in the apparatus together with update information of a Web site.
(5) The administrator can grasp update information in cooperation with a related Web page, Web application, and the like.
(6) The administrator can exploit update information in various ways.
(7) The administrator can finely control the contents and format of update information supplied from the apparatus.
(8) The administrator can flexibly customize update information supplied from the apparatus.
(9) The administrator can grasp a change in application embedded in the apparatus and a change in license which permits the use of the embedded application.
(10) The administrator can grasp update information of documents accumulated in the apparatus.
(11) The administrator can grasp update information of an address book accumulated in the apparatus.
(12) The administrator can grasp information obtained by statistically processing data accumulated in the apparatus.
(13) The administrator can grasp changes including not only addition and modification of data accumulated in the apparatus but also deletion of data from the apparatus.
(14) The administrator can grasp details of deleted data for a predetermined period even after deletion.
(15) When a change in data accumulated in the apparatus pertains to an image, the administrator can grasp the contents of the image as update information.
Other features and advantages of the present invention will be apparent from the following description taken in conjunction with the accompanying drawings, in which like reference characters designate the same or similar parts throughout the figures thereof.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention.
<System Configuration>
The best mode for carrying out the invention will be described with reference to the accompanying drawings.
The image processing apparatus 110 comprises a scanner 113 serving as an image input device, a printer 114 serving as an image output device, a controller unit 111, and an operation unit 112 serving as a user interface. The image processing apparatus 110 is a so-called digital multi-functional peripheral, and can accomplish functions such as copying, printing, image capturing, image filing, and transmission (e.g., E-mail/FAX/FTP/file sharing) by using the above devices.
The scanner 113, printer 114, and operation unit 112 are connected to the controller unit 111, and controlled by instructions from the controller unit 111. The controller unit 111 is connected to the LAN 100.
The image processing apparatuses 120 and 130 have the same configuration as that of the image processing apparatus 110. The image processing apparatus 120 comprises a scanner 123, printer 124, and operation unit 122, which are connected to a controller unit 121. The image processing apparatus 130 comprises a scanner 133, printer 134, and operation unit 132, which are connected to a controller unit 131.
The desktop computer 101 is an information processing apparatus usually used by the user, and stores application programs, user data, and the like which are used by the user. The desktop computer 101 can also execute a distributed application in cooperation with the image processing apparatuses 110, 120, and 130 and a server computer (not shown) via the LAN 100.
<Software Configuration of Image Processing Apparatus>
A user interface (UI) module 201 interfaces between the apparatus and a user operation when the operator performs various operations and settings to the image processing apparatus. This module transfers input information to various modules (to be described later), requests processes, and sets data in accordance with operations by the operator.
An Address-Book module 202 is a database module which manages the data destination, communication destination, and the like. As for data managed by the Address-Book module 202, the Address-Book module 202 adds, deletes, and acquires data in accordance with operation instructions from the UI module 201. The Address-Book module 202 sends data and gives communication destination information to modules (to be described later) in accordance with operations by the operator.
A Web-Server module 203 notifies a Web client of management information of the image processing apparatus in accordance with a request from the Web client (e.g., the desktop computer 101). The management information is acquired via a Universal-Send module 204, Remote-Copy-Scan module 209, Remote-Copy-Print module 210, and Control-API module 218 (to be described later). The Web client is notified of the management information via an HTTP module 212, TCP/IP communication module 216, and Network-Driver 217 (to be described later).
The Universal-Send module 204 controls data distribution. This module distributes data designated by the operator via the UI module 201 to a similarly designated communication (output) destination. When the operator designates generation of data to be distributed using the scanner function of the apparatus, the Universal-Send module 204 operates the apparatus via the Control-API module 218 (to be described later), and generates data.
A P550 module 205 is contained in the Universal-Send module 204, and executed when a printer is designated as an output destination. An E-Mail module 206 is contained in the Universal-Send module 204, and executed when an E-mail address is designated as a communication destination. A DB module 207 is contained in the Universal-Send module 204, and executed when a database is designated as an output destination. A DP module 208 is contained in the Universal-Send module 204, and executed when an image processing apparatus similar to the apparatus in
The Remote-Copy-Scan module 209 reads image information by using the scanner function of the image processing apparatus, and outputs the read image information to another image processing apparatus connected to a network or the like. The Remote-Copy-Scan module 209 implements a copying function, which is originally implemented by a single image processing apparatus, by using a plurality of image processing apparatuses.
The Remote-Copy-Print module 210 outputs, by using the printer function of the image processing apparatus, image information obtained by another image processing apparatus connected via a network or the like. The Remote-Copy-Print module 210 implements a copying function, which is originally implemented by a single image processing apparatus, by using a plurality of image processing apparatuses.
A Web Browser module 211 loads and displays information from various Web sites (homepages) on the Internet or an intranet. The detailed configuration of the Web browser will be described later.
The HTTP module 212 is used when the image processing apparatus performs communication by HTTP (HyperText Transfer Protocol). By using the TCP/IP communication module 216 (to be described later), the HTTP module 212 provides a communication function to the Web-Server module 203 and Web Browser module 211. This module copes with various protocols (e.g., HTTP) used in the Web, and also provides a communication function based on particularly a security protocol.
By using the TCP/IP communication module 216 (to be described later), an Ipr module 213 provides a communication function to the P550 module 205 in the Universal-Send module 204.
By using the TCP/IP communication module 216 (to be described later), an SMTP module 214 provides a communication function to the E-Mail module 206 in the Universal-Send module 204.
By using the TCP/IP communication module 216 (to be described later), an SLM (Salutation-Manager) module 215 provides a communication function to the DB module 207 and DP module 208 in the Universal-Send module 204, the Remote-Copy-Scan module 209, and the Remote-Copy-Print module 210.
By using the Network-Driver 217 (to be described later), the TCP/IP communication module 216 provides a network communication function to various modules described above. The Network-Driver 217 controls a portion physically connected to a network.
A Control-API 218 provides an interface with a downstream module such as a Job-Manager module 219 (to be described later) to an upstream module such as the Universal-Send module 204.
The Job-Manager module 219 interprets various processes designated by various modules described above via the Control-API 218, and gives instructions to respective modules (220, 224, and 226) to be described later. The Job-Manager module 219 unitarily manages hardware processes executed in the image processing apparatus.
A CODEC-Manager module 220 manages and controls various data compression/decompression processes among processes designated by the Job-Manager module 219.
An FBE encoder module 221 encodes, by using the FBE format, data loaded by a scan process executed by the Job-Manager module 219 and a Scan-Manager module 224 (to be described later).
A JPEG-CODEC module 222 JPEG-compresses data loaded in a scan process executed by the Job-Manager module 219 and Scan-Manager module 224. The JPEG-CODEC module 222 JPEG-expands print data in a printing process executed by a Print-Manager module 226.
An MMR-CODEC module 223 MMR-compresses data loaded in a scan process executed by the Job-Manager module 219 and Scan-Manager module 224. The MMR-CODEC module 223 MMR-decompresses print data in a printing process executed by the Print-Manager module 226.
An information-embedded image CODEC (IEI-CODEC) module 229 decodes information embedded in image data loaded in a scan process executed by the Job-Manager module 219 and Scan-Manager module 224. Also, the IEI-CODEC module 229 embeds information in print image data in a printing process executed by the Print-Manager module 226. Embedding of information in image data uses an encoding technique with a barcode, digital watermark, or the like. The IEI-CODEC module 229 supports, as a kind of decoding technique, character recognition of recognizing characters in an image of image data by segmentation and the OCR technique, and converting the characters into text data. The IEI-CODEC module 229 also supports, as a kind of encoding technique (information embedding technique), conversion from a text into image data by using a raster image processor, and overlay of converted image data and original image data.
The Scan-Manager module 224 manages and controls a scan process designated by the Job-Manager module 219.
An SCSI driver 225 interfaces communication between the Scan-Manager module 224 and the scanner unit internally connected to the image processing apparatus.
The Print-Manager module 226 manages and controls a printing process designated by the Job-Manager module 219.
An Engine-I/F module 227 provides an interface between the Print-Manager module 226 and the printing unit.
A Parallel port driver 228 provides an I/F when data is output to an output device (not shown) via a parallel port.
<Hardware Configuration of Image Processing Apparatus>
The controller unit 111 is connected to the scanner 113 serving as an image input device and the printer 114 serving as an image output device. Further, the controller unit 111 is connected to the LAN 100 and a public line (WAN). The controller unit 111 inputs/outputs image information and device information.
A CPU 301 is a controller which controls the whole controller unit 111. A RAM 302 is a system work memory used to operate the CPU 301. The RAM 302 is also an image memory for temporarily storing image data. A ROM 303 is a boot ROM, and stores the boot program of the system. An HDD 304 is a hard disk drive, and stores system software and image data.
An operation unit I/F 306 interfaces the operation unit 112, and outputs, to the operation unit 112, image data to be displayed on the operation unit 112. Also, the operation unit I/F 306 transfers, to the CPU 301, information input by the user via the operation unit 112.
A network interface (Network) 308 controls connection to the LAN 100, and inputs/outputs information to/from the LAN 100. A modem 309 controls connection to the public line, and inputs/outputs information to/from the public line. These devices are arranged on a system bus 307.
An image bus interface (Image Bus I/F) 305 is a bus bridge which connects the system bus 307 and an image bus 310 for transferring image data at high speed, and converts the data structure. The image bus 310 is formed from a PCI bus or I15E1394 bus.
The following devices are arranged on the image bus 310. A raster image processor (RIP) 311 expands a PDL code transmitted from a network into a bitmap image. A device I/F 312 connects the controller unit 111 and the scanner 113 and printer 114 serving as image input/output devices, and performs conversion between a synchronous system and an asynchronous system of image data.
A scanner image processing unit 313 performs correction, process, and editing for input image data. A printer image processing unit 314 performs correction, resolution conversion, and the like corresponding to the performance of the printer 114 for printout image data. An image rotation unit 315 rotates image data. An image compression unit 316 performs a JPEG compression/decompression process for multi-level image data, and JBIG, MMR, and MH compression/decompression processes for binary image data.
The scanner 113 serving as an image input device illuminates an image on paper serving as a document, and scans a 13D line sensor (not shown) to generate raster image data.
When the user sets document sheets on a tray 406 of a document feeder 405 and designates the start of read on the operation unit 112, the CPU 301 of the controller unit 111 instructs the scanner 113 to feed the document sheets set on the tray 406 one by one, and the scanner 113 reads the document image.
The printer 114 serving as an image output device prints raster image data on paper. The printing method includes an electrophotographic method using a photosensitive drum and photosensitive belt, and an inkjet method of discharging ink from a small nozzle array to directly print an image on paper. Any method can be adopted. Note that a printing operation starts in response to an instruction from the CPU 301.
The printer 114 has a plurality of paper feed stages so as to select different paper sizes or different paper orientations, and is equipped with corresponding paper cassettes 401, 402, and 403. A delivery tray 404 receives printed paper.
An LCD display unit 501 is configured by adhering a touch panel sheet 502 on an LCD (Liquid Crystal Display). The LCD display unit 501 displays the operation window and soft keys of the image processing apparatus 110. When a displayed key is touched, the LCD display unit 501 transfers position information representing the touched position to the CPU 301 of the controller unit 111.
A start key 505 is operated to, for example, start reading a document image. An LED display 506 in two, green and red colors is arranged at the center of the start key 505, and the color of the LED display 506 represents whether the start key 505 is available. A stop key 503 is operated to stop an operation of the image processing apparatus 110 in progress. An ID key 507 is operated to input the user ID of the user. A reset key 504 is operated to initialize settings from the operation unit 112.
As described above, the operation unit 112 is connected to the system bus 307 via the operation unit I/F 306. The system bus 307 is connected to the CPU 301, RAM 302, ROM 303, and HDD 304. The CPU 301 comprehensively controls access to various devices connected to the system bus 307 on the basis of control programs and the like stored in the ROM 303 and HDD 304. The CPU 301 loads input information from the scanner 113 connected via the device I/F 312, and outputs an image signal serving as output information to the printer 114 connected via the device I/F 312. The RAM 302 is a main memory, work area, and the like for the CPU 301.
User input information from the touch panel 502 and various hard keys 503, 504, 505, and 507 is transferred to the CPU 301 via an input port 601. The CPU 301 generates display window data on the basis of the contents of user input information and the control program, and outputs display window data to the LCD display unit 501 via an output port 602 for controlling a window output device. If necessary, the CPU 301 controls the two-color LED display 506.
The copying function is used to print, by the printer 114, document image data scanned and read by the scanner 113 and obtain a copy of a document. The sending function is used to send document image data read by the scanner 113 and image data accumulated in the HDD 304 to various output destinations. Output destinations are various output destinations to which data can be sent via the network interface 308 by various protocols, and various output destinations to which data can be sent via the modem 309 by protocols such as a facsimile protocol. A plurality of output destinations can be selected to send data.
The box function is used to browse, edit, print, and send document files which are accumulated in the HDD 304 and include image data and code data. Document files stored in the HDD 304 include document image data read by the scanner 113, data downloaded via the network interface 308, data which accumulates print data received from another apparatus via the network interface 308, and facsimile data received from another apparatus via the modem 309. The box function can be used as an electronic mail box in user's office environment. The box function can also be utilized for secured printing which enhances the confidentiality of a PDL print job by delaying printout on paper until a password is input. The extension function is used to call various extended functions so as to, for example, lock the scanner 113 for use from an external apparatus. The browser function is used to browse a Web site.
A middle portion 702 in
(Operation of Distributed Application by Web Browser)
A contents parser 802 receives contents data in a presentation format such as HTML, XML, or XHTML from the protocol processing unit 801, and executes lexical analysis and syntax analysis to generate a parse tree.
A DOM establishment unit 803 receives the parse tree from the contents parser 802, and establishes a document object model (DOM) corresponding to the structure of contents data. Conventional HTML permits various grammatical omissions and includes various versions. In many cases, actually operated contents are neither well-formed nor valid. For this reason, the DOM establishment unit 803 infers a correct logical structure of grammatically invalid contents data, and tries to establish a valid DOM, similar to another general Web browser.
A DOM processing unit 804 holds and manages, in a memory, a DOM established by the DOM establishment unit 803 as a tree structure presenting the nesting relationship between objects. Various processes by the Web browser are implemented centrally using the DOM.
A layout engine 807 recursively determines a presentation in display of each object in accordance with the tree structure of objects held in the DOM processing unit 804, and as a result, obtains the layout of the entire document. The presentation in display of each object may be explicitly designated in a style sheet format such as Cascading Style Sheet (CSS) by a description embedded in a document or a description in another file linked from the document.
A style sheet parser 806 analyzes a style sheet associated with the document of contents.
The layout engine 807 determines a document layout by reflecting the analysis result of the style sheet.
In accordance with the document layout determined by the layout engine 807, a renderer 808 generates graphical user interface (GUI) data to be displayed on the LCD display unit 501 (
An event processing unit 809 receives the event of an operation performed by the user to the touch panel sheet 502 or each key on the operation unit 112, and performs a process corresponding to the event. The event processing unit 809 also receives a state transition event of the apparatus, a job, or the like from the apparatus control API 218, and performs a process corresponding to the event. Event handlers corresponding to various events are registered for each object class and each object instance in the tree structure of a DOM managed by the DOM processing unit 804. In response to a generated event, the event processing unit 809 determines, among objects managed by the DOM processing unit 804, an object which takes charge of processes of the event. Then, the event processing unit 809 distributes the event. If the object receives the distributed event, it executes various processes in accordance with the algorithm of an event handler corresponding to the event. Processes of the event handler include update of a DOM held by the DOM processing unit 804, a redrawing instruction to the layout engine 807, an instruction to issue an HTTP request to the DOM processing unit 804, and control of the function of the image processing apparatus by calling the apparatus control API 218.
A script interpreter 805 interprets and executes a script such as Java® Script (ECMA Script). The script is embedded in a document or described in another file linked from a document, and performs an operation to the DOM or the like. The contents provider can program the dynamic behavior of a provided document by the script.
An OK button 903 is a soft key for finalizing a URL character string input to the URL input field 902. After the URL is finalized, the Web Browser module 211 issues an HTTP request to acquire the resource. A progress bar 904 represents the progress of a contents acquisition process in response to the HTTP request. A contents display area 905 displays an acquired resource.
A return button 906 is a soft key used to trace back the history of contents display and display again contents which have been displayed before the currently displayed contents. A Next button 907 is a soft key used to, when contents are displayed while the history of contents display is traced back, return to display of contents displayed after the currently displayed contents. A reload button 908 is a soft key used to acquire and display again the currently displayed contents. A stop button 909 is a soft key used to stop a contents acquisition process in progress.
A status area 910 (bottom 703) displays messages from various functions of the image processing apparatus 110. Even while the Web browser window is displayed, a message which is sent from the scanner 113, printer 114, or another function and draws user's attention is displayed in the status area 910. Similarly, a message from the Web browser function is also displayed in the status area 910. The Web browser function sends the URL character string of a link destination, the title character string of contents, a message designated by a script, and the like.
(Addition and Deletion of Embedded Application)
A real time OS 1101 is a real time operating system which controls the overall image forming apparatus. The real time OS 1101 provides software running on the real time OS 1101 with the services and frameworks of various resource management operations that are optimized to control an embedded system. A controller 1102 controls the hardware (e.g., reader unit and printer unit) of the image forming apparatus, and controls jobs which use printing, scanning, image conversion, and the like. An embedded application 1103 provides the copying, box, and sending functions which are implemented mainly using the functions of the controller 1102, and the embedded application 1103 includes a user interface. A JVM 1104 is a Java® virtual machine, and includes an interpreter and the like for operating a Java® program on the device.
An OSGi framework 1105 is a component which manages the lifecycle of an application running on the JVM 1104, and manages installation/uninstallation and start/stop of an application. This mechanism complies with a standard technique “OSGi Framework” which is one of standard techniques of management services. See “OSGi Service Platform Release 2, Oct. 2001, OSGi” for details of the OSGi framework.
An apparatus control class library 1106 provides an interface which allows an additional application to control devices such as the printer and scanner of the image processing apparatus via the controller 1102. A utility class library 1107 provides the additional application with various functions of the image processing apparatus. An imaging class library 1108 provides a basic image processing function, and performs processes such as size reduction of an image and format conversion of an image.
A MIB agent class library 1109 is used to acquire and set MIB (Management Information Base) information set in the image processing apparatus. A security class library 1110 provides an interface corresponding to Java® standard encryption/security packages (JCE and JSSE). A USB common class library 1111 provides a communication function via a USB.
An additional application 1112 is described in a Java® program, and can be dynamically added/deleted to/from the image processing apparatus. Additional applications are classified into an applet type serving as an application which displays a user interface on the operation unit, a servlet type which displays a user interface on a Web browser on a network, and an esplet type having no user information. By adding an application, the functions of the image processing apparatus can be extended.
A system interface service (SIS) 1113 provides an information exchange function between the additional application and the image forming apparatus. The system interface service 1113 is used to notify an application of an event such as a change in power state upon reception of a request from the application, or request a device from an application to control the LED or buzzer.
An applet viewer service 1114 performs, for example, registration, display, and switching of an applet type service. In addition, the applet viewer service 1114 notifies an applet type additional application of an event.
A service management service (SMS) 1115 provides a user interface for managing an additional application. The SMS has the following functions as application management functions.
List Display:
A list of an application name, install date, application ID, state, license state, and resource use status is displayed.
Installation:
An application is installed.
Uninstallation:
An application is completely deleted from the device. Note that no application can be uninstalled unless the license is invalidated.
Start:
A halting application is activated and started.
Stop:
A running (active) application is stopped.
License Installation:
The license file of an application which requires a license is installed.
License Invalidation:
The license of an application is so invalidated as to extract a license file from a device onto a PC.
License Downloading:
An invalid license (license file) is downloaded to a PC. The downloaded license can be installed again in only the same device.
Switching of Authentication Application:
An authentication application is switched. After switching, the device must be activated again.
Change of Display Order:
The display order of applications on the operation unit is changed.
Display of System Information:
System information is displayed.
Application Information List:
A list of information including the license contents of an application is displayed.
Application History List:
A list of uninstalled applications is displayed.
Change of Password:
A password for logging in the SMS is changed.
An HTTP service 1116 is a component which performs communication by HTTP and HTTPS. The function of the HTTP service allows a Web browser on a network to access a system application and additional application. The HTTP service 1116 is extended from the log-in function on the basis of Http Service specifications defined in the above-mentioned “OSGi Framework”.
An uninstall button 1305 is used to uninstall an application selected with the radio button. When a selected application cannot be uninstalled depending on the license state of the application, the button is grayed out to inhibit press of it.
A start button 1306 is used to start an application selected with the radio button. A stop button 1307 is used to stop an application selected with the radio button. A resource information display area 1308 displays a hard disk capacity, memory, thread, socket, and file descriptor which are used by an installed application.
An application selection button 1404 is used to select the file of an application to be installed. When the button 1404 is pressed, an OS standard file selection dialog is displayed. The user can select an application to be installed from this dialog. A field 1405 displays the path of an application file selected by the user.
A license file selection button 1406 is used to select a license file for an application to be installed. When the button 1406 is pressed, an OS standard file selection dialog is displayed. The user can select a license file to be installed from this dialog. A field 1407 displays the path of a license file selected by the user. An OK button 1408 is used to execute installation of an application file and license file selected by the user. A cancel button 1409 is used to cancel an install process.
An application information display area 1505 displays detailed information of an application. The displayed information includes the application ID, application name, install date, manufacturer, and product version. A license information display area 1506 displays license information of an application. The displayed information includes the license state, serial number, term of validity, and counter information. A license management button 1507 is used to call a license management window (
(Generation and Supply of Update Information Feed Data of Provided Service)
The software configuration in the image processing apparatus 110 will be explained. A software structure for generating and supplying the RSS feed of application-related update information includes the JVM 1104, apparatus control class library 1106, service management service 1115, and HTTP service 1116. The internal structure of the service management service 1115 is formed from the following software. Note that the additional application 1112 in
An application management interface 1703 provides a management interface for installing, uninstalling, or controlling from outside the apparatus, an application and license which are embedded in the image processing apparatus 110 and provide services. The application management interface 1703 is installed as a Web application (servlet type service) of the SMS 1115, and can be operated by the administrator 1701 from a remote Web browser via network communication (not shown). The application management interface 1703 may also be installed to provide a user interface to the operation unit 112 locally arranged in the image processing apparatus (applet type service).
A MEAP application database (DB) 1704 accumulates and manages MEAP applications and their licenses 1704A which are installed in the embedded application platform of the image processing apparatus 110.
A syndication DB 1705 stores and manages data used to syndicate update information related to an embedded application of the image processing apparatus 110. The stored/managed data include an update information entry which is generated while holding attribute information on an event every time an event of a change in MEAP application and its license occurs.
A template DB 1706 stores and manages templates which provide XML file formats used for syndication (distribution). Data which describes a generation rule is also contained in template data. Examples of the generation rule are information (monitoring target information) 1706A which defines whether to monitor a change as a target of update information, and information (period information) 1706B on the target period of update information. These pieces of information will be explained later with reference to
An update information generation unit 1707 includes a template engine. Based on templates accumulated and managed in the template DB 1706, the template engine generates an XML file used for syndication from data which are accumulated and managed in the syndication DB 1705, and attributes (e.g., the configuration and state of the image processing apparatus 110) which are obtained from the apparatus control class library 1106. The update information generation unit 1707 stores the generated XML file (syndication data file for RSS, Atom, or the like) in an update information (RSS) storage unit 1708.
The update information (RSS) storage unit 1708 accumulates XML files used for syndication. The update information storage unit 1708 holds a plurality of different files in accordance with types of information to be syndicated. In accordance with the specifications of pursuant XML applications, the update information storage unit 1708 holds a plurality of files which are described in respective RSS versions and formats such as Atom. The update information storage unit 1708 is mounted as a file system which can be accessed by the HTTP server 1116. The files of XML files accumulated in the update information storage unit 1708 are specified by unique URLs when viewed from HTTP clients connected to the HTTP server 1116. When an HTTP client is connected to the HTTP server 1116 and requests acquisition of a resource specified by a URL, the HTTP server 1116 reads out, from the update information storage unit 1708, an XML file corresponding to the URL designated by the acquisition request, and transmits the XML file to the HTTP client.
In response to a request by HTTP or HTTPS from an HTTP client, the HTTP server 1116 transfers, as a response, data of various resources internally held in the image processing apparatus 110. Examples of the resource accessed by the client by HTTP are static data files (including XML files held in the update information storage unit 1708) such as HTML files and image files which are hold in a nonvolatile memory (e.g., HDD 304) in the image processing apparatus 110, and data dynamically generated by a program executed by the CPU 301. Data dynamically generated in response to an HTTP request includes HTML data which are generated by various Web applications (e.g., the above mentioned SMS user interface for remote control from a desktop computer) provided by a MEAP servlet type application running on the JVM 1104.
<Software Configuration of Computer>
The software configuration in the desktop computer 101 will be explained. The RSS reader 1710 is an application program which acquires each RSS version and an XML format (e.g., Atom) for syndication, and formats and displays data. Most of news distribution sites, information providing sites, and Web sites (e.g., weblog or blog) present on the Internet provide syndication data in order to syndicate new articles of sites, in addition to contents of the sites. By using the RSS reader 1710, the user 1702 can efficiently browse the titles and contents of new articles of sites on the Internet. The RSS reader 1710 can access even syndication data not only on the Internet but also on an intranet as far as the data is laid open to the public as a resource which can be specified by a URI and acquired. The RSS reader 1710 designates a URI for identifying syndication data stored in the update information storage unit 1708 of the image processing apparatus 110, and transmits an HTTP acquisition request to the HTTP server 1116. As a response from the HTTP server 1116 to the acquisition request, the RSS reader 1710 can receive syndication data stored in the update information storage unit 1708. In some cases, syndication data which is formatted and displayed by the RSS reader 1710 contains a hyperlink specified by a URI. When the user 1702 selects a specific hyperlink on the display of the RSS reader 1710, the RSS reader 1710 causes the Web browser 1709 to acquire and display the URI in cooperation with the Web browser 1709.
The Web browser 1709 acquires various resources provided in formats specifiable by URIs in Web servers on the Internet and an intranet, for example, document data of markup languages (e.g., HTML and XHTML) and various multimedia data (still image, moving image, and audio data). The Web browser 1709 appropriately formats the data, and graphically displays the data or outputs the data by voice. Data is acquired mainly using a communication protocol such as HTTP or FTP. The Web browser 1709 serves as a client of a client server model in terms of the communication protocol, and is regarded as, e.g., an HTTP client. When data browsed by the user 1702 contains a hyperlink specified by a URI and the user selects the anchor of the specific hyperlink, the Web browser 1709 acquires and displays resources at the designated URI. By using the form of a markup document such as an HTML document, data may be posted from the Web browser 1709 to a resource on the Web server side. The user 1702 uses the Web browser 1709 to issue an acquisition request by designating a URI assigned to a servlet running on the JVM 1104 of the image processing apparatus 110. The HTTP server 1116 of the image processing apparatus 110 transfers the acquisition request to the servlet, and sends back, to the Web browser 1709, a response such as HTML data generated as a result of a process by the servlet.
Note that the RSS reader 1710 and Web browser 1709 are implemented as single application programs in the first embodiment, but may be implemented as a single application program having the functions of both the RSS reader 1710 and Web browser 1709. The RSS reader 1710 and Web browser 1709 run on the desktop computer 101 in the above description, but may run on various general-purpose information processing apparatuses including a portable computer (e.g., PDA), in addition to the desktop computer. Alternatively, the RSS reader 1710 and Web browser 1709 may run on image processing apparatuses such as a multi-functional peripheral and digital camera, like the image processing apparatuses 120 and 130, and various embedded apparatuses such as a cell phone.
A deviceName 1804 represents an apparatus name uniquely given to a specific image processing apparatus 110. The unique apparatus name is assigned by the user (administrator) of the apparatus in order to specify an apparatus for convenience in use. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A deviceSerialNumber 1805 represents a serial number assigned to a specific image processing apparatus 110. The serial number is sometimes used to specify an individual apparatus by the manufacturer of the image processing apparatus 110. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A deviceOptionUnits 1806 represents a character string which describes optional units mounted in the image processing apparatus 110. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A deviceLocation 1807 represents a character string which describes a location where the image processing apparatus 110 is installed. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106.
An administrator 1808 describes the name of a user in charge of management of the image processing apparatus 110, and the E-mail address of the user. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A messageOfTheDay 1809 describes a message which is announced by a user in charge of management of the image processing apparatus 110 to other users. This message is sometimes displayed on the operation unit 122 of the image processing apparatus 110 or a Web application (remote UI). When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106.
An mfpStatus 1810 describes the operation status of the image processing apparatus 110 as a multi-functional peripheral. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A printStatus 1811 describes the operation status of the image processing apparatus as a printer. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. An imageReaderStatus 1812 describes the operation status of the image processing apparatus 110 as an image input apparatus (image scanner, digital camera, or the like). When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A sendStatus 1813 describes the operation status of the image processing apparatus 110 as a transmission apparatus (FAX, IFAX, E-mail, file transfer, or the like). When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A receiveStatus 1814 describes the operation status of the image processing apparatus 110 as a reception apparatus (FAX, IFAX, E-mail, file transfer, or the like). When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106. A storageStatus 1815 describes the operation status of the image processing apparatus 110 as a storage apparatus. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106.
A lastUpdateDate 1816 describes a date and time when the latest update information entry is registered in the syndication DB 1705. An entry 1817 describes a list having a structure for holding a series of update information entries. The structure of each entry contained in the list will be described later. An application 1818 represents a list having a structure for holding information on applications and licenses installed in the MEAP application DB 1704. A user 1819 represents a list having a structure for holding information on the registration user of the image processing apparatus 110. When the update information generation unit 1707 requires the value in this field, this requirement is dynamically solved by acquiring the value from the controller via the apparatus control class library 1106.
The structure of each element contained in a list 1820 of the entry 1817 will be explained. Each element of the list corresponds to an individual update information entry. An entryPermanentLink 1821 describes a URI which specifies a resource for acquiring HTML data that explains detailed information of the update information entry. When the user acquires a resource designated by the URI by using the Web browser 1709 or the like, display of detailed information associated with the update information is obtained. An entryDate 1822 describes a date and time when the update information entry is generated. An entrySubject 1823 describes the subject of the update information entry. For example, for an entry representing installation of a new application, the entrySubject 1823 describes information “install” as an event category.
An entryDescription 1824 describes an explanation of the update information entry. The explanation helps the user understand the contents of update information by reading the explanation, and is described in a natural language. In some cases, the explanation is marked up in HTML or the like, and a hypertext link, image, or the like is embedded. An entryOperator 1825 describes a user who has performed an operation to generate an update event corresponding to the update information entry. When no specific user is involved in generation of an event (for example, an event automatically generated by the timer), the value in this field is “system”, “timer”, or the like. An entryApplicationName 1826 describes the name of an application pertaining to the update information entry. When the application is a Web application, the entryApplicationName 1826 also contains a description of a URI which specifies the Web application. For example, when update information is installation of a new application, the related application is the installed application. An entryApplicationDescription 1827 describes an explanation of the application pertaining to the update information entry. The explanation helps the user understand the contents of an application by reading the explanation, and is described in a natural language. In some cases, the explanation is marked up in HTML or the like, and a hypertext link, image, or the like is embedded.
An entryApplicationSeeAlso 1828 describes a URI which specifies another information source of the application pertaining to the update information entry. For example, an entryApplicationSeeAlso 1828 describes the URL of an application information display window by the SMS, or the URL of an application information page on a Web site provided by the developer of the application. An entryLicenseCondition 1829 describes the license condition and state of the application pertaining to the update information entry. An entryIsNewApplication 1830 becomes true in a case in which the update information entry is based on an event of adding a new available application. An entryIsApplicationUnavailable 1831 becomes true in a case in which the update information entry is based on an event generated when the application becomes unavailable upon uninstallation or the like. An entryIsLicenseExpired 1833 becomes true in a case in which the update information entry is based on an event of losing the license due to expiration.
A switch 1903 is used to set whether to monitor a warning of expiration of the term of validity of a license. When the switch 1903 is set ON and the number of remaining days of the term of validity of the license becomes smaller than a predetermined value (30 days, 10 days, 5 days, or 1 day), the information is recorded in the update information file.
A switch 1904 is used to set whether to monitor invalidation of a license. When the switch 1904 is set ON and the license becomes invalid, the information is recorded as update information. The license becomes invalid when the term of validity is expired or the user invalidates the license.
A switch 1905 is used to set whether to monitor application counter information. When the switch 1905 is set ON and the value of the application counter changes, the information is recorded as update information.
Values set with these switches are saved for the respective items in the monitoring target information 1706A shown in
In step S2001, the flow waits for an operation selection input by the user, and the condition branches in accordance with the operation type. If the selected operation type is installation (corresponding to 1301 in the operation window), the flow advances to step S2002; if the selected operation type is an application list (corresponding to 1401 in the operation window), to step S2007.
In step S2002, both or one of an application file and license file is input. In step S2003, it is determined whether the application file has been input. If the application file has been input, the flow advances to step S2004; if no application file has been input; to step S2005. In step S2004, the input application file is installed in the MEAP application DB 1704. In step S2005, it is determined whether the license file has been input. If the license file has been input, the flow advances to step S2006; if no license file has been input, to step S2012. In step S2006, the input license file is installed in the MEAP application DB 1704. Then, the flow advances to step S2012.
In step S2007, the application selected by the user is selected from the application list. The following operation targets the selected application.
In step S2008, the flow waits for an operation selection input by the user, and the condition branches in accordance with the operation type. If the selected operation type is uninstallation (corresponding to 1305 in the operation window), the flow advances to step S2009; if the selected operation type is the start (corresponding to 1306 in the operation window), to step S2010; if the selected operation type is the stop (corresponding to 1307 in the operation window), to step S2011.
In step S2009, the selected application is uninstalled from the MEAP application DB 1704. Then, the flow advances to step S2012. In step S2010, the operation of the selected application starts. After that, the flow advances to step S2012.
In step S2011, the operation of the selected application stops. Then, the flow advances to step S2012.
In step S2012, an update information entry corresponding to a process executed in the preceding step is generated. More specifically, an update information entry which describes detailed information of the event is generated in correspondence with an event of installing or uninstalling an application or license, or starting or stopping an application. At this time, an update information entry is generated when the monitoring target information 1706A is referred to and the value of an item corresponding to the event represents that the event is a monitoring target.
In step S2013, the generated update information entry is stored in the syndication DB 1705. In step S2014, an RSS feed file generation process is called to generate a new RSS feed file from the syndication DB which has been changed by adding the new update information entry.
In step S2101, job execution by an application is monitored. In step S2102, the total resource use amount along with job execution is counted up. In step S2103, it is determined whether the license condition has been lost upon expiration of the term of validity of the license, an increase in resource use amount, or the like. If the license condition has been lost, the flow advances to step S2104; if the license condition has not been lost, to step S2108.
In step S2104, the MEAP application DB 1704 is changed to invalidate the license of the application whose license has been lost. In step S2105, the operation of the application whose license has been lost is stopped. In step S2106, an update information entry which describes the event of losing the license is generated. At this time, an update information entry is generated when the monitoring target information 1706A is referred to and the value of an item corresponding to the event represents that the event is a monitoring target. In step S2107, the generated update information entry is stored in the syndication DB 1705. Then, the flow advances to step S2111.
In step S2108, the remaining days of the term of validity, the remaining amount of the use amount limitation of the resource, or the like is compared with a default value to determine whether the license condition will be lost soon. If the license condition will be lost soon, the flow advances to step S2109; if the remainder is sufficient, to step S2111. In step S2109, an update information entry which describes an event of losing the license soon is generated. At this time, an update information entry is generated when the monitoring target information 1706A is referred to and the value of an item corresponding to the event, represents that the event is a monitoring target. In step S2110, the generated update information entry is stored in the syndication DB 1705. Then, the flow advances to step S2111.
In step S2111, a statistical process based on monitoring of job execution by the application and the past history is performed. As the statistical process based on monitoring of job execution by the application and the past history, various statistical processes are effective, including calculation of the resource use for each user or each user group, calculation of the correlation between the time period and job execution, calculation of the increase/decrease degree of the application use ratio, integration of the data size by communication and accumulation, and calculation of the running cost of consumables and the maintenance cost unique to the image processing apparatus.
In step S2112, it is determined whether the use count of the job execution-monitored application during a recent predetermined period has increased suddenly from that in the past predetermined period. If the use has increased suddenly, the flow advances to step S2113; if NO, to step S2114. In step S2113, an update information entry which describes the event of suddenly increasing the use of the application is generated. At this time, an update information entry is generated when the monitoring target information 1706A is referred to and the value of an item corresponding to the event represents that the event is a monitoring target. In step S2114, the generated update information entry is stored in the syndication DB 1705.
In step S2115, an RSS feed file generation process is called to generate a new RSS feed file from the syndication DB which has been changed by adding the new update information entry. Then, the flow returns to step S2101 to repeat the application monitoring process.
An RDF element 2201 is the top element of an XML document. The RDF element contains a channel element 2202, image element 2203, and item elements 2204, 2205, and 2206. The channel element 2202 describes basic information on the whole update information. This element corresponds to an RDF subject node. The contents of the channel element contain a title element 2207, link element 2208, description element 2209, image element 2210, and items element 2211. The title element 2207 represents the title of the update information. The link element 2208 represents the URI of a site treated by the update information. The description element 2209 describes an explanation of, e.g., the contents and functions of the site treated by the update information. The image element 2210 describes a URI which specifies an image resource such as the logo of the site treated by the update information. Details of the image element 2210 will be described later in association with the image element 2203 to be described below. The items element 2211 provides the indices of the item elements 2204, 2205, and 2206. A li element 2213 listed in the contents of a Seq element 2212 represents each update information URI. The image element 2203 expresses an image such as a logo. The contents of the image element 2203 contain a title element 2214, url element 2215, and link element 2216. The title element 2214 represents the title of an image, and is sometimes used as an alternative text of the image. The url element 2215 describes the URI of an image resource. When a hyperlink using this image as an anchor is displayed, the link element 2216 describes a URI used as a link destination. The item elements 2204, 2205, and 2206, and the like represent the order of elements each expressing update information. The contents of the item element contain a title element 2217, link element 2218, and description element 2219. The title element 2217 describes the title of update information. The link element 2218 describes the URI of the update information. The description element 2219 describes a description of the update information.
A plurality of template data stored in the template DB 1706 exist in accordance with respective formats (respective RSS versions, Atom, and the like) of syndication data to be output. For example, a system integrator which constructs a system including a user, administrator, and image processing apparatus can easily copy and edit a template file to customize it in accordance with the use environment, or prepare a plurality of template variations to selectively use the template. Since the template is structured text data, it can be easily intuitively edited by a visual editor having a graphical user interface. A template editor (not shown) is provided, and the user can graphically edit the correspondence between the template structure and information to be embedded in the template.
In generating an RSS file from the template, most of the text of the template is directly output to an RSS file, but pseudo-elements (represented by bold characters in
A TMPL_VAR pseudo-element is a template variable, and is replaced by the template engine with the value of a variable having a name of the name attribute. More specifically, the TMPL_VAR pseudo-element is a variable which is replaced with an attribute associated with the configuration, setting, or state of the image processing apparatus. The value to be replaced is based on, for example, information of an update information entry in the syndication DB 1705, application information and license information in the MEAP application DB 1704, and configuration information and state information of the image processing apparatus that are obtained from the controller module via the apparatus control class library 1106.
A TMPL_LOOP pseudo-element is a template control instruction, and repetitively processes contents up to the end tag (</TMPL_LOOP>) of TMPL_LOOP while sequentially selecting variables contained in the list on the basis of a list variable having a name of the name attribute. Each of variables sequentially selected from the list has an internal structure (see the contents of the entry list in
A TMPL_IF pseudo-element is a template control instruction which controls the process of the template engine in accordance with the Boolean value of a variable having a name of the name attribute. If the variable is true, contents up to the end tag (</TMPL_IF>) of TMPL_IF are processed; if false, contents from the start tag to end tag of TMPL_IF are skipped.
Since update information feed data which is generated from the template in
As one of large effects of the first embodiment, it becomes easy to flexibly, strictly expand a data format for feeding update information.
In step S2401, a template used to generate a syndication data file (feed file) is selected from the template DB 1706 and extracted. As described above, a plurality of templates exist with variations corresponding to various XML formats and selective uses. For example, a system integrator which constructs a system including a user, administrator, and image processing apparatus can use a user interface (not shown) to select a plurality of templates which should be selected to generate a feed file. When a plurality of templates are set and the process procedures are called in order to generate a feed file, a plurality of feed files are generated in correspondence with the set templates.
In step S2402, a process of analyzing a template and outputting feed data is performed. The template analysis process procedures are recursively called, and details thereof will be described later (
In step S2501, while template data is loaded as a byte string, tokens divided by lexical analysis are sequentially loaded. In step S2502, it is determined whether the loaded token is a template pseudo-element. If the token is a template pseudo-element, the flow advances to step S2503; if the token is not a template pseudo-element (i.e., a general XML element which should be directly written in the feed file), to step S2513. In step S2503, the template instruction of the template pseudo-element is determined, and the condition branches. If the template pseudo-element is a TMPL_IF start tag, the flow advances to step S2504; if the template pseudo-element is a TMPL_LOOP start tag, to step S2506; if the template pseudo-element is TMPL_VAR, to step S2512.
In step S2504, the variable of a variable name to which the name attribute of the TMPL_IF start tag refers is evaluated to determine the Boolean value. The variable is defined by the schema in the syndication DB 1705, and the variable value is determined on the basis of the update information entry of the syndication DB 1705, the MEAP application DB 1704, and the apparatus control class library 1106. The configuration and state of the image processing apparatus, job information, and the like are obtained from the apparatus control class library 1106. If the Boolean value of the variable is false, the flow advances to step S2505; if true, to step S2514. In step S2505, since the TMPL_IF condition is false, template data up to a TMPL_IF end tag is skipped. Then, the flow advances to step S2514.
In step S2506, a list variable having a name of the name attribute in the TMPL_LOOP start tag is read out from the syndication DB and evaluated. A TMPL_LOOP control instruction is to repetitively process contents up to a TMPL_LOOP end tag (</TMPL_LOOP>) while sequentially selecting variables contained in the list. A case in which the list variable is entry will be explained.
In step S2507, each variable, i.e., each update information entry contained in the list is selected from the entry list read out from the syndication DB. Each variable contained in the list has the internal structure in
In step S2508, an internal variable entryDate of the readout update information entry is compared with the setting of the update information posting period (
In step S2509, a template analysis process is recursively performed within the scope of the selected update information entry until a TMPL_LOOP end tag appears. In step S2510, selection of the selected update information entry is canceled because one loop of the TMPL_LOOP block ends. In step S2511, it is determined whether all update information entries contained in the entry list have been processed. If all update information entries have been processed, the loop ends and the flow advances to step S2514; if an unprocessed update entry remains, the flow advances to step S2506 to repeat the TMPL_LOOP block process.
In step S2512, the variable of a variable name to which the name attribute of the TMPL_VAR pseudo-element refers is evaluated to write the value in the feed file. The variable is defined by the schema in the syndication DB 1705, and the variable value is determined on the basis of the update information entry of the syndication DB 1705, the MEAP application DB 1704, and the apparatus control class library 1106. The configuration and state of the image processing apparatus, job information, and the like are obtained from the apparatus control class library 1106. Thereafter, the flow advances to step S2514.
In step S2513, the loaded token is directly written in the feed file as a text which forms a general XML description. Then, the flow advances to step S2514. In step S2514, it is determined whether all tokens in template data have been processed. If all tokens have not been processed, the flow returns to step S2501 to repeat the series of process procedures; if all tokens have been processed, the flow returns from the process procedures.
An element 2307 is a declaration of version information of a markup language, and declares that syndication data is described in XML 1.0. The RDF element 2201 is the top element of an XML document, as described above. At the same time, the RDF element 2201 is a declaration of the version of syndication data, and declares that the syndication data has the RSS 1.0 format. The channel element 2202 describes information on distribution. The channel element contains a link element 2308 representing a URI associated with distribution, the title element 2207 representing the name of distribution, and a description element 2209 which describes an outline of distribution. The link element 2208 describes the URI of the top page of a Web application (remote UI) of the image processing apparatus 110.
The date element 2301 describes a date and time when feed data is generated. The generatorAgent element 2302 describes software which generates feed data. The subject element 2304 describes the category of an entry. The creator element 2305 describes a user, i.e., operator who is involved in generation of an entry. The date element 2306 describes a date and time when an entry is generated.
The item element 2204 is an item which lists update data obtained by processing an update information entry. That is, the image processing apparatus 110 outputs update data in the format of a markup language notation including a plurality of items. The item element 2204 contains the link element 2218 representing a URI associated with the update information, the title element 2217 representing the name of each update information, and the description element 2219 which describes an outline of each update information. The link element 2218 describes the URI of a page which displays details of update information corresponding to an entry in the Web application (remote UI) of the image processing apparatus 110.
(Acquisition and Use of Update Information Feed Data of Provided Service)
At event 1, the user 1702 (not shown) selects an RSS feed of an image processing apparatus of interest by using the RSS reader 1710.
At event 2, the RSS reader 1710 establishes communication with the HTTP server 1116, and transmits an RSS feed acquisition request. Communication is generally performed using an application protocol such as HTTP or HTTPS.
At event 3, the HTTP server 1116 sends back an update information feed file stored in the image processing apparatus to the RSS reader 1710 as a response to the HTTP request.
At event 4, the RSS reader 1710 analyzes the acquired feed file, and formats and displays an entry which has not been read by the user 1702. The displayed update information displays, as a selectable anchor, link information defined by the XML format of syndication. When a description of the update information entry contains a hypertext such as HTML, the hyperlink is displayed as a selectable anchor.
At event 5, the user selects the anchor of a link contained in the entry displayed by the RSS reader 1710.
At event 6, the RSS reader 1710 performs application communication with the Web browser 1709, and requests the Web browser 1709 to display a resource specified by a URI described by the link.
At event 7, the Web browser 1709 acquires the requested resource. If location information of the URI which specifies the given resource designates the HTTP server 1116 of the image processing apparatus 110, the Web browser 1709 establishes communication with the HTTP server 1116, and transmits a resource acquisition request. Communication is generally performed using an application protocol such as HTTP or HTTPS. For example, the Web browser 1709 issues the acquisition request by designating a URI assigned to a servlet running on the JVM 1104 of the image processing apparatus 110.
At event 8, the HTTP server 1116 sends back the requested resource as a response to the HTTP request to the Web browser 1709. The HTTP server 1116 reads out the requested resource from the storage, or dynamically generates it by the program. For example, when the resource designated by the acquisition request is a servlet, the HTTP server 1116 transfers the acquisition request to the servlet, and sends back a response such as HTL data generated as a result of a process by the servlet.
At event 9, the Web browser 1709 formats and displays the acquired resource.
The right pane in the display window of
A feed logo image 2906 displays the logo image of feed data. Although not shown in the RSS feed example, the feed logo image 2906 corresponds to the image elements 2210 and 2203. Displayed image data is a resource acquired from a URI described in the url element 2215. The displayed image is an anchor, and when the user selects the image, the resource of a URI described in the link element 2216 is acquired and displayed in cooperation with the Web browser 1709. A feed outline 2907 displays a description of an outline of feed data, and corresponds to the description element 2209 in the RSS feed example. As shown in this example, data to be syndicated can be flexibly designed by freely combining feed data formats and template variables which can be replaced with various types of information held in the image processing apparatus. Update information entries 2908, 2909, and 2910 display update information syndicated by feed files. In the RSS feed example, the update information entries 2908, 2909, and 2910 are indexed as a list of the li elements 2213 in the items element 2211, and correspond to elements listed in the item elements 2204, 2205, and 2206.
An entry title 2911 displays the title of the update information entry. In the RSS feed example, the entry title 2911 corresponds to the title element 2217. The displayed title is the anchor of a hypertext, and when the user selects the title, the resource of a URI described in the link element 2218 is acquired and displayed in cooperation with the Web browser 1709. In this example, the entry title 2911 is the anchor of an individual entry information page for browsing details of the update information entry. An entry update date & time 2912 displays a date and time when an update information entry event occurs. In the RSS feed example, the entry update date & time 2912 corresponds to the date element 2306.
An entry description 2913 describes information on an update information entry. In the RSS feed example, the entry description 2913 corresponds to the description element 2219. The entry description is structured as a text marked up in HTML (XHTML) using an image, citation, table, and the like. The entry description is formatted and displayed so as to present the structures of these elements. Links to various resources including a Web page and E-mail address are embedded in the entry description, and their anchors are also displayed. In generating an RSS feed example, displayed information is generated on the basis of templates, various databases in the image processing apparatus, and various types of information obtained via the apparatus control class library 1106. As shown in this example, data to be syndicated can be flexibly designed by freely combining feed data formats and template variables which can be replaced with various types of information held in the image processing apparatus. For example, an anchor described in the “details” attribute value field of the table is a link to the detailed information page of the application, and when the user selects this anchor, a Web page which provides detailed application information as shown in
By the above configuration and operation, when the state of designated data changes, the image processing apparatus according to the first embodiment generates and saves data of a predetermined format (RSS 1.0 in the first embodiment) that represents the change in state and schematic contents of the change. The data of the predetermined format is read out by a computer which can interpret and process the data, and a remote computer can be notified of the change in data that has occurred in the image processing apparatus. Since the data complies with RSS, a change in state of the image processing apparatus can be easily monitored at low cost by causing a computer to execute a program including a commercially available or free RSS reader function. The computer can poll a change in state at a set interval of, e.g., 1 h, 1 day, or 1 week, or poll it at a designated timing. In addition, data is described in XML and can be easily processed.
As the apparatus state, many pieces of information can be monitored, including installation and uninstallation of an application, the start and stop of the application, a warning of expiration of the term of validity of a license, license invalidation, and statistical information. Further, monitoring targets can be selected. The period during which state change information is supplied to a computer can also be designated.
Needless to say, events to be monitored are not limited to the above ones, and another event can also be monitored. For example, a change in settings important to security (e.g., switching of whether to perform encryption, and TCP/IP port setting) may also be monitored.
(Generation and Supply of Feed Data of Box-Related Update Information)
The user 4201 accesses the same image processing apparatus 110 via an embedded RSS reader 4210 running on the image processing apparatus 110, and refers to box-related update information. The user 4201 accesses the same image processing apparatus 110 via an embedded Web browser 211 running on the image processing apparatus 110, and browses a resource and Web application provided by the image processing apparatus 110.
A software configuration for generating and supplying the RSS feed of box-related update information in the image processing apparatus 110 will be explained. A document operation interface 4203 provides an interface for operating the box function of the image processing apparatus 110. A boxed document management system 4204 is a database for the box function serving as the embedded document management system of the image processing apparatus 110. Data stored in the database include a scanned/loaded document file, a document file received by the communication function, a document file input by another input route such as generation by the PDL function, and the thumbnail image file of each document.
A syndication DB 4205 accumulates and manages data used to syndicate update information related to the box function of the image processing apparatus 110. The accumulated/managed data include an update information entry which is generated while holding attribute information on an event every time an event of a change in box structure and documents accumulated in the box occurs.
A template DB 4206 accumulates and manages templates which provide XML file formats used for syndication. XML applications for syndication comply with respective RSS versions and the specifications of Atom and the like. A plurality of templates are prepared in accordance with types of information to be syndicated and pursuant specifications. An update information generation unit 4207 includes a template engine which generates, on the basis of templates accumulated and managed in the template DB 4206, an XML file used for syndication from data which are accumulated and managed in the syndication DB 4205, and attributes (e.g., the configuration and state of the image processing apparatus 110) obtained from an apparatus control class library 1106. The update information generation unit 4207 stores the generated XML file (syndication data file for RSS, Atom, or the like) in an update information (RSS) storage unit 4208.
The update information (RSS) storage unit 4208 accumulates an XML file used for syndication. The update information storage unit 4208 holds a plurality of different files in accordance with types of information to be syndicated. In accordance with the specifications of pursuant XML applications, the update information storage unit 4208 holds a plurality of files which are described in respective RSS versions and formats such as Atom. The update information storage unit 4208 is mounted as a file system which can be accessed by an HTTP server 212. The files of XML files accumulated in the update information storage unit 4208 are specified by unique URLs when viewed from HTTP clients connected to the HTTP server 212. When an HTTP client is connected to the HTTP server 212 and requests acquisition of a resource specified by a URL, the HTTP server 212 reads out, from the update information storage unit 4208, an XML file corresponding to the URL designated by the acquisition request, and transmits the XML file to the HTTP client.
In response to a request based on HTTP or HTTPS from an HTTP client, the HTTP server 212 transfers, as a response, data of various resources internally held in the image processing apparatus 110. Examples of the resource accessed by the client by HTTP are static data files (including XML files held in the update information image storage unit 4208) such as HTML files and image files which are hold in a nonvolatile memory (e.g., HDD 304) in the image processing apparatus 110, and data dynamically generated by a program executed by a CPU 301. Data dynamically generated in response to an HTTP request include HTML data which are generated by various Web applications such as a remote UI 4212.
The remote UI 4212 is a Web application provided by the image processing apparatus 110, and provides the same function as that of the document operation interface 4203 to a client such as a connected Web browser.
The embedded RSS reader 4210 is an embedded application program which acquires each RSS version and an XML format (e.g., Atom) for syndication, and formats and displays data. The display and operation are done on an operation unit 122 of the image processing apparatus 110. Most of news distribution sites, information providing sites, and Web sites (e.g., weblog or blog) present on the Internet provide syndication data in order to syndicate new articles of sites, in addition to contents of the sites. By using the RSS reader 4210, the user 4201 can efficiently browse the titles and contents of new articles of sites on the Internet. The RSS reader 4210 can access even syndication data not only on the Internet but also on an intranet as far as the data is laid open to the public as a resource which can be specified by a URI and acquired. A URI for identifying syndication data stored in the update information storage unit 4208 of the image processing apparatus 110 is designated to transmit an HTTP acquisition request from the RSS reader 4210 to the HTTP server 212. As a response from the HTTP server 212, the RSS reader 4210 can receive syndication data stored in the update information storage unit 4208. In some cases, syndication data which is formatted and displayed by the RSS reader 4210 contains a hyperlink specified by a URI. When the user 4201 selects a specific hyperlink on the display of the RSS reader 4210, the RSS reader 4210 causes the Web browser 211 to acquire and display the URI in cooperation with the embedded Web browser 211. Upon reception of a request from another embedded application by communication with an application in the image processing apparatus 110, the embedded RSS reader 4210 acquires syndication data of a URI designated by the request, and displays the syndication data on the operation unit 122 of the image processing apparatus 110.
The Web browser 211 acquires various resources provided in formats specifiable by URIs in Web servers on the Internet and an intranet, for example, document data of markup languages (e.g., HTML and XHTML) and various multimedia data (still image, moving image, and audio data). The Web browser 211 appropriately formats the data, and graphically displays the data or outputs the data by voice. Data is acquired mainly using a communication protocol such as HTTP or FTP. The Web browser 211 serves as a client of a client server model in terms of the communication protocol, and is regarded as, e.g., an HTTP client. When data browsed by the user 4201 contains a hyperlink specified by a URI and the user selects the anchor of the specific hyperlink, the Web browser 211 acquires and displays resources at the designated URI. By using the form of a markup document such as an HTML document, data may be posted from the Web browser 211 to a resource on the Web server side. The user 4201 can also use the Web browser 211 to issue an acquisition request by designating a URI for specifying the remote UI 4212 of the same image processing apparatus 110. The HTTP server 212 of the image processing apparatus 110 internally transfers the acquisition request to the remote UI 4212 via an interface such as CGI (Common Gateway Interface), and sends back, to the Web browser 211, a response such as HTML data generated as a process result by the remote UI 4212. Upon reception of a request from another embedded application by communication with an application in the image processing apparatus 110, the embedded Web browser 211 acquires the resource of a URI designated by the request, and displays the resource on the operation unit 122 of the image processing apparatus 110.
The software configuration in a desktop computer 101 will be explained. The image processing apparatus 110 and desktop computer 101 are connected via a network, and software programs running on the respective apparatuses communicate data with each other in accordance with a protocol such as HTTP or HTTPS. A user 4202 accesses the image processing apparatus 110 via an RSS reader 4230 running on the desktop computer 101, and refers to box-related update information. The user 4202 accesses the image processing apparatus 110 via a Web browser 4229 running on the desktop computer 101, and browses resources and Web applications provided by the image processing apparatus 110. The operation of the RSS reader 4230 is identical to that of the embedded RSS reader 4210, and the operation of the Web browser 4229 is identical to that of the embedded Web browser 211.
Note that the RSS reader 4210 and Web browser 211, and the RSS reader 4230 and Web browser 4229 are implemented as single application programs in the third embodiment, but the RSS reader 4210 and Web browser 211, or the RSS reader 4230 and Web browser 4229 may be implemented as a single application program having the functions of both the RSS reader and Web browser. The RSS reader 4230 and Web browser 211 run on the desktop computer 101 in the above description, but may run on various general-purpose information processing apparatuses including a portable computer (e.g., PDA), in addition to the desktop computer. Alternatively, the RSS reader 4230 and Web browser 211 may run on various embedded apparatuses such as a cell phone. There is also widely known a technique of implementing distributed systems from combinations of front-end Web browsers and back-end Web applications (see, e.g., Bloglines <http://www.bloglines.com/>). When a Web application which provides such an RSS reader function is used, the operation of the embedded RSS reader 4210 can be substituted by a combination of the embedded Web browser 211 and Web application. The Web application which provides the RSS reader function may run on an external server computer, or may be configured as one of Web applications running in the image processing apparatus 110, similar to the remote UI 4212. When a feed file to be acquired exists in the same image processing apparatus 110, the embedded RSS reader 4210 may directly read out the feed file from the update information storage unit 4208 without using any network communication.
An RDF element 2201 is the top element of an XML document. The RDF element contains a channel element 2202, image element 2203, and item elements 2204, 2205, and 2206. The channel element 2202 describes basic information on the whole update information. This element corresponds to an RDF subject node. The contents of the channel element contain a title element 2207, link element 2208, description element 2209, image element 2210, and items element 2211. The title element 2207 represents the title of the update information. The link element 2208 represents the URI of a site treated by the update information. The description element 2209 describes an explanation of, e.g., the contents and functions of the site treated by the update information. The image element 2210 describes a URI which specifies an image resource such as the logo of the site treated by the update information. Details of the image element 2210 will be described later in association with the image element 2203 to be described below. The items element 2211 provides the indices of the item elements 2204, 2205, and 2206. A li element 2213 listed in the contents of a Seq element 2212 represents each update information URI. The image element 2203 expresses an image such as a logo. The contents of the image element 2203 contain a title element 2214, url element 2215, and link element 2216. The title element 2214 represents the title of an image, and is sometimes used as an alternative text of the image. The url element 2215 describes the URI of an image resource. When a hyperlink using this image as an anchor is displayed, the link element 2216 describes a URI used as a link destination. The item elements 2204, 2205, and 2206, and the like represent the order of elements each expressing update information. The contents of the item element contain a title element 2217, link element 2218, and description element 2219. The title element 2217 describes the title of update information. The link element 2218 describes the URI of the update information. The description element 2219 describes a description of the update information.
In step S4304, a document is loaded and accumulated in the box. In step S4305, the resolution of the loaded image is decreased to generate and accumulate a thumbnail image. In step S4306, a box update information entry is generated. More specifically, an update information entry which describes detailed information of the loaded document is generated. The update information entry also contains the generated thumbnail image. In step S4307, the generated update information entry is stored in the syndication DB. In step S4308, an RSS feed file generation process is called to generate a new RSS feed file from the syndication DB which is changed by adding the new update information entry.
In step S4405, a window for inputting an insertion instruction is displayed. In the insertion instruction window, the user inputs a document to be inserted, insertion position, document name after insertion, and the like. In step S4406, a document insertion process is performed to generate a new document. Then, the flow advances to step S4413. In step S4407, a dialog which prompts the user to confirm whether to actually erase the document is displayed to wait for an input by the user. If the user cancels erase, the flow returns to S4403; if the user responds OK, advances to S4408. In step S4408, the selected document is erased. After that, the flow advances to step S4409.
In step S4409, a template used to generate a syndication data file (feed file) is extracted from the template DB 1706 to determine whether the template contains a link to a thumbnail image. If the template contains a link to a thumbnail image, the flow advances to step S4410; if the template does not contain any link to a thumbnail image, to S4413. In step S4410, the thumbnail image is erased. Thereafter, the flow advances to step S4413. In step S4411, a window for inputting a combine/store instruction is displayed. In the combine/store window, the user inputs documents to be combined, the combination order, document name after combination, and the like. In step S4412, a combine/store process is performed to generate a new document. Then, the flow advances to step S4413.
In step S4413, an update information entry is generated in accordance with the process executed in the preceding step. That is, an update information entry which describes detailed information of the event is generated in correspondence with the event such as document insertion, document erase, or combine & store. In step S4414, the generated update information entry is stored in the syndication DB. In step S4415, an RSS feed file generation process is called to generate a new RSS feed file from the syndication DB which is changed by adding the new update information entry.
In accumulating or editing a boxed document, its importance [more importance/normal/less importance] can be selected and set. The period during which update information is posted in the update information file can be set in accordance with the importance.
That is, date elements 4701 and 4706, a subject element 4704, a creator element 4705, and a generatorAgent element 4702 from an Admin module are combined. The date element 4701 describes a date and time when feed data is generated. The generatorAgent element 4702 describes software which generates feed data. The subject element 4704 describes the category of an entry. The creator element 4705 describes a user, i.e., operator who is involved in generation of an entry. The date element 4706 describes a date and time when an entry is generated. As one of large effects of the third embodiment, it becomes easy to flexibly, strictly expand a data format for feeding update information.
(Acquisition and Display of Update Information Feed Data)
Note that when the window is automatically activated by a boxed document list display operation, the window appears while feed data of a boxed document in the image processing apparatus itself is selected. At this time, the area of the RSS feed list 5301 may be hidden. A feed title 5302 displays the title of feed data for identifying feed data corresponding to an item. An unread count 5303 displays the number of unread entries contained in feed data corresponding to an item. The right pane in the display window of
A feed title 5305 displays the title of feed data, and corresponds to the title element 2207 in the channel element 2202 in the RSS feed example. The displayed title is the anchor of a hypertext, and when the user selects the title, the resource of a URI described in the link element 2208 is acquired and displayed in cooperation with the Web browser. In this example, the feed title 5305 is the anchor of a top page which provides a portal of Web applications in the image processing apparatus 110. A feed logo image 5306 displays the logo image of feed data. Although not shown in the RSS feed example, the feed logo image 5306 corresponds to the image elements 2210 and 2203. The displayed image data is a resource acquired from a URI described in the url element 2215. The displayed image is an anchor, and when the user selects the image, the Web browser is activated to acquire and display the resource of a URI described in the link element 2216.
A feed outline 5307 displays a description of an outline of feed data, and corresponds to the description element 2209 in the RSS feed example. As shown in this example, data to be syndicated can be flexibly designed by freely combining feed data formats and template variables which can be replaced with various types of information held in the image processing apparatus. Update information entries 5308, 5309, and 5310 display update information syndicated by feed files. In the RSS feed example, the update information entries 5308, 5309, and 5310 are indexed as a list of the li elements 2213 in the items element 2211, and correspond to elements listed in the item elements 2204, 2205, and 2206.
An entry title 5311 displays the title of the update information entry. In the RSS feed example, the entry title 5311 corresponds to the title element 2217. The displayed title is the anchor of a hypertext, and when the user selects the title, the Web browser is activated to acquire and display the resource of a URI described in the link element 2218. In this example, the entry title 5311 is the anchor of an individual entry information page for browsing details of the update information entry.
An entry update date & time 5312 displays a date and time when an update information entry event occurs. In the RSS feed example, the entry update date & time 5312 corresponds to the date element 2306. An entry description 5313 describes information on an update information entry. In the RSS feed example, the entry description 5313 corresponds to the description element 2219. The entry description is structured as a text marked up in HTML (XHTML) using an image, citation, table, and the like. The entry description is formatted and displayed so as to present the structures of these elements. Links to various resources including a Web page and E-mail address are embedded in the entry description, and their anchors are also displayed.
In generating an RSS feed example, displayed information is generated on the basis of templates, various databases in the image processing apparatus, and various types of information obtained via the apparatus control class library 1106. As shown in this example, data to be syndicated can be flexibly designed by freely combining feed data formats and template variables which can be replaced with various types of information held in the image processing apparatus. In the example of
When the user performs an editing operation such as registration, editing, or deletion to the address book, an update information entry can be created and stored in the syndication DB to generate a feed file.
When the user performs an editing operation such as registration, editing, or deletion to the bulletin board function of an image processing apparatus, an update information entry can be created and stored in the syndication DB to generate a feed file.
Note that all the first to fifth embodiments have described a digital multi-functional peripheral (image processing apparatus) having the scanner function, the printer function, the copying function using a composition of the scanner and printer functions, the facsimile function, the electronic file function, and the like. These embodiments have described the function of providing a computer connected to the apparatus with the fact that data internally held in the apparatus has been updated, and an outline of the update. However, a connected computer can also be provided with information on update of internal data not only in the image processing apparatus but also in an embedded system connected to a network, i.e., a network device. For example, among home appliances, some recording apparatuses which record TV programs have a function of allowing remote access from a computer and programming recording. In these apparatuses, information on recording, for example, the fact of programming and the completion of recording can be provided as changes in state by RSS feeds, similar to the first to fifth embodiments. The present invention is not limited to these apparatuses, and can also be applied to devices which can be connected to a network (e.g., printer scanner, digital still camera, and video camera).
The image processing apparatuses according to the first to fifth embodiments provide information representing a change in state to a computer connected to the same network (LAN) as that of the image processing apparatuses. However, state (i.e., specific data) information in these embodiments is provided by the application layer, and can be provided over the network. In other words, even if another network (e.g., Internet) is interposed between the computer and the image processing apparatus, the image processing apparatus can provide information to the computer.
Note that the embodiments of the present invention have been explained in conformity with RSS 1.0. However, the format can be Atom or another RSS version such as RSS 0.9 (RDF Site Summary), RSS 0.91 (Rich Site Summary), RSS 0.92, or RSS 2.0 (Really Simple Syndication) as far as update information/summary information of contents can be distributed and announced. The format includes a new format for syndication which will be derived in the future.
Note that the present invention can be applied to an apparatus comprising a single device or to system constituted by a plurality of devices.
Furthermore, the invention can be implemented by supplying a software program, which implements the functions of the foregoing embodiments, directly or indirectly to a system or apparatus, reading the supplied program code with a computer of the system or apparatus, and then executing the program code. In this case, so long as the system or apparatus has the functions of the program, the mode of implementation need not rely upon a program.
Accordingly, since the functions of the present invention are implemented by computer, the program code itself installed in the computer also implements the present invention. In other words, the claims of the present invention also cover a computer program for the purpose of implementing the functions of the present invention.
In this case, so long as the system or apparatus has the functions of the program, the program may be executed in any form, e.g., as object code, a program executed by an interpreter, or scrip data supplied to an operating system.
Examples of storage media that can be used for supplying the program are a floppy disk, a hard disk, an optical disk, a magneto-optical disk, a CD-ROM, a CD-R, a CD-RW, a magnetic tape, a non-volatile type memory card, a ROM, and a DVD (DVD-ROM and a DVD-R).
As for the method of supplying the program, a client computer can be connected to a website on the Internet using a browser of the client computer, and the computer program of the present invention or an automatically-installable compressed file of the program can be downloaded to a recording medium such as a hard disk. Further, the program of the present invention can be supplied by dividing the program code constituting the program into a plurality of files and downloading the files from different websites. In other words, a WWW (World Wide Web) server that downloads, to multiple users, the program files that implement the functions of the present invention by computer is also covered by the claims of the present invention.
Further, it is also possible to encrypt and store the program of the present invention on a storage medium such as a CD-ROM, distribute the storage medium to users, allow users who meet certain requirements to download decryption key information from a website via the Internet, and allow these users to decrypt the encrypted program by using the key information, whereby the program is installed in the user computer.
Furthermore, besides the case where the aforesaid functions according to the embodiments are implemented by executing the read program by computer, an operating system or the like running on the computer may perform all or a part of the actual processing so that the functions of the foregoing embodiments can be implemented by this processing.
Furthermore, after the program read from the storage medium is written to a function expansion board inserted into the computer or to a memory provided in a function expansion unit connected to the computer, a CPU or the like mounted on the function expansion board or function expansion unit performs all or a part of the actual processing so that the functions of the foregoing embodiments can be implemented by this processing.
As many apparently widely different embodiments of the present invention can be made without departing from the spirit and scope thereof, it is to be understood that the invention is not limited to the specific embodiments thereof except as defined in the appended claims.
This application claims the benefit of Japanese Patent Application No. 2005-145881 filed on May 18, 2005, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2005-145881 | May 2005 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2006/310086 | 5/16/2006 | WO | 00 | 9/13/2007 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2006/123806 | 11/23/2006 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5905866 | Nakabayashi et al. | May 1999 | A |
6078415 | Yamamoto | Jun 2000 | A |
6553431 | Yamamoto et al. | Apr 2003 | B1 |
6785023 | Iida | Aug 2004 | B1 |
7069292 | Sugahara | Jun 2006 | B2 |
7113304 | Iida | Sep 2006 | B2 |
7120910 | Matsuda et al. | Oct 2006 | B2 |
7139093 | Iida | Nov 2006 | B2 |
7167264 | Takamiya | Jan 2007 | B2 |
7327478 | Matsuda | Feb 2008 | B2 |
7516450 | Ogura | Apr 2009 | B2 |
7600226 | Aiba | Oct 2009 | B2 |
20010029521 | Matsuda et al. | Oct 2001 | A1 |
20020039148 | Yamamoto | Apr 2002 | A1 |
20020122203 | Matsuda | Sep 2002 | A1 |
20030137682 | Sakai et al. | Jul 2003 | A1 |
20040148379 | Ogura | Jul 2004 | A1 |
20040196508 | Iida | Oct 2004 | A1 |
20050055451 | Tsuyama | Mar 2005 | A1 |
20070139698 | Sato | Jun 2007 | A1 |
20090080013 | Sato et al. | Mar 2009 | A1 |
Number | Date | Country |
---|---|---|
1 024 652 | Feb 2000 | EP |
1 143 695 | Oct 2001 | EP |
1 385 089 | Jan 2004 | EP |
4-139557 | May 1992 | JP |
10-232815 | Sep 1998 | JP |
11-110223 | Apr 1999 | JP |
2000-222333 | Aug 2000 | JP |
2001-84137 | Mar 2001 | JP |
2001-169236 | Jun 2001 | JP |
2001-225531 | Aug 2001 | JP |
2001-232908 | Aug 2001 | JP |
2001-273030 | Oct 2001 | JP |
2001-312462 | Nov 2001 | JP |
2002-149478 | May 2002 | JP |
2003-177989 | Jun 2003 | JP |
2003-281147 | Oct 2003 | JP |
2004-025455 | Jan 2004 | JP |
2004-62531 | Feb 2004 | JP |
2004-129047 | Apr 2004 | JP |
2004-230828 | Aug 2004 | JP |
2004-259222 | Sep 2004 | JP |
2004-266470 | Sep 2004 | JP |
2005-092330 | Apr 2005 | JP |
WO2006123806 | Nov 2006 | WO |
Number | Date | Country | |
---|---|---|---|
20090080013 A1 | Mar 2009 | US |