ID.nl logo
Huis

Doe het met stijl

Om je webpagina’s helemaal naar wens op te maken kan je niet zonder css, ook niet wanneer je een cms als Joomla of een blogtool als WordPress gebruikt. De definitieve specificatie van css3 is weliswaar nog lang niet af, maar je kunt er nu al mee aan de slag!

Css staat voor cascading style sheets,  een specificatie om de vormgeving van webpagina’s los te koppelen van de eigenlijke inhoud. Je kunt css-informatie in de webpagina zelf opnemen, zowel inline, dus in de pagina zelf, als in de <head>-sectie. Voor de overzichtelijkheid kun je het ook onderbrengen in een apart bestand (extern stijlblad) waarnaar je dan vanuit je webpagina verwijst. Omdat zo’n constructie tot potentiële conflicten kan leiden, volgt de css-informatie een watervalsysteem - vandaar de naam ‘cascading’. Een inline opmaakdeclaratie krijgt een hogere prioriteit dan de opmaak die vanuit de <head>-sectie is bepaald en die krijgt op zijn beurt voorrang op een eventueel extern stijlblad.

De eerste css-editie (css1) stamt al uit 1996 en werd twee jaar later opgevolgd door css2. Zo goed als alle moderne browsers ondersteunen nagenoeg volledig beide specificaties. Intussen is men ook al jaren bezig met css3, maar het zal – net als bij html5 – nog lang duren eer de standaard het stadium van een definitieve W3C-aanbeveling bereikt. Dat css(3) nog volop in beweging is, valt goed af te leiden uit een webpagina als www.w3.org/style/css/current-work.

Gelukkig hoef je die eindfase niet af te wachten en kan je nu al aan de slag met css3. Alle moderne browsers ondersteunen namelijk al in mindere of meerdere mate css3. Op www.findmebyip.com/litmus bijvoorbeeld lees je in tabelvorm af hoe goed elke browser op dat vlak presteert. Het zal je opvallen dat vooral Internet Explorer achterloopt, vooral als het op ondersteuning van css-eigenschappen aankomt. Wel is het zo dat Internet Explorer vanaf versie 9 met zowat alle css3-selectors overweg kan: dat bewijst ook de test op www.css3.info/selectors-test.

Her en der op internet vind je al enkele mooie demonstraties van css3 (bijvoorbeeld op www.css3.info/preview of enkele voorzichtige praktijkpogingen op www.css3gallery.net). maar nog veel leuker is het als je er zelf mee experimenteert. In dit artikel bekijken we alvast enkele css3-handigheden.

Selectors

Selectors mogen dan niet het meest sexy onderdeel uit de css-specificatie zijn, ze zijn wel van cruciaal belang. Een css-selector is een item waarop je een bepaalde css-opmaak kunt toepassen. Een eenvoudig voorbeeld met de syntax selector { eigenschap:waarde; } verduidelijkt dit: h2 { font-family: ‘Comic Sans MS’; color: green; }. Alle h2-items worden hierdoor in Comic Sans MS weergegeven als groene tekst. De selectors waren aanvankelijk vooral klassieke html-elementen (zoals h2, p, en dergelijke), waarbij de css-declaratie op elke instantie van dat element werd toegepast. Css3 breidt de selectors flink uit – uiteraard met een wat complexere syntax tot gevolg.

We volstaan hier met een tweetal voorbeelden die je alvast een idee geven. Het eerste stuk code voeg je toe aan de header van het document (tussen <head> en </head>). Het tweede stuk plaats je in de body. In het volgende voorbeeld laten ze zien hoe alle <p>-elementen waarbij “PCM” in de titel voorkomt – en alleen die – een speciale opmaak meekrijgen.

<style type="text/css" >

p[title*="PCM"] { font-family: 'Comic Sans MS'; color: blue; }

</style>

<p>Welkom op de CSS3-pagina van...</p>

<p title="Mijn PCM">PCM, Personal Computer Magazine</p>

Handig zijn verder ook de (pseudoclass-)selectors :checked, :enabled en :disabled, bedoeld om formuliervelden extra focus te geven:

:checked {display: inline-block; width: 6em;}

<form>

<input type="checkbox" /></p>

<input type="radio" name="pcm" /></p>

<input type="radio" name="pcm" />

</form>

Je zal merken dat het selectievakje en de keuzeknoppen meer ruimte innemen – wegens width:6em  - zodra je ze hebt aangeklikt.

Randen en kaders

Ook voor het werken met kaders en randen voorziet css3 in enkele creatieve extra’s.  Om een kader afgeronde hoeken te geven kan één css-declaratie volstaan:

