Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kageurufu/steamdeck_startup_animations
A collection of steamdeck startup animations, plus a script to randomize your startup on each boot
https://github.com/kageurufu/steamdeck_startup_animations
Last synced: 3 months ago
JSON representation
A collection of steamdeck startup animations, plus a script to randomize your startup on each boot
- Host: GitHub
- URL: https://github.com/kageurufu/steamdeck_startup_animations
- Owner: kageurufu
- Created: 2022-08-01T17:01:48.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-10-09T15:54:46.000Z (over 2 years ago)
- Last Synced: 2024-08-01T22:01:21.620Z (6 months ago)
- Language: Shell
- Size: 5.77 MB
- Stars: 219
- Watchers: 9
- Forks: 21
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- starred - kageurufu/steamdeck_startup_animations - A collection of steamdeck startup animations, plus a script to randomize your startup on each boot (Shell)
README
# steamdeck_startup_animations
A collection of steamdeck startup animations, plus a script to randomize your startup on each boot# So far, I've made boot animations from the following consoles:
* dreamcast
* ps1
* ps2
* ps4
* switch
* gamecube
* ps2
* switchfirst (first boot animation)
* switch (regular boot animation)
* xbox
* xbox 360
* xbox one# Installation
```sh
curl -o - https://raw.githubusercontent.com/kageurufu/steamdeck_startup_animations/main/install.sh | bash -
```If you're (justifiably) not a fan of `curl | bash`, you can run this:
```sh
mkdir -p "$HOME/homebrew"
mkdir -p "$HOME/.config/systemd/user"
git clone https://github.com/kageurufu/steamdeck_startup_animations "$HOME/homebrew/startup_animations"
ln -sf "$HOME/homebrew/startup_animations/randomize_deck_startup.service" "$HOME/.config/systemd/user/randomize_deck_startup.service"
systemctl --user daemon-reload
systemctl --user enable --now randomize_deck_startup.service
```# Uninstallation
```sh
bash $HOME/homebrew/startup_animations/uninstall.sh
```# Making an animation (somewhat advanced)
I used youtube-dl to grab the best video and audio tracks from youtube, and then ffmpeg to merge them, resizing down to fit the Deck's 1280x800 screen. Then I use `truncate` to make the file the right size.
This all does work on the steamdeck
### Getting the dependencies
```sh
python3 -m ensurepip
~/.local/bin/pip install --user youtube-dl
```### Creating the animation
```sh
# Get ps1.webm and ps1.m4a. Your file extensions may differ here
~/.local/bin/youtube-dl -f bestvideo -o 'ps1.%(ext)s' https://www.youtube.com/watch?v=1JwbfIi5Uio
~/.local/bin/youtube-dl -f bestaudio -o 'ps1.%(ext)s' https://www.youtube.com/watch?v=1JwbfIi5Uio# Convert the video from whatever input formats to a webm video in VP9 encoding, with vorbis encoded audio
ffmpeg -i ps1.webm -i ps1.m4a \
-map 0:v:0 -map 1:a:0 \
-filter:v "scale='min(1280,iw)':min'(800,ih)':force_original_aspect_ratio=decrease,pad=1280:800:(ow-iw)/2:(oh-ih)/2" \
-c:v vp9 \
-c:a libvorbis \
my_deck_startup_ps1.webm# Make sure the generated file is less than 1840847B here
# Mine was `389670`, plenty small enough
stat -c '%s' my_deck_startup_ps1.webmtruncate -s 1840847 my_deck_startup_ps1.webm
```The ffmpeg command is a bit confusing, so heres a breakdown
* `-i ps1.webm -i ps1.m4a`
Load both the video and audio files we downloaded.
* `-map 0:v:0 -map 1:a:0`
Only use the first video stream from the first file, and first audio stream from the second.
This prevents having multiple video or audio streams in the final file
* `-filter:v "scale='min(1280,iw)':min'(800,ih)':force_original_aspect_ratio=decrease,pad=1280:800:(ow-iw)/2:(oh-ih)/2"`
This is most confusing part, basically we're resizing the video to fit 1280x800
`min'(1280,iw)':min'(800,ih)'` ensures the target size is never upscaled
`force_original_aspect_ratio=decrease` scales to fit within a given size, keeping the original aspect ratio
`pad=1280:800:(ow-iw)/2:(oh-ih)/2` pad the video size to 1280:800, centering the original video. This is optional and I might not use it in the future
* `-c:v vp9 c:a libvorbis` Select our output VP9 / vorbis codecs