Skip to content

fliptopbox/shredder

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

shredder

Eats perfectly fine images and spits them out as spaghetti. Shredded beyond recognition.

BEWARE!!! coz it turns images from this ... from this

into this ... not a very nice thing to do, really! into this (FIG1. default settings)

... ah! look! it's been at it again ... or this (FIG2. -o images/920x260_rgb_example_02.png -w 40 -b 80 -t 0.6)

... sorry ... it was born this way this again (FIG3. -o images/920x260_rgb_example_03.png -w 5 -b 1 -t 0)

Usage:

./shredder.py -i <input-image> [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)

#!/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 1

exit 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 a Spanish actress and an old friend, I helped her create a new website. Say hello.

About

Shreds images beyond recognition. Shredded!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages