US10310788B2 - Control method for generating data used for printing and information processing apparatus - Google Patents

Control method for generating data used for printing and information processing apparatus Download PDF

Info

Publication number
US10310788B2
US10310788B2 US15/688,618 US201715688618A US10310788B2 US 10310788 B2 US10310788 B2 US 10310788B2 US 201715688618 A US201715688618 A US 201715688618A US 10310788 B2 US10310788 B2 US 10310788B2
Authority
US
United States
Prior art keywords
page
print ticket
print
function
setting value
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
US15/688,618
Other languages
English (en)
Other versions
US20180060003A1 (en
Inventor
Akihiro Mitsui
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Canon Inc filed Critical Canon Inc
Assigned to CANON KABUSHIKI KAISHA reassignment CANON KABUSHIKI KAISHA ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MITSUI, AKIHIRO
Publication of US20180060003A1 publication Critical patent/US20180060003A1/en
Application granted granted Critical
Publication of US10310788B2 publication Critical patent/US10310788B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1253Configuration of print job parameters, e.g. using UI at the client
    • G06F3/1254Automatic configuration, e.g. by driver
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1204Improving or facilitating administration, e.g. print management resulting in reduced user or operator actions, e.g. presetting, automatic actions, using hardware token storing data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1205Improving or facilitating administration, e.g. print management resulting in increased flexibility in print job configuration, e.g. job settings, print requirements, job tickets
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1241Dividing a job according to job requirements, e.g. black/white and colour pages, covers and body of books, tabs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1244Job translation or job parsing, e.g. page banding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server

Definitions

  • the present invention relates to a technique to switch print settings for each page in a printer driver that generates a print job for causing a printer to perform printing.
  • Some document data to be printed with a printer are set with print settings varying depending on the pages.
  • the first and second pages are vertically printed on an A4 sheet while the pages from the third page are printed horizontally.
  • the pages from the fifth page may be printed on an A3 sheet.
  • the print settings about the sheet hut also the print settings about the finishing may be varied, for example, the one-sided printing setting is changed to the two-sided printing setting for the pages from the seventh page, and stapling (the staple setting) is enabled for the tenth to fourteenth pages.
  • These different settings are implemented with an application that stores the print settings per page, and a printer driver that issues the print data including a control code per page (Japanese Patent Laid-Open No. 2001-84245).
  • a print job includes one or more documents.
  • the document includes a plurality of pages.
  • Such scopes (the job, the document, and the page) are indicated as levels in the print ticket.
  • the settings at the job level are defined to be applied for the whole print job.
  • the settings at the document level are defined to be applied to each document.
  • the settings at the page level are defined to be applied to each page.
  • the name of each setting in the print ticket necessarily has a prefix such as “Job”, “Document”, or “Page” so that the level of the scope to which the setting is applied can be identified.
  • APIs Application Programming Interfaces
  • One is to configure the settings of a whole print job.
  • the other is to configure the settings for each page.
  • An API for drawing which is referred to as Graphics Device Interface (GDI) and used also in existing systems, configures the settings for a whole print job with CreateDC and the setting for each page with ResetDC.
  • GDI Graphics Device Interface
  • Direct2D configures a whole print job with CreateDocumentPackage and the setting for each page with AddPage.
  • the settings at the job level and the document level include functions such as layout settings including two-sided printing and NUp, and finishing settings including stapling and punching.
  • a control method includes: generating a first command for controlling printing according to a setting value included in a print ticket for a whole job; storing a setting value corresponding to a first function belonging to a job scope or a document scope included in the print ticket on a storage area; when there is a print ticket for a page among a plurality of pages included in the job, comparing the setting value corresponding to the first function included in the print ticket for the page with the stored setting value; and, when the compared setting values are different from each other, issuing a control code for separation, and generating a second command for controlling the printing according to setting values corresponding to a plurality of functions included in the print ticket for the page.
  • FIG. 1 is an exemplary block diagram of a configuration of hardware and software of an information processing apparatus.
  • FIG. 2 illustrates an exemplary network configuration in which clients, a server, and printers are connected.
  • FIG. 3 illustrates an exemplary configuration of a print system including a V4 printer driver.
  • FIG. 4 illustrates an exemplary data structure of an XPS spool file.
  • FIG. 5 is a flowchart for describing a process by an application in consideration of a change of a print setting for each page.
  • FIG. 6 is a flowchart for describing a conversion process of data by a V4 printer driver.
  • FIG. 7 illustrates an exemplary print ticket that defines a function that originally belongs to a document scope as a function that belongs to a page scope in an extended region.
  • FIG. 8 illustrates an exemplary order of APIs used for printing by a GUI application.
  • FIG. 9 illustrates an exemplary order of APIs used for printing by an XPS application.
  • FIG. 10 illustrates an exemplary print ticket included in an XPS spool file.
  • FIG. 11 illustrates exemplary FixedPage included in an XPS spool file.
  • FIG. 12 is a schematic diagram of a plurality of pages included in an XPS spool file and a print ticket that is applied to each page.
  • FIG. 1 is a block diagram of a configuration of a system using a typical information processing apparatus (computer) and depicts an embodiment of the present invention. Needless to say, the present invention may be applied to any configurations that perform the functions of the present invention, such as a discrete functional unit, a system including a plurality of devices, and a system connected via a network to perform a process unless otherwise noted.
  • a CPU 101 controls the whole information processing apparatus according to a program stored on a ROM 1021 or a RAM 1022 in a main memory 102 , or on an auxiliary memory device 105 .
  • the RAM 1022 is also used as a work area when the CPU 101 performs various processes.
  • the auxiliary memory device records, for example, an application 1051 , a printer driver 1052 , and an operating system (OS) 1053 .
  • An input device such as a keyboard 1031 , or a pointing device 1032 typified by a mouse or a touch panel is a device that the user uses to give various instructions to a computer via an input I/F 103 .
  • An output I/F 104 is an interface for outputting data to the outside, and outputs data to an output device such as a monitor 1041 or a printer 1042 .
  • the output I/F 104 may be connected to the printer 1042 not only via a local I/O directly connected but also via a network 1061 connected via a communication I/F 106 .
  • a system bus 107 is a common data system bus used to exchange data, for example, between an I/F and a module. Note that the CPU 101 implements each step of the flowcharts, which the printer driver 1052 of embodiments of the present invention performs, by reading a program about the flowchart from the auxiliary memory device 105 or the RAM 1022 and executing the program.
  • the printer 1042 may be a printing apparatus only having a printing function, a FAX apparatus only having a FAX function, or a multifunction apparatus having plurality of functions including a scanning function and a printing function. Note that the printer 1042 is referred to also as an image processing apparatus or an image forming apparatus.
  • FIG. 2 schematically illustrates an environment of the network 1061 in an embodiment of the present invention.
  • One or a plurality of client computers 201 / 202 that create documents and images to be printed is/are connected to a network.
  • a server computer 203 that manages a user of the client computer and a printer is sometimes connected to the network.
  • One or a plurality of printers 205 and/or 1042 is/are connected to the network.
  • FIG. 2 illustrates that the printer 205 is physically connected to the network but is in an offline state in which the printer 205 is not actually available.
  • the network includes small and large networks such as a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), and a Wide Area Network (WAN).
  • PAN Personal Area Network
  • LAN Local Area Network
  • MAN Metropolitan Area Network
  • WAN Wide Area Network
  • the devices described above are connected to all the networks.
  • the server and the printer may be connected, for example, to cloud computing over the Internet.
  • the information processing apparatus is an apparatus, capable of being connected to another device (for example, an image processing apparatus
  • FIG. 3 is a block diagram of a configuration of a print system of a V4 printer driver established in the client computer 201 / 202 .
  • the illustrated print system includes a function module that the OS 1053 includes.
  • the V4 printer driver print system performs printing, using a file format referred to as XML Paper Specification (hereinafter, abbreviated to XPS) as spool data.
  • Software components 1051 , 1052 , and 1053 in FIG. 3 are stored on the auxiliary memory device 105 and loaded onto the RAM 1022 when being executed by the CPU 101 .
  • the V4 printer driver print system operates on the OS 1053 .
  • a print manager 318 , a GDI to XPS conversion module 307 , and a filter pipeline manager 312 are the modules included the OS 1053 .
  • the GDI to XPS conversion module 307 , and the filter pipeline manager 312 are included in the printer driver 1052 .
  • the GDI to XPS conversion module 307 , and the filter pipeline manager 312 are modules that the OS 1053 provides exclusively to the printer driver 1052 .
  • Filters 313 to 315 that are the filters for the printer driver 1052 and the filter pipeline manager 312 , and a device application 310 are stored as the printer driver 1052 on the auxiliary memory device 105 of FIG. 1 . Note that the device application 310 is automatically installed via the network with the installation of the printer driver.
  • a GDI print application 301 (hereinafter, abbreviated to GDI application) and an XPS print application 302 (hereinafter, abbreviated as XPS application) are stored as the application 1051 on the auxiliary memory device 105 of FIG. 1 .
  • the GDI application 301 performs printing, using a Graphics Device Interface (GDI) provided by the OS 1053 .
  • the XPS application 302 performs printing, directly using the XPS spool file 306 .
  • the user instructs a printing process from the application 301 or XPS application 302 displayed on a monitor 1041 of the output device, using an input device such as the keyboard 1031 or the touch panel/mouse 1032 .
  • the printing process is implemented when three processes “selection of a printer”, “creation of print setting data”, and “conversion of drawing data” are performed in order. The flow of the printing process will be described hereinafter.
  • the user selects a device to be used for printing (for example, the printer 1042 ).
  • the fact that user selects the printer 1042 means that the user selects the printer driver 1052 corresponding to the printer 1042 that performs the printing.
  • print setting data is created.
  • the application 1051 allocates a memory area for the print setting data in the RAM 1022 .
  • the application invokes the configuration module 308 of the printer driver 1052 to create and store the print setting data.
  • the GDI application 301 uses a binary DEVMODE structure 303 as the print setting data whereas the XPS application 302 uses a print ticket 304 described in an eXtensive Markup Language (XML) that is a markup language.
  • the DEVMODE structure 303 includes a default region defined by the operating system and art extended region uniquely defined by the printer driver.
  • the print ticket 304 is the print setting data described in an XML format. The default region and the extended region are described with separate namespaces.
  • the print setting data also includes the information inherent in the model, so that the configuration module 308 creates the print setting data using a feature file 309 .
  • the application 1051 changes a print setting by rewriting the content of the DEVMODE structure 303 or the print ticket 304 .
  • the print setting data includes the setting values necessary for printing, such as the information about the sheet size to be output (for example, “A4”), designation of two-sided printing, polychrome or monochrome printing, and designation of a sheet feeding stage.
  • the specification of the default region of the print setting data is opened externally. Thus, the application may directly be changed. Only the printer driver 1052 holds the detailed specification of the extended region depending on the printer 1042 . Thus, the user normally configures the specification using a user interface included in the device application 310 .
  • the setting values of the print ticket 304 are described in an XML format so that the XPS application 302 can directly change and rewrite all the setting values.
  • the extended region is uniquely defined by the printer driver.
  • the detailed specification is not disclosed and varies depending on the printer 1042 . This makes it easier for the user to use the user interface of the device application 310 in order to change the setting value.
  • the device application 310 is a printer driver 1052 , but is installed as a program different from the printer driver onto the client computer 201 / 202 .
  • the device application 310 exchanges the print setting data with the printer driver using the print ticket 304 .
  • the device application 310 holds a conflict engine 3101 to solve an invalid combination of the print setting data and create correct print setting data. Invalid combinations of the print setting data are described in the feature file 309 .
  • the conflict engine 3101 reads the feature file 309 before displaying the user interface.
  • the printer driver 1052 changes the setting depending on the printer 1042 in the DEVMODE structure 303 or the print ticket 304 according to the content designated via the user interface.
  • the print setting data is required each time a document is printed. Thus, the print setting data is created for each printing.
  • the printer driver about the option device of the printer 1042 or the environmental settings of each user is stored on a registry database 305 or a property bag 317 of the OS 1053 .
  • a print manager 318 of the operating system stores the default values of the print setting data on the registry database 305 .
  • the registry database 305 and the property bag 317 are stored on the auxiliary memory device 105 .
  • the user instructs the start of a printing process via a screen provided by the application 1051 after the print setting data is fixed.
  • drawing data is transmitted from the GDI application 301 to the GDI to XPS conversion module 307 .
  • the XPS spool file 306 created.
  • the GDI to XPS conversion module 307 invokes the configuration module 308 to convert the print setting data from the DEVMODE structure 303 into the print ticket DEVMODE-print ticket conversion module 3081 is used for the conversion.
  • the DEVMODE-print ticket conversion module 3081 can read and write the information on the property bag 317 and thus can refer to and convert the data stored by the device application 310 .
  • the XPS application creates the XPS spool file 306 .
  • the other way is that the OS 1053 creates the XPS spool file 306 according to a drawing command from the XPS application.
  • the XPS spool file 306 is created in the middle of the printing either way.
  • a feature of the V4 printer driver print system is to necessarily create the XPS spool file 306 based on the drawing data when printing is performed.
  • the process is transferred to a print filter pipeline 311 .
  • the print filter pipeline 311 is a mechanism to perform printing through a plurality of filters and a filter configuration file 316 controls the number and order of filters.
  • a filter pipeline manager 312 operating in the print filter pipeline 311 performs processes, for example, in order of a communication filter 313 , a layout filter 314 , and a renderer filter 315 according to the filter configuration file 316 in the present embodiment.
  • the number, types, and order of filters vary depending on the configuration of the printer driver 1052 .
  • an encryption filter to encrypt the print job may be included in addition to the three filters in FIG. 3 .
  • the print system performs the printing process by transferring the XPS spool file 306 to the filters.
  • Each of the filters processes the XPS spool file 36 and transfers the processed XPS spool file 306 to the next filter. This makes the printing process proceed.
  • the XPS spool file 306 is converted into a print job and transmitted to the printer. Note that the printer can interpret the print job, and performs a printing process based on the transmitted print job by interpreting the print job.
  • Each of the filters can store its unique data on the property bag 317 . Furthermore, each of the filters can obtain the information about the OS 1053 and the data of the other filters from the property bag 317 .
  • the communication filter 313 obtains the information required to perform printing in order to rewrite the print ticket 304 , or store the data obtained from the printer on the property bag 317 .
  • the layout filter 314 performs a process related to the layout including changing the magnification, the layout for binding, or the layout of a stamp.
  • the layout filter 314 operates according to the print ticket 304 included in the XPS spool file 306 . Thus, for example, when a layout setting does not exist in the print ticket 304 , the layout filter 314 transfers the XPS spool file 306 to the next filter without performing any process.
  • the renderer filter 315 converts the input XPS spool file 306 into a Page Description Language (hereinafter, abbreviated to PDL) by rendering.
  • PDL Page Description Language
  • the renderer filter 315 further converts the setting included in the default region in the print setting data of the print ticket 304 into a Printer Job Language (hereinafter, abbreviated to PJL).
  • the renderer filter 315 creates a print job by combining the PDL and the PJL and transfers the print job as stream data to the next filter.
  • the renderer filter 315 combines the converted PJL, and the transferred PDL and PJL as a print job, and transfers the combined print job to the filter pipeline manager 312 .
  • the print job is transmitted to the print manager 318 that manages the schedule of the printing process. Such print jobs are consecutively registered in a queue.
  • the print manager 318 communicates with the printer 1042 and transmits the print jobs in order of registration in the queue via the port monitor 319 as soon as the printer 1042 is ready to print.
  • a main role of the printer driver is to convert the drawing data and the print setting data into a print job, and the printing is performed in the client computer 201 / 202 .
  • embodiments of the present invention may be applied to a FAX transmission process although a printing process is used for description and the printer driver is described in the present embodiment.
  • a FAX filter for creating FAX data installed instead of the renderer filter 315 , and a FAX driver is used to transmit the FAX data to a FAX apparatus.
  • FIG. 4 illustrates an exemplary data structure of an XPS spool file.
  • the XPS spool file 306 has a tree structure that starts from Root 401 and includes folders, XML files, and binary resources.
  • the XML files included in the XPS spool file 306 are broadly divided into rels files and the other files. An association (relationship) indicating what role each XML file has is described in the rels file.
  • a file “[Content_Types].xml” 402 associates all the files included in the XPS spool file 306 with the types of resources.
  • a file “FixedDocumentSequence.fdseq” 403 indicates the document included in the XPS spool file 306 .
  • the file “FixedDocumentSequence.fdseq” 403 indicates a file “FixedDocument.fdoc” 405 .
  • a file “Job_PT.xml” 404 is the print ticket for the whole print job.
  • a file “Document_PT.xml” 406 is the print ticket for a document.
  • a file “Page1_PT.xml” 407 is the print ticket for each page.
  • FIG. 10 illustrates an exemplary print ticket 304 .
  • the print settings included in the print ticket 304 are divided into the setting acting on the whole job, the setting acting on the document, and the setting acting only on a page, depending on the functions.
  • the setting acting on the whole job has a prefix “Job” in its function name.
  • the setting acting on the whole job is JobCopiesAllDocuments indicating the number of copies in the example of FIG. 10 .
  • the setting acting on the document has a prefix “Document” in its function name.
  • the setting acting on the document is DocumentDuplex indicating two-sided print setting in the example of FIG. 10 .
  • the setting acting only on a page has a prefix “Page” in its function name.
  • the setting acting only on a page is PageMediaSize indicating the sheet size in the example of FIG. 10 .
  • the divisions are distinctively referred to as the scopes or the levels.
  • the functions for controlling the characteristics of the printer engine such as the color and the image quality are classified as a job scope; the finishing functions such as stapling, punching, and two-sided printing, and the layout functions such as Nup are classified as a document scope; and the functions related to the sheet such as the size or the orientation are classified as a page scope.
  • the print ticket for each page such as the Page1_PT.xml 407 only includes the functions in the page scope.
  • the print ticket for the whole job includes the functions in all of the scopes from the job to page scopes.
  • the print ticket for each page does not exist in the XPS spool file, the settings indicated in the print ticket for the whole job are reflected in each page.
  • the XPS spool file 306 may include a plurality of documents although including only a document in FIG. 4 .
  • the “FixedDocument.fdoc” 405 indicates the pages included in the document “FixedDocument.fdoc” 405 in the XPS spool file 306 . Only a page exists in FIG. 4 , so that the document “FixedDocument.fdoc” 405 indicates only “1.fpage” 408 .
  • the “1.fpage” 408 is the drawing data about a page referred to as FixedPage and described in an XML format.
  • FIG. 11 illustrates exemplary FixedPage.
  • the Path renders a line or a graphic pattern.
  • the Glyphs renders a text.
  • the ImageBrush renders a picture image.
  • FIG. 12 illustrates an example similarly to the XPS spool file 306 including a plurality of pages.
  • FIG. 12 illustrates the example in which print tickets for two pages among six pages of FixedPage exist. In such a case, the third and fifth pages are printed according to the print ticket for each page, and the other pages are printed according to the print ticket for the whole print job.
  • the “*.odttf” 409 in the XPS spool file of FIG. 4 is font data.
  • the font data used for expressing a text is embedded as a subset extracting the data to be used for the text.
  • the “*.jpg;*.png” 410 is picture image data such as JPEG or PNG.
  • a feature of the XPS spool file 306 is that the XPS spool file 306 includes many small parts. In addition, the parts are collected and compressed in ZIP compression. Another feature is that the parts are collected as a file and this collection reduces the size.
  • the application 1051 performs in consideration of switching the print settings per page when printing is performed with the V4 printer driver.
  • the application 1051 according to embodiments of the present invention is stored on the auxiliary memory device 105 of the computer, and is read by the RAM 1022 and executed by the CPU 101 .
  • the application 1051 creates the print settings for a whole print job according to the format of a sheet to be output.
  • the application 1051 declares to the OS 1053 that the application 1051 starts to print, using API (StartDoc). At the declaration, the application 1051 can configure the print settings created in S 501 as the print settings for the whole job by designating the created print settings with the API.
  • the application 1051 determines whether to change the print settings from the next page before drawing a page to be processed in the job. If the application 1051 changes the print settings from the next page, the process goes to S 504 . If not, the process goes to S 506 .
  • the application 1051 creates the print settings (the print ticket) for the page of which print settings to be changed. At that creation, the application 1051 creates the print settings (the print ticket) for a whole including not only the functions in the page scope indicating the values of the print settings to be changed hut also the functions in the document scope and the job scope. Then, in S 505 , the application 1051 designates the created print settings (print ticket) with the API of the OS 1053 that changes the page setting.
  • the API used here is MXDC_ESCAPE.
  • the application 1051 draws the page to be printed.
  • the application 1051 only draws the page as normal when the print settings are not changed in the middle of the printing.
  • the application 1051 determines whether the page drawn in S 506 is the last page of the job. If the drawn page is not the last page, the process returns to S 503 . The application 1051 repeats S 503 to S 506 to print a plurality of pages included in the job. In S 508 , the application 1051 declares to the OS 1053 that the application 1051 terminates the printing, using API (EndDoc).
  • FIG. 8 illustrates APIs in order in which the GDI application 301 invokes when performing printing along the flowchart of FIG. 5 .
  • the GDI application 301 is stored on the auxiliary memory device 105 of the computer, and is read by the RAM 1022 and executed by the CPU 101 .
  • the GDI application 301 invokes the API (StartDoc) for starting printing to generate a print ticket for a job using the DEVMODE-print ticket conversion module 3081 ( 5101 ).
  • ResetDC There are two APIs for switching the settings for each page, an API ( 5102 ) referred to as ResetDC and an API ( 5103 ) referred to as MXDC_ESCAPE.
  • the ResetDC generates a print ticket for a page using the DEVMODE-print ticket conversion module 3081 .
  • the MXDC_ESCAPE is used when the GDI application 301 generates a print ticket by itself for direct insertion.
  • the GDI application 301 uses the DEVMODE structure to create a print ticket.
  • the GDI application 301 uses the MXDC_ESCAPE ( 5103 )
  • the GDI application 301 generates the print ticket by itself.
  • the GDI application 301 uses the MXDC_ESCAPE as the API used to switch (change) the setting for each page instead of the ResetDC. This is because only a print ticket only including the functions in the page scope can be generated with the DEVMODE-print ticket conversion module 3081 when the ResetDC ( 5102 ) is used.
  • FIG. 9 illustrates APIs in order in which the XPS application 302 invokes when performing printing along the flowchart of FIG. 5 using an API group referred to as Direct2D.
  • the XPS application 302 is stored on the auxiliary memory device 105 of the computer, and is read by the RAM 1022 and executed by the CPU 101 .
  • the XPS application 302 designates the print ticket 304 for the whole job, which the XPS application 302 creates by itself, with an API referred to as CreateDocumentPackage to apply the print settings for the whole job ( 5201 ). Similarly, the XPS application 302 uses an API referred to as AddPage to designate the print ticket 304 for the whole job, which the XPS application 302 creates by itself, to switch the print settings for each page.
  • the renderer filter 315 receives the XPS spool file 306 from the filter pipeline manager 312 .
  • the renderer filter 315 obtains the print ticket for the whole job from the XPS spool file 306 .
  • the renderer filter 315 interprets the print ticket for the whole job and generates a PJL that is a printer job language for the whole print job.
  • the renderer filter 315 stores the setting values of the print setting items corresponding to a plurality of functions in the job scope and the document scope of the print ticket for the whole job on the storage area (for example, the RAM 1022 ).
  • the renderer filter 315 checks whether there is a print ticket for the page that is currently to be processed among the pages in the print job in the XPS spool file 306 . If there is the print ticket 304 for the page that is currently to be processed, the process goes to S 606 . If there is not the print ticket for the page, the process goes to S 609 .
  • the renderer filter 315 compares the print setting items corresponding to the functions belonging to the job scope and the document scope included in the print ticket for each page with the setting values of the print setting items held in S 604 , respectively. If there is a difference between the setting values of any of the print setting items, the process goes to S 607 . If there is not a difference between the setting values, the process goes to S 608 .
  • the fact that the process goes to S 607 means that at least a print setting value corresponding to any of functions belonging to the job scope or the document scope is changed in one of the pages included in the job.
  • the renderer filter 315 puts a control code (a PJL command) as a separator to make the printer 1042 recognize that the job or the document is switched. Issuing such a control code can generate another PJL for control the printing, which has at least a different print setting value corresponding to any of functions belonging to the job scope or the document scope from the previous print setting value in a page in the job. Note that, in order to change a setting value corresponding to a function belonging to the page scope, a PJL command about the page to be processed is issued as normal, or the PDT drawing data is switched, instead of putting a control code as a separator.
  • a control code a PJL command
  • the renderer filter 315 further generates a PJL that is different from the PJL generated in S 603 and according to the setting values corresponding to the functions in the job scope and the document scope included in the print ticket for the page to be processed.
  • the renderer filter 315 generates a PJL of the page to be processed from the print ticket for that page.
  • the renderer filter 315 obtains FixedPage from the XPS spool file 306 to generate a PDL of the page to be processed.
  • the renderer filter 315 determines whether the last page is processed. If there is a next page, the process returns to S 605 and the renderer filter 315 repeats S 605 to S 609 . If there is not a next page, in other words, if the renderer filter 315 recognizes that the process of the last page is completed, the renderer filter 315 transmits the XPS spool file 306 to the next filter in S 611 and ends the process.
  • the present exemplary embodiment enables switching (changing) a function belonging to scopes other than the page scope, such as stapling, punching, or two-sided printing, at a page in the middle of the job when the V4 printer driver is used.
  • a setting value included in the print ticket for a page sometimes conflicts with a setting value included in the print ticket for another page among a plurality of pages in a job in the first exemplary embodiment.
  • a print ticket for the fourth page and a print ticket for the sixth page in a job there are a print ticket for the fourth page and a print ticket for the sixth page in a job, and a setting value for turning the staple setting ON is described in the print ticket for the fourth page and a setting value for turning the punch setting ON is described in the print ticket for the sixth page.
  • the printer 1042 is a model that does not enable the stapling function and the punching function simultaneously, it may be impossible to reflect the setting for the sixth page in the output result.
  • the renderer filter 315 also checks the setting value of another function likely to conflict with the function of which setting value is changed when comparing the changed setting value with the previously held content in S 606 .
  • the renderer filter 315 compares the priorities of the conflicting functions.
  • the process in S 607 is skipped.
  • the order of priorities of the functions is previously defined.
  • Such a process enables properly changing the print settings in a page in the middle of a job according to the priority order among the functions.
  • FIG. 7 illustrates a print ticket that defines two-sided print settings, which are normally defined as a function belonging to the document scope, as a function belonging to the page scope.
  • the print ticket defines the two-sided print settings as a function belonging to the page scope in an extended region that the printer driver uniquely defines.
  • the name of the function includes a prefix “Page”.
  • Such definition makes it possible to treat the two-sided print settings as a function for a page. This enables the GDI application 301 to switch the print settings without using the MXDC_ESCAPE ( 5103 ).
  • Embodiment(s) of the present invention can also be realized by a computer of a system or apparatus that reads out and executes computer executable instructions (e.g., one or more programs) recorded on a storage medium (which may also be referred to more fully as a ‘non-transitory computer-readable storage medium’) to perform the functions of one or more of the above-described embodiment(s)) and/or that includes one or more circuits (e.g., application specific integrated circuit (ASIC)) for performing the functions of one or more of the above-described embodiment(s), and by a method performed by the computer of the system or apparatus by, for example, reading out and executing the computer executable instructions from the storage medium to perform the functions of one or more of the above-described embodiment(s) and/or controlling the one or more circuits to perform the functions of one or more of the above-described embodiment(s).
  • computer executable instructions e.g., one or more programs
  • a storage medium which may also be referred to more fully as
  • the computer may comprise one or more processors (e.g., central processing unit (CPU), micro processing unit (MPU)) and may include a network of separate computers or separate processors to read out and execute the computer executable instructions.
  • the computer executable instructions may be provided to the computer, for example, from a network or the storage medium.
  • the storage medium may include, for example, one or more of a hard disk, a random-access memory (RAM), a read only memory (ROM), a storage of distributed computing systems, an optical disk (such as a compact disc (CD), digital versatile disc (DVD), or Blu-ray Disc (BD)TM), a flash memory device, a memory card, and the like.
US15/688,618 2016-08-30 2017-08-28 Control method for generating data used for printing and information processing apparatus Active US10310788B2 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2016167778A JP6827738B2 (ja) 2016-08-30 2016-08-30 制御方法、プログラム及び情報処理装置
JP2016-167778 2016-08-30

Publications (2)

Publication Number Publication Date
US20180060003A1 US20180060003A1 (en) 2018-03-01
US10310788B2 true US10310788B2 (en) 2019-06-04

Family

ID=61242663

Family Applications (1)

Application Number Title Priority Date Filing Date
US15/688,618 Active US10310788B2 (en) 2016-08-30 2017-08-28 Control method for generating data used for printing and information processing apparatus

Country Status (2)

Country Link
US (1) US10310788B2 (ja)
JP (1) JP6827738B2 (ja)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20190187937A1 (en) 2017-12-19 2019-06-20 Kyocera Document Solutions, Inc. Printing computing device for operating a multi-function printing device
US11068214B2 (en) 2017-12-19 2021-07-20 Kyocera Document Solutions, Inc. Printing computing device for printing PPL jobs having video data and methods for use with a printing system for printing PPL jobs having video data

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001084245A (ja) 1999-09-10 2001-03-30 Fuji Xerox Co Ltd 文書処理装置および文書処理方法
US20070013931A1 (en) * 2005-07-15 2007-01-18 Konica Minolta Business Technologies, Inc. Source document management method, print control apparatus, and print control program
US20100306646A1 (en) * 2009-05-26 2010-12-02 Konica Minolta Business Technologies, Inc. Image processing apparatus and computer-readable storage medium
US20110199648A1 (en) * 2010-02-12 2011-08-18 Konica Minolta Business Technologies, Inc. Control program and image forming apparatus
US20120268792A1 (en) * 2011-04-21 2012-10-25 Canon Kabushiki Kaisha Print processing apparatus, print processing method, and print control program
US20180136889A1 (en) * 2016-11-15 2018-05-17 Ricoh Company, Ltd. Storing preflight data of a print job based on page ranges

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4759464B2 (ja) * 2006-07-31 2011-08-31 キヤノン株式会社 文書処理装置および文書処理方法
JP2012146240A (ja) * 2011-01-14 2012-08-02 Canon Inc アプリケーションプログラムとプリンタードライバー間のデータ通信方法およびプログラム
JP6289276B2 (ja) * 2014-06-06 2018-03-07 キヤノン株式会社 情報処理装置およびプログラム、制御方法

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001084245A (ja) 1999-09-10 2001-03-30 Fuji Xerox Co Ltd 文書処理装置および文書処理方法
US20070013931A1 (en) * 2005-07-15 2007-01-18 Konica Minolta Business Technologies, Inc. Source document management method, print control apparatus, and print control program
US20100306646A1 (en) * 2009-05-26 2010-12-02 Konica Minolta Business Technologies, Inc. Image processing apparatus and computer-readable storage medium
US20110199648A1 (en) * 2010-02-12 2011-08-18 Konica Minolta Business Technologies, Inc. Control program and image forming apparatus
US20120268792A1 (en) * 2011-04-21 2012-10-25 Canon Kabushiki Kaisha Print processing apparatus, print processing method, and print control program
US20180136889A1 (en) * 2016-11-15 2018-05-17 Ricoh Company, Ltd. Storing preflight data of a print job based on page ranges

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
Print Schema Specification, Microsoft Corporation; Chapter 4. PrintTicket Documents, pp. 35-36, Sep. 5, 2013.