.hoeken { border: 8px outset red; width: 400px; height: 100px; border-radius: 10px; }

<div class="hoeken">Een kader met afgeronde hoeken</div>

Overigens hoef je niet noodzakelijk alle hoeken af te ronden. Het beperken tot één of meerdere hoeken doe je met behulp van de eigenschappen border-top-left-radius, border-bottom-right-radius, enzovoort. Nog meer afronding is natuurlijk ook mogelijk, zodat je bijvoorbeeld een perfecte cirkel krijgt:

.cirkel { background: red; color: yellow; width: 100px; height: 100px; text-align: center; border-radius: 50px; display: box;  box-orient: horizontal; box-pack: center; box-align: center;}

<div class="cirkel">Cirkel met tekst</div>

Zonder de vetgedrukte items krijg je weliswaar een cirkelvorm, maar staat de tekst niet mooi in (het midden van) de cirkel. Om dat gedaan te krijgen maak je dus gebruik van een nieuw “box-model”, dat vastlegt hoe zo’n box in een ander box geplaatst moet worden. Lang niet alle browsers ondersteunen momenteel deze eigenschap, maar als het goed is lukt je dat met behulp van een browser-specifieke prefix alsnog. Voor browsers die worden aangestuurd door de Gecko-engine (voornamelijk Mozilla Firefox) is dat de prefix –moz- en voor browsers met de WebKit-engine (Safari en Chrome) is dat –webkit-. De declaratie ziet er voor dit laatste browsertype dan als volgt uit:

.cirkel { background: red;  color: yellow; width: 100px; height: 100px; text-align: center; border-radius: 50px; display: -webkit-box;  -webkit-box-orient: horizontal; -webkit-box-pack: center; -webkit-box-align: center; }

Overigens hoeft niets je te weerhouden de drie types eigenschappen broederlijk naast elkaar te declareren (display: box;  display: -webkit-box;  display: -moz-box;).

Ook leuk is de mogelijkheid om twee of meer verschillende afbeeldingen als kaderachtergrond te gebruiken. Je hoeft eigenlijk alleen een komma te zetten tussen de diverse plaatjes. Houd er wel rekening mee dat niet alle browsers hiermee al overweg kunnen. Sommige gaan zelfs compleet voorbij aan de declaratie met als gevolg een lege achtergrond. In onze code hebben we dat alvast opgevangen (zie vetgedrukte tekst):

.kader { width: 500px; height: 100px; background: url(pcm.gif) no-repeat; background: url(pcm.gif) no-repeat, url(hub.gif) repeat; background-position: bottom right, 50% 30; }

<div class="kader"></div>

De waarden die bij de eigenschap background-position horen bepalen waar (en hoe) de afbeelding precies getoond wordt binnen het kader. De syntax hiervan is behoorlijk complex. Je vindt alle nodige details, inclusief voorbeelden, op www.w3.org/tr/css3-background/#background-position.

Tekst en webfonts

Aan saaie teksten kan css3 weinig verhelpen, maar de specificatie kan er in elk geval wel voor zorgen dat de tekst er leuk uitziet. Een leuke toevoeging is bijvoorbeeld text-shadow. Deze eigenschap doet precies wat de naam suggereert:

h1 { text-shadow: 2px 3px 5px red }

<h1>PCM, Personal Computer Magazine</h1>

De eerste twee waarden bepalen de verschuiving van de schaduw ten opzichte van de eigenlijke tekst (horizontaal en verticaal). De derde waarde legt de vervagingsradius van de schaduw vast en red geeft uiteraard de kleur aan. Het is trouwens ook mogelijk meer dan één schaduweffect op tekst toe te passen, bijvoorbeeld:

h1 {text-shadow: 2px 3px 5px red, -2px -3px 2px yellow}.

Het aantal webpagina’s dat volop inzet op schreefloze fonts (sans serif) als Verdana valt niet te tellen. Toegegeven, dergelijke fonts laten zich lekker lezen op een scherm, maar je kunt ook wat creatiever uit de hoek komen: met webfonts bijvoorbeeld. Dat zijn lettertypes die door de browser automatisch kunnen worden gedownload. Webfonts zijn geen uitvinding van css3, maar de specificatie heeft het concept wel nieuw leven ingeblazen. Je kunt in css3 namelijk ieder (open) truetype font (extensies .ttf en .otf) inzetten.

@font-face { font-family: Inkinthemeat; src: url("inkinthemeat.otf") }

