Giter Site home page Giter Site logo

jepler / cropgui Goto Github PK

View Code? Open in Web Editor NEW
83.0 8.0 28.0 953 KB

gtk frontend for lossless cropping of jpeg images

License: GNU General Public License v2.0

Python 92.45% Shell 7.55%
crop-image gtk hacktoberfest image image-processing lossless tk tkinter

cropgui's Introduction

A GTK GUI for lossless JPEG cropping

Of the pictures I'd like to put online, I've found that in 75% of the cases where I want to retouch the photo, it's to crop it and nothing else. Since I shoot in jpeg, it's a lossy process to load the jpeg in gimp, crop it, and write the result.

It turns out that debian's jpegtran has a "-crop" flag which performs lossless cropping of jpeg images as long as the crop is to a multiple of what the manpage calls the "iMCU boundary", usually an 8x8 or 16x16 block of pixels. This feature may have been pioneered by Guido of jpegclub.org some years ago.

There's apparently a nice Windows front-end to this program, but I didn't find a Linux one. So I wrote one! It's pretty basic, but it gets the job done. You can download it below.

To run cropgui, either list files on the commandline or select them from a file browser (in the latter case, you're returned to the browser after cropping the selected file(s); hit 'cancel' to exit completely). The output filename is chosen automatically, and never overwrites the original (but it will silently overwrite an earlier cropped version). For example, if the input is "moon.jpg" then the output is "moon-cropped.jpg".

Images are automatically scaled by a power of 2 (e.g., 1/2, 1/4 or 1/8) in order to fit onscreen. While dragging, the cropped image boundary will snap to a multiple of 8 or 16 pixels; this represents the limitation that the upper-left corner must be at a multiple of the iMCU blocks.

PREREQUISITES

cropgui is written in Python and requires the following packages:

  • Debian: python3, python3-pil, python3-pil.imagetk, (python-tkinter, python-imaging, python-imaging-tk on older systems), libjpeg-progs, and libimage-exiftool-perl.
  • Fedora: dnf install python2-pillow libjpeg-turbo-utils pygtk2 pygtk2-libglade ImageMagick and perl-Image-ExifTool python3-pillow-tk.

The specific external programs required are:

  • jpegtran to crop jpeg images (debian package: libjpeg-turbo-progs or libjpeg-progs)
  • exiftool to clear the EXIF rotation flag from jpeg output images (debian package: libimage-exiftool-perl)
  • convert to rotate and crop other image types (debian package: imagemagick or graphicsmagick-imagemagick-compat)
  • magick on Windows (download from ImageMagick and install)

INSTALLATION

Although there are packages in the making, for a system-wide install, first make sure prerequisites are met for your system and the "flavor" of cropgui you want to install. For the GTK version, you may skip the TK dependencies. But make sure jpegtran, exiftool and convert are installed.

Then do this on command line after cloning this repo:

$ sudo bash ./install.sh -p /usr -P /usr/bin/python

Where the -p flag tells install.sh to install to /usr instead of your home dir. And flag -P points to your python binary, which you can find via $ type python. You may set the optional -f flag to switch between tk and gtk (the default) flavor of the app.

Development status

The author (@jepler) is not actively developing this project. Issues and pull requests are not likely to be acted on. I would be interested in passing this project to a new maintainer.

LICENSE

cropgui is available under the terms of the GNU GPL version 2 or later.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.