Also Published As

Publication number Publication date
JP6827738B2 (ja) 2021-02-10
JP2018036755A (ja) 2018-03-08
US20180060003A1 (en) 2018-03-01

Similar Documents

Publication Publication Date Title
US9607250B2 (en) Information processing apparatus, method for controlling the same, and information processing program
JP5072676B2 (ja) 情報処理装置、情報処理方法及び印刷システム
US8553263B2 (en) Information processing apparatus, control method for information processing apparatus, and storage medium
JP6454213B2 (ja) 画像出力システム、画像処理装置、画像出力装置、これらにおける方法及びプログラム
EP2388685B1 (en) Information processing apparatus and control method thereof, and storage medium
US9507544B2 (en) Information processing apparatus, recording medium, and control method to process print data using filters
JP2013012033A (ja) プリンタドライバ
US20150160894A1 (en) Information processing apparatus, recording medium, and control method
US9830541B2 (en) Image output system, image output method, document server, and non-transitory computer readable recording medium
US20180253561A1 (en) Information processing apparatus, storage medium, and control method therefor
US8670134B2 (en) Print control apparatus, print control method, and storage medium
US10310788B2 (en) Control method for generating data used for printing and information processing apparatus
US11520536B2 (en) Information processing apparatus, control method and program therefor, and server system capable of communicating with the information processing apparatus
JP5700938B2 (ja) 情報処理装置、情報処理方法及びプログラム
US9990572B2 (en) Information processing apparatus, print data generation method, and storage medium
US9117158B2 (en) Image forming apparatus, image forming method, and non-transitory computer readable medium
JP5734089B2 (ja) 情報処理装置および制御方法およびプログラム
US11775236B2 (en) Information processing apparatus, processing method of information processing apparatus, and storage medium
JP6437076B2 (ja) 情報処理装置及びその制御方法とプログラム
JP4661832B2 (ja) 印刷制御装置およびプリンタドライバのプログラム
JP2003341191A (ja) 印刷制御装置、印刷制御方法、プログラムおよび記憶媒体

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: CANON KABUSHIKI KAISHA, JAPAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MITSUI, AKIHIRO;REEL/FRAME:044349/0355

Effective date: 20170807

STPP Information on status: patent application and granting procedure in general

Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS

STPP Information on status: patent application and granting procedure in general

Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4