Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.
Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.
Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.
Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.
V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od
… více »Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.
Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.
OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.
Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.
mám proměnné
pole=array['0položka','1položka','2položka','3položka','4položka','5položka','6položka','7položka','8položka','9položka']
$aktualni_ID=0
$max_polozek_na_stranku=3
$celkem_polozek=10
for(i=$aktualni_ID;i=$max_polozek_na_stranku; i++ )
if($aktualni_ID==i)
echo pole[i].'<<<'
else
echo pole[i]
Kroky směrem dolů
0položka<<<
1položka
2položka
0položka
1položka<<<
2položka
0položka
1položka
2položka<<<
1položka
2položka
3položka<<<
2položka
3položka
4položka<<<
3položka
4položka
5položka<<<
4položka
5položka
6položka<<<
5položka
6položka
7položka<<<
6položka
7položka
8položka<<<
7položka
8položka
9položka<<<
Kroky zpět (směrem nahoru)
7položka
8položka
9položka<<<
7položka
8položka<<<
9položka
7položka<<<
8položka
9položka
6položka<<<
7položka
8položka
5položka<<<
6položka
7položka
4položka<<<
5položka
6položka
3položka<<<
4položka
5položka
2položka<<<
3položka
4položka
1položka<<<
2položka
3položka
0položka<<<
1položka
2položka
<?php
// (C) 2022, Dušan Kreheľ
// Licence: MIT
class MenuBox
{
private $items=array();
private $items_count=array();
private $max_items=10;
private $position=0; /* index */
private $box_first=0; /* index */
function __construct($items, $draw_max_items)
{
$this->items=$items;
$this->max_items=$draw_max_items;
$this->items_count=count($items);
}
function down()
{
if($this->position == ($this->items_count-1))
return;
$this->position++;
if(abs($this->position-$this->box_first) == $this->max_items)
$this->box_first++;
}
function up()
{
if($this->position == 0)
return;
if($this->position == $this->box_first)
$this->box_first--;
$this->position--;
}
function draw()
{
$count_steps=$this->max_items + $this->box_first;
for($i=$this->box_first;$i<$count_steps;$i++)
if($i == $this->position)
echo " \033[35m".$this->items[$i]."\033[0m\n";
else
echo " ".$this->items[$i]."\n";
echo "\n";
}
}
$items=array("A","B","C","D","E","F","G");
$box= new MenuBox($items, 4);
$box->draw();
$box->down();
$box->draw();
$box->down();
$box->draw();
$box->down();
$box->draw();
$box->down();
$box->draw();
$box->down();
$box->draw();
$box->down();
$box->draw();
echo "hore dalej\n";
$box->up();
$box->draw();
$box->up();
$box->draw();
$box->up();
$box->draw();
$box->up();
$box->draw();
$box->up();
$box->draw();
$box->up();
$box->draw();
<?php
// (C) 2022, Dušan Kreheľ
// Licence: MIT
class MenuBox
{
private $items=array();
private $items_count=-1;
private $max_items=10;
private $position=0;
private $box_first=0;
function __construct($items, $draw_max_items)
{
$this->items=$items;
$this->max_items=$draw_max_items;
$this->items_count=count($items);
}
function down()
{
if($this->position == ($this->items_count-1))
return;
$this->position++;
if(abs($this->position-$this->box_first) == $this->max_items)
$this->box_first++;
}
function up()
{
if($this->position == 0)
return;
if($this->position == $this->box_first)
$this->box_first--;
$this->position--;
}
function draw()
{
$count_steps=$this->max_items + $this->box_first;
for($i=$this->box_first;$i<$count_steps;$i++)
if($i == $this->position)
echo " \033[35m".$this->items[$i]."\033[0m\n";
else
echo " ".$this->items[$i]."\n";
echo "\n";
}
function set_position($index_position, $index_box_first_line)
{
$this->position=$index_position;
$this->box_first=$index_box_first_line;
}
}
$items=array("A","B","C","D","E","F","G");
$box= new MenuBox($items, 4);
$box->set_position(2, 1);
$box->draw();
$box->down();
$box->draw();
$box->set_position(2, 1);tak tu hodnotu 1 musíš vypočítat ručně, ne? Myslel jsem spíš volat jen s jednou hodnotou a tu druhou by si vypočítal sám.
$box->set_position(2);Omlouvám se, ale nevím jestli se vyjadřuji k pochopení.
first = count - lines
if sel < first:
first = sel - (lines // 2)
if first < 0:
first = 0
kde first je index první položky menu, count je počet položek menu, lines je počet řádek menu
#!/usr/bin/env python3
def draw(sel, lines):
menu = ('a', 'b', 'c', 'd', 'e', 'f')
count = len(menu)
first = count - lines
if sel < first:
first = sel - (lines // 2)
if first < 0:
first = 0
print('-------------')
for line in range(lines):
item = line + first
print(menu[item], '<<<' if item == sel else '')
for sel in range(7):
draw(sel, 3)
výstup je:
$ python3 menu.py ------------- a <<< b c ------------- a b <<< c ------------- b c <<< d ------------- d <<< e f ------------- d e <<< f ------------- d e f <<< ------------- d e f
Tiskni
Sdílej: