Skip to main content

Cut a picture into pieces by cutting along pixel lines

Project description

Pixsaw

Cuts an image up into multiple pieces by following pixel lines that contrast with targeted piece color. Most pixels are kept in the process since very fine saw blades are used.

Try out by running the pixsaw.sh script that will prompt for necessary options and run pixsaw inside a docker container. It will use the files in the examples directory by default.

# Build and run using docker
./pixsaw.sh

Installing

Requires:

Install with pip in editable mode for developing and use virtualenv to isolate python dependencies::

python3 -m venv .venv
source .venv/bin/activate
pip install -e .

Usage

Running the pixsaw script will show some help. It basically needs a path to a directory to store the generated files, an image that shows where to cut, and the image that should be cut into pieces.

Example

mkdir tmp-small-puzzle-example
pixsaw --dir tmp-small-puzzle-example --lines examples/small-puzzle-lines.png examples/320px-White_Spoon_Osteospermum.jpg

The puzzle lines

Image example

Image from: http://en.wikipedia.org/wiki/File:White_Spoon_Osteospermum.JPG

The output (combined into one file with glue to better show it):

Output of pixsaw

Contributing

Please contact me or create an issue.

Any submitted changes to this project require the commits to be signed off with the git command option '--signoff'. This ensures that the committer has the rights to submit the changes under the project's license and agrees to the Developer Certificate of Origin.

License

GNU Lesser General Public License v3.0

Maintenance

Where possible, an upkeep comment has been added to various parts of the source code. These are known areas that will require updates over time to reduce software rot. The upkeep comment follows this pattern to make it easier for commands like grep to find these comments.

Example UPKEEP comment has at least a 'due:' or 'label:' or 'interval:' value surrounded by double quotes (").

Example-> # UPKEEP due: "2022-12-14" label: "an example upkeep label" interval: "+4 months"

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pixsaw-0.6.1.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pixsaw-0.6.1-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file pixsaw-0.6.1.tar.gz.

File metadata

  • Download URL: pixsaw-0.6.1.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pixsaw-0.6.1.tar.gz
Algorithm Hash digest
SHA256 35d60dfa8c325b076cd6d060e5bdec8b59e8e56980dccf2511b93c906512cdd4
MD5 7387768c59db8278a815ecdfc66dcfe3
BLAKE2b-256 9336e466ac76bd10c980a7fd73955771cd00af942a0f333e8880d22a86bc5822

See more details on using hashes here.

File details

Details for the file pixsaw-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: pixsaw-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pixsaw-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d456cc6d96c121466114cdaa9163ddefa4dd1bc03244b4f6ae2b934b8e96aff3
MD5 30396f8c5d157ead8aed3d8b7e798108
BLAKE2b-256 efce2290e78b1184c3027d1facaef6457d60daffcc5a9539e20004efd8068dc9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page