Menambahkan Frame pada Hasil ScreenShot dengan ImageMagick
Sekenario Masalah
Saya baru-baru saja menyeragamkan semua produksi video yang saya jadikan vlog di YouTube.
Dalam video tersebut, saya menggunakan frame seperti ini:
Gambar 1. obs-frame
Nah, permasalahannya adalah:
Saya ingin membuat hasil screenshot pada laptop ThinkPad X61 dengan resolusi layar 1024x768 ini langsung otomatis memiliki frame tersebut.
Saat ini, hasil screenshot yang diambil langsung dari laptop ThinkPad X61 saya, seperti ini:
Gambar 2. thinkpad-x61-1024x768
Nah, hasil screenshot di atas memiliki resolusi 1024x768.
Saya ingin menggabungkan hasil screenshot dengan frame.
Gambar 3. mockup-imagemagick
Pemecahan Masalah
Solusinya sangat mudah untuk ditemukan.
Saya langsung terpikir menggunakan ImageMagick, tapi saya tidak pernah benar-benar mencoba dan mengulik banyak hal dengan tools ini. Biasanya, saya hanya membaca manual, kalau saya perlukan. Saya seperti sekarang. Hehe.
Kita akan menggunakan Image Sequence Operator yang bernama -composite
.
Bentuk commandnya seperti ini
convert frame.png target.png -geometry WxH^ -composite hasil.png
frame.png adalah gambar yang akan dijadikan frame.
target.png adalah gambar hasil screenshot.
-geometry WxH^ adalah ukuran/resolusi dari gambar target.png.
Nah, kemudian tinggal digabungkan dengan aplikasi pembuat screenshot.
Dalam hal ini, saya menggunakan scrot.
Maka seperti inilah yang saya gunakan.
$ scrot "Screenshot_%Y-%m-%d_%H-%M-%S.png" -e "convert ~/pic/ScreenShots/obs-frame.png *.png -geometry 1024x768^ -composite *.png; mv *.png ~/pic/ScreenShots/"
Dibagian akhir dari proses tersebut, saya memindahkan hasil screenshot ke direktori ~/pic/ScreenShots/
menggunakan command mv
. Teman-teman dapat menyesuaikan dengan direktori screenshot yang teman-teman miliki.
Kalau mau ditambahkan di keybind Window Manager juga bisa. Tinggal tambahkan di konfigurasi Window Manager masing-masing.
Misal, seperti saya, sedang menggunakan BSPWM.
1# ...2# ...34# screenshot5super + Print6 scrot "Screenshot_%Y-%m-%d_%H-%M-%S.png" \7 -e "convert ~/pic/ScreenShots/obs-frame.png *.png -geometry 1024x768^ \8 -composite *.png; mv *.png ~/pic/ScreenShots/" \9 ; notify-send "Scrot" "Screen has been captured!"
Hasilnya seperti ini.
Gambar 4. hasil-screenshot-frame-imagemagick
Tambahan
Terkadang saya tidak ingin setiap hasil screenshot langsung diframing. Namun, saya malas menulis command ImageMagick yang panjang. Maka sayapun membuat Ruby script untuk menghandle hal tersebut.
1#!/usr/bin/env ruby23# Please write your screenshot dir with full path. Later, I'll improve this.4ss_dir = "/home/bandithijo/pic/ScreenShots"5ss_frame = "/home/bandithijo/pic/ScreenShots/obs-frame.png"6Dir.chdir(ss_dir)7list_file = %x(ls -p | grep -v /)8files = list_file.split(" ")9target_file = files.last10target_file_mod = files.last.split("").insert(-5, 'X').join1112%x(convert #{ss_frame} #{target_file} -geometry 1024x768^ \13-set gamma 2.2 -composite #{target_file_mod})1415puts "SS_DIR: #{ss_dir}"16puts "SOURCE: #{target_file}17TARGET: #{target_file_mod}18FRAMING SUCCESS!"
Mantap!!!
Saya rasa hanya ini yang dapat saya tuliskan saat ini.
Mudah-mudahan dapat bermanfaat untuk teman-teman.
Terima kasih.
(^_^)
Referensi
-
imagemagick.org/script/command-line-processing.php#geometry
Diakses tanggal: 2020/07/25 -
PNG image becomes too bright
Diakses tanggal: 2020/08/03