h1 { font-family: Inkinthemeat, Verdana; color: blue; font-size: 6em; }

<h1> PCM, Personal Computer Magazine</h1>

Je hoeft niet ver te zoeken gratis fonts die je effectief als webfonts kunt en mag inzetten. Een bezoekje aan een site als www.dafont.com. Handig is ook www.google.com/webfonts. Eigenlijk is deze pagina bedoeld om webfonts via een Google api op je webpagina’s te gebruiken. Je kunt de fonts echter ook probleemloos in .ttf-formaat downloaden, naar je eigen site uploaden en alsnog via css3 in je webpagina’s opnemen. Je hoeft het gewenste font alleen te downloaden en ergens online bereikbaar te maken. Je kunt het bijvoorbeeld op dezelfde locatie als je webpagina plaatsen.

Toch nog een kanttekening: Internet Explorer ondersteunt weliswaar css-webfonts, maar jammer genoeg alleen in het .eot-formaat (Embedded OpenType). Dat hoeft geen onoverkomelijk probleem te zijn. Op www.cuvou.com/wizards/ttf2eot.cgi vind je een gratis online converter evenals de nodige html-code om het font zowel in Internet Explorer als in andere browsers correct weer te geven.

Kleur en animatie

Css3 heeft ook het kleurenpalet verder uitgebreid. Nieuw zijn onder meer de kleurenschema’s hsla en rgba, waarbij de a voor ‘alpha channel’ (alfakanaal) staat. Meer achtergrondinformatie vind je op www.w3.org/tr/css3-color. Hiermee is het mogelijk de transparantiegraad van tekst of andere objecten nauwkeurig te bepalen. Dat kan ook met de eigenschap ‘opacity’, bijvoorbeeld als volgt: <div style=”background: rgb (255, 100, 50); opacity: 0.25;”>Deze tekst is bijna volledig transparant</div>. Met hsla/rgba-kleurenschema’s wordt het echter nog iets eenvoudiger:

<div style="background: hsla(0,100%,50%,0.7);">beetje transparant!</div>

<div style="background: rgba(255,100,50,0.2);">bijna volledig transparant!</div>

Over de precieze verschillen tussen opacity en rgba lees je meer op www.css3.info/introduction-opacity-rgba. Ook hier blijft Internet Explorer weer flink achter. Met het browserspecifieke filter kan je het als volgt oplossen: <p style="background-color: green; color: white; width:100%; filter:alpha(opacity=20) ;">Deze alinea is bijna geheel doorzichtig!</p>.

            Css3 maakt ook erg fraaie animaties mogelijk, al dan niet in combinatie met JavaScript. Sites als www.1stwebdesigner.com/css/50-awesome-css3-animations en http://blog.insicdesigns.com/2010/02/the-beauty-of-css3-animation hebben alvast een aantal overtuigende demo’s verzameld. We beperken ons hier noodzakelijkerwijs tot een instapvoorbeeld aan de hand van de eigenschap ‘animation’, die verschillende animatie-eigenschappen verenigt. Eerst bepaal je het gewenste keyframe (zie regel 1), waarna je de eigenlijke animatie vastlegt (regel 2) en die uiteindelijk ook aanroept:

@-webkit-keyframes mijn_animatie {from {left: 50 px; top: 50 px;} to {left: 400 px; top: 200 px;}}

#kader {-webkit-animation: mijn_animatie 4s linear 1 infinite alternate;position:absolute; height: 30px; width:122px; background-color: red;}

<div id="kader">PCM in beweging…</div>

Zoals je merkt, is de animatie-eigenschap momenteel nog browserspecifiek (-webkit-animation) en krijg je die voorlopig alleen aan de praat op browsers met de Webkit-engine. De parameters van de tweede regel, waarin de animatie vastleggen, vergen enige toelichting. Je treft daar de volgende eigenschappen aan:

-animation-name: de naam van je animatie, zoals bepaald door @-webkit-keyframes;

-animation-duration: de duur van een enkele animatie (standaard is dat 0, dus géén animatie – in ons voorbeeld staat die op 4s ingesteld);

-animation-timing-function: bepaalt hoe de animatie tussen twee keyframes moet bewegen (mogelijke waarden zijn onder meer ease, linear, ease-in en ease-out);

-animation-delay: de startvertraging;

-animation-iteration-count: herhalingsfactor (dat kan een cijfer zijn maar bijvoorbeeld ook infinite);

-animation-direction: richting (normal of alternate – in dit laatste geval wordt de animatie ook afgespeeld in omgekeerde richting).

