parent
15a2a69ac1
commit
024d5b30e1
@ -0,0 +1,372 @@ |
||||
#!/bin/bash |
||||
# |
||||
# Developed by Fred Weinhaus 2/24/2022 .......... revised 2/24/2022 |
||||
# |
||||
# ------------------------------------------------------------------------------ |
||||
# |
||||
# Licensing: |
||||
# |
||||
# Copyright © Fred Weinhaus |
||||
# |
||||
# My scripts are available free of charge for non-commercial use, ONLY. |
||||
# |
||||
# For use of my scripts in commercial (for-profit) environments or |
||||
# non-free applications, please contact me (Fred Weinhaus) for |
||||
# licensing arrangements. My email address is fmw at alink dot net. |
||||
# |
||||
# If you: 1) redistribute, 2) incorporate any of these scripts into other |
||||
# free applications or 3) reprogram them in another scripting language, |
||||
# then you must contact me for permission, especially if the result might |
||||
# be used in a commercial or for-profit environment. |
||||
# |
||||
# My scripts are also subject, in a subordinate manner, to the ImageMagick |
||||
# license, which can be found at: http://www.imagemagick.org/script/license.php |
||||
# |
||||
# ------------------------------------------------------------------------------ |
||||
# |
||||
#### |
||||
# |
||||
# USAGE: position [-m method] [-d direction] [-o offset] [-l leftpt] |
||||
# [-r rightpt] [-b bcolor] [-f format] [-T trim] infile1 infile2 outfile |
||||
# |
||||
# USAGE: position [-h or -help] |
||||
# |
||||
# OPTIONS: |
||||
# |
||||
# -m method positioning method; choices are: offset or cpoints; |
||||
# default=offset |
||||
# -d direction positioning direction; choices are: horizontal or |
||||
# vertical; default=horizontal |
||||
# -o offset offset +X+Y values for left/ope edge of second image |
||||
# relative to right/bottom edge of first image. Used when |
||||
# method=offset; positive or negative offsets are allowed; |
||||
# default=+0+0 |
||||
# -l leftpt left (first) image control x,y point; default=0,0 |
||||
# -r rightpt right (second) image control x,y point; default=0,0 |
||||
# -b bcolor background color to fill empty spaces |
||||
# -f format output color format; choices are: RG, GB, BR or RGB; |
||||
# default=RGB |
||||
# -T trim trim output to remove any background fill areas |
||||
# |
||||
### |
||||
# |
||||
# NAME: POSITION |
||||
# |
||||
# PURPOSE: To position one image relative to another image. |
||||
# |
||||
# DESCRIPTION: POSITION aligns or offsets one image relative to a another |
||||
# image. The second image is positioned relative to the first image either |
||||
# horizontally or vertically. Positioning can be done using X and Y offsets |
||||
# or by specifying one controll point for each image. |
||||
# |
||||
# OPTIONS: |
||||
# |
||||
# -m method ... positioning METHOD. The choices are: offset (o) or cpoints (c). |
||||
# The default=offset. |
||||
# |
||||
# -d direction ... positioning DIRECTION. The choices are: horizontal (h) or |
||||
# vertical (v). The default=horizontal. |
||||
# |
||||
# -o offset ... OFFSET +X+Y values for left/top edge of second image relative |
||||
# to right/bottom edge of first image. This is used when method=offset. |
||||
# Position X and Y offsets may be either positive or negative. The default=+0+0 |
||||
# |
||||
# -l leftpt ... LEFT (first) image control x,y POINT. Values are integers>0. |
||||
# The default=0,0 |
||||
# |
||||
# -r rightpt ... RIGHT (second) image control x,y POINT. Values are integers>0. |
||||
# The default=0,0 |
||||
# |
||||
# -b bcolor ... BGCOLOR is the background color to fill empty spaces. Any |
||||
# Imagemagick color is allowed. The default=none (transparent) |
||||
# |
||||
# -f format ... output color FORMAT; The choices are: RG, GB, BR or RGB. |
||||
# RGB is the normal color image. RG, for example, is first image in Red and |
||||
# second image in Green and any overlay will show in yellow (mix of Red and |
||||
# Green). The default=RGB. |
||||
# |
||||
# -T trim ... TRIM output to remove any background fill areas. |
||||
# Choices are: yes (y) or no (n). The default=no. Background color must be |
||||
# unique in the image for the trim to work properly. |
||||
# |
||||
# LIMITATIONS: TRIM option only works for Imagemagick 7.0.9-0 or higher. |
||||
# |
||||
# CAVEAT: No guarantee that this script will work on all platforms, |
||||
# nor that trapping of inconsistent parameters is complete and |
||||
# foolproof. Use At Your Own Risk. |
||||
# |
||||
###### |
||||
# |
||||
|
||||
# set default values |
||||
method="offset" # offset or cpoints |
||||
direction="horizontal" # horizontal or vertical |
||||
offset=+0+0 # offset |
||||
#offset=-90-40 # offset |
||||
leftpt="0,0" # left image single control point |
||||
rightpt="0,0" # right image single control point |
||||
#leftpt="287,49" # left image single control point |
||||
#rightpt="76,89" # right image single control point |
||||
bcolor=none # background color |
||||
format="RGB" # RG or GB or BR or RGB output color format |
||||
trim="no" # trim output; yes or no |
||||
|
||||
# set directory for temporary files |
||||
tmpdir="/tmp" |
||||
|
||||
# set up functions to report Usage and Usage with Description |
||||
PROGNAME=`type $0 | awk '{print $3}'` # search for executable on path |
||||
PROGDIR=`dirname $PROGNAME` # extract directory of program |
||||
PROGNAME=`basename $PROGNAME` # base name of program |
||||
usage1() |
||||
{ |
||||
echo >&2 "" |
||||
echo >&2 "$PROGNAME:" "$@" |
||||
sed >&2 -e '1,/^####/d; /^###/g; /^#/!q; s/^#//; s/^ //; 4,$p' "$PROGDIR/$PROGNAME" |
||||
} |
||||
usage2() |
||||
{ |
||||
echo >&2 "" |
||||
echo >&2 "$PROGNAME:" "$@" |
||||
sed >&2 -e '1,/^####/d; /^######/g; /^#/!q; s/^#*//; s/^ //; 4,$p' "$PROGDIR/$PROGNAME" |
||||
} |
||||
|
||||
|
||||
# function to report error messages |
||||
errMsg() |
||||
{ |
||||
echo "" |
||||
echo $1 |
||||
echo "" |
||||
usage1 |
||||
exit 1 |
||||
} |
||||
|
||||
|
||||
# function to test for minus at start of value of second part of option 1 or 2 |
||||
checkMinus() |
||||
{ |
||||
test=`echo "$1" | grep -c '^-.*$'` # returns 1 if match; 0 otherwise |
||||
[ $test -eq 1 ] && errMsg "$errorMsg" |
||||
} |
||||
|
||||
# test for correct number of arguments and get values |
||||
if [ $# -eq 0 ] |
||||
then |
||||
# help information |
||||
echo "" |
||||
usage2 |
||||
exit 0 |
||||
elif [ $# -gt 19 ] |
||||
then |
||||
errMsg "--- TOO MANY ARGUMENTS WERE PROVIDED ---" |
||||
else |
||||
while [ $# -gt 0 ] |
||||
do |
||||
# get parameter values |
||||
case "$1" in |
||||
-h|-help) # help information |
||||
echo "" |
||||
usage2 |
||||
exit 0 |
||||
;; |
||||
-m) # method |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID METHOD SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
method=`echo "$1" | tr "[:upper:]" "[:lower:]"` |
||||
case "$method" in |
||||
offset|o) method="offset" ;; |
||||
cpoints|c) method="cpoints" ;; |
||||
*) errMsg "--- METHOD=$method IS AN INVALID VALUE ---" |
||||
esac |
||||
;; |
||||
-d) # direction |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID DIRECTION SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
direction=`echo "$1" | tr "[:upper:]" "[:lower:]"` |
||||
case "$direction" in |
||||
horizontal|h) direction="horizontal" ;; |
||||
vertical|v) direction="vertical" ;; |
||||
*) errMsg "--- DIRECTION=$direction IS AN INVALID VALUE ---" |
||||
esac |
||||
;; |
||||
-o) # offset |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID OFFSET SPECIFICATION ---" |
||||
#checkMinus "$1" |
||||
offset=`expr "$1" : '\([-+][0-9]*[-+][0-9]*\)'` |
||||
[ "$offset" = "" ] && errMsg "--- OFFSET=$offset IS INVALID ---" |
||||
;; |
||||
-l) # leftpt |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID LEFTPT SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
leftpt=`expr "$1" : '\([0-9]*,[0-9]*\)'` |
||||
[ "$leftpt" = "" ] && errMsg "--- LEFTPT=$leftpt IS INVALID ---" |
||||
;; |
||||
-r) # rightpt |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID RIGHTPT SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
rightpt=`expr "$1" : '\([0-9]*,[0-9]*\)'` |
||||
[ "$rightpt" = "" ] && errMsg "--- RIGHTPT=$rightpt IS INVALID ---" |
||||
;; |
||||
-b) # bcolor |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID BCOLOR SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
bcolor="$1" |
||||
;; |
||||
-f) # format |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID FORMAT SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
format=`echo "$1" | tr "[:lower:]" "[:upper:]"` |
||||
case "$format" in |
||||
RG) ;; |
||||
GB) ;; |
||||
BR) ;; |
||||
RGB) ;; |
||||
*) errMsg "--- FORMAT=$format IS AN INVALID VALUE ---" |
||||
esac |
||||
;; |
||||
-T) # trim |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID TRIM SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
trim=`echo "$1" | tr "[:upper:]" "[:lower:]"` |
||||
case "$trim" in |
||||
yes) ;; |
||||
no) ;; |
||||
*) errMsg "--- TRIM=$trim IS AN INVALID VALUE ---" |
||||
esac |
||||
;; |
||||
-) # STDIN and end of arguments |
||||
break |
||||
;; |
||||
-*) # any other - argument |
||||
errMsg "--- UNKNOWN OPTION ---" |
||||
;; |
||||
*) # end of arguments |
||||
break |
||||
;; |
||||
esac |
||||
shift # next option |
||||
done |
||||
# |
||||
# get infiles and outfile |
||||
infile1="$1" |
||||
infile2="$2" |
||||
outfile="$3" |
||||
fi |
||||
|
||||
# test that infile1 provided |
||||
[ "$infile1" = "" ] && errMsg "--- NO INPUT FILE 1 SPECIFIED ---" |
||||
|
||||
# test that infile2 provided |
||||
[ "$infile2" = "" ] && errMsg "--- NO INPUT FILE 2 SPECIFIED ---" |
||||
|
||||
# test that outfile provided |
||||
[ "$outfile" = "" ] && errMsg "--- NO OUTPUT FILE SPECIFIED ---" |
||||
|
||||
|
||||
dir="$tmpdir/POSITION.$$" |
||||
|
||||
mkdir "$dir" || echo "--- FAILED TO CREATE TEMPORARY FILE DIRECTORY ---" |
||||
trap "rm -rf $dir; exit 0" 0 |
||||
trap "rm -rf $dir; exit 1" 1 2 3 15 |
||||
|
||||
# read input images |
||||
# test if infile exists, is readable and is not zero size |
||||
convert -quiet "$infile1" +repage $dir/tmpI1.mpc || |
||||
echo "--- FILE $infile1 DOES NOT EXIST OR IS NOT AN ORDINARY FILE, NOT READABLE OR HAS ZERO SIZE ---" |
||||
|
||||
convert -quiet "$infile2" +repage $dir/tmpI2.mpc || |
||||
echo "--- FILE $infile2 DOES NOT EXIST OR IS NOT AN ORDINARY FILE, NOT READABLE OR HAS ZERO SIZE ---" |
||||
|
||||
# get image1 dimensions |
||||
ww=`convert $dir/tmpI1.mpc -format "%w" info:` |
||||
hh=`convert $dir/tmpI1.mpc -format "%h" info:` |
||||
#echo "ww=$ww; hh=$hh;" |
||||
|
||||
# get page values for second image |
||||
if [ "$method" = "cpoints" ]; then |
||||
lx=`echo "$leftpt" | cut -d, -f1` |
||||
ly=`echo "$leftpt" | cut -d, -f2` |
||||
rx=`echo "$rightpt" | cut -d, -f1` |
||||
ry=`echo "$rightpt" | cut -d, -f2` |
||||
pagex=$((lx-rx)) |
||||
pagey=$((ly-ry)) |
||||
|
||||
else # offsets |
||||
xoff=`echo $offset | sed -n 's/^\([+-].*\)[+-].*$/\1/p'` |
||||
yoff=`echo $offset | sed -n 's/^[+-].*\([+-].*\)$/\1/p'` |
||||
if [ "$direction" = "horizontal" ]; then |
||||
pagex=$((ww+xoff)) |
||||
pagey=$((yoff)) |
||||
else |
||||
# vertical |
||||
pagex=$((xoff)) |
||||
pagey=$((hh+yoff)) |
||||
fi |
||||
fi |
||||
#echo "ww=$ww; hh=$hh; xoff=$xoff; yoff=$yoff; lx=$lx; ly=$ly; rx=$rx; ry=$ry; pagex=$pagex; pagey=$pagey;" |
||||
|
||||
# set up for trim |
||||
[ "$trim" = "yes" ] && trimming="-background $bcolor -define trim:percent-background=0% -trim +repage" |
||||
|
||||
# align the two images |
||||
if [ "$format" = "RG" ]; then |
||||
convert \ |
||||
\( $dir/tmpI1.mpc -colorspace gray -set page +0+0 -write mpr:img1 +delete \) \ |
||||
\( $dir/tmpI2.mpc -colorspace gray -set page +${pagex}+${pagey} -write mpr:img2 +delete \) \ |
||||
\( \( mpr:img2 -background black -colorize 100 \) \( mpr:img1 +level-colors "black,red" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
\( \( mpr:img1 -background black -colorize 100 \) \( mpr:img2 +level-colors "black,green1" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
-compose over -compose blend -composite $trimming \ |
||||
"$outfile" |
||||
|
||||
elif [ "$format" = "GB" ]; then |
||||
convert \ |
||||
\( $dir/tmpI1.mpc -colorspace gray -set page +0+0 -write mpr:img1 +delete \) \ |
||||
\( $dir/tmpI2.mpc -colorspace gray -set page +${pagex}+${pagey} -write mpr:img2 +delete \) \ |
||||
\( \( mpr:img2 -background black -colorize 100 \) \( mpr:img1 +level-colors "black,green1" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
\( \( mpr:img1 -background black -colorize 100 \) \( mpr:img2 +level-colors "black,blue" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
-compose over -compose blend -composite $trimming \ |
||||
"$outfile" |
||||
|
||||
elif [ "$format" = "BR" ]; then |
||||
convert \ |
||||
\( $dir/tmpI1.mpc -colorspace gray -set page +0+0 -write mpr:img1 +delete \) \ |
||||
\( $dir/tmpI2.mpc -colorspace gray -set page +${pagex}+${pagey} -write mpr:img2 +delete \) \ |
||||
\( \( mpr:img2 -background black -colorize 100 \) \( mpr:img1 +level-colors "black,blue" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
\( \( mpr:img1 -background black -colorize 100 \) \( mpr:img2 +level-colors "black,red" \) \ |
||||
-background "$bcolor" -layers merge +repage \) \ |
||||
-compose over -compose blend -composite $trimming \ |
||||
"$outfile" |
||||
|
||||
else # RGB |
||||
convert \ |
||||
\( $dir/tmpI1.mpc -set page +0+0 \) \ |
||||
\( $dir/tmpI2.mpc -set page +${pagex}+${pagey} \) \ |
||||
-background "$bcolor" -layers merge +repage $trimming \ |
||||
"$outfile" |
||||
|
||||
|
||||
fi |
||||
|
||||
exit 0 |
@ -0,0 +1,268 @@ |
||||
#!/bin/bash |
||||
# |
||||
# Developed by Fred Weinhaus revised 6/9/2012 .......... revised 4/25/2015 |
||||
# |
||||
# ------------------------------------------------------------------------------ |
||||
# |
||||
# Licensing: |
||||
# |
||||
# Copyright © Fred Weinhaus |
||||
# |
||||
# My scripts are available free of charge for non-commercial use, ONLY. |
||||
# |
||||
# For use of my scripts in commercial (for-profit) environments or |
||||
# non-free applications, please contact me (Fred Weinhaus) for |
||||
# licensing arrangements. My email address is fmw at alink dot net. |
||||
# |
||||
# If you: 1) redistribute, 2) incorporate any of these scripts into other |
||||
# free applications or 3) reprogram them in another scripting language, |
||||
# then you must contact me for permission, especially if the result might |
||||
# be used in a commercial or for-profit environment. |
||||
# |
||||
# My scripts are also subject, in a subordinate manner, to the ImageMagick |
||||
# license, which can be found at: http://www.imagemagick.org/script/license.php |
||||
# |
||||
# ------------------------------------------------------------------------------ |
||||
# |
||||
#### |
||||
# |
||||
# USAGE: splitcrop [-x xcoord] [-y ycoord] [-L] infile [outfile] |
||||
# USAGE: splitcrop [-h or -help] |
||||
# |
||||
# OPTIONS: |
||||
# |
||||
# -x xcoord x coordinate for split; 0<integer<width; default=center |
||||
# -y xcoord y coordinate for split; 0<integer<height; default=center |
||||
# -L list crop dimensions and offsets to the terminal |
||||
# |
||||
# Note, the output images will be named automatically from the outfile name and |
||||
# suffix. Two or four of the following: _left, _right, _top, _bottom, |
||||
# _topleft, _topright, _bottomleft, _bottomright will be appended before the |
||||
# suffix. If no outfile is provided, then the infile name and suffix will be |
||||
# used for the output. |
||||
# |
||||
### |
||||
# |
||||
# NAME: SPLITCROP |
||||
# |
||||
# PURPOSE: To crop an image into two or four sections according to the given |
||||
# x,y coordinates. |
||||
# |
||||
# DESCRIPTION: SPLITCROP crops an image into two or four sections according to |
||||
# the given x,y coordinates. One or both of the x,y coordinates may be |
||||
# specified. If one coordinate is specified, then the image will be split into |
||||
# two parts. If two coordinate are specified, then the image will be split both |
||||
# ways into four parts. Note that these are coordinates and not sizes. The top, |
||||
# left or topleft section will include the coordinate specified. The size of |
||||
# the split will be the coordinate plus 1. If the image dimension is odd, |
||||
# then the top, left or topleft will contain the extra pixel(s). |
||||
# |
||||
# OPTIONS: |
||||
# |
||||
# -x xcoord ... XCOORD is the x coordinate for the split. Values are |
||||
# 0<integers<width. The default=center of image |
||||
# |
||||
# -y ycoord ... YCOORD is the y coordinate for the split. Values are |
||||
# 0<integers<height. The default=center of image |
||||
# |
||||
# -L ... LIST crop dimensions and offsets to the terminal |
||||
# |
||||
# CAVEAT: No guarantee that this script will work on all platforms, |
||||
# nor that trapping of inconsistent parameters is complete and |
||||
# foolproof. Use At Your Own Risk. |
||||
# |
||||
###### |
||||
# |
||||
|
||||
# set default values |
||||
xcoord="" # x coordinate for split |
||||
ycoord="" # y coordinate for split |
||||
list="off" |
||||
|
||||
# set directory for temporary files |
||||
dir="." # suggestions are dir="." or dir="/tmp" |
||||
|
||||
# set up functions to report Usage and Usage with Description |
||||
PROGNAME="splitcrop" # search for executable on path |
||||
PROGDIR=`dirname $PROGNAME` # extract directory of program |
||||
PROGNAME=`basename $PROGNAME` # base name of program |
||||
usage1() |
||||
{ |
||||
echo >&2 "" |
||||
echo >&2 "$PROGNAME:" "$@" |
||||
sed >&2 -e '1,/^####/d; /^###/g; /^#/!q; s/^#//; s/^ //; 4,$p' "$PROGDIR/$PROGNAME" |
||||
} |
||||
usage2() |
||||
{ |
||||
echo >&2 "" |
||||
echo >&2 "$PROGNAME:" "$@" |
||||
sed >&2 -e '1,/^####/d; /^######/g; /^#/!q; s/^#*//; s/^ //; 4,$p' "$PROGDIR/$PROGNAME" |
||||
} |
||||
|
||||
|
||||
# function to report error messages |
||||
errMsg() |
||||
{ |
||||
echo "" |
||||
echo $1 |
||||
echo "" |
||||
usage1 |
||||
exit 1 |
||||
} |
||||
|
||||
|
||||
# function to test for minus at start of value of second part of option 1 or 2 |
||||
checkMinus() |
||||
{ |
||||
test=`echo "$1" | grep -c '^-.*$'` # returns 1 if match; 0 otherwise |
||||
[ $test -eq 1 ] && errMsg "$errorMsg" |
||||
} |
||||
|
||||
|
||||
# test for correct number of arguments and get values |
||||
if [ $# -eq 0 ] |
||||
then |
||||
# help information |
||||
echo "" |
||||
usage2 |
||||
exit 0 |
||||
elif [ $# -gt 6 ] |
||||
then |
||||
errMsg "--- TOO MANY ARGUMENTS WERE PROVIDED ---" |
||||
else |
||||
while [ $# -gt 0 ] |
||||
do |
||||
# get parameter values |
||||
case "$1" in |
||||
-h|-help) # help information |
||||
echo "" |
||||
usage2 |
||||
exit 0 |
||||
;; |
||||
-x) # get xcoord |
||||
shift # to get the next parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID XCOORD SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
xcoord=`expr "$1" : '\([0-9]*\)'` |
||||
[ "$xcoord" = "" ] && errMsg "--- XCOORD=$xcoord MUST BE A NON-NEGATIVE INTEGER ---" |
||||
;; |
||||
-y) # get ycoord |
||||
shift # to get the neyt parameter |
||||
# test if parameter starts with minus sign |
||||
errorMsg="--- INVALID YCOORD SPECIFICATION ---" |
||||
checkMinus "$1" |
||||
ycoord=`expr "$1" : '\([0-9]*\)'` |
||||
[ "$ycoord" = "" ] && errMsg "--- YCOORD=$ycoord MUST BE A NON-NEGATIVE INTEGER ---" |
||||
;; |
||||
-L) # get list |
||||
list="on" |
||||
;; |
||||
-) # STDIN and end of arguments |
||||
break |
||||
;; |
||||
-*) # any other - argument |
||||
errMsg "--- UNKNOWN OPTION ---" |
||||
;; |
||||
*) # end of arguments |
||||
break |
||||
;; |
||||
esac |
||||
shift # next option |
||||
done |
||||
# |
||||
# get infile and outfile |
||||
infile="$1" |
||||
outfile="$2" |
||||
fi |
||||
|
||||
# test that infile provided |
||||
[ "$infile" = "" ] && errMsg "NO INPUT FILE SPECIFIED" |
||||
|
||||
# test that outfile provided |
||||
|
||||
if [ "$outfile" = "" ]; then |
||||
# separate infile to outname and suffix |
||||
outname=`echo "$infile" | sed -n 's/^\(.*\)[\.].*$/\1/p'` |
||||
suffix=`echo "$infile" | sed -n 's/^.*[\.]\(.*\)$/\1/p'` |
||||
else |
||||
# separate outfile to outname and suffix |
||||
outname=`echo "$outfile" | sed -n 's/^\(.*\)[\.].*$/\1/p'` |
||||
suffix=`echo "$outfile" | sed -n 's/^.*[\.]\(.*\)$/\1/p'` |
||||
fi |
||||
|
||||
# setup temporary images |
||||
tmpA1="$dir/split_A_$$.mpc" |
||||
tmpA2="$dir/split_A_$$.cache" |
||||
trap "rm -f $tmpA1 $tmpA2;" 0 |
||||
trap "rm -f $tmpA1 $tmpA2; exit 1" 1 2 3 15 |
||||
trap "rm -f $tmpA1 $tmpA2; exit 1" ERR |
||||
|
||||
|
||||
# read the input image into the temporary cached image and test if valid |
||||
convert -quiet "$infile" +repage "$tmpA1" || |
||||
errMsg "--- FILE $infile DOES NOT EXIST OR IS NOT AN ORDINARY FILE, NOT READABLE OR HAS ZERO size ---" |
||||
|
||||
|
||||
# get input dimensions |
||||
ww=`convert $tmpA1 -format "%w" info:` |
||||
hh=`convert $tmpA1 -format "%h" info:` |
||||
#echo "ww=$ww; hh=$hh" |
||||
|
||||
x=$xcoord |
||||
y=$ycoord |
||||
|
||||
# trap for no coordinates specified |
||||
if [ "$x" = "" -a "$y" = "" ]; then |
||||
x=`convert xc: -format "%[fx:round($ww/2)-1]" info:` |
||||
y=`convert xc: -format "%[fx:round($hh/2)-1]" info:` |
||||
fi |
||||
|
||||
# trap for coordinates at boundary or outside image |
||||
if [ "$x" != "" ]; then |
||||
( [ $x -eq 0 ] || [ $x -ge $ww ] ) && errMsg "--- INVALID X COORDINATE SPECIFIED ---" |
||||
fi |
||||
if [ "$y" != "" ]; then |
||||
( [ $y -eq 0 ] || [ $y -ge $ww ] ) && errMsg "--- INVALID Y COORDINATE SPECIFIED ---" |
||||
fi |
||||
|
||||
# options depending upon whether x or y or (x and y) specified |
||||
if [ "$x" != "" -a "$y" != "" ]; then |
||||
#split into four parts |
||||
tlsize=`convert xc: -format "%[fx:$x+1]x%[fx:$y+1]+0+0" info:` |
||||
trsize=`convert xc: -format "%[fx:$ww-$x-1]x%[fx:$y+1]+%[fx:$x+1]+0" info:` |
||||
blsize=`convert xc: -format "%[fx:$x+1]x%[fx:$hh-$y-1]+0+%[fx:$y+1]" info:` |
||||
brsize=`convert xc: -format "%[fx:$ww-$x-1]x%[fx:$hh-$y-1]+%[fx:$x+1]+%[fx:$y+1]" info:` |
||||
if [ "$list" = "on" ]; then |
||||
echo "tlsize=$tlsize" |
||||
echo "trsize=$trsize" |
||||
echo "blsize=$blsize" |
||||
echo "brsize=$brsize" |
||||
fi |
||||
convert $tmpA1 -crop $tlsize +repage "${outname}_topleft.$suffix" |
||||
convert $tmpA1 -crop $trsize +repage "${outname}_topright.$suffix" |
||||
convert $tmpA1 -crop $blsize +repage "${outname}_bottomleft.$suffix" |
||||
convert $tmpA1 -crop $brsize +repage "${outname}_bottomright.$suffix" |
||||
elif [ "$x" != "" ]; then |
||||
#split into two parts horizontally |
||||
lsize=`convert xc: -format "%[fx:$x+1]x${hh}+0+0" info:` |
||||
rsize=`convert xc: -format "%[fx:$ww-$x-1]x${hh}+%[fx:$x+1]+0" info:` |
||||
if [ "$list" = "on" ]; then |
||||
echo "lsize=$lsize" |
||||
echo "rsize=$rsize" |
||||
fi |
||||
convert $tmpA1 -crop $lsize +repage "${outname}_left.$suffix" |
||||
convert $tmpA1 -crop $rsize +repage "${outname}_right.$suffix" |
||||
elif [ "$y" != "" ]; then |
||||
#split into two parts vertically |
||||
tsize=`convert xc: -format "${ww}x%[fx:$y+1]+0+0" info:` |
||||
bsize=`convert xc: -format "${ww}x%[fx:$hh-$y-1]+0+%[fx:$y+1]" info:` |
||||
if [ "$list" = "on" ]; then |
||||
echo "tsize=$tsize" |
||||
echo "bsize=$bsize" |
||||
fi |
||||
convert $tmpA1 -crop $tsize +repage "${outname}_top.$suffix" |
||||
convert $tmpA1 -crop $bsize +repage "${outname}_bottom.$suffix" |
||||
fi |
||||
|
||||
exit 0 |
@ -0,0 +1,10 @@ |
||||
#!/usr/bin/env bash |
||||
set -ex |
||||
|
||||
./splitcrop -x $1 -y $1 $2 corners.png |
||||
|
||||
./position -d horizontal corners_bottomright.png corners_bottomleft.png bottom.png |
||||
|
||||
./position -d horizontal corners_topright.png corners_topleft.png top.png |
||||
|
||||
./position -d vertical bottom.png top.png result-grid.png |
Loading…
Reference in new issue