8.2. Video výstupy pro tradiční video karty

8.2.1. Xv

Pod XFree86 4.0.2, nebo novějším, můžete použít hardwarové YUV rutiny karty pomocí rozšíření XVideo. Přesně toto používá volba -vo xv. Toto rozhraní také podporuje nastavování jasu/kontrastu/barevného tónu atd. (pokud nepoužíváte strarý, pomalý DirectShow DivX kodek, který to podporuje všude), viz man stránka.

Abyste to zprovoznili, ujistěte se o následujícím:

  1. Musíte používat XFree86 4.0.2 nebo novější (předchozí verze nemají XVideo)

  2. Vaše karta aktuálně podporuje hardwarovou akceleraci (moderní karty ano)

  3. X nahrává rozšíření XVideo. Zpráva ve /var/log/XFree86.0.log vypadá asi takto:

    (II) Loading extension XVideo

    Poznámka

    Takto se nahraje pouze rozšíření pro XFree86. To je v dobré instalaci nahráno vždy a neznamená to, že je načtena i podpora XVideo pro kartu!

  4. Vaše karta má podporu Xv pod Linuxem. Abyste si to ověřili, zkuste xvinfo, které je součástí distribuce XFree86. Měl by se vypsat dlouhý text podobný tomuto:

    X-Video Extension version 2.2
    screen #0
      Adaptor #0: "Savage Streams Engine"
        number of ports: 1
        port base: 43
        operations supported: PutImage
        supported visuals:
          depth 16, visualID 0x22
          depth 16, visualID 0x23
        number of attributes: 5
    (...)
        Number of image formats: 7
          id: 0x32595559 (YUY2)
            guid: 59555932-0000-0010-8000-00aa00389b71
            bits per pixel: 16
            number of planes: 1
            type: YUV (packed)
          id: 0x32315659 (YV12)
            guid: 59563132-0000-0010-8000-00aa00389b71
            bits per pixel: 12
            number of planes: 3
            type: YUV (planar)
    (...atd...)

    Musí podporovat pixelové formáty YUY2 packed a YV12 planar, aby byla použitelná s MPlayerem.

  5. A nakonec si ověřte, jestli byl MPlayer skompilován s podporou 'xv'. Proveďte mplayer -vo help | grep xv . Pokud byla skompilována podpora 'xv', měl by se objevi řádek podpobný tomuto:

      xv      X11/Xv

8.2.1.1. Karty 3dfx

Starší ovladače 3dfx byly známy svými problémy s XVideo akcelerací. Nepodporovaly ani YUY2 ani YV12, atp. Ověřte, že máte XFree86 verze 4.2.0 nebo vyšší, které pracuje dobře s YV12 a YUY2. Předchozí verze, včetně 4.1.0, padá s YV12. Pokud zažívate podivné situace při používání -vo xv, zkuste SDL (má rovněž XVideo) a uvidíte, zda to pomůže. Prostudujte si sekci SDL pro více informací.

NEBO, zkuste NOVÉ -vo tdfxfb rozhraní! Viz sekce tdfxfb.

8.2.1.2. Karty S3

S3 Savage3D by měly fungovat dobře, ale pro Savage4 použijte XFree86 verze 4.0.3 nebo vyšší (v případě problémů s obrazem, zkuste 16bpp). Stejně ajko S3 Virge: má sice podporu xv, ale karta samotná je velmi pomalá, takže ji raději prodejte.

Pro karty S3 Virge nyní existuje nativní framebuffer ovladač podobný tdfxfb. Nastavte si framebuffer (čili přidejte "vga=792 video=vesa:mtrr" do příkazového řádku kernelu) a použijte -vo s3fb (-vf yuy2 a -dr rovněž pomůžou).

Poznámka

Zatím není jasné, kterým modelům Savage chybí podpora YV12 a konvertují ovladačem (pomalé). Pokud podezříváte kartu, opatřete si novější ovladač, nebo slušně požádejte v konferenci MPlayer-users o ovladač s MMX/3DNow!.

8.2.1.3. Karty nVidia

nVidia není vždy pod Linuxem nejlepší volbou... Open-source ovladač v XFree86 podporuje většinu těchto karet, ale v některých případech musíte použít binární closed-source ovladač od nVidie, který je k dispozici na serveru nVidia. Tento ovladač budete potřebovat vždy, pokud zároveň chcete 3D akceleraci.

