image: Performance improvements
This commit is contained in:
parent
ffe94c26ee
commit
ae7271578a
1 changed files with 48 additions and 40 deletions
88
neofetch
88
neofetch
|
@ -3594,22 +3594,20 @@ get_term_size() {
|
||||||
# Tmux has a special way of reading escape sequences
|
# Tmux has a special way of reading escape sequences
|
||||||
# so we have to use a slightly different sequence to
|
# so we have to use a slightly different sequence to
|
||||||
# get the terminal size.
|
# get the terminal size.
|
||||||
if [[ -n "$TMUX" ]]; then
|
if [[ "$image_backend" == "tycat" ]]; then
|
||||||
printf "%b" "\ePtmux;\e\e[14t\e\e[c\e\\"
|
printf '%b' '\e}qs\000'
|
||||||
read_flags=(-d c)
|
|
||||||
|
|
||||||
elif [[ "$image_backend" == "tycat" ]]; then
|
|
||||||
printf "%b" "\e}qs\000"
|
|
||||||
|
|
||||||
else
|
else
|
||||||
printf "%b" "\e[14t\e[c"
|
case "${TMUX:-null}" in
|
||||||
read_flags=(-d c)
|
"null") printf '%b' '\e[14t' ;;
|
||||||
|
*) printf '%b' '\ePtmux;\e\e[14t\e\\ ' ;;
|
||||||
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# The escape codes above print the desired output as
|
# The escape codes above print the desired output as
|
||||||
# user input so we have to use read to store the out
|
# user input so we have to use read to store the out
|
||||||
# -put as a variable.
|
# -put as a variable.
|
||||||
IFS=";" read -s -t 1 "${read_flags[@]}" -r -a term_size
|
IFS=';t' read -d t -t 0.05 -sra term_size
|
||||||
|
|
||||||
# Split the string into height/width.
|
# Split the string into height/width.
|
||||||
if [[ "$image_backend" == "tycat" ]]; then
|
if [[ "$image_backend" == "tycat" ]]; then
|
||||||
|
@ -3618,7 +3616,7 @@ get_term_size() {
|
||||||
|
|
||||||
else
|
else
|
||||||
term_height="${term_size[1]}"
|
term_height="${term_size[1]}"
|
||||||
term_width="${term_size[2]/t*}"
|
term_width="${term_size[2]}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[[ "$image_backend" == "kitty" ]] && \
|
[[ "$image_backend" == "kitty" ]] && \
|
||||||
|
@ -3627,16 +3625,20 @@ get_term_size() {
|
||||||
# Get terminal width/height if \e[14t is unsupported.
|
# Get terminal width/height if \e[14t is unsupported.
|
||||||
if (( "${term_width:-0}" < 50 )) && [[ "$DISPLAY" && "$os" != "Mac OS X" ]]; then
|
if (( "${term_width:-0}" < 50 )) && [[ "$DISPLAY" && "$os" != "Mac OS X" ]]; then
|
||||||
if type -p xdotool >/dev/null 2>&1; then
|
if type -p xdotool >/dev/null 2>&1; then
|
||||||
current_window="$(xdotool getactivewindow)"
|
IFS=$'\n' read -d "" -ra win < <(xdotool getactivewindow getwindowgeometry --shell %1)
|
||||||
source <(xdotool getwindowgeometry --shell "$current_window")
|
term_width="${win[3]/WIDTH=}"
|
||||||
term_height="$HEIGHT"
|
term_height="${win[4]/HEIGHT=}"
|
||||||
term_width="$WIDTH"
|
|
||||||
|
|
||||||
elif type -p xwininfo >/dev/null 2>&1; then
|
elif type -p xwininfo >/dev/null 2>&1; then
|
||||||
# Get the focused window's ID.
|
# Get the focused window's ID.
|
||||||
if type -p xdpyinfo >/dev/null 2>&1; then
|
if type -p xdo >/dev/null 2>&1; then
|
||||||
current_window="$(xdpyinfo | grep -E -o "focus:.*0x[0-9a-f]+")"
|
current_window="$(xdo id)"
|
||||||
|
|
||||||
|
elif type -p xdpyinfo >/dev/null 2>&1; then
|
||||||
|
current_window="$(xdpyinfo | grep -F "focus:")"
|
||||||
current_window="${current_window/*window }"
|
current_window="${current_window/*window }"
|
||||||
|
current_window="${current_window/,*}"
|
||||||
|
|
||||||
elif type -p xprop >/dev/null 2>&1; then
|
elif type -p xprop >/dev/null 2>&1; then
|
||||||
current_window="$(xprop -root _NET_ACTIVE_WINDOW)"
|
current_window="$(xprop -root _NET_ACTIVE_WINDOW)"
|
||||||
current_window="${current_window##* }"
|
current_window="${current_window##* }"
|
||||||
|
@ -3644,10 +3646,11 @@ get_term_size() {
|
||||||
|
|
||||||
# If the ID was found get the window size.
|
# If the ID was found get the window size.
|
||||||
if [[ "$current_window" ]]; then
|
if [[ "$current_window" ]]; then
|
||||||
term_size="$(xwininfo -id "$current_window" |\
|
term_size="$(xwininfo -id "$current_window")"
|
||||||
awk -F ': ' '/Width|Height/ {printf $2 " "}')"
|
term_width="${term_size#*Width: }"
|
||||||
term_width="${term_size/ *}"
|
term_width="${term_width/$'\n'*}"
|
||||||
term_height="${term_size/${term_width}}"
|
term_height="${term_size/*Height: }"
|
||||||
|
term_height="${term_height/$'\n'*}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -3693,19 +3696,20 @@ get_image_size() {
|
||||||
done
|
done
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*) image_size="${image_size/px}" ;;
|
*)
|
||||||
|
image_size="${image_size/px}"
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
width="${width:-$image_size}"
|
width="${width:-$image_size}"
|
||||||
height="${height:-$image_size}"
|
height="${height:-$image_size}"
|
||||||
|
|
||||||
text_padding="$((width / font_width + gap + xoffset/font_width))"
|
text_padding="$((width / font_width + gap + xoffset/font_width))"
|
||||||
}
|
}
|
||||||
|
|
||||||
make_thumbnail() {
|
make_thumbnail() {
|
||||||
# Name the thumbnail using variables so we can
|
# Name the thumbnail using variables so we can
|
||||||
# use it later.
|
# use it later.
|
||||||
image_name="$crop_mode-$crop_offset-$width-$height-${image##*/}"
|
image_name="${crop_mode}-${crop_offset}-${width}-${height}-${image##*/}"
|
||||||
|
|
||||||
# Handle file extensions.
|
# Handle file extensions.
|
||||||
case "${image##*.}" in
|
case "${image##*.}" in
|
||||||
|
@ -3717,13 +3721,12 @@ make_thumbnail() {
|
||||||
# Create the thumbnail dir if it doesn't exist.
|
# Create the thumbnail dir if it doesn't exist.
|
||||||
mkdir -p "$thumbnail_dir"
|
mkdir -p "$thumbnail_dir"
|
||||||
|
|
||||||
# Check to see if the thumbnail exists before we do any cropping.
|
if [[ ! -f "${thumbnail_dir}/${image_name}" ]]; then
|
||||||
if [[ ! -f "$thumbnail_dir/$image_name" ]]; then
|
|
||||||
# Get image size so that we can do a better crop.
|
# Get image size so that we can do a better crop.
|
||||||
if [[ -z "$size" ]]; then
|
[[ -z "$size" ]] && {
|
||||||
read -r og_width og_height <<< "$(identify -format "%w %h" "$image")"
|
read -r og_width og_height <<< "$(identify -format "%w %h" "$image")"
|
||||||
((og_height > og_width)) && size="$og_width" || size="$og_height"
|
((og_height > og_width)) && size="$og_width" || size="$og_height"
|
||||||
fi
|
}
|
||||||
|
|
||||||
case "$crop_mode" in
|
case "$crop_mode" in
|
||||||
"fit")
|
"fit")
|
||||||
|
@ -3737,9 +3740,9 @@ make_thumbnail() {
|
||||||
-trim +repage \
|
-trim +repage \
|
||||||
-gravity south \
|
-gravity south \
|
||||||
-background "$c" \
|
-background "$c" \
|
||||||
-extent "$size"x"$size" \
|
-extent "${size}x${size}" \
|
||||||
-scale "$width"x"$height" \
|
-scale "${width}x${height}" \
|
||||||
"$thumbnail_dir/$image_name"
|
"${thumbnail_dir}/${image_name}"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
"fill")
|
"fill")
|
||||||
|
@ -3747,27 +3750,32 @@ make_thumbnail() {
|
||||||
-background none \
|
-background none \
|
||||||
"$image" \
|
"$image" \
|
||||||
-trim +repage \
|
-trim +repage \
|
||||||
-scale "$width"x"$height"^ \
|
-scale "${width}x${height}^" \
|
||||||
-extent "$width"x"$height" \
|
-extent "${width}x${height}" \
|
||||||
"$thumbnail_dir/$image_name"
|
"${thumbnail_dir}/${image_name}"
|
||||||
|
;;
|
||||||
|
|
||||||
|
"none")
|
||||||
|
cp "$image" "${thumbnail_dir}/${image_name}"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
"none") cp "$image" "$thumbnail_dir/$image_name" ;;
|
|
||||||
*)
|
*)
|
||||||
convert \
|
time convert \
|
||||||
-background none \
|
-background none \
|
||||||
"$image" \
|
"$image" \
|
||||||
|
-strip \
|
||||||
|
-define "jpeg:size=100x100" \
|
||||||
-gravity "$crop_offset" \
|
-gravity "$crop_offset" \
|
||||||
-crop "$size"x"$size"+0+0 \
|
-crop "${size}x${size}+0+0" \
|
||||||
-quality 95 \
|
-quality 40 \
|
||||||
-scale "$width"x"$height" \
|
-sample "${width}x${height}" \
|
||||||
"$thumbnail_dir/$image_name"
|
"${thumbnail_dir}/${image_name}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# The final image.
|
# The final image.
|
||||||
image="$thumbnail_dir/$image_name"
|
image="${thumbnail_dir}/${image_name}"
|
||||||
}
|
}
|
||||||
|
|
||||||
display_image() {
|
display_image() {
|
||||||
|
|
Loading…
Reference in a new issue