abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:11 | Nová verze

    Yocto Project byl vydán ve verzi 5.0. Její kódové jméno je Scarthgap. Yocto Project usnadňuje vývoj vestavěných (embedded) linuxových systémů na míru konkrétním zařízením. Cílem projektu je nabídnou vývojářům vše potřebné. Jedná se o projekt Linux Foundation.

    Ladislav Hagara | Komentářů: 0
    dnes 17:56 | Nová verze

    Operační systém 9front, fork operačního systému Plan 9, byl vydán v nové verzi "do not install" (pdf). Více o 9front v FQA.

    Ladislav Hagara | Komentářů: 0
    dnes 13:11 | Nová verze

    Svobodná webová platforma pro sdílení a přehrávání videí PeerTube (Wikipedie) byla vydána v nové verzi 6.1. Přehled novinek i s náhledy v oficiálním oznámení a na GitHubu. Řešeny jsou také 2 bezpečnostní chyby.

    Ladislav Hagara | Komentářů: 2
    dnes 12:33 | Zajímavý software

    Lennart Poettering na Mastodonu představil utilitu run0. Jedná se o alternativu k příkazu sudo založenou na systemd. Bude součástí systemd verze 256.

    Ladislav Hagara | Komentářů: 12
    včera 23:22 | Nová verze

    Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.

    Ladislav Hagara | Komentářů: 11
    včera 21:44 | Komunita

    Ubuntu 24.10 bude Oracular Oriole (věštecká žluva).

    Ladislav Hagara | Komentářů: 11
    včera 20:22 | Nová verze

    Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | IT novinky

    Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".

    Ladislav Hagara | Komentářů: 0
    včera 01:00 | Nová verze

    Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:33 | Nová verze Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (75%)
     (8%)
     (2%)
     (15%)
    Celkem 885 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Konverzia unicode znaku na dva chary (utf-8)

    18.6.2008 00:52 ...............23 | skóre: 15 | blog: Various Stuff blog
    Konverzia unicode znaku na dva chary (utf-8)
    Přečteno: 541×
    V týchto veciach sa moc nevyznám ale snáď sa vyjadrím správne:
    Potrebujem nejakú funkciu (ideálne by bolo C makro) na konverziu jedného 16-bitového unicode znaku, napr. 0x00fd na dva 8-bitové znaky podľa UTF-8, v tomto prípade by to napríklad boli 0xc3 a 0xbd. Opačnú konverziu (dva chary na unicode znak) som vyhrabal v kóde SDL_ttf, ale toto som nikde nenašiel. Vďaka za každú odpoveď.

    Odpovědi

    18.6.2008 05:10 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    neslo by na to nasroubovat knihovnu iconv?
    In Ada the typical infinite loop would normally be terminated by detonation.
    18.6.2008 11:17 ...............23 | skóre: 15 | blog: Various Stuff blog
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    hm, no funkcia iconv chce na vstupe pointer na pole charov, takže už to chce asi v tvare po dvojiciach bajtov...
    18.6.2008 08:27 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    wctomb(). Pozor, vplyv má nastavenie locale (buď premenné prostredia LC_* a LANG, prípadne volanie funkcie setlocale() )
    18.6.2008 11:26 ...............23 | skóre: 15 | blog: Various Stuff blog
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    wctomb vyzerá že by to mohlo byť ono, ale stále mi to vracia -1 :-)

    proste ja by som potreboval opačnú operáciu k tomuto
    #define TO_UNICODE(c1, c2) ((Uint16)(((unsigned char)c1)&0x1F) << 6 | (Uint16)(((unsigned char)c2)&0x3F))
    ale asi nakoniec tie znaky nechám v unicode a upravím pár funkcií na prácu s nimi, bude to rýchlejšie...
    18.6.2008 12:13 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    Jste si jistý, že všechny UCS-2 znaky je možné zakódovat do 2 B UTF-8?
    18.6.2008 12:21 ...............23 | skóre: 15 | blog: Various Stuff blog
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    Do 2 bajtov samozrejme nie, ale viacbajtové znaky (japonské a podobné hovadiny) zatiaľ nepotrebujem :-)
    18.6.2008 16:52 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    I české texty ale nebudou mít v UTF-8 všechny znaky dvoubajtové – spodní polovina ASCII tabulky se kóduje v UTF-8 do jednobajtových znaků.
    18.6.2008 18:27 ...............23 | skóre: 15 | blog: Various Stuff blog
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    Konvertujem len znaky ktoré nie sú v ASCII... Proste pri stlačení klávesu dostanem unicode číslo toho znaku a potrebujem ho skonvertovať na UTF-8, viď tu http://www.libsdl.org/cgi/docwiki.cgi/SDL_keysym

    Druhá možnosť by bola nechať tie data v unicode, ale to by som musel upraviť istú časť kódu ktorý už mám...
    18.6.2008 19:13 Andrej Herceg | skóre: 43
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    Možno by sa dalo použiť niečo takéto (nerieši sa tam endianness):
    #include <stdio.h>
    
    #define FROM_UNICODE(c, c1, c2, c3) \
    if ((Uint16)(c) <= 0x7f) { \
    	c1 = (unsigned char)(c); \
    	c2 = c3 = 0; \
    } else if ((Uint16)(c) <= 0x7ff) { \
            c1=(unsigned char)(((c) >> 6) | 0xc0); \
            c2=(unsigned char)(((c) & 0x3f) | 0x80); \
            c3 = 0; \
    } else if ((Uint16)(c) <= 0xd7ff) { \
            c1=(unsigned char)(((c) >> 12) | 0xe0); \
            c1=(unsigned char)((((c) >> 6) & 0x3f) | 0x80); \
            c3=(unsigned char)(((c) & 0x3f) | 0x80); \
    } else { \
    	c1 = c2 = c3 = 0; \
    }
    
    typedef unsigned short int Uint16;
    
    int main(void)
    {
    	Uint16 z = 0xfd;
    	unsigned char c1, c2, c3;
    
    	FROM_UNICODE(z, c1, c2, c3);
    
    	printf("%x, %x %x %x\n", z, c1, c2, c3);
    	return 0;
    }
    
    Ja by som tam pravdepodobne používal originálne dáta v UCS-2 alebo v UTF-16 (alebo čo sa to tam vlastne používa).
    18.6.2008 19:47 ...............23 | skóre: 15 | blog: Various Stuff blog
    Rozbalit Rozbalit vše Re: Konverzia unicode znaku na dva chary (utf-8)
    Super, díky moc! To je presne čo som potreboval.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.