Dit is het proces van het vak CSS to the rescue. Gemaakt door Stefan Radouane
Ik wil tijdens dit vak de nieuwste CSS features leren en experimenteren met 3D objecten, vervolgens wil ik deze nieuw geleerde technieken toepassen in mijn eindopdracht.
Voor het project is het de bedoeling dat we een keuze maakten uit 3 opdrachten de opdrachten de opties waren:
- Een bedieningspaneel
- Een vuurwerkshow
- Een rubiks cube
Ik heb uiteindelijk gekozen voor de rubiks cube, omdat ik toevallig zelf ook bezig was met het leren van een rubiks cube oplossen. Daarnaast paste dit precies bij het leerdoel van mij dat ik wil leren om 3D objecten te maken met CSS.
Na de eerste dag aan de opdracht werken had ik eigenlijk al een rubiks cube gemaakt van HTML en CSS. Deze cubus bestond uit 54 losse div
's. Ik liep alleen tegen een probleem aan nu en dat is dat ik de losse divs niet draaibaar kon maken, omdat ik deze divs met een eigen transform op de cube had geplaatst.
Vervolgens heb ik de hele cube opnieuw gemaakt, maar nu met 24 span
's voor alle blokken op de cube. Elk blokje kan bestaan uit 1, 2 of 3 vlakken. En elke vlak heeft een eigen positie in een 3D omgeving, deze omgeving is maximaal 300px bij 300px bij 300px. Elke 'blokje' is maximaal 300px bij 300px en staat ontzichtbaar gecentreerd in het midden van de kubus. De vlakken zijn wel zichtbaar en zijn allemaal correct gepositioneerd. Op deze manier kan ik het midden van het blokje draaien, en hierdoor draaien de vlakken correct mee.
Om dit idee uit te werken heb ik eerst een schets gemaakt.
Om eerlijk was het wel een beetje puzzelen hoe de kubus nou precies opgebouwd moest worden uit kleuren, maar het is uiteindelijk wel gelukt.
Zoals je kan zien gebruik ik
data-color
om de kleur van het vlak te bepalen. Dit zorgt ervoor dat ik gemakkelijk verschillende level kan implementeren.
Nu ik de cubus had ging ik proberen om de rijen van de kubus te laten draaien. Na veel proberen met de kubus had ik het opgegeven, omdat ik hoofdpijn kreeg van het proberen. Ik heb op dit moment bedacht om mijn idee te veranderen naar de 'impossible cube'. Het lukte mij wel om de losse blokken te transformeren, alleen niet op een realistiche wijze, daarom dacht ik met CSS kan je de natuurwetten een beetje verbuigen en dat zorgt ervoor dat de impossible cube wel mogelijk was op een website.
Tijdens werd mij verteld dat ik het toch nog een keer moest proberen om de kubus draaibaar te maken. Ik heb hiernaar geluisterd en heb het een tweede kans gegeven. Aangezien een kubus 43.252.003.274.489.856,000 mogelijkheden, heb ik dit iets versimpeld voor mijzelf. Ik weet dat er een beginners stappen plan is om te leren hoe je een kubus moet oplossen, en ik heb dus besloten om mijn concept te veranderen naar een 'cube trainer'. Dit concept splitst de kubus op in 7 levels. Elk level heeft een aantal stappen die gevolgt moeten worden, om de kubus op te lossen. Ik heb besloten om de laatste stap van deze stappenreeks uit te werken.
Als eerst heb ik bedacht om dit te doen met een soort spel bedieningspaneel. Ik heb hiervoor een schets gemaakt, maar ik vond zelf gelijk na het schetsen dat dit paneel te druk was. Ik heb bepaalde onderdelen hiervan wel verwerkt in de uiteindelijke werking van mijn concept.
Daarnaast heb ik ook een schets gemaakt van het level overzicht.
Ik heb besloten om wel te werken met 6 knoppen (links onder op de schets). Met deze knoppen wil ik het mogelijk maken om de kubus op te lossen. Ik heb ervoor gekozen dat de juiste knop elke keer op een andere plaats staat, zodat dit niet elke keer bijvoorbeeld links boven is.
Nadat ik de laatste level werkend heb gemaakt ben ik begonnen met het uitbreiden van de website. Ik spectator mode in level 1 mogelijk gemaakt en heb een opgelosde cube spectator mode gemaakt. In deze modus zijn er geen knoppen aan de zijkant beschikbaar. Ik vond het toch leuk om de impossible cube nog te implementeren en heb hiervoor een knop gemaakt die de kubus breekt. Daarnaast slot heb ik een aantal eastereggs toegevoegd, zodat ik extra kon experimenteren met achtergronden. Tot slot heb ik alle bestand gefactord, zodat deze enigsinds productie klaar zijn. Ik heb deze bestanden aangepast door overal comments toe te voegen en Ik ben uiteindelijk ontzettend trots op het eindresultaat.
Ik heb geexperementeerd met een hoop CSS properties. Hieronder een opsomming:
- Verschillende pseudoselectoren (:not, :is, :has & :where)
- Display-p3 kleuren
- Custom properties
- verschillende CSS '@' methoden
- font-palette
- Nesting
Ik heb niet alle punten van deze lijst geimplementeed. Bijvoorbeeld CSS nesting heb ik niet gebruikt ondanks dat ik SASS altijd fijner vind dan CSS, omdat CSS al lastig is om te debuggen, maar het chrome is nog niet klaar om CSS nesting te gebruiken en te debuggen.
Hieronder heb ik korte voorbeelden van hoe ik deze properties heb geimplementeerd:
Met de :has
selector kan je op een krachtige wijze een soort van 'if statement' in je CSS maken. Ik heb de :has
selector veel gebruikt om te zorgen dat iets pas in beeld komt als bijvoorbeeld een checkbox is geselecteerd.
:root:has(fieldset[data-layer="7"]:valid) {
--current-step: "Complete";
}
In dit voorbeeld word de variabel
--current-step
aangepast op het moment dat een checkbox is geselecteerd.
Display-p3 kleuren zorgen ervoor dat een website een groot scala aan extra kleuren kunnen projecteren (Als het display deze kleuren ook aan kan).
@supports (color: color(display-p3 1 1 1)) {
:root {
--color-blue: color(display-p3 0.13 0.128 0.909 / 1);
--color-green: color(display-p3 0.113 0.779 0.087 / 1);
--color-yellow:color(display-p3 0.943 0.907 0.138 / 1);
--color-orange:color(display-p3 1 0.596 0.053 / 1);
--color-red:color(display-p3 0.862 0.128 0.041 / 1);
--color-white:color(display-p3 1 1 1 / 1);
}
}
Ik heb de kleuren in een
@support
tag gezet, zodat de kleuren niet transparent worden als display-p3 niet ondersteund wordt.
Met @font-palette-values
kan je de kleuren van een gekleurd font veranderen.
@font-palette-values --base {
font-family: "Rocher";
base-palette: 2;
override-colors:
0 #ffffff,
1 hsl(223, 85%, 40%),
2 hsl(223, 85%, 50%),
3 hsl(223, 85%, 40%)
;
}
Voor de fallback gebruik ik normale hsl kleuren
Met de @property
kan je het mogelijk maken om variabelen te animeren. Ik heb dit gebruikt tijdens de tweede eateregg. Door deze property is het dus mogelijk om variabelen kleuren te animeren.
@property --color-red {
syntax: '<color>';
inherits: true;
initial-value: hsl(0, 100%, 40%);
}
Naast de
syntax: '<color>'
zijn er nog een aantal van andere soorten syntax.
Gemaakt door Stefan Radouane
Maart 2023