mirror of
https://github.com/gotbletu/shownotes
synced 2024-11-10 19:10:36 +00:00
130 lines
3.9 KiB
Bash
Executable File
130 lines
3.9 KiB
Bash
Executable File
#!/bin/bash
|
|
# Let it Rain!
|
|
# Copyright (C) 2011, 2013 by Yu-Jie Lin
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
#
|
|
# The above copyright notice and this permission notice shall be included in
|
|
# all copies or substantial portions of the Software.
|
|
#
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
# THE SOFTWARE.
|
|
#
|
|
# Blog: http://blog.yjl.im/2013/07/let-it-rain.html
|
|
# Gist: https://gist.github.com/livibetter/5933594
|
|
# Gif : https://lh5.googleusercontent.com/-0WJ1vSZcFPs/UdadOwdPEXI/AAAAAAAAE-c/6kuH9hP3cUo/s800/rain.sh.gif
|
|
# Clip: http://youtu.be/EssRgAh2w_c
|
|
#
|
|
# Modified from falling-<3s.sh:
|
|
# http://blog.yjl.im/2011/02/time-to-have-falling-hearts-screensaver.html
|
|
|
|
RAINS=("|" "│" "┃" "┆" "┇" "┊" "┋" "╽" "╿")
|
|
COLORS=("\e[37m" "\e[37;1m")
|
|
# More from 256 color mode
|
|
for i in {244..255}; do
|
|
COLORS=("${COLORS[@]}" "\e[38;5;${i}m")
|
|
done
|
|
NRAINS=${#RAINS[@]}
|
|
NCOLORS=${#COLORS[@]}
|
|
NUM_RAIN_METADATA=5
|
|
|
|
|
|
sigwinch() {
|
|
TERM_WIDTH=$(tput cols)
|
|
TERM_HEIGHT=$(tput lines)
|
|
STEP_DURATION=0.025
|
|
((MAX_RAINS = TERM_WIDTH * TERM_HEIGHT / 4))
|
|
((MAX_RAIN_LENGTH = TERM_HEIGHT < 10 ? 1 : TERM_HEIGHT / 10))
|
|
# In percentage
|
|
((NEW_RAIN_ODD = TERM_HEIGHT > 50 ? 100 : TERM_HEIGHT * 2))
|
|
((NEW_RAIN_ODD = NEW_RAIN_ODD * 75 / 100))
|
|
((FALLING_ODD = TERM_HEIGHT > 25 ? 100 : TERM_HEIGHT * 4))
|
|
((FALLING_ODD = FALLING_ODD * 90 / 100))
|
|
}
|
|
|
|
do_exit() {
|
|
echo -ne "\e[${TERM_HEIGHT};1H\e[0K"
|
|
|
|
# Show cursor and echo stdin
|
|
echo -ne "\e[?25h"
|
|
stty echo
|
|
exit 0
|
|
}
|
|
|
|
do_render() {
|
|
# Clean screen first
|
|
for ((idx = 0; idx < num_rains * NUM_RAIN_METADATA; idx += NUM_RAIN_METADATA)); do
|
|
X=${rains[idx]}
|
|
Y=${rains[idx + 1]}
|
|
LENGTH=${rains[idx + 4]}
|
|
for ((y = Y; y < Y + LENGTH; y++)); do
|
|
(( y < 1 || y > TERM_HEIGHT )) && continue
|
|
echo -ne "\e[${y};${X}H "
|
|
done
|
|
done
|
|
|
|
for ((idx = 0; idx < num_rains * NUM_RAIN_METADATA; idx += NUM_RAIN_METADATA)); do
|
|
if ((100 * RANDOM / 32768 < FALLING_ODD)); then
|
|
# Falling
|
|
if ((++rains[idx + 1] > TERM_HEIGHT)); then
|
|
# Out of screen, bye sweet <3
|
|
rains=("${rains[@]:0:idx}"
|
|
"${rains[@]:idx+NUM_RAIN_METADATA:num_rains*NUM_RAIN_METADATA}")
|
|
((num_rains--))
|
|
continue
|
|
fi
|
|
fi
|
|
X=${rains[idx]}
|
|
Y=${rains[idx + 1]}
|
|
RAIN=${rains[idx + 2]}
|
|
COLOR=${rains[idx + 3]}
|
|
LENGTH=${rains[idx + 4]}
|
|
for ((y = Y; y < Y + LENGTH; y++)); do
|
|
(( y < 1 || y > TERM_HEIGHT )) && continue
|
|
echo -ne "\e[${y};${X}H${COLOR}${RAIN}"
|
|
done
|
|
done
|
|
}
|
|
|
|
trap do_exit TERM INT
|
|
trap sigwinch WINCH
|
|
# No echo stdin and hide the cursor
|
|
stty -echo
|
|
echo -ne "\e[?25l"
|
|
|
|
echo -ne "\e[2J"
|
|
rains=()
|
|
sigwinch
|
|
while :; do
|
|
read -n 1 -t $STEP_DURATION ch
|
|
case "$ch" in
|
|
q|Q)
|
|
do_exit
|
|
;;
|
|
esac
|
|
|
|
if ((num_rains < MAX_RAINS)) && ((100 * RANDOM / 32768 < NEW_RAIN_ODD)); then
|
|
# Need new |, 1-based
|
|
RAIN="${RAINS[NRAINS * RANDOM / 32768]}"
|
|
COLOR="${COLORS[NCOLORS * RANDOM / 32768]}"
|
|
LENGTH=$((MAX_RAIN_LENGTH * RANDOM / 32768 + 1))
|
|
X=$((TERM_WIDTH * RANDOM / 32768 + 1))
|
|
Y=$((1 - LENGTH))
|
|
rains=("${rains[@]}" "$X" "$Y" "$RAIN" "$COLOR" "$LENGTH")
|
|
((num_rains++))
|
|
fi
|
|
|
|
# Let rain fall!
|
|
do_render
|
|
done
|