Module Cpdfpage

module Cpdfpage: sig .. end

Working with pages


val output_page_info : ?json:bool -> ?raisejson:bool -> Pdfunits.t -> Pdf.t -> int list -> unit

Print page info (Mediabox etc) to standard output.

val json_page_info : Pdf.t -> int list -> Pdfunits.t -> Cpdfyojson.Safe.t

Return page info for selected pages in JSON format.

val process_pages : (int -> Pdfpage.t -> Pdfpage.t * int * Pdftransform.transform_matrix) ->
Pdf.t -> int list -> Pdf.t

Given a function from page number and page to page, a document, and a list of page numbers to apply it to, apply the function to all those pages.

val iter_pages : (int -> Pdfpage.t -> unit) -> Pdf.t -> int list -> unit

Same as process_pages, but iterate rather than map.

val map_pages : (int -> Pdfpage.t -> 'a) -> Pdf.t -> int list -> 'a list

Same as process_pages but return the list of outputs of the map function.

val hard_box : Pdf.t -> int list -> string -> bool -> bool -> Pdf.t

Clip a page to one of its boxes, or the media box if that box is not present. This is a hard clip, done by using a clipping rectangle, so that the page may then be used as a stamp without extraneous material reapearing.

val shift_pdf : ?fast:bool -> (float * float) list -> Pdf.t -> int list -> Pdf.t

Shift a PDF in x and y (in pts) in the given pages. List of (x, y) pairs is for all pages in pdf.

val shift_boxes : (float * float) list -> Pdf.t -> int list -> Pdf.t

Shift a PDF's boxes in x and y (in pts) in the given pages. List of (x, y) pairs is for all pages in pdf.

val rectify_boxes : ?fast:bool -> Pdf.t -> Pdfpage.t -> Pdfpage.t

Change a page's media box so its minimum x and y are 0, making other operations simpler to think about. Any shift that is done is reflected in other boxes (clip etc.)

val change_boxes : (float * float * float * float -> float * float * float * float) ->
Pdf.t -> Pdfpage.t -> Pdfpage.t

Change the media box and other known boxes by a function which takes xmin, xmax, ymin, ymax as input.

val scale_contents : ?fast:bool -> Cpdfposition.position -> float -> Pdf.t -> int list -> Pdf.t

Scale the contents of a page by a given factor centred around a given point in a given range.

val set_mediabox : (float * float * float * float) list -> Pdf.t -> int list -> Pdf.t

set_mediabox xywhlist pdf range sets the media box on the given pages.

val remove_cropping_pdf : Pdf.t -> int list -> Pdf.t

Remove any cropping from the given pages.

val remove_trim_pdf : Pdf.t -> int list -> Pdf.t

Remove any trim box from the given pages.

val remove_bleed_pdf : Pdf.t -> int list -> Pdf.t

Remove any bleed box from the given pages.

val remove_art_pdf : Pdf.t -> int list -> Pdf.t

Remove any art box from the given pages.

val upright : ?fast:bool -> int list -> Pdf.t -> Pdf.t

Modify the rotation of the page and its contents to leave the rotation at 0 with the page effectively unaltered.

val rotate_pdf : int -> Pdf.t -> int list -> Pdf.t

Change rotation to a given value 0, 90, 180, 270 on given pages.

val rotate_pdf_by : int -> Pdf.t -> int list -> Pdf.t

Rotate clockwise by 0, 90, 180, 270 on given pages.

val rotate_contents : ?fast:bool -> float -> Pdf.t -> int list -> Pdf.t

Rotate the contents by the given angle on the given pages. If fast is true, assume PDF is well-formed.

val scale_pdf : ?fast:bool -> (float * float) list -> Pdf.t -> int list -> Pdf.t

Scale a PDF in sx, sy in the given pages. List of (sx, sy) pairs is for all pages in pdf.

val scale_to_fit_pdf : ?fast:bool ->
Cpdfposition.position ->
float -> (float * float) list -> 'a -> Pdf.t -> int list -> Pdf.t

scale_to_fit_pdf fast position input_scale x y op pdf range scales a page to fit the page size given by (x, y) and by the input_scale (e.g 1.0 = scale to fit, 0.9 = scale to fit leaving a border etc.). op is unused.

val stretch : ?fast:bool -> (float * float) list -> Pdf.t -> int list -> Pdf.t
val center_to_fit : (float * float) list -> Pdf.t -> int list -> Pdf.t

Stamping

val combine_pages : bool -> Pdf.t -> Pdf.t -> bool -> bool -> bool -> Pdf.t

combine_pages fast under over scaletofit swap equalize combines the page content of two PDFs, page-by-page. If equalize is true the output will have the same number of pages as the shorter file. If scaletofit is true, the over file will be scaled to fit. If swap is true, over and under are swapped. If fast is true, the PDFs are assumed to be well-formed and no fixes are done.

val stamp : bool ->
Cpdfposition.position ->
bool -> bool -> bool -> bool -> bool -> int list -> Pdf.t -> Pdf.t -> Pdf.t

stamp relative_to_cropbox position topline midline fast scale_to_fit isover range over pdf stamps the first page of over over each page of the PDF. The arguments have the same meaning as in combine_pages.

Page geometry

val hasbox : Pdf.t -> int -> string -> bool

True if a given page in a PDF has a given box

val crop_pdf : ?box:string ->
(float * float * float * float) list -> Pdf.t -> int list -> Pdf.t

crop_pdf xywhlist pdf range sets the cropbox on the given pages.

val setBox : string -> float -> float -> float -> float -> Pdf.t -> int list -> Pdf.t

setBox boxname x y w h pdf range sets the given box on the given pages.

val vflip_pdf : ?fast:bool -> Pdf.t -> int list -> Pdf.t

Flip the given pages vertically

val hflip_pdf : ?fast:bool -> Pdf.t -> int list -> Pdf.t

Flip the given pages horizontally

val trim_marks : ?fast:bool -> Pdf.t -> int list -> Pdf.t

Add trim marks.

val show_boxes : ?fast:bool -> Pdf.t -> int list -> Pdf.t

Show the page boxes for debug.

val copy_box : string -> string -> bool -> Pdf.t -> int list -> Pdf.t

Copy one box to another in the given pages.

val allupright : int list -> Pdf.t -> bool

True if all pages are "upright" i.e no rotation and (0,0)-based.

val alluprightonly : int list -> Pdf.t -> bool

True if all pages are "upright" i.e no rotation.

val change_pattern_matrices_page : Pdf.t -> Pdftransform.transform_matrix -> Pdfpage.t -> Pdfpage.t

When a page is transformed, its patterns must be too.

val redact : process_struct_tree:bool -> Pdf.t -> int list -> Pdf.t