1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
.. _TextWriter:
================
TextWriter
================
*(New in v1.16.18)* This class represents a MuPDF *text* object. It can be thought of as a collection of text *"spans"*. Each span has its own starting position, font and font size. It is an elegant alternative for writing text to PDF pages, when compared with methods :meth:`Page.insertText` and friends:
* **Improved text positioning:** Choose any point where insertion of a text span should start. Storing a text span returns the coordinates of the *last character* of the span.
* **Free font choice:** Each text span has its own font and fontsize. This lets you easily switch between font and font characteristics when composing a larger text.
* **Automatic fallback fonts:** If a character is not represented by the chosen font, alternative fonts are automatically searched. This significantly reduces the risk of seeing unprintable symbols in the output ("TOFUs"). PyMuPDF now also comes with the **universal font "Droid Sans Fallback Regular"**, which supports **all Latin** characters (incuding Cyrillic and Greek), and **all CJK** characters (Chinese, Japanese, Korean).
* **Cyrillic and Greek Support:** The :ref:`Base-14-fonts` have integrated support of Cyrillic and Greek characters **without specifying encoding.** If your text is a mixture of Latin, Greek and Cyrillic, it will be shown correctly if you just use e.g. font "Helvetica".
* **Transparency support:** Parameter *opacity* is supported. This offers a handy way to create watermark-style text.
* **Justified text:** Supported for any font -- not just simple fonts as in :meth:`Page.insertText`.
* **Reusability:** A TextWriter object exists independent from any page. It can be written multiple times, either to the same or to other pages, in the same or in different PDFs, choosing different colors or transparency.
Using this object entails three steps:
1. When **created**, a TextWriter requires a fixed **page rectangle** in relation to which it calculates text span positions. Text can be written to a page if and only if its size equals that of the TextWriter.
2. Store text in the TextWriter using methods :meth:`TextWriter.append` and :meth:`TextWriter.fillTextbox` as often as desired.
3. Output the TextWriter object on some PDF page with a compatible size.
.. note:: Starting with version 1.17.0, TextWriters **do support** text rotation via the *morph* parameter of :meth:`TextWriter.writeText`.
There also exists :meth:`Page.writeText` which lets you combine one or more TextWriters and jointly write them to a given rectangle and with a given rotation angle -- much like :meth:`Page.showPDFpage`.
**Class API**
.. class:: TextWriter
.. method:: __init__(self, rect, opacity=1, color=None)
:arg rect-like rect: rectangle internally used for text positioning computations.
:arg float opacity: sets the transparency for the text to store here. Values outside the interval ``[0, 1)`` will be ignored. A value of e.g. 0.5 means 50% transparency.
:arg float,sequ color: the color of the text. All colors are specified as floats *0 <= color <= 1*. A single float represents some gray level, a sequence implies the colorspace via its length.
.. method:: append(pos, text, font=None, fontsize=11, language=None)
Add new text, usually (but not necessarily) representing a text span.
:arg point_like pos: start position of the text, the bottom left point of the first character.
:arg str text: a string (Python 2: unicode is mandatory!) of arbitrary length. It will be written starting at position "pos".
:arg font: a :ref:`Font`. If omitted, ``fitz.Font("helv")`` will be used.
:arg float fontsize: the fontsize, a positive number, default 11.
:arg str language: the language to use, e.g. "en" for English. Meaningful values should be compliant with the ISO 639 standards 1, 2, 3 or 5. Reserved for future use: currently has no effect as far as we know.
:returns: :attr:`textRect` and :attr:`lastPoint`.
.. method:: fillTextbox(rect, text, pos=None, font=None, fontsize=11, align=0, warn=True)
Fill a given rectangle with text. This is a convenience method to use as an alternative to :meth:`append`.
:arg rect_like rect: the area to fill. No part of the text will appear outside of this.
:arg str,sequ text: the text. Can be specified as a (UTF-8) string or a list / tuple of strings. A string will first be converted to a list using *splitlines()*. Every list item will begin on a new line (forced line breaks).
:arg point_like pos: *(new in v1.17.3)* start storing at this point. Default is a point near rectangle top-left.
:arg font: the :ref:`Font`, default `fitz.Font("helv")`.
:arg float fontsize: the fontsize.
:arg int align: text alignment. Use one of TEXT_ALIGN_LEFT, TEXT_ALIGN_CENTER, TEXT_ALIGN_RIGHT or TEXT_ALIGN_JUSTIFY.
:arg bool warn: warn on text overflow (default), or raise an exception. In any case, text not fitting will not be written.
.. note:: Use these methods as often as is required -- there is no technical limit (except memory constraints of your system). You can also mix appends and text boxes and have multiple of both. Text positioning is controlled by the insertion point. There is no need to adhere to any order.
.. method:: writeText(page, opacity=None, color=None, morph=None, overlay=True)
Write the TextWriter text to a page.
:arg page: write to this :ref:`Page`.
:arg float opacity: override the value of the TextWriter for this output.
:arg sequ color: override the value of the TextWriter for this output.
:arg sequ morph: modify the text appearance by applying a matrix to it. If provided, this must be a sequence *(fixpoint, matrix)* with a point-like *fixpoint* and a matrix-like *matrix*. A typical example is rotating the text around *fixpoint*.
:arg bool overlay: put in foreground (default) or background.
.. attribute:: textRect
The :ref:`Rect` currently occupied. This value changes when more text is added.
.. attribute:: lastPoint
The "cursor position" -- a :ref:`Point` -- after the last written character (its bottom-right).
.. attribute:: opacity
The text opacity (modifyable).
.. attribute:: color
The text color (modifyable).
.. attribute:: rect
The page rectangle for which this TextWriter was created. Must not be modified.
To see some demo scripts dealing with TextWriter, have a look at `this <https://github.com/pymupdf/PyMuPDF-Utilities/tree/master/textwriter>`_ repository.
.. note::
1. Opacity and color apply to **all the text** in this object.
2. If you need different colors / transpareny, you must create a separate TextWriter. Whenever you determine the color should change, simply append the text to the respective TextWriter using the previously returned :attr:`lastPoint` as position for the new text span.
3. Appending items or text boxes can occur in arbitrary order: only the position parameter controls where text appears.
4. Font and fontsize can freely vary within the same TextWriter. This can be used to let text with different properties appear on the same displayed line: just specify *pos* accordingly, and e.g. set it to :attr:`lastPoint` of the previously added item.
5. You can use the *pos* argument of :meth:`TextWriter.fillTextbox` to indent the first line, so its text may continue any preceeding one in a continuous manner.
|