1. Field of the Invention
The present invention relates to an image processing method and image processing apparatus for editing and outputting image data acquired from an input device.
2. Description of the Related Art
As low-cost scanner devices become available, an original can be easily scanned and converted into digital data even at home. Inkjet printers as printing apparatuses have been developed, and even a multifunctional peripheral (MFP) called a multi-function printer capable of not only printing an image, but also scanning an image becomes popular. The user can use a scanner device and printer device to easily copy his originals and contents at home.
An example of contents which improve user's convenience when copied is “sheet music”. In general, the user purchases sheet music as a book. However, it impairs user's convenience to set sheet music purchased as a book directly on a music stand. For example, when the user sets sheet music of many pages directly on a music stand to see a desired page, he must forcibly open the sheet music, damaging the sheet music. To prevent this, a music stand devised to fix sheet music at a desired page is also commercially available. However, such a music stand makes it difficult to turn a page. It is generally cumbersome to turn a page of sheet music during the performance. This work is very troublesome especially during the performance of a musical instrument using both hands, such as the piano.
During the music lesson of the piano or the like, the teacher often writes an instruction directly on sheet music. It is popular to copy sheet music and keep the original clean.
When editing and distributing sheet music of a composition by a user or when editing music composed in response to user's request and distributing it as sheet music, various editing operations are required. For this purpose, a technique for, for example, editing sheet music is disclosed.
To reduce the number of page turns, a musician sometimes arranges and prints a plurality of pages of sheet music on one paper sheet. By using the layout copy function of an MFP, a plurality of pages of sheet music as a purchased book can be arranged and copied on one paper sheet. When sheet music data is saved in a PC, the player can designate layout printing via a printer driver to print a plurality of pages of sheet music on one paper sheet.
The following techniques have been disclosed as patents regarding layout printing and editing of an image such as sheet music.
Japanese Patent Laid-Open No. 2002-144664 discloses a method of dividing a 1-page original image into a predetermined number of output areas, arranging different types of documents in the respective output areas in correspondence with each other, and outputting the documents.
Japanese Patent No. 2879941 discloses a method of resizing a given area represented by a five-line staff of sheet music and laying it out so that the resized area represented by a five-line staff width and five-line staff length becomes homothetic to the given area.
Japanese Patent No. 3169142 discloses a method of designating the boundary between parts of sheet music or that between bars, moving the position of the boundary so that the designated boundary coincides with the screen display, and displaying the sheet music.
Japanese Patent Laid-Open Nos. 06-149235 and 06-149236 disclose a method of aligning in the lateral direction the left ends of the five-line staffs of simultaneously played parts in accordance with the coordinates of the top and bottom lines of the five-line staffs of the parts.
Sheet music as a general book describes information for a performance based on rules built up through historical development. Sheet music is not convenient for all players. Therefore, a player edits sheet music so as to easily play for himself by, for example, copying sheet music and dividing it into a plurality of paper sheets so as to allow easy page turning, by coloring sheet music, or by writing signs on it. The editing work optimizes sheet music for the player. However, it is very cumbersome for the player to edit sheet music, so demands have arisen for easy editing of sheet music.
However, this layout printing simply rearranges images corresponding to respective pages for each page. For example, when the output 1001 is sheet music, visibility sometimes becomes poor.
The present invention has been made to overcome the conventional drawbacks, and has as its feature to provide an image processing method and image processing apparatus capable of changing the arrangement of the original images of a plurality of pages not for each page but with high degree of freedom and laying them out on one page by simple editing work.
According to an aspect of the present invention, there is provided an image processing method of laying out and outputting an image of an original formed from a plurality of pages on one page. The method includes inputting image data of the original formed from the plurality of pages; dividing the image data input in the inputting into a plurality of blocks; selecting unnecessary information from each block obtained by division in the dividing based on a predetermined rule to maintain continuity of the original formed from the plurality of pages when laying out, on one page, the image data of the original formed from the plurality of pages; discarding the unnecessary information selected in the selecting; appending necessary information to each block obtained by division in the dividing based on the predetermined rule; replacing the respective blocks obtained by division in the dividing with the block from which the unnecessary information is discarded in the discarding, and the block to which the necessary information is appended in the appending; and outputting the respective blocks which have undergone replacement in the replacing by laying out the respective blocks on one page.
According to another aspect of the present invention, there is provided an image processing apparatus which lays out and outputs an image of an original formed from a plurality of pages on one page. The apparatus includes an input unit which inputs image data of the original formed from the plurality of pages; a division unit which divides the image data input by the input unit into a plurality of blocks; a selection unit which selects unnecessary information from each block obtained by division by the division unit based on a predetermined rule to maintain continuity of the original formed from the plurality of pages when laying out, on one page, the image data of the original formed from the plurality of pages; a discard unit which discards the unnecessary information selected by the selection unit; an appending unit which appends necessary information to each block obtained by division by the division unit based on the predetermined rule; a replacement unit which replaces the respective blocks obtained by division by the division unit with the block from which the unnecessary information is discarded by the discard unit, and the block to which the necessary information is appended by the appending unit; and an output unit which outputs the respective blocks which have undergone replacement by the replacement unit by laying out the respective blocks on one page.
According to yet another aspect of the present invention, there is provided a computer-readable medium containing computer-executable instructions utilized in an image processing apparatus configured to lay out and output an image of an original formed from a plurality of pages on one page. Here, the computer-readable medium includes computer-executable instructions for inputting image data of the original formed from the plurality of pages; computer-executable instructions for dividing the image data input in the inputting into a plurality of blocks; computer-executable instructions for selecting unnecessary information from each block obtained by division in the dividing based on a predetermined rule to maintain continuity of the original formed from the plurality of pages when laying out, on one page, the image data of the original formed from the plurality of pages; computer-executable instructions for discarding the unnecessary information selected in the selecting; computer-executable instructions for appending necessary information to each block obtained by division in the dividing based on the predetermined rule; computer-executable instructions for replacing the respective blocks obtained by division in the dividing with the block from which the unnecessary information is discarded in the discarding, and the block to which the necessary information is appended in the appending; and computer-executable instructions for outputting the respective blocks which have undergone replacement in the replacing by laying out the respective blocks on one page.
According to the present invention, when laying out and printing the images of a plurality of pages on one paper sheet, not only the images can be simply rearranged for each page, but also the layout can be changed with high degree of freedom to improve user visibility, thereby printing the images.
Further features of the present invention will become apparent from the following description of exemplary embodiments with reference to the attached drawings.
Various embodiments of the present invention will be described in detail below with reference to the accompanying drawings.
<PC Application>
An embodiment for carrying out the present invention by application software running on a personal computer (to be referred to as a PC hereinafter) serving as a host apparatus will be explained.
An image processing system 101 in
In
The CPU 202 controls the operation of the PC 103 via the bus 207 in accordance with a program and data stored in the ROM 201. At the same time, the CPU 202 performs image processing using the RAM 203 as a work memory. For example, the CPU 202 performs image processing for image data input via the I/O unit 204 or NIC 205, or image data stored in advance in a storage medium such as the HDD 206. The CPU 202 outputs the processed image data via the I/O unit 204 or NIC 205, or stores it in a storage medium such as the HDD 206.
For example, the I/O unit 204 is connected via a predetermined interface to an image input/output device such as a monitor (e.g., CRT or LCD), a printer, or a scanner, or a storage device having a storage medium such as a magnetic disk or optical disk. The I/O unit 204 can receive/output image data via the NIC 205 from/to the above-mentioned image input/output device and a computer device connected to the storage device. Examples of the network are Ethernet, FDDI (Fiber Distributed Data Interface), IEEE1394 serial bus, and USB (Universal Serial Bus).
<MFP>
The same effects as the above-described ones can also be obtained by using an image processing system in which a single multi-function printer (to be referred to as an MFP hereinafter) operates without the mediacy of a PC.
In
In
The reading unit 302 having a CCD reads an original image to output analog luminance data of red (R), green (G), and blue (B). The reading unit 302 may also include a contact image sensor (CIS) instead of the CCD. When the ADF 308 as shown in
The card interface 306 receives, in accordance with a predetermined operation to the operation unit 305, image data captured by a digital camera or the like and recorded on a memory card or the like. If necessary, an image processing unit 402 converts image data received via the card interface 306. For example, the image processing unit 402 converts image data corresponding to the color space (e.g., YCbCr) of a digital camera into one corresponding to the RGB color space (e.g., NTSC-RGB or sRGB). If necessary, the received image data undergoes various processes necessary for an application, such as resolution conversion into an effective pixel count based on header information of the image data.
A camera interface 307 is directly connected to a digital camera to read image data.
The image processing unit 402 performs image processes (to be described later) such as image analysis, calculation of the conversion characteristic, conversion from a luminance signal (RGB) into a density signal (CMYK), scaling, gamma conversion, and error diffusion. Data obtained by these image processes are stored in a RAM 407. When corrected data stored in the RAM 407 reach a predetermined amount necessary to print by the printing unit 303, the printing unit 303 executes a print operation.
A nonvolatile RAM 408 is, for example, a battery backed-up SRAM, and stores data unique to the MFP 301 and the like.
The operation unit 305 has a photo direct print start key to select image data stored in a storage medium and start printing, a key to print an order sheet, and a key to read an order sheet. The operation unit 305 also has a copy start key to perform monochrome copying or color copying, a mode key to designate a mode such as resolution or image quality in copying, a stop key to stop a copy operation or the like, a numeric keypad to input the number of copies, a registration key, and the like. The CPU 401 detects the pressed states of these keys, and controls each unit in accordance with the states.
The display unit 304 includes a dot matrix type liquid crystal display (LCD) and LCD driver, and presents various displays under the control of the CPU 401. The display unit 304 displays the thumbnail of image data stored in a storage medium.
The printing unit 303 includes an inkjet head of an inkjet type, general-purpose IC, and the like. The printing unit 303 reads out print data stored in the RAM 407, and prints it out as a hard copy under the control of the CPU 401.
A driving unit 411 includes a stepping motor for driving feed and delivery rollers in the operations of the reading unit 302 and printing unit 303, a gear for transmitting the driving force of the stepping motor, and a driver circuit for controlling the stepping motor.
A sensor unit 410 includes a sensor for detecting the width of a print medium, a sensor for detecting the presence/absence of a print medium, a sensor for detecting the width of an original image, a sensor for detecting the presence/absence of an original image, and a sensor for detecting the type of print medium. Based on pieces of information obtained from these sensors, the CPU 401 detects the states of an original and print medium.
A PC interface 414 is an interface between the PC and the MFP 301. The MFP 301 executes operations such as printing and scanning based on instructions transmitted from the PC via the PC interface 414.
In copying, image data of an original image read by the reading unit 302 is processed in the MFP 301, and printed by the printing unit 303. When the user designates a copy operation via the operation unit 305, the reading unit 302 reads an original set on the original table. Image data of the read original image is transmitted to the image processing unit 402, and undergoes image processing (to be described later). The processed image data is transmitted to the printing unit 303, and printed.
In step S110, image data which is read by the reading unit 302 and A/D-converted undergoes shading correction to correct variations of image sensors.
In step S120, the image data undergoes input device color conversion to convert image data corresponding to a color space unique to the reading unit 302 serving as an input device into image data corresponding to a standard color space. More specifically, the image data is converted into image data corresponding to a color space such as sRGB defined by IEC (International Electrotechnical Commission) or AdobeRGB proposed by Adobe Systems. The conversion method is, for example, an arithmetic method based on a 3×3 or 3×9 matrix, or a look-up table method of looking up to a table describing a conversion rule and determining a resultant value based on the table.
In step S130, the image data having undergone color conversion undergoes image correction/manipulation processing. The processing contents include edge emphasis processing of correcting blurring generated upon reading an original image, processing of removing offset generated upon reading by light irradiation, and character manipulation processing for improving character readability.
In step S140, enlargement/reduction processing is executed to convert the image data at a desired ratio when the user designates resizing or in layout copying of laying out two original sheets on one paper sheet. The conversion method is generally a bicubic method, nearest neighbor method, or the like. When laying out and printing a plurality of images on one print medium in layout copying or the like, the operations in steps S110 to S140 are repeated to read a plurality of images and lay out the read images on one page. Then, the process shifts to the following print operation.
In step S150, the image data corresponding to the standard color space is converted into image data corresponding to a color space unique to an output device. Similar to step S120, the conversion method suffices to be the arithmetic method based on a matrix or the look-up table method. Image data corresponding to the color space unique to the output device is converted into one corresponding to the color space of the colors of inks used in an MFP 301 of inkjet type, such as cyan, magenta, yellow, and black.
In step S160, the image data undergoes quantization processing. For example, when an ink dot is expressed by a binary value representing whether or not to discharge an ink dot, the image data suffices to be binarized according to a quantization method such as error diffusion. As a result, the image data is converted into a data format printable by the printing unit. The print operation is executed based on the image data of this data format, forming an image.
A first embodiment of the present invention will be described below referring to the drawings.
First, in step S210, the number N of pages of original images that is designated for layout by the user using an operation unit 305 of an MFP 301 or the like is substituted as a Count value.
Then, in step S220, image data of one page of an original image undergoes pre-processing. As the pre-processing, skew correction of an original image is executed first. This is because the reading device may read an original image with a skew. When the original image is sheet music, skew correction suffices to use a method of correcting a skew using a five-line staff of the sheet music. For example, the image density of read sheet music is calculated at a plurality of angles to create a histogram, as shown in
In step S230, the image data of the original image is divided into a plurality of rectangular blocks. In this step, image area separation is executed to separate the image into at least three types of attributes “text part”, “natural image part”, and “background part”. Each separated image is divided into rectangular blocks for each attribute. For example, when the original image expressed by the image data having undergone pre-processing in step S220 is an original image in
In step S240, the divided rectangular blocks are numbered based on a rule made in advance to maintain the original continuity of a plurality of pages. In this step, the respective rectangular blocks of a 1-page original image are numbered in ascending order from an upper left block toward a lower right block.
Next, in step S250, information which becomes unnecessary in layout is selected based on the rule made in advance to maintain the original continuity of a plurality of pages and, block-level information as well as some information contained within a block are discarded. For example, when the original images of a plurality of pages are divided into blocks and blocks are laid out on one page according to the present invention, the page number of an original image is unnecessary information. Thus, information of the block 901 in
In step S260, information which becomes necessary in layout is appended based on the rule made in advance to maintain the original continuity of a plurality of pages. As described above, a brace, G clef, and F clef are necessary at the beginning of a great staff. After the layout change, the blocks 911 and 912 move to the beginnings of great staffs, and require braces, G clefs, and F clefs.
The Count value is decremented in step S270, and it is determined in step S280 whether the Count value has reached 0. If it is determined that the Count value has not reached 0 (YES in step S280), steps S220 to S270 are repeated for the original image of the next page. If it determined that the Count value has reached 0 (NO in step S280), the process advances to step S290.
In step S290, the layout of numbered rectangular blocks is changed in accordance with a user instruction regarding the number of blocks to be laid out. As described above,
In the first embodiment, the layout of sheet music of two pages including 6-bar great staffs is changed into sheet music of one page including 9-bar great staffs. The number of bars of each great staff after layout change is uniquely determined by the number of sheet music pages to be laid out into 1-page sheet music, the number of great staffs, and the number of bars of one great staff. It is, therefore, preferable to calculate in advance the number of bars of each great staff after layout change.
The interval between the treble and base staffs of each great staff is not constant, and the width of a bar is not constant. Thus, it is desirable to resize each block in layout so as to make the treble and base staffs match each other.
Accordingly, even when laying out and printing a plurality of pages on one paper sheet, a printed material with good visibility can be created.
A second embodiment of the present invention will be described below referring to the drawings. In the first embodiment, the original image is sheet music having a fixed format. In the second embodiment, the original image is a document having no fixed format.
First, in step S310, grouping processing is executed to group blocks divided in step S230 of
Then, in step S320, group division processing is executed to divide a group. The group division processing is to divide a group in the lateral direction at a break between blocks in the lateral direction in a group made up of a plurality of blocks among groups. A concrete example of the group division processing will be explained with reference to
In step S330, a block separated as the “text part” in step S230 of
According to the same procedure, each of the groups 1702, 1703, 1704, 1707, 1708, 1709, and 1710 of the “text part” in
In this fashion, blocks are divided based on the result of image area separation. Even when laying out and printing an original image having no fixed format, like a document created by a PC or a Web page, a printed material with good visibility can be generated. The second embodiment is directed to a case where neither information which becomes unnecessary in layout nor information which becomes necessary in layout is detected. For example, when an original image contains a page number, the page number of the original image can be regarded as unnecessary information to exclude the page number from the layout.
A third embodiment of the present invention will be described below referring to the drawings.
When laying out and printing the original images of a plurality of pages on one page according to the present invention, an optimal layout differs depending on the user. For example, as for the text layout as shown in
First, in step S410, a count M which is determined in accordance with a user instruction and at which the layout result is displayed is set as a Count value.
Then, in step S420, layout change processing is done. The layout change processing is, for example, layout change processing in step S290 of
In step S430, the layout result changed in step S420 is displayed.
In step S440, it is determined whether the layout result display count has reached the count set by the user in step S410. If the layout result display count has reached this count (NO in step S440), the layout result is displayed, and the processing for determining a layout ends. If the layout result display count has not reached this count (YES in step S440), the process advances to step S450. When the layout result is displayed and the processing for determining a layout ends, conventional layout printing of laying out and printing an original image for each page is executed.
In step S450, the Count value is decremented, and the process advances to step S460.
In step S460, the user determines whether to employ the layout displayed in step S430. If the user determines via a UI to select the layout result (YES in step S460), the layout result is selected, and the process ends. If the user does not select the layout result (NO in step S460), the process returns to step S420.
An example of a layout result displayed in step S430 of
In
As described above, when dividing a plurality of pages into blocks and laying out the blocks again, an infinite number of layouts are available. An optimal layout differs depending on the user. For this reason, a plurality of layout rules are prepared. The user is presented with layout results processed based on these layout rules, and prompted to select a layout optimal for him. As a result, an optimal layout result can be provided.
The present invention is also carried out by supplying the program codes of software for implementing the functions of the above-described embodiments to, for example, an apparatus connected to various devices, and operating these devices in accordance with programs stored in the computer of the apparatus or the like.
In this case, the program codes of the software implement the functions of the above-described embodiments, and the program codes themselves and means such as a storage medium for supplying the program codes to a computer constitute the present invention. Concrete examples of the storage medium are a flexible disk, hard disk, optical disk, magnetooptical disk, CD-ROM, magnetic tape, nonvolatile memory card, and ROM.
The present invention includes program codes when the functions of the above-described embodiments are implemented by executing the program codes supplied to the computer. The present invention also includes program codes when the functions of the above-described embodiments are implemented by an OS (Operating System) and another application software or the like running on the computer in cooperation with each other.
The functions of the above-described embodiments are also implemented when program codes supplied to the computer are stored in the memories of a function expansion board and function expansion unit of the computer, and, for example, the CPUs of the function expansion board and function expansion unit execute processing based on the instructions of the program codes. The present invention also incorporates these program codes.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2007-331071, filed on Dec. 21, 2007, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2007-331071 | Dec 2007 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4958551 | Lui | Sep 1990 | A |
5690496 | Kennedy | Nov 1997 | A |
5706363 | Kikuchi | Jan 1998 | A |
5864631 | Shutoh | Jan 1999 | A |
5931680 | Semba | Aug 1999 | A |
6169239 | Aiardo | Jan 2001 | B1 |
6175070 | Naples et al. | Jan 2001 | B1 |
6333455 | Yanase et al. | Dec 2001 | B1 |
6365819 | Yamada | Apr 2002 | B2 |
6380471 | Matsumoto | Apr 2002 | B2 |
6545208 | Hiratsuka | Apr 2003 | B2 |
6580805 | Nakano | Jun 2003 | B1 |
6635815 | Kosakaya | Oct 2003 | B2 |
6727418 | Matsumoto | Apr 2004 | B2 |
6809246 | Errico | Oct 2004 | B2 |
6945784 | Paquette et al. | Sep 2005 | B2 |
7074999 | Sitrick et al. | Jul 2006 | B2 |
7094960 | Ikeya et al. | Aug 2006 | B2 |
7098392 | Sitrick et al. | Aug 2006 | B2 |
7479595 | Shen et al. | Jan 2009 | B2 |
7579541 | Guldi | Aug 2009 | B2 |
7649134 | Kashioka | Jan 2010 | B2 |
7703014 | Funaki | Apr 2010 | B2 |
7728212 | Fujishima et al. | Jun 2010 | B2 |
7763790 | Robledo | Jul 2010 | B2 |
7838755 | Taub et al. | Nov 2010 | B2 |
7919703 | Hong et al. | Apr 2011 | B2 |
20010023633 | Matsumoto | Sep 2001 | A1 |
20020005109 | Miller | Jan 2002 | A1 |
20020118562 | Hiratsuka | Aug 2002 | A1 |
20030005814 | Matsumoto | Jan 2003 | A1 |
20040069115 | Hiratsuka et al. | Apr 2004 | A1 |
20040112201 | Funaki | Jun 2004 | A1 |
20050016361 | Ikeya et al. | Jan 2005 | A1 |
20050016368 | Perla | Jan 2005 | A1 |
20060150803 | Taub | Jul 2006 | A1 |
20070022866 | Perla | Feb 2007 | A1 |
20070227336 | Fukada | Oct 2007 | A1 |
20070261536 | Shen et al. | Nov 2007 | A1 |
20070295194 | Reverdin | Dec 2007 | A1 |
20080060500 | La et al. | Mar 2008 | A1 |
20080092723 | Sawyer-Kovelman et al. | Apr 2008 | A1 |
20080156171 | Guldi | Jul 2008 | A1 |
20080289477 | Salter | Nov 2008 | A1 |
20090013855 | Fujishima et al. | Jan 2009 | A1 |
20090095144 | Nakano | Apr 2009 | A1 |
20090158915 | Ishii et al. | Jun 2009 | A1 |
20090161164 | Goto et al. | Jun 2009 | A1 |
20090161176 | Yamazoe et al. | Jun 2009 | A1 |
20090161917 | Hori et al. | Jun 2009 | A1 |
20100024629 | Hiratsuka | Feb 2010 | A1 |
20100089221 | Miller | Apr 2010 | A1 |
Number | Date | Country |
---|---|---|
2120657 | Jul 1995 | CA |
05-035924 | Feb 1993 | JP |
06-102869 | Apr 1994 | JP |
06-102870 | Apr 1994 | JP |
06-102871 | Apr 1994 | JP |
06-149235 | May 1994 | JP |
06-149236 | May 1994 | JP |
07-129156 | May 1995 | JP |
07-304245 | Nov 1995 | JP |
07-311543 | Nov 1995 | JP |
2879941 | Apr 1999 | JP |
2000-163044 | Jun 2000 | JP |
3169142 | May 2001 | JP |
2002-144664 | May 2002 | JP |
2003-015636 | Jan 2003 | JP |
2003-177745 | Jun 2003 | JP |
2003-288075 | Oct 2003 | JP |
3801939 | Jul 2006 | JP |
2009-086973 | Apr 2009 | JP |
Number | Date | Country | |
---|---|---|---|
20090161164 A1 | Jun 2009 | US |