Český telekomunikační úřad zveřejnil Výroční zprávu za rok 2024 (pdf), kde shrnuje své aktivity v loňském roce a přináší i základní popis situace na trhu. Celkový objem přenesených mobilních dat za rok 2024 dosáhl dle odhadu hodnoty přibližně 1,73 tis. PB a jeho meziroční nárůst činí zhruba 30 %. Průměrná měsíční spotřeba dat na datovou SIM kartu odhadem dosáhla 12,5 GB – v předchozím roce šlo o 9,8 GB.
Z novinek představených na Google I/O 2025: Přehledy od AI (AI Overviews) se rozšiřují do dalších zemí. Užitečné, syntetizované přehledy od generativní AI jsou nově k dispozici i českým uživatelům Vyhledávače.
Šestice firem označovaných jako „MAMAAN“ – tedy Meta (Facebook, Instagram), Alphabet (Google), Microsoft, Apple, Amazon a Netflix – je zodpovědná za více než padesát procent světového internetového provozu. Dalšími velkými hráči jsou TikTok a Disney+. Společně tak zásadně určují podobu digitálního prostředí, spotřebitelského chování i budoucích trendů v oblasti technologií. I přesto, že se podíl těchto gigantů od roku 2023 o něco snížil, jejich dominantní postavení zvyšuje volání po regulaci.
Evropská komise (EK) navrhuje zavést plošný poplatek ve výši dvou eur (zhruba 50 Kč) za každý malý balík vstupující do Evropské unie. Poplatek se má týkat balíků v hodnotě do 150 eur (zhruba 3700 Kč), které v EU nepodléhají clu. V loňském roce bylo do EU doručeno kolem 4,6 miliardy takovýchto balíků. Poplatek má krýt náklady na kontroly rostoucího počtu zásilek levného zboží, které pochází především z Číny.
Dnes a zítra probíhá vývojářská konference Google I/O 2025. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
V Bostonu probíhá konference Red Hat Summit 2025. Vybrané přednášky lze sledovat na YouTube. Dění lze sledovat na síti 𝕏 (#RHSummit).
Společnost Red Hat oficiálně oznámila vydání Red Hat Enterprise Linuxu 10. Vedle nových vlastností přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Podrobnosti v poznámkách k vydání.
Tuto sobotu 24. května se koná historicky první komunitní den projektu Home Assistant. Zváni jsou všichni příznivci, nadšenci a uživatelé tohoto projektu. Pro účast je potřebná registrace. Odkazy na akce v Praze a v Bratislavě.
Troy Hunt představil Have I Been Pwned 2.0, tj. nový vylepšený web služby, kde si uživatelé mohou zkontrolovat, zda se jejich hesla a osobní údaje neobjevily v únicích dat a případně se nechat na další úniky upozorňovat.
Microsoft představil open source textový editor Edit bežící v terminálu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
O co jde. Uživatel celý život tvořil literární díla na mechanickém psacím stroji a návrhům na užití elektrického stroje či počítače tvrdohlavě odolával. Jenže slábnoucí zrak už má problém s malými nekontrastními písmeny na papíře. Řešením by mohla být rozumně velká obrazovka s klávesnicí, ale v módu co nejvíce emulujícím psací stroj (typewriter, proto TWedit ...).
Takže co musí textový editor umět:
Mám představu, že by to běželo na upraveném raspbianu a z hlediska uživatele by se to prostě zaplo do zdi, co nejrychleji nabootovalo a psalo se. Ukládání po wifi a jako záloha lokálně (fleška ? datový oddíl). Ideální by bylo, kdyby se to dalo vypnout prostým vytažením ze zdi, což řeší i možné výpadky proudu atd. Rychlý sync jednoho souboru si dovedu po wifi představit i častěji než za vteřinu. Jen si nejsem jistý, jestli nevyjít z něčeho prefabrikovaného (QT4 ? nějaká pythoní zhůvěřilost ?), grafiku si "řešit sám" anebo to pojmout jako terminálový program ?. Dalo by se to psát i v C/C++ ale pro tento účel je i rpi "dělo", takže bych to klidně spatlal v pythonu.
Díky za tipy, nápady a připomínky (sorry, asi by to patřilo spíš do poradny než do blogu, ale myslím, že by to tam zapadlo)
Tiskni
Sdílej:
No jako hračka je to pěkný. Reálně jsem na mechanickém psacím stroji začínal a musím říct, že se nechová zcela stejně. Korekční myši se stále prodávají, stejně tak páska (i když červenočervenou jsem už dlouho nekupoval, tak nevím). Spíš bych později implementoval funkci "přepiš slovo" (na jeden čudlík).
Textadept není v debianních repozitáříchStiahni si binárku.
import java.awt.Dimension; import java.awt.HeadlessException; import javax.swing.JFrame; import javax.swing.JTextPane; public class ParodyTextEditor extends JFrame { public ParodyTextEditor() throws HeadlessException { JTextPane tp = new JTextPane(); setMinimumSize(new Dimension(400, 300)); setContentPane(tp); } public static void main(String[] args) { ParodyTextEditor te = new ParodyTextEditor(); te.pack(); te.setVisible(true); } }
import java.awt.Frame; import java.awt.HeadlessException; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.StringReader; import javax.swing.JFrame; import javax.swing.JTextPane; public class ParodyTextEditor extends JFrame { private class WindowAdapterSave extends WindowAdapter { @Override public void windowClosing(WindowEvent e) { saveFile(); } } private String fileName; JTextPane tp = new JTextPane(); public ParodyTextEditor(String fileName) throws HeadlessException { this.fileName = fileName; setContentPane(tp); addWindowListener(new WindowAdapterSave()); openFile(); } public void openFile() { try { BufferedReader fr = new BufferedReader(new FileReader(fileName)); String s = null; StringBuilder sb = new StringBuilder(); String nr = System.getProperty("line.separator"); while ((s = fr.readLine()) != null) { sb.append(s); sb.append(nr); } fr.close(); tp.setText(sb.toString()); } catch (Exception e) { e.printStackTrace(); } } public void saveFile() { BufferedReader br = new BufferedReader(new StringReader(tp.getText())); try { BufferedWriter bw = new BufferedWriter(new FileWriter(fileName)); String s = null; while ((s = br.readLine()) != null) { bw.write(s); bw.newLine(); } bw.flush(); bw.close(); } catch (Exception e) { System.err.println("Do souboru se nepovedlo zapsat."); } } public static void main(String[] args) { String fn; if (args.length == 0) fn = System.getProperty("user.home") + System.getProperty("file.separator") + "test.txt"; else fn = args[0]; ParodyTextEditor te = new ParodyTextEditor(fn); te.pack(); if (te.getExtendedState() != Frame.MAXIMIZED_BOTH) te.setExtendedState(Frame.MAXIMIZED_BOTH); te.setResizable(false); te.setVisible(true); } }
e.printStackTrace();
te.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);Takže s každým spuštěním zůstane po zavření okna aktivní instance Java Virtual Machine.
Kódovaní je implicitní Javy, kde ho nastavovat ?No právě, implicitní = závislé na platformě a jazyku/locale. Takže pokud někdo má angličtinu a otevře UTF-8 soubor, tak si užije spoustu zajímavých otazníčků (o tom že by tam byly nějaké bukvy nebo katakana ani nemluvě).
Máme 21. století, textové soubory mají být v UTF-8!
Vždy používat Files.newBufferedReader (pro 6 a nižší kombianci FileInputStream + InputStreamReader) s explicitně určeným kódováním. FileReader měl být IMCO Deprecated už v 1.2Za hrubku považuji zapomenutýJo, tohle... to si nejsem jist jak tohle vadí na serverech, tam se většinou GUI nespouštíte.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);Takže s každým spuštěním zůstane po zavření okna aktivní instance Java Virtual Machine.
Jo, tohle... to si nejsem jist jak tohle vadí na serverech, tam se většinou GUI nespouštíMe to taky zmatlo. Proto jsem zminoval to handlovani vyjimky.
FileReader určitě není Deprecated ani v Javě 1.8, tím jsem si jist.Ne, ale měl by. Spousta lidí si totiž myslí toto:
Implicitní kódování Javy je UTF8, takže by mělo vyhovět.A to právě není pravda - implicitní kódování je určeno podle nastavení uživatele (závisí na platformě: locale, user settings, lokalizace OS, atd). Ukázka (groovy, aby to byl oneliner):
augur:~ % (export LC_ALL=cs_CZ ; echo "ďábelský kůň и буквы" | groovy -e 'println new FileReader(new FileDescriptor(0)).readLine()') ďábelský kůň и буквы augur:~ % (export LC_ALL=C ; echo "ďábelský kůň и буквы" | groovy -e 'println new FileReader(new FileDescriptor(0)).readLine()') ????belsk?? k???? ?? ??????????Jasně, v případě jednoúčelového psacího stroje to problém není, ale u aplikací běžících na serveru (kde se často věci spouští bez jakéhokoliv locale) nebo na růzých mutaích Windows to bývá docela chyták.
public class JTextPaneWdthHighRow extends JTextPane { private static final long serialVersionUID = 802326126658140029L; public JTextPaneWdthHighRow() { init(); } public JTextPaneWdthHighRow(StyledDocument doc) { super(doc); init(); } private void init(){ setOpaque(false); } @Override protected void paintComponent(Graphics g) { g.setColor(getBackground()); g.fillRect(0, 0, getWidth(), getHeight()); try { Rectangle rect = modelToView(getCaretPosition()); if (rect != null) { g.setColor(Color.CYAN); g.fillRect(0, rect.y, getWidth(), rect.height); } } catch (BadLocationException e) { } super.paintComponent(g); } @Override public void repaint(long tm, int x, int y, int width, int height) { // This forces repaints to repaint the entire TextPane. super.repaint(tm, 0, 0, getWidth(), getHeight()); } }
import java.awt.Frame; import java.awt.HeadlessException; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.StringReader; import javax.swing.JFrame; import javax.swing.JTextPane; import javax.swing.text.AbstractDocument; import javax.swing.text.AttributeSet; import javax.swing.text.BadLocationException; import javax.swing.text.DefaultStyledDocument; import javax.swing.text.DocumentFilter; import javax.swing.text.StyledDocument; public class ParodyTextEditor extends JFrame { private static final String N_L = "\n"; private class BeepDocListener extends DocumentFilter { @Override public void replace(FilterBypass fb, int offset, int length, String text, AttributeSet attrs) throws BadLocationException { if (N_L.equals(text)) { java.awt.Toolkit.getDefaultToolkit().beep(); //System.out.println("Beep"); } super.replace(fb, offset, length, text, attrs); } @Override public void insertString(FilterBypass fb, int offset, String string, AttributeSet attr) throws BadLocationException { if (N_L.equals(string)) { java.awt.Toolkit.getDefaultToolkit().beep(); //System.out.println("Beep"); } super.insertString(fb, offset, string, attr); } } private static final long serialVersionUID = -8546298818112441622L; private class WindowAdapterSave extends WindowAdapter { @Override public void windowClosing(WindowEvent e) { saveFile(); } } private String fileName; private JTextPane tp; private StyledDocument styledDocument; public ParodyTextEditor(String fileName) throws HeadlessException { this.fileName = fileName; setContentPane(getTp()); addWindowListener(new WindowAdapterSave()); openFile(); } public void openFile() { try { BufferedReader fr = new BufferedReader(new FileReader(fileName)); String s = null; StringBuilder sb = new StringBuilder(); String nr = System.getProperty("line.separator"); while ((s = fr.readLine()) != null) { sb.append(s); sb.append(nr); } fr.close(); getTp().setText(sb.toString()); } catch (Exception e) { System.err.println("Nepovedlo se nacist soubor."); e.printStackTrace(System.err); } } public void saveFile() { BufferedReader br = new BufferedReader(new StringReader(getTp().getText())); try { BufferedWriter bw = new BufferedWriter(new FileWriter(fileName)); String s = null; while ((s = br.readLine()) != null) { bw.write(s); bw.newLine(); } bw.flush(); bw.close(); } catch (Exception e) { System.err.println("Do souboru se nepovedlo zapsat."); e.printStackTrace(System.err); } } public static void main(String[] args) { String fn; if (args.length == 0) fn = System.getProperty("user.home") + System.getProperty("file.separator") + "test.txt"; else fn = args[0]; ParodyTextEditor te = new ParodyTextEditor(fn); te.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); te.pack(); if (te.getExtendedState() != Frame.MAXIMIZED_BOTH) te.setExtendedState(Frame.MAXIMIZED_BOTH); te.setResizable(false); te.setVisible(true); } protected JTextPane getTp() { if (tp == null) { tp = new JTextPane(getStyledDocument()); ((AbstractDocument) tp.getDocument()).setDocumentFilter(new BeepDocListener()); } return tp; } protected StyledDocument getStyledDocument() { if (styledDocument == null) { styledDocument = new DefaultStyledDocument(); } return styledDocument; } }