1. Yad Progress
Display progress indication dialog.
#!/bin/bash
for ((i=1; i<=100; i++)) {
echo $i
echo "# $((i))%"
sleep 0.5
} | yad --progress \
--text="Progress demo..." \
--width=300 \
--button=yad-cancel \
--auto-kill
data:image/s3,"s3://crabby-images/f54c1/f54c16c0b169261ae0fe9c9695c02a1f0ff33c6b" alt="yad progress"
When the --progress
option is used, yad reads lines of progress data from stdin.
When the lines begin with the text after
is displayed in the progress barlabel.
Numeric values treats like a persents for progress bar.
1.1. --pulsate
Pulsate progress bar.
This option works only in single-bar mode.
#!/bin/bash
for ((i=1; i<=100; i++)) {
echo $i
echo "# $((i))%"
sleep 0.2
} | yad --progress \
--pulsate \
--text="Pulsate..." \
--width=300 \
--button=yad-cancel \
--auto-kill
data:image/s3,"s3://crabby-images/46812/46812d21171e041b2669bd506aabaaf9988792ab" alt="yad progress pulsate"
1.2. --auto-close
Dismiss the dialog when 100% has been reached.
1.3. --auto-kill
Kill parent process if cancel button is pressed.
1.4. --progress-text=TEXT
Set the label of progress bar to TEXT
.
This option works only in single-bar mode.
yad --progress --progress-text=Demo 20
data:image/s3,"s3://crabby-images/a14d6/a14d61444ab3fd0940fdf617a4640ae2d75dd639" alt="yad progress progress text"
1.5. --rtl
Right-To-Left progress bar direction.
This option works only in single-bar mode.
#!/nin/bash
for ((i=1; i<=100; i++)) {
echo $i
echo "# $((i))%"
sleep 0.2
} | yad --progress \
--text="Progress demo..." \
--width=300 \
--button=yad-cancel \
--auto-kill --rtl
data:image/s3,"s3://crabby-images/820cf/820cf0f9169f8b18ec0202dc975032e80a8058d1" alt="yad progress rtl"
1.6. --vertical
Set vertical orientation of progress bars.
yad --progress --vertical 20
data:image/s3,"s3://crabby-images/5640a/5640a2921d4ba56476f86a85159fa61958338ead" alt="yad progress vertical"
1.7. --enable-log=[TEXT]
Show log window.
#!/bin/sh
for ((i=1; i<=100; i++)) {
echo $i
echo "# Remaining $((100-i))% to finish the job"
sleep 0.2
} | yad --progress \
--enable-log="Test Log" \
--text="Testing..." \
--width=300 \
--button=yad-cancel \
--auto-kill
data:image/s3,"s3://crabby-images/6b585/6b585abff727fac2209a8cb923b83f8e9df3f31c" alt="yad progress log 0"
data:image/s3,"s3://crabby-images/c807f/c807f90309034168360838192b66d9259dc41a12" alt="yad progress log 1"
1.8. --log-expanded
Expand log window.
#!/bin/sh
for ((i=1; i<=100; i++)) {
echo $i
echo "# Remaining $((100-i))% to finish the job"
sleep 0.2
} | yad --progress \
--enable-log="Test Log" \
--text="Testing..." \
--width=300 \
--button=yad-cancel \
--log-expanded \
--auto-kill
data:image/s3,"s3://crabby-images/c807f/c807f90309034168360838192b66d9259dc41a12" alt="yad progress log 1"
1.9. --log-height
--log-height
Height of log window.
#!/bin/sh
for ((i=1; i<=100; i++))
{
echo $i
echo "# Remaining $((100-i))% to finish the job"
sleep 0.2
} | yad --progress \
--log-height=100 \
--enable-log="Test Log" \
--log-expanded \
--text="Testing..." \
--width=300 \
--button=yad-cancel \
--auto-kill
data:image/s3,"s3://crabby-images/ef0ce/ef0ce5a48902d6886b80c44fba168ecdbf2041c3" alt="yad progress log height 100"
2. Yad Multi progress bars
Initial values for bars sets as an extra arguments.
Each lines with progress data passed to stdin must be started from N: where N is a number of progress bar.
In a single-bar mode N: is not needed.
yad --progress \
--width=250 \
--bar="Bar 1" 10 \
--bar="Bar 2" 20
data:image/s3,"s3://crabby-images/8b814/8b814e893788bba62ccbec1d50c6e505170eafae" alt="yad multi progress bar 1"
2.1. --bar=LABEL[:TYPE]
Add progress bar.
LABEL
is a text label for progress bar.
TYPE
is a progress bar type.
Types are: NORM
for normal progress bar, RTL
for inverted progress bar and PULSE
for pulsate progress bar.
If no bars specified, the progress dialog works in single-bar mode.
yad --progress \
--width=250 \
--bar="Bar 1:rtl" 10 \
--bar="Bar 2:rtl" 20
data:image/s3,"s3://crabby-images/bacb9/bacb9df214db701634717217a182e29fc49d4a3e" alt="yad multi progress bar rtl"
2.2. --watch-bar=NUMBER
Watch for specific bar for auto close
2.3. --auto-close
Dismiss the dialog when 100% of all bars has been reached
2.4. --auto-kill
Kill parent process if cancel button is pressed
3. Examples
3.1. xdf
Here is an excellent example of multiple progress bars. It will only show the drives that are currently mounted.
#!/bin/sh
eval exec yad \
--title="xdf" \
--image=drive-harddisk \
--text="Disk\ usage:" \
--buttons-layout=end \
--width=650 \
--progress \
$(df -hT $1 | tail -n +2 | \
awk '{printf "--bar=\"<b>%s</b> (%s - %s) [%s/%s]\" %s ", $7, $1, $2, $4, $3, $6}')
data:image/s3,"s3://crabby-images/bc0f2/bc0f230403495146d3e2acf30eae6cc2901e9811" alt="yad multi progress bar 2"