Blíží se prázdniny a než se rozutečete k moři, je na čase se opět sejít na Virtuální Bastlírně - pravidelném setkání elektroniků, ajťáků, bastlířů a obecně nadšenců do techniky. Co si pro vás strahovští bastlíři připravili tentokrát? Určitě proberou blížící se Linux Days i další události. U softwaru se chvíli zdrží a poví si kupříkladu o tom, jak se zbavit Bambu Cloudu, ale nepřijít o možnost ovládat tiskárnu na dálku. Řeč dojde i na AI,
… více »Vývojáři postmarketOS vydali verzi 26.06 tohoto operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 2.55.0 distribuovaného systému správy verzí Git. Přispělo 100 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Craig Loewen na blogu Microsoftu oznámil veřejnou preview verzi WSL kontejnerů, tj. linuxových kontejnerů ve Windows Subsystem for Linux (WSL). Spouští se příkazem wslc.exe.
Byla vydána (𝕏, Bluesky) nová verze 2026.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem 9 nových nástrojů v oficiálním oznámení na blogu.
Grafická aplikace Krokiet/Czkawka pro vyhledávání a odstraňovaní nepotřebných souborů (duplicitní soubory, prázdné složky, podobné obrázky, podobná videa, poškozené soubory a další) byla vydána ve verzi 12.0.0. Podrobný přehled novinek v příspěvku na Medium. Jedná se o poslední verzi frontendu Czkawka GTK nad Czkawka Core. Uživatelům se doporučuje migrovat na frontend Krokiet postavený nad frameworkem Slint. Představena byla aplikace Cedinia pro Android využívající Czkawka Core. Dostupná je jako APK pro ruční instalaci.
Po téměř třech letech od vydání verze 9 byla vydána nová verze 10 linuxové distribuce Mageia (Wikipedie). Přehled novinek v poznámkách k vydání.
Nourish (GitHub) je nový správce oken pro Linux. Tradiční plochy nahrazuje nekonečným plátnem a posouváním a přibližováním. Využívá vlastní kompozitor pro Wayland s názvem y5. Videoukázka.
Po 20 letech a 17 otevřených (open source) krátkých filmech Blender Studio oznámilo plán na svůj první celovečerní film. Cílem samozřejmě není jenom nový otevřený film, ale především vývoj a vylepšení otevřených nástrojů pro spolupráci napříč celým procesem a vytvoření otevřené příručky (playbook) pro filmovou produkci ve velkém měřítku s informacemi, které jsou obvykle dostupné pouze uvnitř komerčních studií, a pomoci tak nezávislým tvůrcům překonat technické a organizační bariéry.
Byla vydána nová verze 26.6.25 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Řešení dotazu:
Nějak nerozumim kde je problém. Pár IF a je hotovo ne. Zkus se rozepsat pro co to vlastně chceš popřípadě vložit kód co máš. Nerozumim tomu co ti nejde.
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=5
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
#sel=$((sel-1))
sel=$((sel+1))
sleep 1
done
Tohle ? (Pohyb kurzorovejma klávesama UP/DOWN) ESC konec
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=10
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
echo $k
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < max -1 )) ; then
let sel++
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
fi
if ((k == 27)) ; then
break
fi
done
Teda tohle UP/DOWN a stop je ctrl+c
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=10
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < max -1 )) ; then
let sel++
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
fi
No ještě jedna verze (vypisuje jen 5 ale roluje)
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#ttt[@]}
max=5
pos=0
while [ 1 ]
do
clear
for ((i=$pos; i<($pos+$max); i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < (sum -1) )) ; then
let sel++
if (((pos +5) < sum)); then
let pos++
fi
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
if (( (pos ) > 0 )); then
let pos--
fi
fi
done
Spustím program a dostanu výsledek >1111111111< 2222222222 3333333333 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 >2222222222< 3333333333 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 >3333333333< 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 3333333333 >4444444444< 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 3333333333 4444444444 >5555555555< stisk klávesy dolů, ted prijde zmena výsledek 2222222222 3333333333 4444444444 5555555555 >6666666666< stisk klávesy dolů, výsledek, tohle se opakuje až po poslední položku 3333333333 4444444444 5555555555 6666666666 >7777777777< *********************************** ted stisk klávesy nahoru, výsledek *********************************** 3333333333 4444444444 5555555555 >6666666666< 7777777777 stisk klávesy nahoru, výsledek 3333333333 4444444444 >5555555555< 6666666666 7777777777 stisk klávesy nahoru, výsledek 3333333333 >4444444444< 5555555555 6666666666 7777777777 stisk klávesy nahoru, výsledek >3333333333< 4444444444 5555555555 6666666666 7777777777 stisk klávesy nahoru, ted prijde zmena výsledek >2222222222< 3333333333 4444444444 5555555555 6666666666 stisk klávesy nahoru, výsledek >1111111111< 2222222222 3333333333 4444444444 5555555555Děkuji
Tady ?
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#ttt[@]}
max=5
pos=0
center=0
while [ 1 ]
do
clear
for ((i=$pos; i<($pos+$max); i++ ))
do
if [ $sel = $i ]
then
echo -e ">\e[5;31m${ttt[i]}\e[0m<"
else
echo " ${ttt[i]} "
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < (sum -1) )) ; then
let sel++
if ((center < max)); then
let center++
fi
if ((center == max )) && (((pos +5) < sum)); then
let pos++
fi
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
if ((center > 0)); then
let center--
fi
if ((center == 0 )) && (( (pos ) > 0 )); then
let pos--
fi
fi
done
a číslo účtu??
To je nekonečná práce , přidat ještě tunu IF proti všem možnejm kombinacím , přidat ( http://www.bashguru.com/2010/04/how-to-handle-cursor-movement-in-shell.html ) pozici zobrazení , orámování , a stále bude co vylepšovat. Nakonec to raději udělá někdo za pomoci ncurses v céčku. :)
Ať to čtu jak to čtu stále nevím co vlastně chcete ...
Zkuste svůj požadavek upřesnit.
Hodnotu těch proměnných echo $prommena si můžete vypsat. Nebo nechápete princip ? O co jde ?
Nebo jdi sem , pokud tam budu nebo někdo bude : http://cz3dtc.cz/linux.htm
Aha , celej kód je naprd , oprava bude : http://pastebin.com/9etQa14z
Teda až to předělam.
Děkuji za informace Veroniky která vyšťourala že je to celé na prd :)
Tak zde je opravená verze :
#!/bin/bash
start=1
clear
tput civis -- invisible
trap "stty $(stty -g)" EXIT
stty -echo -icanon time 2 || exit $?
KEYS="" ; IFS=$'\a'
ttt=("Volba 1" "Volba 2" "Volba 3" "Volba 4" "Volba 5" "Volba 6" "Volba 7" "Volba 8" "Volba 9" "Volba 10" "Volba 11" "Volba 12" "Volba 13" "Volba 14" "Volba 15")
ap=0; let start--
pp=${#ttt[@]}
mp=5
if ((pp < mp)) ; then let mp=pp ; fi
posun_seznamu=0
center=0
acc=5
function zobraz ()
{
let tmpap=ap ; let tmpap++
echo -en "\033[1;1H"
echo "ESC = Konec , ENTER = výběr volby"
let posa=$posun_seznamu ; let posb=($posun_seznamu+$mp)
let posa=($posa + $center) ; let posb=($posb + $center)
echo -e "\033[1m\033[46m \e[0m"
for ((i=$posa; i<($posb); i++ ))
do
if [ $ap = $i ]
then
echo -e "\033[1m\033[46m \e[0m\033[1m\033[44m${ttt[i]}\e[0m\033[1m\033[46m \e[0m"
else
echo -e "\033[1m\033[46m \e[0m\033[30m\033[47m${ttt[i]}\e[0m\033[1m\033[46m \e[0m"
fi
done
echo -e "\033[1m\033[46m \e[0m"
}
for ((l=0; l<($start); l++ ))
do
zobraz
if ((ap < (pp -1 ) )) ; then
let ap++
if (((center + (mp -1)) < ap)) ; then let center++ ; fi
fi
done
zobraz
while [ 1 ]; do
while read -t 0 ; do read -s -r -d "" -N 1 -t 0.2 CHAR && KEYS="$KEYS$CHAR" || break
done
if [ -z "$KEYS" ]; then sleep 0.05 ; continue ; fi
case "$KEYS" in
$'\x1B\x5B\x42'*)
KEYS="${KEYS##???}"
if ((ap < (pp -1 ) )) ; then
let ap++
if (((center + (mp -1)) < ap)) ; then let center++ ; fi
fi
zobraz
;;
$'\x1B\x5B\x41'*)
KEYS="${KEYS##???}"
if ((ap > 0)); then
let ap--
if ((ap < posa )) ; then let center-- ; fi
fi
zobraz
;;
$'\n'*|$'\r'*)
KEYS="${KEYS##?}"
echo "Vybraná položka : ${ttt[ap]} "
tput cnorm -- normal
exit 0
;;
$'\x1B')
KEYS="${KEYS##?}"
echo "Program ukončen ..."
tput cnorm -- normal
exit 0
;;
[$'\x01'-$'\x1F'$'\x7F']*)
KEYS="${KEYS##?}"
;;
*)
KEY="${KEYS:0:1}"
KEYS="${KEYS#?}"
;;
esac
done
Tiskni
Sdílej: