Ever wanted to make your own custom card game but without the hassle of a craft knife, a rotary cutter, or a paper guillotine? How about making your own proxies to playtest your favorite TCG?
You can do it all with the press of a button and a cutting machine! And I can show you how!
If this is your first time here, check out the tutorial! Please join our Discord server too!
Watch me cut 104 cards in 26 minutes without breaking a sweat!
The purpose of this repo is to enable you to use a Silhouette cutting machine to create card games and proxies. Proxies are only intended to be used for casual play and playtesting.
Proxies should be easily identifiable as proxies. You may not use this repo to create counterfeit cards to decieve people or to play in sanctioned tournaments. You are only permitted to sell cards if you are the full privileged copyright holder.
- documentation
- tutorial
- supply list
- create_pdf.py, a script for laying out your cards in a PDF
- offset_pdy.py, a script for adding an offset to your PDF
- cutting_templates/, a directory containing Silhoutte Studio cutting templates
- calibration/, a directory containing offset calibration sheets
- examples/, a directory containing sample games
- plugins/, a directory containing scripts for streamlining card image acquisition
This project supports the following card and paper sizes, with more in the future:
Format | letter |
tabloid |
a4 |
a3 |
archb |
---|---|---|---|---|---|
standard |
✅ | ✅ | ✅ | ✅ | ✅ |
standard_double |
✅ | ❌ | ✅ | ❌ | ❌ |
japanese |
✅ | ❌ | ✅ | ❌ | ❌ |
poker |
✅ | ✅ | ✅ | ❌ | ❌ |
poker_half |
✅ | ❌ | ✅ | ❌ | ❌ |
bridge |
✅ | ✅ | ✅ | ❌ | ❌ |
bridge_square |
✅ | ❌ | ❌ | ❌ | ❌ |
tarot |
✅ | ✅ | ✅ | ❌ | ❌ |
domino |
✅ | ❌ | ❌ | ❌ | ❌ |
domino_square |
✅ | ✅ | ❌ | ❌ | ❌ |
Card size | Inches | Millimeters | Notes |
---|---|---|---|
standard |
2.48 x 3.46 | 63 x 88 |
|
standard_double |
4.96 x 3.46 | 126 x 88 |
|
japanese |
2.32 x 3.39 | 59 x 86 |
|
poker |
2.5 x 3.5 | 63.5 x 88.9 | |
poker_half |
1.75 x 2.45 | 44.45 x 62.23 | |
bridge |
2.25 x 3.5 | 57.15 x 88.9 | |
bridge_square |
2.25 x 2.25 | 57.15 x 57.15 | |
tarot |
2.75 x 4.75 | 69.85 x 120.65 | |
domino |
1.75 x 3.5 | 44.45 x 88.9 | |
domino_square |
1.75 x 1.75 | 44.45 x 44.45 |
Paper size | Inches | Millimeters |
---|---|---|
letter |
8.5 x 11 | 215.9 x 279.4 |
tabloid |
11 x 17 | 279.4 x 431.8 |
a4 |
8.3 x 11.7 | 210 x 297 |
a3 |
11.7 x 16.5 | 297 x 420 |
archb |
12 x 18 | 304.8 x 457.2 |
You can find all the cutting templates for Silhouette Studio in cutting_templates/
.
If you enjoyed using Silhouette Card Maker, consider donating to help support me and the project. Thank you!
create_pdf.py
is a CLI tool that layouts your card images into a PDF with registration marks that can be cut out with the appropriate cutting template in cutting_templates/
.
Create a Python virtual environment.
python -m venv venv
Activate the Python virtual environment. Terminal (macOS/Linux):
. venv/bin/activate
PowerShell (Windows):
.\venv\Scripts\Activate.ps1
Download Python packages.
pip install -r requirements.txt
Put your front images in the game/front/
folder.
Put your back image in the game/back/
folder.
Run the script.
python create_pdf.py
Get your PDF at game/output/game.pdf
.
Plugins streamline the process for acquiring card images for various games.
The Magic: The Gathering plugin supports various decklist formats, including MTGA, MTGO, Archidekt, Deckstats, Moxfield, and Scryfall.
The Yu-Gi-Oh! plugin supports YDK and YDKE formats.
The Lorcana plugin supports Dreamborn format.
The Riftbound plugin supports Tabletop Simulator, Pixelborn, and Piltover Archive formats.
The Altered plugin supports Ajordat format.
The Netrunner plugin supports *text, bbCode, markdown, plain text, and Jinteki formats.
The Gundam plugin supports DeckPlanet, Limitless TCG, Egman Events, and ExBurst formats.
The Grand Archive plugin supports Omnideck format.
The Digimon plugin supports Tabletop Simulator, Digimoncard.io, Digimoncard.dev, Digimoncard.app, DigimonMeta, and Untap formats.
The One Piece plugin supports OPTCG Simulator and Egman Events formats.
The Flesh and Blood plugin supports Fabrary format.
To create double-sided cards, put front images in the game/front/
folder and back images in the game/double_sided/
folder. The filenames (and file extensions) must match for each pair.
If your card images have rounded corners, they may be missing print bleed in the PDF. Because of the missing print bleed, when the cards are cut, they may have a sliver of white on the corners.
The --extend_corners
option can ameliorate this issue. You may need to experiment with the value but I recommend starting with 10
python create_pdf.py --extend_corners 10
One solution for registration issues is to use a Post-It note to cover up cards near the registration marks.
However, if you would prefer to skip this manual step, you can skip the card near registration marks using the --skip
option.
python create_pdf.py --skip 4
If you cut from the back, you might consider:
python create_pdf.py --skip 0
Usage: create_pdf.py [OPTIONS]
Options:
--front_dir_path TEXT The path to the directory containing the
card fronts. [default: game/front]
--back_dir_path TEXT The path to the directory containing one or
more card backs. [default: game/back]
--double_sided_dir_path TEXT The path to the directory containing card
backs for double-sided cards. [default:
game/double_sided]
--output_path TEXT The desired path to the output PDF.
[default: game/output/game.pdf]
--output_images Create images instead of a PDF.
--card_size [standard|standard_double|japanese|poker|poker_half|bridge|bridge_square|tarot|domino|domino_square]
The desired card size. [default: standard]
--paper_size [letter|tabloid|a4|a3|archb]
The desired paper size. [default: letter]
--only_fronts Only use the card fronts, exclude the card
backs.
--crop TEXT Crop the outer portion of front and double-
sided images. Examples: 3mm, 0.125in, 6.5.
--extend_corners INTEGER RANGE Reduce artifacts produced by rounded corners
in card images. [default: 0; x>=0]
--ppi INTEGER RANGE Pixels per inch (PPI) when creating PDF.
[default: 300; x>=0]
--quality INTEGER RANGE File compression. A higher value corresponds
to better quality and larger file size.
[default: 75; 0<=x<=100]
--load_offset Apply saved offsets. See `offset_pdf.py` for
more information.
--skip INTEGER RANGE Skip a card based on its index. Useful for
registration issues. Examples: 0, 4. [x>=0]
--name TEXT Label each page of the PDF with a name.
--version Show the version and exit.
--help Show this message and exit.
Create poker-sized cards with A4 sized paper.
python create_pdf.py --card_size poker --paper_size a4
Crop the borders of the front and double-sided images by 3 mm on all sides. This option is useful if your images already have print bleed like those from MPCFill.
python create_pdf.py --crop 3mm
Remove the rounded corners from the PDF and load the saved offset from offset_pdf.py
.
python create_pdf.py --extend_corners 10 --load_offset
Produce a 600 pixels per inch (PPI) file with minimal compression.
python create_pdf.py --ppi 600 --quality 100
It's pivotal to ensure that your card fronts and backs are aligned. The front and back alignment is mainly determined by your printer, but it's not always possible to calibrate it.
offset_pdf.py
is a CLI tool that adds an offset to every other page in a PDF. This offset can compensate for the natural offset of your printer, allowing you to have good front and back alignment.
First, you must determine the offset by using the calibration sheets.
<paper size>_calibration.pdf
has a front page and a back page.
The front page is a simple grid of squares.
The back page is the same grid of squares, except each square has a slight offset. The following grid illustrates the applied offsets.
| (-2, -2) | (-1, -2) | ( 0, -2) | ( 1, -2) | ( 2, -2) |
--------------------------------------------------------
| (-2, -1) | (-1, -1) | ( 0, -1) | ( 1, -1) | ( 2, -1) |
--------------------------------------------------------
| (-2, 0) | (-1, 0) | Center | ( 1, 0) | ( 2, 0) |
--------------------------------------------------------
| (-2, 1) | (-1, 1) | ( 0, 1) | ( 1, 1) | ( 2, 1) |
--------------------------------------------------------
| (-2, 2) | (-1, 2) | ( 0, 2) | ( 1, 2) | ( 2, 2) |
To determine the required offset, print out <paper size>_calibration.pdf
with the card stock you plan to use.
Shine a strong light on the front so you can see the shadows on the back. Determine which set of front and back squares are aligned. This set will provide your offset.
Create and start your virtual Python environment and install Python dependencies if you have not done so already. See here for more information.
Run the script with your offset.
python offset_pdf.py --x_offset -5 --y_offset 10
Get your offset PDF at game/output/game_offset.pdf
.
You can save your x and y offset with the --save
option. After saving your offset, it'll be automatically applied every time you run offset_pdf.py
. You can override the loaded offset using --x_offset
and --y_offset
.
python offset_pdf.py --x_offset -5 --y_offset 10 --save
Additionally, you can automatically apply a saved offset in create_pdf.py
by using the --load_offset
option.
python create_pdf.py --load_offset
Usage: offset_pdf.py [OPTIONS]
Options:
--pdf_path TEXT The path of the input PDF.
--output_pdf_path TEXT The desired path of the offset PDF.
-x, --x_offset INTEGER The desired offset in the x-axis.
-y, --y_offset INTEGER The desired offset in the y-axis.
-s, --save Save the x and y offset values.
--ppi INTEGER RANGE Pixels per inch (PPI) when creating PDF. [default:
300; x>=0]
--help Show this message and exit.