This application is based on and claims priority under 35 USC 119 from Japanese Patent Application No. 2018-107108 filed Jun. 4, 2018.
The present disclosure relates to an information processing apparatus and a non-transitory computer readable medium storing a program.
Japanese Unexamined Patent Application Publication No. 2006-209508 discloses a printing system in which a print server divides a print job received from a client terminal on a page basis and transmits the print job divided on a page basis to a printer.
Aspects of non-limiting embodiments of the present disclosure relate to an information processing apparatus and a non-transitory computer readable medium storing a program, in which print data including a common image used in common over a plurality of pages may be divided so that the data amount of the print data becomes equal to or smaller than an upper limit value set in advance.
Aspects of certain non-limiting embodiments of the present disclosure address the above advantages and/or other advantages not described above. However, aspects of the non-limiting embodiments are not required to address the advantages described above, and aspects of the non-limiting embodiments of the present disclosure may not address advantages described above.
According to an aspect of the present disclosure, there is provided an information processing apparatus comprising a receiver that receives print data including a common image used in common over a plurality of pages, a divider that divides the print data received by the receiver based on each type of the common image in use, and an adjuster that performs adjustment by redividing or combining pieces of the print data of each type of the common image that is divided by the divider so that a data amount of each piece of the divided print data becomes equal to or smaller than an upper limit value set in advance.
An exemplary embodiment of the present disclosure will be described in detail based on the following figures, wherein:
An exemplary embodiment of the present disclosure is described in detail with reference to the drawings.
As illustrated in
The printers 20A and 20B in the printing system of this exemplary embodiment are continuous paper printers that perform printing on so-called continuous paper. The printer 20A is provided for printing on a front side of the continuous paper. The printer 20B is provided for printing on a back side of the continuous paper. The continuous paper whose front side has been subjected to printing by the printer 20A is reversed by the reversing apparatus 21 and supplied to the printer 20B.
The controller 30 controls the printers 20A and 20B to execute printing processing based on received print data (print job).
The conversion processing server 10 performs processing of converting print data described by a certain page description language (PDL) to print data described by a PDL different from the certain PDL, such as a general-purpose PDL in a PostScript (registered trademark) format (hereinafter abbreviated as a PS format) or the like. The print data format is not limited to the PDL. For example, the print data may be a text data sequence in a format such as comma-separated values (CSV).
The reason why the conversion processing server 10 performs the PDL conversion processing is described with reference to
In an output business in which large-quantity and high-speed printing processing is required, the continuous paper printer is often used. In the continuous paper printer for business use, the printing processing is performed by using print data described by a dedicated PDL unique to each manufacturer. The print data described by a dedicated PDL unique to each manufacturer is often used not only in the continuous paper printer but also in printers that may perform high-speed printing processing for business.
As illustrated in
Therefore, when printing processing that uses print data described by a PDL of a certain manufacturer is performed in a printer of a different manufacturer, it is necessary to create print data again in a format in which the printer of the different manufacturer may perform printing. To eliminate such time and effort, as illustrated in
The print data 51 described by a general-purpose page description language may be interpreted by the printer 71 of Company B. Thus, the printer 71 of Company B may execute the printing processing.
In general, printers convert print data described by various PDLs to raster images by raster image processors (RIPs) corresponding to the types of the PDLs. For example, print data described by PostScript (registered trademark) is converted to a raster image by a RIP called Configurable PostScript Interpreter (CPSI). Print data described by Portable Document Format (PDF) is converted to a raster image by a RIP called Adobe PDF Print Engine (APPS).
In those RIPs, an upper limit may be provided for the data amount of processable print data. If the printer has received print data whose data amount exceeds the upper limit, a problem arises in that the RIP fails to process the received print data and the printing processing is not executable.
When the conversion processing server 10 converts the print data 50 described by the page description language of Company A to the print data 51 described by a general-purpose page description language, it is necessary to divide the print data so that the data amount becomes equal to or smaller than an upper limit value set in a RIP that processes the general-purpose page description language.
When the print data is divided so that the data amount becomes equal to or smaller than the upper limit value set in advance, there is a possibility that the data amount of each piece of the divided print data is not equal to or smaller than the upper limit value if the print data is divided based only on a page count.
For example, when print data including a common image such as a common form image used in common over a plurality of pages is divided so that the data amount becomes equal to or smaller than the upper limit value set in advance, there is a possibility that the data amount of each piece of the divided print data is not equal to or smaller than the upper limit value if the print data is divided based only on the page count.
For example, the common image refers to various images of a form and a graphical object such as a mark of a logotype of a company, which are used in common over a plurality of pages. The common image is prepared separately from data on print contents of each page. In each page, the common image may be used as the print contents of each page by simply specifying the use of the common image.
Referring to
It is supposed that the print data will be divided so that the data amount of each piece of the divided print data becomes equal to or smaller than 500 MB. If the print data is divided based simply on the page count, it is appropriate to divide the original print data into two parts because 1 GB/500 MB=2. That is, it is appropriate to divide the data having 1000 pages into pieces of print data each having 500 pages.
When the print data illustrated in
Therefore, the conversion processing server 10 of this exemplary embodiment divides the print data including the common image so that the data amount becomes equal to or smaller than the upper limit value set in advance without dividing the print data based only on the page count.
As illustrated in
The CPU 11 controls an operation of the conversion processing server 10 by executing predetermined processing based on a control program stored in the memory 12 or the storage device 13. In this exemplary embodiment, description is made under the assumption that the CPU 11 reads and executes the control program stored in the memory 12 or the storage device 13. The program may be provided to the CPU 11 by being stored in a storage medium such as a CD-ROM.
As illustrated in
For example, the print data receiving part 31 receives print data described by the PDL unique to Company A from the controller 30 or a recording medium such as a CD-ROM. The print data includes a common image such as a common form image or a common graphical object. The print data receiving part 31 functions as a receiver that receives print data including a common image. The common image refers to various images of a form and a graphical object that are used in common over a plurality of pages.
The print data storing part 32 spools (stores) the print data received by the print data receiving part 31.
The PDL conversion part 33 converts the print data received by the print data receiving part 31, stored in the print data storing part 32, and described by the PDL unique to Company A to print data described by a description language different from this PDL, such as a PDL in the PS format that is a general-purpose description language that does not depend on a printer that executes printing processing.
The print data transmitting part 34 transmits, to the controller 30, the print data described by the general-purpose PDL through the conversion performed by the PDL conversion part 33.
The PDL conversion part 33 includes a pre-scanning processing part 41, a division part 42, an adjustment part 43, and a resource management part 44.
The pre-scanning processing part 41 executes pre-scanning processing for the print data stored in the print data storing part 32 to investigate the page structure of the print data stored in the print data storing part 32 and the usage of the common image in each page, thereby generating form usage information.
The division part 42 divides the print data received by the print data receiving part 31 and stored in the print data storing part 32 based on each type of the common image in use. The division of the print data is not limited to actual division of the print data into a plurality of pieces of print data but encompasses tentative determination of division candidate locations. That is, the division part 42 determines candidate locations where the print data stored in the print data storing part 32 is divided into a plurality of pieces of print data based on each type of the common image in use.
The division part 42 divides the print data stored in the print data storing part 32 based on each type of the common image in use by using the form usage information that is an investigation result from the pre-scanning processing part 41.
The adjustment part 43 performs adjustment by redividing or combining the plurality of pieces of the print data of each type of the common image that is divided by the division part 42 so that the data amount of each piece of the print data becomes equal to or smaller than the upper limit value set in advance.
The upper limit value set in advance refers to a value limited in the processing to be performed by the RIP such as CPSI when print data is converted to a raster image in the controller 30 or in the printers 20A and 20B that execute printing processing based on the print data.
When the data amount of each piece of the divided print data of each type of the common image exceeds the upper limit value, the adjustment part 43 redivides each piece of the divided print data so that the data amount becomes equal to or smaller than the upper limit value in a state in which the common image is included in each piece of the divided print data.
Specifically, the adjustment part 43 redivides each piece of the print data of each type of the common image by a division count that is calculated by dividing the data amount of data other than the common image in each piece of the divided print data of each type of the common image by a value obtained by subtracting the data amount of the common image from the upper limit value.
At this time, the adjustment part 43 redivides each piece of the divided print data of each type of the common image at a boundary between pages. When imposition processing is performed, the adjustment part 43 redivides each piece of the divided print data of each type of the common image at a boundary between physical pages.
The imposition processing refers to processing of performing printing so that a plurality of logical pages are included in one physical page. The physical page refers to a page on actual print paper. The logical page refers to each page arranged within one physical page instead of the page on actual print paper.
When the data amount of each piece of the divided print data of each type of the common image is equal to or smaller than the upper limit value and when the total of the data amount of each piece of the divided print data of each type of the common image and the data amount of a subsequent piece of the divided print data of each type of the common image is equal to or smaller than the upper limit value, the adjustment part 43 combines the plurality of pieces of the divided print data of each type of the common image.
The resource management part 44 manages various types of information such as resource names and data sizes of various common images such as a common form image and a common graphical object image. A specific example of how the resource management part 44 manages various types of information on the common images is described later.
Next, an operation of the conversion processing server 10 in the printing system of this exemplary embodiment is described in detail with reference to the drawings.
First, an overall operation of the conversion processing server 10 is described with reference to
When the print data receiving part 31 has received print data described by the PDL unique to Company A (Step S101), the received print data is stored in the print data storing part 32 until the reception of all the print data is completed (Steps S102 and S103).
When the reception of all the print data has been completed (“YES” in Step S102), the PDL conversion part 33 performs PDL conversion processing for converting the print data described by the PDL unique to Company A to print data described by a general-purpose PDL in the PS format or the like (Step S104).
Finally, the print data transmitting part 34 transmits the print data described by the general-purpose PDL to the controller 30 (Step S105).
Next, details of the PDL conversion processing for the print data described by the PDL unique to Company A in the flowchart of
In the PDL conversion part 33, the pre-scanning processing part 41 first executes pre-scanning processing for the print data spooled in the print data storing part 32 (Step S201).
In the pre-scanning processing, contents of each page of the spooled print data are interpreted to generate form usage information indicating the page structure of the print data and a common form image specified in each page. The following description is directed to a case of using the common form image as the common image. The same applies to a case of using a common image other than the common form image. Details of the pre-scanning processing are described later.
When the pre-scanning processing is finished, processing of calculating a division page count is performed (Step S202). The division page count refers to a page count at which the print data is divided. That is, a page location where the print data is divided is determined in the processing of calculating the division page count.
In the processing of calculating the division page count, the division part 42 first divides the print data stored in the print data storing part 32 based on each type of the common image in use by using the form usage information that is the investigation result from the pre-scanning processing part 41. When the data amount of each piece of the print data of each type of the common image that is divided by the division part 42 exceeds the upper limit value, the adjustment part 43 redivides each piece of the divided print data so that the data amount becomes equal to or smaller than the upper limit value in a state in which the common image is included in each piece of the divided print data. When the data amount of each piece of the divided print data is small and therefore the data amount does not exceed the upper limit value even if two or more pieces of the print data are combined, the adjustment part 43 performs processing of combining the plurality of pieces of the divided print data.
Through the processing performed by the division part 42 and the adjustment part 43, a division page location where the data amount becomes equal to or smaller than the upper limit value among all the pieces of the divided print data is determined.
The PDL conversion part 33 executes conversion processing for converting the print data described by the PDL unique to Company A to print data described by a general-purpose PDL in a state in which the print data is divided based on the division page location determined as described above (Step S203).
Next, details of the pre-scanning processing for the spooled print data in the flowchart of
First, the pre-scanning processing part 41 reads one record of the print data spooled in the print data storing part 32 (Step S301). The record refers to a unit of print data to be stored. With one record of the print data, for example, form specification that specifies a common form image in use or page break specification that specifies page feed is performed.
The pre-scanning processing part 41 sequentially interprets contents of the read record until the reading of all the records that configurate the print data is completed (Steps S302 and S303).
When the interpreted contents of the record indicate the form specification that specifies a form in use (“YES” in Step S304), the pre-scanning processing part 41 identifies a common form image specified in the current page to be processed and updates the form usage information (Step S305).
When the interpreted contents of the record do not indicate the form specification that specifies a form in use (“NO” in Step S304), the pre-scanning processing part 41 determines whether the interpreted contents of the record indicate the page break specification (Step S306).
When the interpreted contents of the record indicate the page break specification (“YES” in Step S306), the pre-scanning processing part 41 updates page count information (Step S307). When the interpreted contents of the record do not indicate the page break specification (“NO” in Step S306), the pre-scanning processing part 41 reads a subsequent record of the print data without performing any processing (Step S301).
When the reading of all the records of the print data has been completed (“YES” in Step S302), the pre-scanning processing part 41 terminates the pre-scanning processing.
That is, in the pre-scanning processing, only the records of the form specification and the page break specification are counted to generate the form usage information.
Next, a specific operation of the conversion processing server 10 is described with reference to specific print data illustrated in
The common form images are registered as a resource set together with other common images. When the common form image is registered in the resource set in advance, a common form image used in the print data is specified. A packet called download form is present as a packet for specifying the common form image used in the print data. When the print data is received and the download form packet is recognized in the received print data, the download form packet is extracted, converted dynamically to a common form image in the PS format, and stored in the resource set. When the common form image used in the print data is similarly specified afterwards, the form registered in the resource set is used.
In the example of the print data illustrated in
Various attributes of the common images are managed by the resource management part 44 in a resource management table illustrated in
The example of the resource management table illustrated in
In the division part 42 and the adjustment part 43, processing of identifying a division page location in the print data illustrated in
First, the division part 42 divides the print data (or determines a division candidate) based on each type of the common image in use, in this case the common form image, by referring to the form usage information illustrated in
Specifically, the division part 42 divides the print data into four pieces of print data corresponding to pages 1 to 20000, pages 20001 to 30000, pages 30001 to 40000, and pages 40001 to 50000.
Next, the adjustment part 43 calculates a division count to be used when each of the four pieces of divided print data is redivided.
In the example of the processing of calculating the division count in
For example, in a case of calculating a division count of the print data corresponding to pages 1 to 20000, the data size of the specified common form image OVL1 is first acquired from the resource management table of
The page count of the print data is 20000 and therefore the data size of print contents is set to 2.2 GB by multiplying 20000 by 0.11 MB that is the maximum data size per page.
That is, the overall data size of the print data corresponding to pages 1 to 20000 is 2.7 GB (0.5 GB+2.2 GB).
The adjustment part 42 calculates a value by subtracting the data size (data amount) of the common image from the upper limit value. The upper limit value is 1.6 GB and the data size of the common image OVL1 is 0.5 GB. Therefore, the adjustment part 42 obtains a value of 1.1 GB (B).
Next, the adjustment part 42 calculates a division count by dividing the data amount of data other than the common image in each piece of the divided print data by the value obtained in the above. Specifically, the adjustment part 42 obtains a division count of 2 (2.2 GB/1.1 GB) by dividing 2.2 GB (A) that is the data size of the print contents of the data other than the common image by 1.1 GB (B).
In the case of the print data corresponding to pages 20001 to 30000, the adjustment part 42 obtains a value of 0.6 GB by subtracting 1.0 GB that is the data size of the common image OVL2 from 1.6 GB that is the upper limit value. Then, the adjustment part 42 calculates a value of 1.8 by dividing 1.1 GB that is the data size of print contents of data other than the common image by 0.6 GB. As a result, the adjustment part 42 calculates a division count of 2 by rounding up 1.8 to an integer.
In the case of the print data corresponding to pages 30001 to 40000, the adjustment part 42 obtains a value of 0.4 GB by subtracting 1.2 GB that is the data size of the common image OVL3 from 1.6 GB that is the upper limit value. Then, the adjustment part 42 calculates a value of 2.7 by dividing 1.1 GB that is the data size of print contents of data other than the common image by 0.4 GB. As a result, the adjustment part 42 calculates a division count of 3 by rounding up 2.7 to an integer.
In the case of the print data corresponding to pages 40001 to 50000, the overall data size of the print data is 1.1 GB and is smaller than the upper limit value of 1.6 GB. Therefore, the adjustment part 43 does not redivide the print data.
Referring to
As illustrated in
As described above, the print data illustrated in
Referring to
For example, the description is made under the assumption that the data sizes of two pieces of print data divided by the division part 42 are 0.6 GB and 0.2 GB as illustrated in
In this case, the total of the data sizes of the two pieces of print data is 0.8 GB and does not exceed the upper limit value of 1.6 GB. In this case, the adjustment part 43 combines the two pieces of print data to obtain one piece of print data.
The foregoing description of the exemplary embodiment of the present disclosure has been provided for the purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure to the precise forms disclosed. Obviously, many modifications and variations will be apparent to practitioners skilled in the art. The embodiment was chosen and described in order to best explain the principles of the disclosure and its practical applications, thereby enabling others skilled in the art to understand the disclosure for various embodiments and with the various modifications as are suited to the particular use contemplated. It is intended that the scope of the disclosure be defined by the following claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2018-107108 | Jun 2018 | JP | national |