Novinky v CSS3: Multiple Background

Martin Smola 12. 9. 2012

Pozadí webové stránky není žádná novinka, vlastně je to jedna z nejstarších vlastností. Určitě si pamatujete různé obláčky, pohyblivé panáčky či jiné obludnosti. Dnes jsme naštěstí dál a můžeme na stránce nadefinovat dokonce několik různých pozadí najednou. K čemu to vlastně je a jak to pořádně využít?

Novinky v CSS3 - Multiple Background

Pomocí CSS3 je nyní možné definovat elementu pozadí, z kolika obrázků se nám jen zachce. Tato vlastnost je i poměrně jednoduchá a jasná. Pro multiple background používáme buďto vlastnost background, nebo background-image. Tyto dvě vlastnosti slouží k definování toho, co vlastně na pozadí bude. Jejich hodnoty vypadají následovně: url('url_adresa.png/jpg/gif'), url('url_adresa.png/jpg/gif'); Takto jsme definovali jednomu elementu dva obrázky na pozadí. V tomto případě se řídí vrstvení (co bude navrch a co vespod) podle zapsání jednotlivých obrázků. První obrázek bude navrch, druhý pod ním. Pokud tedy budeme zapisovat css styl nějakému elementu, bude to vypadat následovně.

#id_naseho_elementu {
	background-image: url('trava.png'), url('zidka.png');
}

Takto potom může vypadat výsledek složený z obrázku trávy a zdi. Samozřejmě musí být obrázek s trávou průhledný. Takže PNG nebo GIF.

Další vlastností pro multiple background je vlastnost background-position, která umožňuje pozicování jednotlivých obrázků v pozadí. Buďto je lze pozicovat zapsáním vždy dvojice, například center top, nebo přímo souřadnicemi vždy ve dvojici pro souřadnice X a Y. Tedy background-position: 50px 20px. Pokud chceme zapisovat pozici pro oba obrázky pozadí, bude to vypadat takto: background-position: 20px 30px, 40px 20px; tedy nejprve prvni dvojice souřadnic, čárka, druhá dvojice souřadnic.

Totéž platí i pro background-repeat. Například zapíšeme background-repeat: repeat, no-repeat. V tomto případě by se první obrázek pozadí opakoval a druhý vespod by byl vykreslen pouze jednou.

Věřím, že si mnozí říkáte, na co vlastně může taková vlastnost být, vždyť pokud budu chtít dva obrázky přes sebe, neměl by to být zas takový problém i bez CSS3. To ale není pravda v případě, kdybychom potřebovali vytvořit něco takového s proměnnou šířkou a výškou:

V tomto případě si budeme muset připravit obrázky rohů a opakující se části rámů, obrázky jsou zde:

Pokud už máme grafickou část připravenou, napíšeme si css styl, který nám všechny tyto obrázky postaví na správné místo a povolí nebo zakáže některým z nich opakování. Vlastnosti background-image přiřadíme nejprve url adresy všech čtyř rohů, aby byly vždy navrchu a nemohly je překrývat opakující se středové příčky. Co se týče background-position, první roh (vlevo nahoře) bude pozicovaný k left top. Horní pravý k right top a tak dále. Poslední je opakování. Pokud bude něco potřeba opakovat, budou to příčky a co se týče rohů, těm opakování zakážeme. Horní a dolní příčce nastavíme do vlastnosti background-repeat: repeat-x, což zaručí, že se budou opakovat jen ve směru X. Levé a pravé příčce nastavíme repeat-y. Výsledný stzl bude vypadat takto:

#id_elementu {
	background-image: url('levyhorni.png'), url('pravyhorni.png'), url('pravydolni.png'),  url('levydolni.png'), url('hornipricka.png'), url('dolnipricka,png'), url('levapricka.png'), url('pravapricka.png');
	background-position:left top, right top, right bottom, left bottom, left top, left bottom, left top, right top;
	background-repeat:no-repeat, no-repeat, no-repeat, no-repeat, repeat-x, repeat-x, repeat-y, repeat-y;
	width:450px; /* velikost můžete poté nastavovat, jakou chcete, takto nastavené pozadí se vždycky přizpůsobí. */  
	height:300px;
}

Jako příklad jsem zvolil textarea jako element, na kterém toto ukážu, má totiž ve spodním pravém roku úchop na zvětšování velikosti. Lze to ale použít na mnoho elementů. V kombinaci s jinými obrázky jdou dělat pomocí tohoto vylepšení poměrně velké věci, které bychom jinak museli nahrazovat buďto pomocí js, nebo dělat na každou velikost jiný obrázek v pozadí.

Stejnou funkci jako background-image: má i vlastnost background:. A na výsledný efekt nemá vliv, jestli použijeme jednu nebo druhou.

Co se týče podpory v prohlížečích:

Vlastnost background-image: podporuje

  • Mozilla Firefox od verze 3.6
  • Safari 1.0+
  • Chrome 1.3+
  • Opera 10.5+
  • IE 9.0+

Příště se podíváme na nové možnosti rámečků Border.

Našli jste v článku chybu?
DigiZone.cz: DVB-T2: je tu certifikace od ČRa

DVB-T2: je tu certifikace od ČRa

Lupa.cz: Online porno ničí sexuální život mladých mužů

Online porno ničí sexuální život mladých mužů

Podnikatel.cz: Zajímavý paradox: Daří se vedle konkurence

Zajímavý paradox: Daří se vedle konkurence

DigiZone.cz: Pevnost Boyard v září a česká

Pevnost Boyard v září a česká

Root.cz: Xiaomi má vlastní notebook podobný Macu

Xiaomi má vlastní notebook podobný Macu

DigiZone.cz: Loewe uvede 4K s obrazovkou OLED

Loewe uvede 4K s obrazovkou OLED

Podnikatel.cz: SMS oznamují nedoplatek na dani, nic neplaťte

SMS oznamují nedoplatek na dani, nic neplaťte

Lupa.cz: Pirate Bay se drží 13 let. A bojuje s Hollywoodem

Pirate Bay se drží 13 let. A bojuje s Hollywoodem

Podnikatel.cz: Musí rentiér odvádět DPH?

Musí rentiér odvádět DPH?

Podnikatel.cz: Emailové kampaně, co neštvou, ale fascinují

Emailové kampaně, co neštvou, ale fascinují

120na80.cz: Pylová sezóna nejsilnějších alergenů končí

Pylová sezóna nejsilnějších alergenů končí

Lupa.cz: Hackujete? Můžete mít problém sehnat práci

Hackujete? Můžete mít problém sehnat práci

DigiZone.cz: Elektrická Formule E. Práva má Arena Sport

Elektrická Formule E. Práva má Arena Sport

Podnikatel.cz: Mění se pravidla pro rodičovskou

Mění se pravidla pro rodičovskou

120na80.cz: Bylinka pro dobrý sex. Jaká to je?

Bylinka pro dobrý sex. Jaká to je?

Podnikatel.cz: Sami na firemní web: Jak nastavit design?

Sami na firemní web: Jak nastavit design?

Lupa.cz: Jak připojit Colours? Gong má chytrou Wi-Fi

Jak připojit Colours? Gong má chytrou Wi-Fi

Podnikatel.cz: Čauky mňauky. Proč hledají lidé tento výraz?

Čauky mňauky. Proč hledají lidé tento výraz?

Vitalia.cz: Jak pít při sportu

Jak pít při sportu

DigiZone.cz: Film+ a nevhodné snímky přes den

Film+ a nevhodné snímky přes den