2022-12-15 13:41:19 +01:00
|
|
|
open Pdfutil
|
|
|
|
|
|
|
|
type drawops_colspec =
|
|
|
|
NoCol
|
|
|
|
| RGB of float * float * float
|
|
|
|
| Grey of float
|
|
|
|
| CYMK of float * float * float * float
|
|
|
|
|
|
|
|
type drawops =
|
|
|
|
| Rect of float * float * float * float (* x, y, w, h *)
|
|
|
|
| To of float * float
|
|
|
|
| Line of float * float
|
2022-12-16 14:13:55 +01:00
|
|
|
| ClosePath
|
|
|
|
| SetFill of drawops_colspec
|
|
|
|
| SetStroke of drawops_colspec
|
2022-12-15 15:20:41 +01:00
|
|
|
| SetLineThickness of float
|
|
|
|
| SetLineCap of int
|
|
|
|
| SetLineJoin of int
|
|
|
|
| SetMiterLimit of float
|
|
|
|
| SetDashPattern of float list * float
|
2022-12-16 13:13:38 +01:00
|
|
|
| Matrix of Pdftransform.transform_matrix
|
|
|
|
| Push
|
|
|
|
| Pop
|
2022-12-16 14:13:55 +01:00
|
|
|
| Fill
|
|
|
|
| FillEvenOdd
|
|
|
|
| Stroke
|
|
|
|
| FillStroke
|
|
|
|
| FillStrokeEvenOdd
|
2022-12-16 17:49:59 +01:00
|
|
|
| SoftXObject of drawops list
|
|
|
|
| HardXObject of drawops list
|
2022-12-16 13:13:38 +01:00
|
|
|
|
2022-12-16 17:49:59 +01:00
|
|
|
let rec ops_of_drawop = function
|
2022-12-16 14:13:55 +01:00
|
|
|
| Push -> [Pdfops.Op_q]
|
|
|
|
| Pop -> [Pdfops.Op_Q]
|
2022-12-16 13:13:38 +01:00
|
|
|
| Matrix m -> [Pdfops.Op_cm m]
|
2022-12-15 13:41:19 +01:00
|
|
|
| Rect (x, y, w, h) -> [Pdfops.Op_re (x, y, w, h)]
|
|
|
|
| To (x, y) -> [Pdfops.Op_m (x, y)]
|
|
|
|
| Line (x, y) -> [Pdfops.Op_l (x, y)]
|
2022-12-16 14:13:55 +01:00
|
|
|
| SetFill x ->
|
2022-12-15 13:41:19 +01:00
|
|
|
begin match x with
|
|
|
|
| RGB (r, g, b) -> [Op_rg (r, g, b)]
|
|
|
|
| Grey g -> [Op_g g]
|
|
|
|
| CYMK (c, y, m, k) -> [Op_k (c, y, m, k)]
|
|
|
|
| NoCol -> []
|
|
|
|
end
|
2022-12-16 14:13:55 +01:00
|
|
|
| SetStroke x ->
|
2022-12-15 13:41:19 +01:00
|
|
|
begin match x with
|
|
|
|
| RGB (r, g, b) -> [Op_RG (r, g, b)]
|
|
|
|
| Grey g -> [Op_G g]
|
|
|
|
| CYMK (c, y, m, k) -> [Op_K (c, y, m, k)]
|
|
|
|
| NoCol -> []
|
|
|
|
end
|
2022-12-16 14:13:55 +01:00
|
|
|
| ClosePath
|
|
|
|
| Fill -> [Pdfops.Op_f]
|
|
|
|
| FillEvenOdd -> [Pdfops.Op_f']
|
|
|
|
| Stroke -> [Pdfops.Op_S]
|
|
|
|
| FillStroke -> [Pdfops.Op_B]
|
|
|
|
| FillStrokeEvenOdd -> [Pdfops.Op_B']
|
|
|
|
| SetLineThickness t -> [Pdfops.Op_w t]
|
|
|
|
| SetLineCap c -> [Pdfops.Op_J c]
|
|
|
|
| SetLineJoin j -> [Pdfops.Op_j j]
|
|
|
|
| SetMiterLimit m -> [Pdfops.Op_M m]
|
|
|
|
| SetDashPattern (x, y) -> [Pdfops.Op_d (x, y)]
|
2022-12-16 17:49:59 +01:00
|
|
|
| SoftXObject l | HardXObject l ->
|
|
|
|
[Pdfops.Op_q] @ ops_of_drawops l @ [Pdfops.Op_Q]
|
2022-12-15 13:41:19 +01:00
|
|
|
|
2022-12-16 17:49:59 +01:00
|
|
|
and ops_of_drawops drawops =
|
|
|
|
flatten (map ops_of_drawop drawops)
|
2022-12-15 13:41:19 +01:00
|
|
|
|
|
|
|
(* Draw all the accumulated operators *)
|
|
|
|
let draw fast range pdf drawops =
|
|
|
|
let s = Pdfops.string_of_ops (ops_of_drawops drawops) in
|
|
|
|
Cpdftweak.append_page_content s false fast range pdf
|