We hebben in deze workshop niet alle mogelijkheden van css3 kunnen bespreken, maar de voorbeelden geven een aardig idee van wat je met css3 kunt. Zoals gezegd is de specificatie nog volop in beweging en valt het niet helemaal uit te sluiten dat bepaalde eigenschappen alsnog verdwijnen of worden aangepast. Anderzijds komen er ook geregeld nieuwe elementen bij en staan er nog wel een aantal op stapel (onder meer voor wiskundige formules en het weergeven van grafieken). Dit alles hoeft je niet te weerhouden css3 in je eigen webpagina’s te gebruiken, zolang je je bewust bent dat niet alle browsers alle css3-eigenschappen (even goed) weergeven.

▼ Volgende artikel
Waar voor je geld: 5 betaalbare all-in-one-printers met scanfunctie
© MG | ID.nl
Huis

Waar voor je geld: 5 betaalbare all-in-one-printers met scanfunctie

Heb je een kantoorbaan en werk je ook veel thuis? Dan loop je vast wel eens tegen het probleem aan dat je een document wil afdrukken of iets belangrijks moet inscannen of kopiëren, maar dat je dan weer moet wachten tot je op kantoor bent. Waarom niet gewoon thuis alles doen? Met een betaalbare all-in-one-printer met scanfunctie doe je alles vanuit je eigen werkkamer. Handig voor iedereen in huis.

Canon PIXMA TS3750i

Met de Canon PIXMA TS3750i haal je een inkjet all-in-one-printer in huis die printen, kopiëren en scannen combineert in één apparaat. Het is een kleureninkjet met een maximale printresolutie van 4800 x 1200 dpi en A4 als grootste papierformaat. Je legt papier in één papierlade met een capaciteit van 90 vellen, waarbij de invoer handmatig gebeurt. De printer ondersteunt standaard A4-papier en print zwart tot ongeveer 7 ipm en kleur tot 4 ipm. De scanner is een flatbed-type zonder automatische documentinvoer; je legt dus losse pagina’s op de glasplaat en scant enkelzijdig.

De verbinding met je netwerk verloopt via wifi, waardoor je via een laptop maar ook een tablet of telefoon kunt printen. De printer werkt uiteraard goed met Windows- en macOS-systemen en hij is compatibel met mobiele besturingssystemen als iOS en Android.

De TS3750i gebruikt twee cartridges (zwart en kleur) maar vier inkten, waarbij de kleuren in één gecombineerde kleurcartridge zitten.

HP DeskJet 2921

De HP DeskJet 2921 is een thermische inkjet-all-in-one die speciaal bedoeld is voor thuisgebruik. Je hebt één apparaat dat kan printen, kopiëren en scannen; de scanner is een flatbedscanner zonder automatische documentinvoer. De printtechniek gebruikt twee cartridges: een zwarte en een driekleurencartridge. De kleurfunctie is beschikbaar voor zowel printen als kopiëren. De papierlade biedt ruimte aan 60 vellen normaal papier en ondersteunt DL-enveloppen.

Als draadloze all-in-one-printer kan deze DeskJet via wifi op je netwerk worden aangesloten, maar het is ook mogelijk om de printer via een usb-kabel rechtstreeks met een computer aan te verbinden. De printsnelheid bij dit model is rond de 7 pagina's in zwart en 5,5 pagina's per minuut in kleur. Automatisch dubbelzijdig afdrukken wordt niet ondersteund.

Epson Expression Home XP-2200

Bij de Epson Expression Home XP-2200 draait het om een compacte kleureninkjet waarmee je zowel kunt printen als scannen en kopiëren. De printer werkt met vier afzonderlijke inkten en heeft een maximale printresolutie van 4800 x 1200 dpi. De maximale papiermaat is A4 en de papierlade kan 50 vellen bevatten. Printen gebeurt via een handmatige papierinvoer, zonder extra lade.

De XP-2200 heeft een flatbed-scanner zonder automatische documentinvoer; dubbelzijdig scannen wordt niet automatisch ondersteund. Op printsnelheid scoort dit model tot 27 pagina’s per minuut in zwart en tot 15 pagina’s per minuut in kleur in de snelste modus. Verbinden gaat via usb of draadloos via wifi. Via een fysieke WPS-knop maak je eenvoudig verbinding.

Epson Expression Home XP-3200

