Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fliptopbox/shredder
Shreds images beyond recognition. Shredded!
https://github.com/fliptopbox/shredder
Last synced: 4 days ago
JSON representation
Shreds images beyond recognition. Shredded!
- Host: GitHub
- URL: https://github.com/fliptopbox/shredder
- Owner: fliptopbox
- Created: 2018-05-20T12:08:12.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2020-04-04T18:08:59.000Z (almost 5 years ago)
- Last Synced: 2024-11-08T16:34:46.711Z (about 2 months ago)
- Language: Jupyter Notebook
- Size: 18.4 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# shredder
_Eats perfectly fine images and spits them out as spaghetti. Shredded beyond recognition._
**BEWARE!!! coz it turns images from this ...**
![from this](images/920x260_rgb_example.png)**into this ... not a very nice thing to do, really!**
![into this](images/920x260_rgb_example_shredded.png)
(FIG1. default settings)**... ah! look! it's been at it again ...**
![or this](images/920x260_rgb_example_02.png)
(FIG2. -o images/920x260_rgb_example_02.png -w 40 -b 80 -t 0.6)**... sorry ... it was born this way**
![this again](images/920x260_rgb_example_03.png)
(FIG3. -o images/920x260_rgb_example_03.png -w 5 -b 1 -t 0)## Usage:
./shredder.py -i [options]
## Options
| argument | type | def | comment |
| -------------- | ----------- | ---- | --------------------------------------- |
| -i, --input=* | filename | | image file name (PNG recommended) |
| -o, --output=* | filename | | input file name plus "_shredded" suffix |
| -w, --width=* | int (px) | 20 | width of the slices |
| -b, --border=* | int (px) | 1 | width of the edge border |
| -t, --tint=* | float (0-1) | 0.9 | 0 = black, 1 = transparent |## Dependancies
- Python3 - v3.6+
- OpenCV - v4.2.0-2 - Arch AUR: `yay -Syu opencv`
- Numpy - v1.18.2 +## Usefull application ... Anyone?
There is none. This is a silly useless script to waste my ... oh hang on.
- Do you use i3 window manager?
- Do you use i3lock to prevent people from fiddling?
- Do you know what `scrot` or `maim` is used for?
- Do you need a new rice?If you answered those question with a majority YES, then you know what this script is good for.
## Use with the i3lock (on Manjaro i3)
First install all the python dependencies as global modules `sudo pip3 install numpy opencv-python` then copy `shredder.py` to the `/usr/bin/`directory, using sudo so that the script has execute permission.
Finally open `/usr/bin/blurlock` and make it look like this ... (I have kept the original code in comments)
```bash
#!/bin/bash
# on Manjaro (Arch) this file lives in ...
# /usr/bin/blurlock# The import program is a member of the ImageMagick(1) suite of tools.
import -window root /tmp/screenshot.png# Shredder it ... :D - /usr/bin/shredder.py requires execute permission
python /usr/bin/shredder.py -i /tmp/screenshot.png -w 80 -b 4 -t 0.85# Lock the screen using the new image
i3lock -i /tmp/screenshot_shredded.png# Sleep 1 adds a small delay to prevent possible race conditions with suspend
sleep 1exit 0
```
## ... and what is the _"shredder.sh"_ file ... ?
Ah! yes, you caught me. The bash script was the original solution.
It uses ImageMagick to cut up an image into pieces, these are saved in a working folder, with a random numeric filename.
When the slicing is done, we use IM again, to stitch all the images back together. The random filenames result in the file system ordering then, and in affect it shuffles the original sequence. Cute idea right? Unfortunately it is VERY slow, well compared to vector maths with openCV and numpy ... it's slow.So I abandoned that approach in favour of python. Have a look at the jupyter notebook, that was also fun to work with. I wish web dev had something as easy as that.
The disadvantage of the python is the dependencies. It was a bitch to get openCV installed. But that being done, it is a dream to work with. Anyway that is the story.
Looking at the number of lines, bash is the winner. Use which ever you like.
## ... and lastly ... who is the girl?
[Ivana Miño](http://ivanamino.com/) a Spanish actress and an old friend, I helped her create a new website. Say hello.