Requirements
imagemagick 7.x
flameshot 0.8.x
xclip 0.13
ruby 2.7.x
Sekenario Masalah
Beberapa waktu yang lalu, saya menulis tentang “Membuat Hasil ScreenShot pada GNU/Linux seperti Milik macOS”.
Pada artikel tersebut, script dijalankan setelah gambar hasil screenshot jadi.
Namun, bagaimana apabila screenshot yang dihasilkan berasal dari flameshot?
Kalau membuat sequence command seperti ini,
$ flameshot gui; imagemagick-script
Permasalahannya adalah, apabila kita tidak jadi melakukan screenshot dengan flameshot, maka script imagemagick-script
akan tetap dijalankan, dan akan memodifikasi gambar terakhir pada direktori screenshot.
Pemecahan Masalah
Kita perlu memasukkan perintah flameshot ke dalam script.
Nantinya, yang kita panggil bukan lagi flameshot, melainkan script kita –untuk menjalankan flameshot dengan hasil yang telah dimodifikasi dengan imagemagick.
Saya beri nama flameshot-imgck
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/env ruby
require 'date'
# Please wite your dir with ~/ first
screenshot_dir = '~/pic/ScreenShots'
Dir.chdir(File.expand_path(screenshot_dir))
original_file = Time.now.strftime('Screenshot_%Y-%m-%d_%H-%M-%S.png')
target_file = original_file.split('').insert(-5, 'X').join
color_profile = '/usr/share/color/icc/colord/sRGB.icc'
border_size = '1'
background_color = '"#FFFFFF"' # 'none' for transparent; Hex color use '"#000000"'
background_size = '10'
shadow_size = '50x10+0+10'
font = 'JetBrains-Mono-Regular-Nerd-Font-Complete'
font_size = '11'
color_fg = '#ffffff'
color_bg = '#666666'
author_position = ['SouthWest', '+30+26']
author = 'Shooter: @' + `echo $USER`.strip
%x(
flameshot gui --raw > #{original_file}
magick convert #{original_file} -bordercolor '#{color_bg}' -border #{border_size} \
#{target_file}
magick convert #{target_file} \\( +clone -background black \
-shadow #{shadow_size} \\) +swap -background none \
-layers merge +repage #{target_file}
magick convert #{target_file} -bordercolor #{background_color} \
-border #{background_size} #{target_file}
echo -n " #{author} " | magick convert #{target_file} \
-gravity #{author_position[0]} -pointsize #{font_size} -fill '#{color_fg}' \
-undercolor '#{color_bg}' -font #{font} \
-annotate #{author_position[1]} @- #{target_file}
magick convert #{target_file} -gravity South -chop 0x#{background_size.to_i / 2} \
#{target_file}
magick convert #{target_file} -gravity North -background #{background_color} \
-splice 0x#{background_size.to_i / 2} #{target_file}
magick convert #{target_file} -profile #{color_profile} #{target_file}
)
list_file = `ls -p | grep -v /`
last_file = list_file.split(' ').last
if last_file.include? 'X'
`notify-send "ImageMagick" "Improving success!" -t 3000`
`xclip -selection clipboard -i #{target_file} -t image/png`
end
size = `find #{last_file} -printf %s`
if size == '0' || size <= '20'
`rm -rf #{last_file}`
`notify-send "Flameshot" "Process Aborted!" -t 1000`
end
Kalau kita menjalankan script di atas, akan menghasilkan dua buah file.
Screenshot_2020-08-16_11-32-45.png <- Original
Screenshot_2020-08-16_11-32-45X.png <- Modifikasi
Alamat screenshot_dir
dengan alamat yang ada di Flameshot, harus sama.
Kalau tidak, maka script tidak berjalan sebagaimana mestinya.
File Original tidak dimodifikasi, tujuannya sebagai backup. Karena saya menyadari bahwa pengambilan screenshot adalah hal yang sangat crucial dan terkadang tidak dapat diulang dua kali.
File Modifikasi adalah hasil pengolahan dengan imagemagick, kalau dibuka akan seperti ini hasilnya.
Nah, dengan seperti ini, kita tetap dapat memanfaatkan fitur annotate milik flameshot.
Mulai dari sekarang, hasil flameshot kita akan berbeda dari screenshot-screenshot sebelumnya.
Modifikasi Script
Beberapa modifikasi yang sering saya lakukan adalah:
Menghilangkan Border
Baris ke-11, adalah variabel untuk mendefinisikan border dari hasil screenshot.
Ubah nilainya ke 0
apabila tidak ingin menggunakan border.
Mengganti Author (ScreenShoter)
Baris ke-20, adalah variabel untuk mendifinisikan author dari pengambil screenshot.
Ubah nilainya sesuai dengan preferensi teman-teman.
Disable Author
Baris ke 35-38, adalah proses pemberian author.
Kalau ingin dihilangkan, cukup dengan memberikan tanda #
di setiap awal baris ke-34 sampai baris ke-37.
Mengganti Author Font
Baris ke-15, adalah variable untuk mendifinisikan font.
Ganti nilainya sesuai dengan preferensi teman-teman.
Cara untuk mendapatkan nama font, gunakan perintah di bawah.
$ convert -list font
Untuk mendapatkan hasil yang lebih spesifik, gunakan grep dengan mengambil awal kata dari nama font.
$ convert -list font | grep -i 'fura'
Hasilnya akan seperti ini.
... ... Font: Fura-Code-Regular-Nerd-Font-Complete family: FuraCode Nerd Font glyphs: /usr/share/fonts/TTF/Fura Code Regular Nerd Font Complete.ttf Font: Fura-Code-Regular-Nerd-Font-Complete-Mono family: FuraCode Nerd Font Mono glyphs: /usr/share/fonts/TTF/Fura Code Regular Nerd Font Complete Mono.ttf ... ...
Tinggal pilih font yang sesuai dengan preferensi teman-teman.
Ambil value yang ada di dalam Font:
Mengganti Author Font Size
Baris ke-16, adalah variable yang mendifinisikan ukuran font.
Ganti sesuai preferensi teman-teman dalan satuan ukuran pt (point).
Mengganti Author Position
Baris ke-19, adalah variabel untuk mendifinisikan nilai posisi dari author.
Index ke-0 berisi, 8 arah mata angin + 1 Center.
NorthWest, North, NorthEast, West, Center, East, SouthWest, South, SouthEast
Sebagai acuan untuk memposisikan object dengan singkat.
Index ke-1 berisi, jarak +X+Y
Hasilnya,
Background Transparent
Baris ke-12, adalah variable untuk mendifinisikan border color yang digunakan untuk memberikan background pada hasil screenshot.
Ubah nilainya menjadi none
untuk transparent.
Kalau ingin menggunakan warna,
Background Padding
Baris ke-13, adalah variable untuk mendifinisikan padding dari background dengan screenshot.
Ganti sesuai preferensi teman-teman.
Sesuaikan dengan besar dari shadow yang digunakan, agar shadow tidak terpotong.
Shadow
Baris ke-14, adalah variable untuk mendifinisikan shadow yang ada di bawah screenshot.
Ganti sesuai preferensi teman-teman.
Color Profile
Menambahkan color profile ini penting untuk Telegram. Kalau tidak menambahkan color profile, gambar kita akan terlihat “over bright” di Telegram Android meskipun tidak terlihat di Telegram Desktop.
Save to Clipboard!
Jangan lupa modifikasi pendefinisikan shortcut untuk COPY yang defaultnya menggunakan Ctrl+C, menjadi Enter pada file ~/.config/flameshot/flameshot.ini.
1
2
3
4
5
6
# ...
[Shortcuts]
# ...
TYPE_COPY=Return
# ...
Apabila telah selesai melakukan screenshot, kita dapat menyimpan dengan menekan tombol ENTER.
Maka, hasil screenshot kita akan disimpan ke clipboard.
Tinggal kita paste di Telegram.
Namun, dengan Ruby script ini, hasil screenshot tetap berada pada direktori screenshot yang sudah kita set.
Jangan lupa untuk mendisable tombol save pada configurasi interface di Flameshot.
$ flameshot config
Tujuannya agar kita tidak latah lalu menekan tombol save. Agar hanya ada satu pilihan untuk menyimpan, yaitu menekan tombol ENTER.
Menghandle Escape
Apabila kita tidak jadi melakukan screenshot dan menekan tombol ESC, proses screenshot dengan script ini akan meninggalkan file kosong (sebesar 0 B - 10 B).
Untuk menghandle hal tersebut, saya memilih mendeteksi size dari file tersebut dan menghapusnya.
Pesan Penulis
Mantap!!!
Saya rasa hanya ini yang dapat saya tuliskan saat ini.
Mudah-mudahan dapat bermanfaat untuk teman-teman.
Terima kasih.
(^_^)
BONUS
Alternatif Project
1. Awesome Flameshot (Bash Version oleh Berrabe)
Tidak semua temann-teman memiliki Ruby, namun, biasanya sudah memiliki Bash secara default.
Versi Bash ini dapat menjadi alternatif yang sangat praktis untuk teman-teman.
Terima kasih kepada bro Berrabe telah mem-porting ke Bash.
Teman-teman dapat menikmati source nya di sini yaa, Bash version oleh Berrabe.
Versi Python
Versi Python sudah tidak saya maintain lagi.
Saya beri nama flameshot-imgck-python
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#!/usr/bin/env python
import os
from datetime import datetime
# Please write your screenshot dir with full path. Later, I'll improve this.
screenshot_dir = "/home/bandithijo/pic/ScreenShots"
os.chdir(screenshot_dir)
original_file = datetime.now().strftime("Screenshot_%Y-%m-%d_%H-%M-%S.png")
target = list(original_file)
target.insert(-4, 'X')
target_file = ''.join(target)
color_profile = "/usr/share/color/icc/colord/sRGB.icc"
border_size = "1"
background_color = "white" # "none" for transparent; Hex color use "'#ffffff'"
background_size = "10"
shadow_size = "50x10+0+10"
font = "JetBrains-Mono-Regular-Nerd-Font-Complete"
font_size = "11"
color_fg = "#ffffff"
color_bg = "#666666"
author_position = ["SouthWest", "+30+26"]
author = "Shooter: @" + \
os.popen("echo $USER").read().rstrip("\n")
os.system(f"""
flameshot gui --raw > {original_file}
magick convert {original_file} -bordercolor '{color_bg}' -border {border_size} \
{target_file} \
magick convert {target_file} \\( +clone -background black \
-shadow {shadow_size} \\) +swap -background none \
-layers merge +repage {target_file} \
magick convert {target_file} -bordercolor {background_color} \
-border {background_size} {target_file} \
echo -n " {author} " | magick convert {target_file} \
-gravity {author_position[0]} -pointsize {font_size} -fill '{color_fg}' \
-undercolor '{color_bg}' -font {font} \
-annotate {author_position[1]} @- {target_file} \
magick convert {target_file} -gravity South -chop 0x{int(background_size)/2} \
{target_file} \
magick convert {target_file} -gravity North -background {background_color} \
-splice 0x{int(background_size)/2} {target_file} \
magick convert {target_file} -profile {color_profile} {target_file} \
""")
list_file = os.popen("ls -p | grep -v /").read().split("\n")[:-1]
last_file = list_file[-1]
if 'X' in last_file:
os.system("notify-send 'ImageMagick' 'Improving success!' -t 3000")
os.system(f"xclip -selection clipboard -i {target_file} -t image/png")
size = os.popen(f"find {last_file} -printf %s").read()
if size == '0' or size <= '20':
os.system(f"rm -rf {last_file}")
os.system("notify-send 'Flameshot' 'Process Aborted!' -t 1000")
Referensi
- Membuat Hasil ScreenShot pada GNU/Linux seperti Milik macOS
Diakses tanggal: 2020/08/16
Lisensi
Atribusi-NonKomersial-BerbagiSerupa 4.0 Internasional (CC BY-NC-SA 4.0)
Penulis
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