De Epson Expression Home XP-3200 is een all-in-one-printer met iets meer mogelijkheden aan de bedieningskant. De inkjet is voorzien van een 1,44-inch lcd-scherm en kan dubbelzijdig printen. De maximale afdrukresolutie is 5760 x 1440 dpi. Het apparaat ondersteunt diverse papierformaten tot en met A4 en ook verschillende envelop- en fotopapierformaten accepteert de printer.

De geïntegreerde flatbed-scanner haalt een optische scanresolutie van 1200 x 2400 dpi, met 48-bit kleurdiepte bij de invoer en 24-bit bij de uitvoer. De XP-3200 gebruikt vier losse cartridges en heeft een papierlade voor standaard papier; randloos printen behoort ook tot de mogelijkheden. De printsnelheid ligt rond de 10 pagina’s per minuut in zwart en 5 in kleur. Voor verbinding met je netwerk is wifi aanwezig, plus usb voor directe koppeling. Apple AirPrint wordt ondersteund.

HP Smart Tank 5108 - Multifunctionele printer

De HP Smart Tank 5108 is een inkjet all-in-one met navulbare inkttanks in plaats van losse cartridges. De printer kan scannen en kopiëren. De papierlade heeft volgens de gegevens plaats voor 100 vellen en ondersteunt verschillende formaten, met een formaatbereik tot ongeveer 215,9 x 355,6 mm.

Bij de printspecificaties wordt een snelheid van ongeveer 12 pagina’s per minuut in zwart en 5 in kleur genoemd en automatisch dubbelzijdig afdrukken is eveneens mogelijk. De scanner is een flatbedscanner en ondersteunt enkelzijdige scans; automatische documentinvoer en automatisch dubbelzijdig scannen zijn niet aanwezig. De verbinding met netwerk gaat via wifi en je kunt de printer direct via usb aansluiten.

▼ Volgende artikel
PlayStation State of Play: hier kijk je vanavond om 23:00 uur
Huis

PlayStation State of Play: hier kijk je vanavond om 23:00 uur

Sony PlayStation zendt aanstaande donderdagavond om 23:00 uur Nederlandse tijd een nieuwe State of Play-livestream uit. Martin, Simon en Jacco kijken live met je mee!

Er gingen al geruchten over de komst van de State of Play, en die blijken nu dus te kloppen. Nate the Hate, de insider die wel vaker de komst van aan games gerelateerde presentaties op voorhand lekt, claimde dat onlangs namelijk al.

Op PlayStation Blog schrijft Sony dat de presentatie meer dan zestig minuten beslaat en "nieuws, gameplay-updates en aankondigingen van gamestudio's verspreid over de wereld" bevat voor aankomende PlayStation 5-games. Daarbij zullen er zowel games van PlayStation Studios zelf als andere bedrijven de revue passeren.

Zoals gezegd wordt de State of Play op donderdag 12 februari om 23:00 uur Nederlandse tijd uitgezonden, en zal deze te zien zijn via YouTube en Twitch. De presentatie zal ook hieronder te zien zijn zodra hij begint. Uiteraard streamen we de presentatie ook op Twitch, YouTube en TikTok!

Over de precieze inhoud van de State of Play-presentatie is nog niets bekend. Wel is het opvallend dat de presentatie meer dan een uur duurt, wat het een van de langste State of Play-presentaties tot dusver maakt.

Watch on YouTube

Wat is er te zien in de nieuwe State of Play?

Sony brengt dit jaar in ieder geval Saros, Marathon en Marvel's Wolverine uit, maar van die laatste is inmiddels bevestigd dat de game in de lente van dit jaar een update krijgt.

Verder werd vorige week een nieuwe Horizon-game met een focus op multiplayergameplay aangekondigd, genaamd Horizon Hunters Gathering. We weten ook dat The Last of Us-ontwikkelaar Naughty Dog aan hun nieuwe game Intergalactic: The Heretic Prophet werkt, en volgens geruchten wordt er bij PlayStation Studios ook een nieuwe God of War-game ontwikkeld met metroidvania-elementen.

Andere titels die vermoedelijk voorbijkomen zijn: Resident Evil Requiem, Helldivers 2, Marvel Tokon: Fighting Souls, Ace Combat 8, Marathon en Phantom Blade Zero.

Kunnen we dan helemaal geen verrassingen verwachten? Volgens geruchten werkt Sony Santa Monica al een tijdje aan een tweedimensionale God of War-game met Kratos' broer Deimos in de hoofdrol, en vermoed wordt dat deze eindelijk wordt aangekondigd. Sowieso zijn er veel God of War-geruchten: ook zou er gewerkt worden aan een heruitgave van de eerste drie delen en spin-off met personages Atreus in de hoofrol.