What happens, if you give your visiting card to someone? Either he manually types the text into his computer or mobilefone, or it will end up in a box and be forgotten. Nowadays data is required electronically, not on paper. Here is the solution: A visiting card with QR-Code that contains a full [vcard], so that it can be scanned with an [app] on the mobilefone and therefore automatically imported into the electronic contacts. This also works well, when you are offline and bluetooth transfer fails. So here is the highly configurable businescard or visitingcards with full [vcard] as QR-Code, ready to send to online printers. You can specify the exact size of the paper and the content within the paper, inluding generation of crop marks.
Other available visitingcard templates, such as [mschlenker] distribute the cards on an A4 paper. But if you want a professional printer, such as [onlineprinters], then you need to be able to generate a PDF with exactly one card, an exactly defined border and crop marks.
[](examples/john-doe-hongkong.tex)
[](examples/peter-muster-example-company-zuerich.tex)
[](examples/example.tex)
- full privacy control: input is optional, specify only what you need, you decide what information to share, e.g. I print three cards, with phone and address, without address and only with electronical contacts, no phone nor address
- optional icons, optional small hint texts
- several alignments
- freely defined size of paper and content
- supports honoric titles, full names, address with post office box and extended information
- supports telefone, email, [jabber] and [matrix] chat
**Important:** You must use **`xelatex`** for compilation, because `xelatex` properly supports UTF-8 (e.g. needed for german umlauts or chinese characters). The package `inputenc` messes up with package `qrcode`.
Note for iOS: vCard content inside the QR now uses CRLF line endings (per spec) to improve import robustness on iOS without changing the vCard version (still 4.0 by default). Also the QR error correction level can be configured.
-`paperwidth=`: width of the physical paper where the card is printed on (incl. border), default: `89mm`
-`paperheight=`: height of the physical paper where the card is printed on (incl. border), default: `59mm`
-`contentwidth=`: width of the card's content without the border that is cut, default: `85mm`
-`contentheight=`: height of the card's content without the border that is cut, default: `55mm`
-`fontsize=`: any fontsize allowed in `extarticle`, that are `8pt`, `9pt`, `10pt`, `11pt`, `12pt`, `14pt`, `17pt` and `20pt`, default: `8pt`
-`padding=`: padding within the card's content, default: `2mm`
-`cutdist=`: distance in `mm` where the cut marks are set, default: `2`
-`cutlen=`: length of the cut marks in `mm`, default: `1`
-`textwidth=`: relative width of the text block `1` means full width, so `qrwidth` plus `textwidth` should be smaller than `1` the remainig space is left empty between the text and QR-Code, default: `0.55` (that's 55% of the available space)
-`qrwidth=`: relative width of the QR-Code `1` means full width, so `qrwidth` plus `textwidth` should be smaller than `1` the remainig space is left empty between the text and QR-Code, default: `0.40` (that's 40% of the available space)
-`lang=`: language of the wikipedia page, will be prepended before `wikipedia.org`, e.g. `de.wikipedia.org`, default: `de`
-`address`or `noaddress`: disable rendering of the address in text and QR-Code, default: address
-`hint` or `nohint`: show the little text hints, default: `hint`
-`icon` or `noicon`: show the icons, default: `icon`
-`rightalign` or `leftalign`: align text left or right, default: `rightalign`
-`iconleft` or `iconright`: show icon left or right of the text, default: `iconleft`
-`fill` or `nofill`: fill empty space between icon and text, default: `fill`
-`qrfirst` or `textfirst`: switch position of QR-Code and text block, default: `qrfirst`
-`https` or `www`: should links in the hints be prefixed with `https://` or `www.`, default: `https`
-`countryformat=`: how to format the country in address. Values: `auto` (default: inline with mdash if <4 chars and city/zip exists), `inline` (always inline with mdash), `below` (always separate line)
-`qreclevel=`: QR error correction level `L` (~7%), `M` (~15%), `Q` (~25%), or `H` (~30%), default: `Q`. Use `H` when `photoinqr=true`.
-`photoinqr` or `nophotoinqr`: place photo in the center of the QR code (`photoinqr`) instead of next to the name, default: `nophotoinqr`. **Requires `qreclevel=H` for reliable scanning**.
-`qrlogoscale=`: photo size in QR code as fraction of QR width (1.0 = 100%), default: `0.25` (25% width). Recommended values: Level H: 0.25-0.3, Level Q: 0.2, Level M: 0.15, Level L: 0.1. Higher values may reduce scannability.
-`qrlogoborder=`: transparent padding around photo in QR code as fraction of QR width (1.0 = 100%), default: `0.02` (2%). Adds space between photo and QR modules.
-`photoscale=`: scale factor for photo next to name (1.0 = 100% of name height), default: `1.0`. Use values like `2.0` or `2.5` for larger photos.
-`bgscale=`: background image scale factor (1.0 = 100% of card height), default: `1.0`. Use values like `1.5` or `2.0` for zoomed/cropped backgrounds. Only affects images, not colors.
-`bgopacity=`: background image opacity/transparency (1.0 = 100% visible, 0.0 = invisible), default: `1.0`. Use lower values like `0.2` or `0.3` to fade the background so text remains readable. Only affects images, not colors.
-`qrbgopacity=`: QR code background opacity (1.0 = solid white, 0.0 = transparent), default: `1.0`. White background behind QR code ensures scannability over background images. Use `0.0` for no background or lower values like `0.8` for semi-transparent.
Your data is entered with commands in the document, e.g.:
\email{name@example.com}
**Important:**: Spaces *must* be escaped by a backslash `\` in all data definitions, if they should be kept in the QR-Code. This is a limitation of the `qrcode`-package- Without escaping `\`, spaces are show in the text block, but not in the QR-Code. You may make use of this feature, if you do not escape the spaces in `\phone` and `\pgpfingerprint`, but everywhere else. This way, phone number and pgp fingerprint are condensed in the QR-Code.
-`\country`: full name of country of the address in the language of the card (short codes like `CH`, `USA`, `D` are automatically placed inline with mdash before city/zip, longer names on separate line)
-`\phone`: your phone number, the phone is marked as mobile, so to be used for voice and text (SMS)
-`\email`: your email address
-`\jabber`: your [jabber] or xmpp chat address
-`\matrixorg`: your [matrix] chat addres, hint: use [riot] messenger for [matrix]
-`\cloud`: your [nextcloud federation id] — the url is prepended automatically
-`\homepage`: url to a web site with «home» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\world`: url to a web site with «world» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\link`: url to a web site with «link» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\wordpress`: url to a web site with «wordpress» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\drupal`: url to a web site with «» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\joomla`: url to a web site with «joomla» icon — without `https://` not `www` (unless it is required), this is prepended automatically
-`\wikipedia`: if you or your company have a [wikipedia] entry, specify documentclass option `lang` for the language of you entry and use this definition for the name of your page — the url is prepended automatically
-`\git`: the url of your [git] repository — without `https://` not `www` (unless it is required), this is prepended automatically
-`\gitea`: the url of your [gitea] project page, you can use this tag also for other project management sites, such as [gogs] — without `https://` not `www` (unless it is required), this is prepended automatically
-`\github`: your account name on [github] — only the name of the account, the url is prepended automatically
-`\facebook`: your account name on [facebook] or the name of your page — only the name of the account or page, the url is prepended automatically
-`\twitter`: your account name on [twitter] — only the name of the account, the url is prepended automatically
-`\youtube`: your account name on [youtube] — only the name of the account, the url is prepended automatically
-`\google`: your account name on [google+] — only the name of the account, the url is prepended automatically
-`\pgpurl`: the full url to your pgp public key (only added to the QR-Code, not shown in the text)
-`\pgpfingerprint`: the fingerprint of your pgp public key
-`\photo`: path to photo file (PNG, JPG, etc.) for display next to name or in QR code (if `photoinqr` option is set)
-`\background`: path to background image file or color name (e.g., `yellow!20`, `blue!10`). If file exists, it's used as image; otherwise treated as color.
The card is designed for professional printing service, such as [onlineprinters]. Please *check* the card and the *QR-Code* well before you pay money for printing! Choose a format, default is `89mm×59mm` with 2mm boder, so the card content is `85mm×55mm`. But the card can be adapted to any other printing format. To print cards of size `10cm×5cm` with `2mm` cut, you specify, [e.g.](examples/special-papersize.tex):
You can add an optional photo that appears next to the name or in the center of the QR code. The photo is dynamically scaled to match the name line height (when next to name) or to 25% of the QR code width (when in QR).
Note: Use `bgopacity` to fade the background (e.g., `0.2` or `0.3`) so text remains readable. The QR code has a white background by default (`qrbgopacity=1.0`) to ensure scannability.
If you are missing a feature or a configuration option, consult the [project] page. Just open a [ticket] and the [author] will care about it. Or extend it, it's [lgpl].