بسم الله الرحمن الرحيم

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_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_thinkpad-x61-1024x768

Nah, hasil screenshot di atas memiliki resolusi 1024x768.

Saya ingin menggabungkan hasil screenshot dengan frame.

gambar_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.

FILE$HOME/.config/sxhkd/sxhkdrc
1
2
3
4
5
6
7
8
9
# ...
# ...

# screenshot
super + Print
    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/" \
    ; notify-send "Scrot" "Screen has been captured!"

Hasilnya seperti ini.

gambar_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.

FILE$HOME/.local/bin/scrot-imgck
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#!/usr/bin/env ruby

# Please write your screenshot dir with full path. Later, I'll improve this.
ss_dir = "/home/bandithijo/pic/ScreenShots"
ss_frame = "/home/bandithijo/pic/ScreenShots/obs-frame.png"
Dir.chdir(ss_dir)
list_file = %x(ls -p | grep -v /)
files = list_file.split(" ")
target_file = files.last
target_file_mod = files.last.split("").insert(-5, 'X').join

%x(convert #{ss_frame} #{target_file} -geometry 1024x768^ \
-set gamma 2.2 -composite #{target_file_mod})

puts "SS_DIR: #{ss_dir}"
puts "SOURCE: #{target_file}
TARGET: #{target_file_mod}
FRAMING SUCCESS!"

Mantap!!!

Saya rasa hanya ini yang dapat saya tuliskan saat ini.

Mudah-mudahan dapat bermanfaat untuk teman-teman.

Terima kasih.

(^_^)

Referensi

  1. imagemagick.org/script/command-line-processing.php#geometry
    Diakses tanggal: 2020/07/25

  2. PNG image becomes too bright
    Diakses tanggal: 2020/08/03


Penulis

bandithijo

My journey kicks off from reading textbooks as a former Medical Student to digging bugs as a Software Engineer – a delightful rollercoaster of career twists. Embracing failure with the grace of a Cat avoiding water, I've seamlessly transitioned from Stethoscope to Keyboard. Armed with ability for learning and adapting faster than a Heart Beat, I'm on a mission to turn Code into a Product.

- Rizqi Nur Assyaufi

d98d8237fef8f1017d0be931b6e291341cbe6ca8