-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmarkvid.sh
190 lines (162 loc) · 5.23 KB
/
markvid.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
#!/bin/bash
# ---------------------------------------------------------------------------
# markvid - Add a watermark image to a video. You do not need to know the
# dimensions of the video or the watermark image, just how far from the
# lower-right corner you want the watermark to be. A new video will be output
# with "-marked" appended to the file name.
#
# This is barely more than an alias, but is a lot easier than remembering all
# the configuration parameters.
#
# This script requires ffmpeg to be installed: https://ffmpeg.org
# Copyright 2021, Ivan Boothe <[email protected]>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License at <http://www.gnu.org/licenses/> for
# more details.
# USAGE
#
# $ ./markvid.sh <VIDEOFILE> <WATERMARKFILE> <PIXELDIST>
# $ ./markvid.sh [-h|--help]
# EXAMPLES
#
# Run the script with a path to the video, a path to the watermark file, and the
# distance (in pixels) you want the watermark to appear from the lower-right
# corner.
#
# $ ./markvid.sh video.mp4 watermark.png 10
# > [ffmpeg reports conversion progress]
# > Done. Video created at video-marked.mp4
# RESOURCES
#
# https://gist.github.com/bennylope/d5d6029fb63648582fed2367ae23cfd6
# https://ffmpeg.org/ffmpeg-filters.html#overlay-1
# Revision history:
# 2021-11-29 Updating license (1.2)
# 2021-10-15 Adding help, dependency checks, and other standardization (1.1)
# 2021-10-06 Initial release (1.0)
# ---------------------------------------------------------------------------
# Standard variables
PROGNAME=${0##*/}
VERSION="1.2"
red=$(tput setaf 1)
green=$(tput setaf 2)
yellow=$(tput setaf 3)
cyan=$(tput setaf 6)
bold=$(tput bold)
reset=$(tput sgr0)
# Error handling
error_exit() {
local error_message="${red}$1${reset}"
printf "%s\n" "${PROGNAME}: ${error_message:-"Unknown Error"}" >&2
exit 1
}
graceful_exit() {
exit 0
}
signal_exit() {
local signal="$1"
case "$signal" in
INT)
error_exit "${yellow}Program interrupted by user.${reset}"
;;
TERM)
printf "\n%s\n" "${red}$PROGNAME: Program terminated.${reset}" >&2
graceful_exit
;;
*)
error_exit "${red}$PROGNAME: Terminating on unknown signal.${reset}"
;;
esac
}
# Usage: Separate lines for mutually exclusive options.
usage() {
printf "%s\n" \
"${bold}Usage:${reset} ${PROGNAME} <VIDEOFILE> <WATERMARKFILE> <PIXELDIST>"
printf "%s\n" \
" ${PROGNAME} [-h|--help]"
}
# Help message for --help
help_message() {
cat <<-_EOF_
${bold}${PROGNAME} ${VERSION}${reset}
${cyan}
Add a watermark image to a video. You do not need to know the dimensions of the
video or the watermark image, just how far from the lower-right corner you want
the watermark to be. A new video will be output with "-marked" appended to the
file name.
This is barely more than an alias, but is a lot easier than remembering all the
configuration parameters.${reset}
$(usage)
${bold}Options:${reset}
-h, --help Display this help message and exit.
${bold}Examples:${reset}
Run the script with a path to the video, a path to the watermark file, and the
distance (in pixels) you want the watermark to appear from the lower-right
corner.
${green}$ ${PROGNAME} video.mp4 watermark.png 10${reset}
> [ffmpeg reports conversion progress]
> Done. Video created at video-marked.mp4
_EOF_
}
# Options and flags from command line
while getopts :-:h OPT; do
if [ "$OPT" = "-" ]; then
OPT="${OPTARG%%=*}" # extract long option name
OPTARG="${OPTARG#$OPT}" # extract long option argument (may be empty)
OPTARG="${OPTARG#=}" # remove assigning `=`
fi
case "$OPT" in
h | help)
help_message
graceful_exit
;;
??*) # bad long option
usage >&2
error_exit "Unknown option --$OPT"
;;
?) # bad short option
usage >&2
error_exit "Unknown option -$OPTARG"
;;
esac
done
shift $((OPTIND - 1)) # remove parsed options and args from $@ list
# Program variables
file=$1
name="${1%.*}"
ext="${1##*.}"
wm=$2
dist=$3
if [[ ! $file ]]; then
usage >&2
error_exit "Video filename must be provided."
fi
if [[ ! $wm ]]; then
usage >&2
error_exit "Watermark filename must be provided."
fi
if [[ ! $dist ]]; then
usage >&2
error_exit "Distance (in pixels) must be provided."
fi
# Dependencies
ffmpeg=$(command -v ffmpeg)
if [[ ! $ffmpeg ]]; then
error_exit "Ffmpeg must be installed <https://ffmpeg.org>. Aborting."
fi
if [ -f "${file}" ]; then # Make sure video file exists
if [ -f "${wm}" ]; then # Make sure watermark file exists
"$ffmpeg" -v quiet -stats -i "$file" -i "$wm" -filter_complex "overlay=main_w-overlay_w-${dist}:main_h-overlay_h-${dist}" "${name}"-marked."${ext}"
printf "%s\n" "${green}Done. Video created at: ${reset}${bold}${name}-marked.${ext}${reset}"
else
error_exit "Watermark file '${wm}' not found."
fi
else
error_exit "Video file '${file}' not found."
fi