Karty Riva128 nemají podporu XVideo v nVidia ovladači z XFree86 :( Stěžujte si nVidii.

Ačkoli MPlayer obsahuje VIDIX ovladač pro většinu nVidia karet, zatím je ve stavu beta verze a má jisté nedostatky. Více informací naleznete v sekci nVidia VIDIX.

8.2.1.4. Karty ATI

Ovladač GATOS (který byste měli použít, pokud nemáte Rage128 nebo Radeon) má zapnutý VSYNC ve výchozím stavu. To znamená, že rychlost dekódování (!) je synchronizována s obnovovacím kmitočtem monitoru. Pokud se vám zdá přehrávání pomalé, zkuste nějak vypnout VSYNC, nebo nastavte obnovovací kmitočet na n*(snímková rychlost filmu) Hz.

Radeon VE - pokud potřebujete X, použijte pro tuto kartu XFree86 4.2.0 nebo vyšší. Není zde podpora pro TV out. Samozřejmě s MPlayerem můžete mít s trochou štěstí akcelerovaný display s nebo bez TV výstupu a nepotřebujete žádné X knihovny. Přečtěte si sekci VIDIX.

8.2.1.5. Karty NeoMagic

Tyto karty lze nalézt v mnoha laptopech. Musíte použít XFree86 4.3.0 nebo vyšší, nebo použijte ovladače s podporou Xv od Stefana Seyfrieda. Stačí vybrat ten, který je vhodný pro vaši verzi XFree86.

XFree86 4.3.0 obsahuje podporu Xv, avšak Bohdan Horst poslal malý patch pro zdrojový kód XFree86, který zrychluje operace s framebufferem (čili XVideo) až čtyřikrát. Patch byl zařazen do XFree86 CVS a měl by být v další verzi vydané po 4.3.0.

Abyste mohli přehrávat obsah velikosti DVD, změňte svůj XF86Config takto:

Section "Device"
    [...]
    Driver "neomagic"
    Option "OverlayMem" "829440"
    [...]
EndSection

8.2.1.6. Karty Trident

Chcete-li používat Xv s kartou Trident, což nepracuje s 4.1.0, nainstalujte si XFree 4.2.0. 4.2.0 přidává podporu pro celoobrazovkové Xv pro kartu Cyberblade XP.

Alternativně, MPlayer obsahuje VIDIX ovladač pro kartu Cyberblade/i1.

8.2.1.7. Karty Kyro/PowerVR

Pokud chcete používat Xv s kartou založenou na čipu Kyro (například Hercules Prophet 4000XT), měli byste si stáhnout ovladače z PowerVR serveru.

8.2.2. DGA

PŘEDMLUVA.  Tento dokument se několika slovy snaží vysvětlit co je to DGA a co výstupní videorozhraní DGA pro MPlayer udělat může (a co ne).

CO JE DGA.  DGA je zkratka pro Direct Graphics Access, což je program pro obejití X servru a přímou modifikaci paměti framebufferu. Technicky to znamená mapování paměti framebufferu do paměťového prostoru vašeho procesu. To kernel umožňuje pouze pokud máte práva superuživatele. Ty dostanete buď nalogováním se jako root, nebo nastavením SUID bitu spustitelnému souboru MPlayeru (nedoporučujeme ).

Existují dvě verze DGA: DGA1 je používáno XFree 3.x.x a DGA2 bylo představeno v XFree 4.0.1.

DGA1 poskytuje pouze přímý přístup k framebufferu jak byl popsán výše. Chcete-li přepínat rozlišení videosignálu, musíte se spolehnout na rozšíření XVidMode.

DGA2 zahrnuje vlastnosti rozšíření XVidMode a rovněž umožňuje přepínat barevnou hloubku zobrazovače. Takže můžete jendoduše provozovat X server s hloubkou 32 bitů a přepnout na barevnou hloubku 15 bitů a naopak.

DGA má ovšem i jisté obtíže. Zdá se, že je nějak závislé na grafickém čipu, který používáte a na implementaci video ovladače X serveru, který tento čip obsluhuje. Takže nefunguje na všech systémech...

INSTALACE PODPORY DGA PRO MPLAYER.  Nejprve si ověřte, že X nahrávají rozšíření DGA, viz v /var/log/XFree86.0.log:

(II) Loading extension XFree86-DGA

XFree86 4.0.x nebo vyšší je vřele doporučován! Video rozhraní DGA MPlayeru je autodetekováno ./configure, nebo jej můžete vynutit pomocí --enable-dga.

Pokud rozhraní nemůže přepnout do menšího rozlišení, experimentujte s volbami -vm (pouze s X 3.3.x), -fs, -bpp, -zoom, abyste nalezli videorežim, do kterého se video napasuje. Momentálně není žádný převodník :(

Staňte se rootem. DGA vyžaduje práva roota, aby mohl přímo zapisovat do video paměti. Pokud jej chcete provozovat jako uživatel, pak nainstalujte MPlayer jako SUID root:

chown root /usr/local/bin/mplayer
chmod 750 /usr/local/bin/mplayer
chmod +s /usr/local/bin/mplayer

A nyní to bude pracovat také pod obyčejným uživatelem.

Bezpečnostní riziko

Toto je velké bezpečnostní riziko! Nikdy to nedělejte na serveru nebo počítači ke kterému mohou mít přístup ostatní lidé, jelikož ti mohou získat superuživatelská práva díky SUID root MPlayeru.

Nyní použijte volbu -vo dga a je to! (doufám:) Také byste měli vyzkoušet, jestli vám pracuje volba -vo sdl:dga! Je mnohem rychlejší!

PŘEPÍNÁNÍ ROZLIŠENÍ.  Rozhraní DGA umožňuje přepínání rozlišení výstupního signálu. To odstraňuje potřebu (pomalého) softwarového škálování a zároveň poskytuje obraz na celou obrazovku. Ideálně by se mělo přepnout na přesné rozlišení (s výjimkou dodržení poměru stran) video dat, ale X server umožňuje poze přepínání do rozlišení předdefinovaných v /etc/X11/XF86Config (nebo /etc/X11/XF86Config-4 pro XFree 4.X.X). Ty jsou definovány takzvanými "modelines" a závisí na schopnostech vašeho video hardwaru. X server projíždí tento konfigurační soubor při startu a zakáže režimy (modelines) nevhodné pro váš hardware. Povolené videorežimy naleznete v X11 log souboru. Tel lze nalézt zde: /var/log/XFree86.0.log.

Tyto vstupy jsou známy dobrou funkcí na Riva128 čipu, s použitím modulu ovladače nv.o X serveru.

Section "Modes"
  Identifier "Modes[0]"
  Modeline "800x600"  40     800 840 968 1056  600 601 605 628
  Modeline "712x600"  35.0   712 740 850 900   400 410 412 425
  Modeline "640x480"  25.175 640 664 760 800   480 491 493 525
  Modeline "400x300"  20     400 416 480 528   300 301 303 314 Doublescan
  Modeline "352x288"  25.10  352 368 416 432   288 296 290 310
  Modeline "352x240"  15.750 352 368 416 432   240 244 246 262 Doublescan
  Modeline "320x240"  12.588 320 336 384 400   240 245 246 262 Doublescan
EndSection

DGA & MPLAYER.  DGA je v MPlayeru použito na dvou místech: SDL rozhraní může být nastaveno pro jeho použití (-vo sdl:dga) a přímé DGA rozhraní (-vo dga). Výše uvedené je platné pro obě varianty; v následující sekci vysvětlíme jak pracuje DGA rozhraní MPlayeru.

VLASTNOSTI.  DGA rozhraní je použito zadáním volby -vo dga na příkazovém řádku. Výchozím chováním je přepnout na rozlišení co nejbižší originálním rozměrům videa. Zcela záměrně se ignorují volby -vm a -fs (umožňující přepínání videorežimů a zobrazení na celou obrazovku) - vždy zkouší pokrýt tak velkou plochu obrazovky, jak je to jen možné pomocí přepnutí videorežimu, což nás oprostí od využívání dalších CPU cyklů pro škálování obrazu. Pokud se vám nelíbí režim, který vybere automatika, můžete ji přinutit pro výběr režimu nejblíže odpovídajícímu rozlišení, které zadáte pomocí -x a -y. Při zadání volby -v, vypíše DGA rozhraní, spolu s dalšími věcmi, seznam všech rozlišení podporovaných vašim aktuálním XF86Config souborem. Máte-li DGA2, můžete jej rovněž přinutit použít různé barevné hloubky pomocí volby -bpp. Platné barevné hloubky jsou 15, 16, 24 a 32. To jestli jsou tyto barevné hloubky nativně podporovány, nebo musí být provedena (pravděpodobně pomalá) konverze závisí na vašem hardware.

Pokud jste natolik šťastlivci, že máte dostatek volné mimoobrazové paměti, aby se zde vměstnal celý obrázek, použije DGA rozhraní dvojitou vyrovnávací paměť, což vám zajistí mnohem plynulejší přehrávání filmů. Rozhraní vás bude informovat jestli je dvojitý buffer zapnutý nebo ne.

Dvojitou vyrovnávací pamětí se rozumí to, že je další snímek vykreslován do paměti mimo zobrazovanou plochu, zatímco je zobrazován aktuální snímek. Jakmile je další snímek připraven, grafický čip je informován o pozici v paměti, kde je nový snímek a jednoduše přesune data k zobrazení odtud. Mezitím je další buffer v paměti zaplňován novými videodaty.

Dvojitá vyrovnávací paměť může být zapnuta volbou -double a vypnuta volbou -nodouble. Současná výchozí hodnota je vypnutí dvojité vyrovnávací paměti. Při použití DGA rozhraní bude display na obrazovce (OSD) pracovat pouze při zapnuté dvojité vyrovnávací paměti. Zapnutí dvojité vyrovnávací paměti však může vyústit velkou ztrátou výkonu (na mé K6-II+ 525 to použije dalších 20% CPU výkonu!) v závislosti na implementaci DGA pro váš hardware.

OTÁZKA RYCHLOSTI.  Obecně by přístup přes DGA framebuffer měl být alespoň tak rychlý jako použití rozhraní X11 navíc s celoobrazovkovým režimem. Procentní hodnoty rychlosti vypisované MPlayerem byste měli brát s rezervou, jelikož například při použití X11 nezahrnují čas spotřebovaný X serverem pro vlastní vykreslování. Zavěste terminál na sériovou linku počítače a spusťte top, abyste viděli co se opravdu děje ve vašem počítači.

Obecně zrychlení použitím DGA oproti 'běžnému' X11 velmi závisí na vaší grafické kertě a jak dobře je pro ni optimalizován modul X serveru.

Pokud máte pomalý stroj, raději použijte 15 nebo 16 bitovou hloubku, jelikož vyžaduje pouze poloviční průchodnost paměti oproti 32 bitovému zobrazení.

Použití hloubky 24 bitů je dobré i v případě, že vaše karta nativně podporuje pouze barevnou hloubku 32 bitů, jelikož se přenáší o 25% méně dat oproti režimu 32/32.

Viděl jsem pár AVI souborů přehrávat na Pentiu MMX 266. Procesory AMD K6-2 pracují při 400 MHZ a výše.

ZNÁMÉ CHYBY.  Podle některých vývojářů XFree je DGA zvěrstvo. Říkají, abyste je raději nepoužívali. Jeho implementace není vždy bezproblémová v každém dostupném ovladači pro XFree.

  • V XFree 4.0.3 je v nv.o chyba vedoucí k podivným barvám.

  • Ovladač pro ATI vyžaduje více než jedno zpětné přepnutí režimu po skončení používání DGA.

  • Některé ovladače selžou při přepnutí do normálního rozlišení (použijte Ctrl-Alt-Numerické + a Ctrl-Alt-Numerické - pro ruční přepnutí).

  • Některé ovladače zobrazují divné barvy.

  • Některé ovladače lžou o množství paměti kterou mapují do adresového prostoru procesu, takže vo_dga nepoužije dvojitou vyrovnávací paměť (SIS?).

  • Některé ovladače nezvládnou ohlásit dokonce ani jeden platný režim. V tom případě rozhraní DGA spadne s hláškou o nesmaslném režimu 100000x100000 nebo tak.

  • OSD pracuje pouze se zapnutou dvojitou vyrovnávací pamětí (jinak poblikává).

8.2.3. SDL

SDL (Simple Directmedia Layer) je zjednodušeně unifikované video/audio rozhraní. Programy, které ji používají, znají pouze SDL a ne jaký audio nebo video ovladač SDL aktuálně používá. Například klon DOOMa může běžet na svgalib, aalib, X, fbdev a dalších. Musíte jen nastavit (například) video ovladač pomocí proměnné prostředí SDL_VIDEODRIVER. Aspoň teoreticky.

V MPlayeru používáme její softwarový škálovač ovladače X11 pro karty/ovladače, které nepodporují XVideo, dokud nevytvoříme vlastní (rychlejší, hezčí) softwarový škálovač. Rovněž jsme používali její výstup na aalib, ale nyní máme vlastní, což je mnohem pohodlnější. Její DGA režim byl až doposud lepší než náš. Sledujete? :)

Rovněž pomáhá s některými chybnými ovladači/kartami, pokud je video roztřesené (nikoli problém pomalého stroje), nebo se zpožďuje zvuk.

SDL video rozhraní podporuje zobrazování titulků pod filmem, v (pokud je) černém okraji.

8.2.4. SVGAlib

INSTALACE.  Budete muset nainstalovat svgalib i s development balíčkem, aby MPlayer vytvořil své SVGAlib rozhraní (autodetekováno, ale nelze vynutit) a nezapomeňte upravit /etc/vga/libvga.config tak, aby odpovídal vaší kartě a monitoru.

Poznámka

Ujistěte se, že nepoužíváte volbu -fs, jelikož zapíná použití softwarového škálování, což je pomalé. Pokud jej opravdu potřebujete, použijte volbu -sws 4, což poskytuje špatnou kvalitu, ale je o poznání rychlejší.

PODPORA EGA (4BPP).  SVGAlib obsahuje EGAlib a MPlayer umí zobrazovat jakýkoli film v 16 barvách, což je vhodné v následujících konfiguracích:

  • EGA karta s EGA monitorem: 320x200x4bpp, 640x200x4bpp, 640x350x4bpp

  • EGA karta s CGA monitorem: 320x200x4bpp, 640x200x4bpp

Hodnota bpp (bitů na pixel) musí být nastavena na 4 ručně: -bpp 4

Obraz bude nejspíš muset být zmenšený tak, aby se vešel v EGA režimu:

-vf scale=640:350

nebo

-vf scale=320:200

Když potřebujeme rychlou, ale nekvalitní škálovací rutinu:

-sws 4

Možná bude muset být vypnuta automatická korekce poměru stran:

-noaspect

Poznámka

Podle mých zkušeností lze dosáhnout nejlepší kvality obrazu na EGA obrazovkách mírným snížením jasu: -vf eq=-20:0. Na svém počítači jsem rovněž musel snížit vzorkovací kmitočet zvuku, protože zvuk pří 44kHz byl vadný: -srate 22050.

Zapnout OSD a titulky můžete pouze v kombinaci s expand filtrem, viz man stránka pro přesné parametry.

8.2.5. Výstup na Framebuffer (FBdev)

Podpora pro cíl FBdev je autodetekována během ./configure. Přečtěte si dokumentaci framebufferu ve zdrojových kódech kernelu (Documentation/fb/*) pro více informací.

Pokud vaše karta nepodporuje standard VBE 2.0 (starší ISA/PCI karty, jako S3 Trio64), pouze VBE 1.2 (nebo straší?): Nuže, stále máte k dispozici VESAfb, ale budete muset nahrát SciTech Display Doctor (původně UniVBE) před startem Linuxu. Použijte bootovací disk DOSu nebo tak. A nezapoměňte si zaregistrovat svůj UniVBE ;))

Výstup FBdev přijímá několik dodatečných voleb:

-fb

nastaví zařízení framebufferu k použití (výchozí: /dev/fb0)

-fbmode

název režimu k použití (podle /etc/fb.modes)

-fbmodeconfig

config soubor režimů (výchozí: /etc/fb.modes)

-monitor-hfreq, -monitor-vfreq, -monitor-dotclock

důležité hodnoty, viz example.conf

Pokud se chcete přepnout do určitého režimu, pak použijte

mplayer -vm -fbmode name_of_mode soubor

  • -vm samotná zvolí nejpříhodnější režim z /etc/fb.modes. Může být rovněž použita spolu s volbami -x a -y. Volba -flip je podporována pouze pokud pixelový formát filmu odpovídá pixelovému formátu videorežimu. Věnujte pozornost hodnotě bpp. Ovladač fbdev zkusí použít aktuální, nebo pokud zadáte volbu -bpp, pak tuto.

  • Volba -zoom není podporována (použijte -vf scale). Nelze použít režimy 8bpp (nebo nižší).

  • Pravděpodobně budete chtít vypnout kursor:

    echo -e '\033[?25l'

    nebo

    setterm -cursor off

    a spořič obrazovky:

    setterm -blank 0

    Pro opětovné zapnutí kursoru:

    echo -e '\033[?25h'

    nebo

    setterm -cursor on

Poznámka

Změna videorežimu FBdev nepracuje ve VESA framebufferu a nechtějte to po nás, jelikož to není omezení MPlayeru.

8.2.6. Matrox framebuffer (mga_vid)

mga_vid je kombinací výstupního video rozhraní a Linuxového jaderného modulu, který používá Matrox G200/G400/G450/G550 video scaler/overlay jednotku pro konverzi YUV->RGB barevného prostoru a libovolé škálování videa. mga_vid má hardwarovou podporu VSYNC s trojitou vyrovnávací pamětí. Pracuje jak ve framebuffer konzoli, tak v X, ale pouze s Linuxem 2.4.x.

Chcete-li verzi ovladače pro Linux 2.6.x, podívejte se na http://attila.kinali.ch/mga/.

Instalace:

  1. Pokud jej chcete použít, nejdříve musíte sestavit mga_vid.o:

    cd drivers
    make

  2. Pake spusťte (jako root)

    make install

    což by mělo nainstalovat modul a vytvořit pro vás soubor zařízení. Ovladač nahrajte pomocí

    insmod mga_vid.o

  3. Měli byste ověřit velikost detekované paměti pomocí příkazu dmesg. Pokud je špatná, použijte volbu mga_ram_size (nejdřív rmmod mga_vid), nastavte velikost paměti karty v MB:

    insmod mga_vid.o mga_ram_size=16

  4. Aby se nahrával/odstraňoval automaticky podle potřeby, nejdříve přidejte následující řádek na konec /etc/modules.conf:

    alias char-major-178 mga_vid

  5. Teď budete muset (pře)kompilovat MPlayer, ./configure zdetekuje /dev/mga_vid a zakompiluje 'mga' rozhraní. V MPlayeru se používá pomocí -vo mga pokud máte matroxfb konzoli, nebo -vo xmga pod XFree86 3.x.x nebo 4.x.x.

Ovladač mga_vid spolupracuje s Xv.

Určité informace lze přečíst z /dev/mga_vid zařízení, například pomocí

cat /dev/mga_vid

a může do něj být zapsána změna jasu:

echo "brightness=120" > /dev/mga_vid

Ve stejném adresáři je i testovací aplikace jménem mga_vid_test. Měla by na obrazovku kreslit obrázky 256x256 bodů, pokud vše pracuje jak má.

8.2.7. Podpora 3Dfx YUV

Tento ovladač používá ovladač framebufferu tdfx z jádra pro přehrávání filmů s YUV akcelerací. Budete potřebovat jádro s podporou tdfxfb a rekompilovat s

./configure --enable-tdfxfb

8.2.8. tdfx_vid

Toto je kombinace Linuxového jaderného modulu a video výstupního rozhraní podobného mga_vid. Budete potřebovat 2.4.x kernel s agpgart ovladačem, jelikož tdfx_vid používá AGP. Předejte --enable-tdfxfb do configure abyste sestavili video výstupní rozhraní a sestavte jaderný modul pomocí následujících instrukcí.

Instalace jaderného modulu tdfx_vid.o:

  1. Kompilace tdfx_vid.o:

    cd drivers
    make

  2. Pak spusťte (jako root)

    make install

    což by mělo nainstalovat modul a vytvořit soubor zařízení. Nahrajte ovladač pomocí

    insmod tdfx_vid.o

  3. Aby se nahrával a odstraňoval automaticky podle potřeby, vložte nejprve následující řádku na konec /etc/modules.conf:

    alias char-major-178 tdfx_vid

Ve stejném adresáři je testovací aplikace jménem tdfx_vid_test. Měla by vypisovat pár užitečných informací, pokud vše dobře pracuje.

8.2.9. Rozhraní OpenGL

MPlayer podporuje zobrazování filmů pomocí OpenGL, ale pokud vaše platforma/ovladač podporuje xv což by měl být případ PC s Linuxem, použijte raději xv, jelikož výkon OpenGL je o poznání horší. Pokud máte X11 implementaci bez podpory xv, je OpenGL slušná alternativa.

Naneštěstí ne všechny ovladače tuto vlastnost podporují. Ovladače Utah-GLX (pro XFree86 3.3.6) ji podporují pro všechny karty. Viz http://utah-glx.sf.net pro detaily jak je nainstalovat.

XFree86(DRI) 4.0.3 nebo pozdější podporují OpenGL s kartami Matrox a Radeon, 4.2.0 a pozdější podporují Rage128. Viz http://dri.sf.net pro stažení a instalační instrukce.

Rada od jednoho z uživatelů: GL video výstup lze použít pro dosažení vertikálně synchronizovaného TV výstupu. Budete muset nastavit proměnnou prostředí (aspoň na nVidii):

export __GL_SYNC_TO_VBLANK=1

8.2.10. AAlib – zobrazování v textovém režimu

AAlib je knihovna pro zobrazování grafiky v textovém režimu pomocí výkonného ASCII renderovače. Existuje spousta programů, ktaré ji již podporují, jako DOOM, Quake, atd. MPlayer pro ni obsahuje šikovné rozhraní. Pokud ./configure zjistí nainstalovanou aalib, sestaví se aalib libvo rozhraní.

Můžete použít některé klávesy v AA okně pro změnu renderovacích voleb:

KlávesaAkce
1 sníží kontrast
2 zvýší kontrast
3 sníží jas
4 zvýší jas
5 vypíná/zapíná rychlé renderování
6 nastaví rozhodovací režim (žádný, error distribution, Floyd Steinberg)
7 inverze obrazu
8 přepíná mezi ovládáním aa a MPlayeru

Můžete použít následující volby příkazového řádku:

-aaosdcolor=V

změna barvy OSD

-aasubcolor=V

změna barvy titulků

kde V může být: 0 (normální), 1 (tmavé), 2 (tučné), 3 (polotučný font), 4 (reverz), 5 (speciální).

AAlib samotná poskytuje velké množství voleb. Zde je několik důležitých:

-aadriver

Nastaví doporučený aa ovladač (X11, curses, Linux).

-aaextended

Použití všech 256 znaků.

-aaeight

Použití osmibitového ASCII.

-aahelp

Vypíše všechny aalib volby.

Poznámka

Renderování je velmi náročné na CPU, zvlášť při použití AA-na-X (aalib na X) a nejméně náročné je na standardní neframebuferované konzoli. Použijte SVGATextMode pro nastavení velkého textového režimu a užijte si! (secondary head Hercules cards rock :)) (ale IMHO můžete použít volbu -vf 1bpp pro grafiku na hgafb:)

Použijte volbu -framedrop, pokud váš počítač není dostatečně rychlý pro renderování všech snímků!

Při přehrávání na terminálu dosáhnete lepší rychlosti i kvality použitím ovladače Linux, bez curses (-aadriver linux). Ale pak budete potřebovat práva k zápisu do /dev/vcsa<terminal>! Aalib to nedetekuje, ale vo_aa zkouší najít nejlepší režim. Pro více ladících možností viz http://aa-project.sf.net/tune.

8.2.11. libcaca – Barevná ASCII Art knihovna

Knihovna libcaca je grafická knihovna produkující text místo pixelů, takže může fungovat na starších video kartách a textových terminálech. Není nepodobná známé knihovně AAlib. libcaca vyžaduje k činnosti terminál, takže by měla fungovat na všech Unixových systémech (včetně Mac OS X) pomocí buď knihovny slang nebo knihovny ncurses, pod DOSem pomocí knihovny conio.h a na systémech Windows pomocí buď slang nebo ncurses (pomocí emulace Cygwin) nebo conio.h. Pokud ./configure detekuje libcaca, bude sestaveno rozhraní caca libvo.

Odlišnosti od AAlib jsou:

  • 16 dostupných barev pro znakový výstup (256 barev pro pár)

  • rozhodování podle barev v obrázku

Ale libcaca má také následující omezení:

  • nemá podpora pro jas, kontrast a gamu

V caca okně můžete použít některé klávesy pro změnu renderovacích volby:

KlávesaAkce
d Přepíná metody rozhodování v libcaca.
a Přepíná vyhlazování v libcaca.
b Přepíná pozadí v libcaca.

libcaca také respektuje některé proměnné prostředí:

CACA_DRIVER

Nastaví doporučený caca ovladač, jako ncurses, slang, x11.

CACA_GEOMETRY (pouze X11)

Nastaví počet řad a sloupců. Např. 128x50.

CACA_FONT (pouze X11)

Nastaví použitý font. Např. fixed, nexus.

Použijte volbu -framedrop, pokud váš počítač není dost rychlý pro renderování všech snímků.

8.2.12. VESA - výstup do VESA BIOSu

Tento ovladač byl navržen a představen jako obecný ovladač pro jakoukoli video kartu, která má VESA VBE 2.0 kompatibilní BIOS. Další výhodou tohoto ovladače je, že zkouší vynutit zapnutí výstupu na TV. VESA BIOS EXTENSION (VBE) Version 3.0 Date: September 16, 1998 (Strana 70) uvádí:

Karty Dual-Controller.  VBE 3.0 podporuje karty s dual-controllerem za předpokladu že, jelikož jsou typicky oba controllery vybaveny stejným OEM a nastavovány jedinou BIOS ROM na stejné grafické kartě, je možné skrýt před aplikací přítomnost dvou controllerů. To omezuje nezávislé použití jednotlivých controllerů, ale umožňuje aplikacím vydaným před VBE 3.0 pracovat normálně. VBE funkce 00h (Návrat informací o controlleru) vrací kombinované informace obou conrollerů, včetně kombinovaného seznamu platných režimů. Příslušný controller je aktivován jakmile aplikace vybere režim. Všechny ostatní VBE funkce pak pracují s aktivním controllerem.

Máte tedy možnost s tímto rozhraním dostat funkční TV výstup. (Soudím že TV výstup má velmi často samostatnou jednotku, nebo aspoň samostatný výstup.)

VÝHODY

  • Máte šanci sledovat video dokonce i když Linux nezná váš video hardware.

  • Nepotřebujete mít ve svém Linuxu nainstalovány žádné věci související s grafikou (jako X11 (alias XFree86), fbdev atd). Toto rozhraní lze provozovat z textového režimu.

  • Máte šanci získat funkční TV-out. (Je to pravda minimálně s kartami ATI).

  • Toto rozhraní volá int 10h handler, takže není emulátorem – volá skutečné věci skutečného BIOSu v reálném režimu (ve skutečnosti v režimu vm86).

  • Můžete s ním použít VIDIX, takže dostanete akcelerované video a TV výstup současně! (Doporučeno pro karty ATI.)

  • Máte-li VESA VBE 3.0+ a nastavili jste si někde monitor-hfreq, monitor-vfreq, monitor-dotclock (config soubor nebo příkazový řádek) dostanete nejvyšší možný obnovovací kmitočet. (Using General Timing Formula). Abyste této funkce dosáhli, musíte nastavit všechna nastavení monitoru.

NEVÝHODY

  • Pracuje pouze na systémech x86.

  • Může to použít pouze root.

  • Zatím je dostupné pouze pro Linux.

Důležité

Nepoužívejte toto rozhraní s GCC 2.96! Nefunguje!

VOLBY PŘÍKAZOVÉHO ŘÁDKU DOSTUPNÉ PRO VESA

-vo vesa:volby

zatím dostupné: dga pro vynucení dga režimu a nodga pro jeho potlačení. V režimu dga můžete zapnout dvojitou vyrovnávací paměť pomocí volby -double. Poznámka: Tyto volby můžete vynechat, abyste zapli autodetekci dga režimu.

ZNÁMÉ PROBLÉMY A KLIČKY

  • Pokud máte nainstalován NLS font v Linuxové konzoli a použijete VESA rozhraní v textovém režimu, pak po ukončení MPlayeru budete mít nahrán ROM font místo národního. Můžete si opět nahrát národní font například pomocí utility setsysfont z distribuce Mandrake/Mandriva. (Tip: Stejná utilita je použita pro lokalizaci fbdev).

  • Některé Linuxové grafické ovladače neobnovují aktivní režim BIOSu v DOSové paměti. Takže pokud máte tento problém – vždy používejte VESA rozhraní pouze v textovém režimu. Jinak bude přesto aktivován textový režim (#03) a budete muset restartovat počítač.

  • Často po ukončení VESA rozhraní dostanete černou obrazovku. Chcete-li vrátit obraz do původního stavu – jednoduše se přepněte do jiné konzole (stiskem Alt-F<x>) a pak se přepněte zpět stejným způsobem.

  • Chcete-li funkční TV-out, musíte mít připojený TV konektor před startem počítače, jelikož se video BIOS inicializuje pouze jednou během POST procedury.

8.2.13. X11

Pokud možno se mu vyhněte. Posílá obraz do X11 (používá rozšíření sdílená paměť) bez jakékoli hardwarové akcelerace. Podporuje (MMX/3DNow/SSE akcelerované, ale přesto pomalé) softwarové škálování. Použijte volby -fs -zoom. Většina karet má hardwarovou podporu škálování, použijte pro ně volbu -vo xv, nebo -vo xmga pro karty Matrox.

Problém je, že většina karet nepodporuje hardwarovou akceleraci na sekundárním výstupu/TV. V těchto případech uvidíte místo filmu zelenou/modrou obrazovku. Teď se hodí toto rozhraní, ale potřebujete silný procesor pro použití softwarového škálování. Nepoužívejte SDL softwarový výstup a škálování, má horší kvalitu obrazu!

Softwarové škálování je velmi pomalé, zkuste raději měnit videorežimy. Je to jednoduché. Viz modelines v DGA sekci a přidejte je do svého XF86Config.

  • Máte-li XFree86 4.x.x: použijte volbu -vm. Ta změní rozlišení tak, aby do něj film dobře vešel. Když ne:

  • S XFree86 3.x.x: musíte cyklovat dostupnými rozlišeními pomocí tlačítek Ctrl-Alt-Numerické + a Ctrl-Alt-Numerické -

Pokud nemůžete najír rozlišení, která jste vložili, pročtěte si výstup XFree86. Některé ovladače nezvládnou nízké bodové kmitočty potřebné pro režimy s nízkým rozlišením videa.

8.2.14. VIDIX

PŘEDMLUVA.  VIDIX je zkratka pro VIDeo Interface for *niX (video rozhraní pro *nix). VIDIX bylo navrženo a představeno jako rozhraní pro rychlé uživatelské ovladače dosahujících video výkonu jako dosahuje mga_vid na kartách Matrox. Je rovněž dobře přenositelné.

Toto rozhraní bylo navrženo jako pokus napasovat existující video akcelerující rozhraní (známé jako mga_vid, rage128_vid, radeon_vid, pm3_vid) do pevného schéma. Poskytuje vysokoúrovňové rozhraní k čipům známým jako BES (BackEnd scalers) nebo OV (Video Overlays). Neposkytuje nízkoúrovňové rozhraní k věcem známým jako grafické servery. (Nechci konkurovat X11 týmu v přepínání grafických režimů). Čili hlavním cílem tohoto rozhraní je maximalizace rychlosti přehrávání videa.

POUŽITÍ

  • Můžete použít samostatné video rozhraní: -vo xvidix. Toto rozhraní bylo vytvořeno jako front end X11 k technologii VIDIX. Vyžaduje X server a může pracovat pouze pod X serverem. Poznamenejme, že jelikož přímo komunikuje s hardwarem a obchází X ovladač, pixmapy uložené v paměti grafické karty můžou být poškozeny. Můžete se tomu vyhnout omezením množství video paměti použité X pomocí volby "VideoRam" v XF86Config o 4MB. Pokud máte méně než 8MB video ram, můžete místo toho použít volbu "XaaNoPixmapCache" v sekci screen.

  • Existuje konzolové VIDIX rozhraní: -vo cvidix. To vyžaduje pro většinu karet funkční inicializovaný framebuffer (jinak pouze rozhodíte obrazovku) a dosáhnete podobného efektu jako s -vo mga nebo -vo fbdev. nVidia karty však jsou schopny zobrazit plně grafické video na reálné textové konzoli. Viz sekci nvidia_vid pro více informací. Abyste se zbavili textu na okrajích a blikajícího kursoru, zkuste něco jako

    setterm -cursor off > /dev/tty9

    (předpokládáme, že tty9 není dosud používaná) a pak se přepneme do tty9. Na druhou stranu volba -colorkey 0 by měla poskytnout video běžící na "pozadí", zprávná funkce však závisí na funkčnosti colorkey.

  • Můžete použít VIDIXové podzařízení, které bylo zabudováno do několika video ovladačů, například: -vo vesa:vidix (pouze Linux) a -vo fbdev:vidix.

Nezáleží na tom, které video výstupní rozhraní je použito s VIDIX.

POŽADAVKY

  • Video karta by měla být v grafickém režimu (vyjma karet nVidia s výstupním rozhraním -vo cvidix).

  • Výstupní video rozhraní MPlayeru by mělo znát aktivní video režim a být schopno sdělit VIDIXovému podzařízení některé video charakteristiky serveru.

METODY POUŽITÍ.  Když použijete VIDIX jako subdevice (-vo vesa:vidix), pak je konfigurace video režimu je provedeno výstupním video rozhraním (zkrátka vo_serverem). Takže můžete zadat na příkazovém řádku MPlayeru stejné volby jako pro vo_server. Návdavkem rozeznává volbu -double jako globální parametr. (Doporučuji použít tuto volbu s VIDIX aspoň pro ATI kartu). Stejně jako -vo xvidix, dosud zná následující volby: -fs -zoom -x -y -double.

Rovněž můžete uvést VIDIXový ovladač jako třetí podvolbu na příkazovém řádku:

mplayer -vo xvidix:mga_vid.so -fs -zoom -double soubor.avi

nebo

mplayer -vo vesa:vidix:radeon_vid.so -fs -zoom -double -bpp 32 soubor.avi

Ale je to nebezpečné a neměli byste to dělat. V tomto případě bude zadaný ovladač vynucen a výsledek je nepředvídatelný (může vám zatuhnout počítač). Měli byste to použít POUZE pokud jste si absolutně jistí, že to bude fungovat a MPlayer to neudělá automaticky. Řekněte o tom prosím vývojářům. Správný způsob je použití VIDIX bez argumentů, aby proběhla autodetekce.

Jelikož VIDIX vyžaduje přímý přístup k hardware, můžete jej buď spustit jako root, nebo nastavit SETUID bit binárce MPlayeru (Varování: Toto je bezpečnostní risk!). Alternativně můžete použít speciální jaderný modul, například:

  1. Stáhněte si vývojovou verzi svgalib (například 1.9.17), NEBO si stáhněte verzi vatvořenou Alexem speciálně pro použití s MPlayerem (ke kompilaci nepotřebuje zdrojový kód svgalib) z odtud.

  2. Skompilujte modul v adresáři svgalib_helper (naleznete ji v svgalib-1.9.17/kernel/, pokud jste si stáhli zdrojový kód ze serveru svgalib) a nahrajte (insmod) jej.

  3. Pro vytvoření potřebných zařízení v adresáři /dev proveďte jako root

    make device

    v adresáři svgalib_helper.

  4. Přesuňte adresář svgalib_helper do mplayer/main/libdha/svgalib_helper.

  5. Odkomentujte řádek CFLAGS obsahující text "svgalib_helper" v souboru libdha/Makefile.

  6. Překompilujte a nainstalujte libdha.

8.2.14.1. Karty ATI

V současnosti je většina ATI karet podporována nativně od Mach64 až po nejnovější Radeony.

Existují dvě skompilované binárky: radeon_vid pro Radeony a rage128_vid pro karty Rage 128. Můžete některou vynutit, nebo nechat VIDIX rozhraní autodetekovat všechny dostupné ovladače.

8.2.14.2. Karty Matrox

Matrox G200, G400, G450 a G550 jsou hlášeny jako funkční.

Ovladač podporuje video ekvalizéry a měl by být téměř tak rychlý jako Matrox framebuffer

8.2.14.3. Karty Trident

Existuje ovladač pro čipset Trident Cyberblade/i1, který lze nalézt na motherboardech VIA Epia.

Ovladač byl napsán a je udržován Alastairem M. Robinsonem

8.2.14.4. Karty 3DLabs

Ačkoli existuje ovladač pro čipy 3DLabs GLINT R3 a Permedia3, nikdo je netestoval, takže hlášení vítáme.

8.2.14.5. Karty nVidia

Unikátní vlastností ovladače nvidia_vid je jeho schopnost zobrazit video na jednoduché, čisté, pouze textové konzoli – bez framebufferu nebo nějaké X magie. Pro tento účel budete muset použít video rozhraní cvidix, jak to ukazuje následující příklad:

mplayer -vo cvidix příklad.avi

8.2.14.6. Karty SiS

Toto je velmi experimentální kód, stejně jako nvidia_vid.

Byl testován na SiS 650/651/740 (nejobvyklejší čipsety použité v SiS verzích "Shuttle XPC" barebones boxes out there)

Hlášení očekávána!

8.2.15. DirectFB

"DirectFB je grafická knihovna navržená se zřetelem na vestavěné systémy. Nabízí maximálně hardwarově akcelerovaný výkon při minimální spotřebě zdrojů a zatížení." – citováno z http://www.directfb.org

Vlastnosti DirectFB v této sekci vynechám.

Ačkoli MPlayer není podporován jako "video provider" v DirectFB, toto video rozhraní umožní přehrávání videa přes DirectFB. Bude to samozřejmě akcelerované. Na mém Matroxu G400 byla rychlost DirectFB stejná jako XVideo.

Vždy se snažte používat nejnovější verzi DirectFB. Můžete nastavovat volby pro DirectFB na příkazovém řádku pomocí volby -dfbopts. Volbu vrstvy lze provést metodou podzařízení, např.: -vo directfb:2 (výchozí je vrstva -1: autodetekce)

8.2.16. DirectFB/Matrox (dfbmga)

Přečtěte si prosím hlavní DirectFB sekci pro obecné informace.

Toto video výstupní zařízení zapne CRTC2 (na sekundárním výstupu) na kartách Matrox G400/G450/G550, takže zobrazuje video nezávisle na hlavním výstupu.

Ville Syrjala's má README a HOWTO na své domácí stránce, kde vysvětluje, jak rozběhnout DirectFB TV výstup na kartách Matrox.

Poznámka

První DirectFB verze se kterou se nám to povedlo byla 0.9.17 (je chybová, potřebuje surfacemanager patch z výše uvedeného URL). Portace CRTC2 kódu do mga_vid bylo plánováno léta, patche vítáme.