Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Eric Migicovsky představil Pebble Emulator, tj. emulátor hodinek Pebble (PebbleOS) běžící ve webovém prohlížeči. Za 6 hodin jej napsal Claude Code. Zdrojové kódy jsou k dispozici na GitHubu.
Byla vydána nová verze 3.41 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.11 souvisejícího programovacího jazyka Dart (Wikipedie).
Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.
Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.
Agent umělé inteligence vytvořil 'útočný' článek o Scottu Shambaughovi, dobrovolném správci knihovny matplotlib, poté, co vývojář odmítl agentem navrženou změnu kódu (pull request). 'Uražený' agent autonomně sepsal a publikoval na svém blogu článek, který přisuzuje Shambaughovi smyšlené motivace, egoismus a strach z AI coby konkurence.
Bylo vydáno Ubuntu 24.04.4 LTS, tj. čtvrté opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
V pátek 20. února 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 6. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj a uživatelský prostor. Akce proběhne od 10:00 do večera. Hackday je určen všem, kteří si chtějí prakticky vyzkoušet práci s linuxovým jádrem i uživatelským prostorem, od posílání patchů například pomocí nástroje b4, přes balíčkování a Flatpak až po drobné úpravy
… více »Ř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: