Creative Web: building dynamic websites for work and play
Alistair Shepherd
Developer — Series Eight
A lot of the web is boring
But first, some admin... 😨
- Slides at accud.io/creative-web
- Content warning: Animated demos and videos
- Visual effects, will do my best to explain
- Not much code, linked blog post have demos and code samples
Parallax with CSS scroll animations
'Live' colour theming with custom properties
Generative SVG dividers
Background
data:image/s3,"s3://crabby-images/f7b4b/f7b4be05488974b186289149ba64ff1c5bc3a12b" alt="an illustration of a layered landscape by the video game Firewatch. It's split into 3 sections: the left is a light blue morning colour scheme with rain; centre is a light orange mid-day colour scheme that's clear; the right is a dark orange evening colour scheme with snow"
data:image/s3,"s3://crabby-images/421d3/421d39a7e409f6504de7138ed50902a8b6588d82" alt="Screenshot of website with title 'Alistair Shepherd - full stack web developer in Edinburgh and the Scottish Highlands'. On the right is a website navigation sidebar and the background has a video of a mountain stream"
2019–2020
A new personal site
I used the skills and tools available to me...
...by asking my talented artist sister for help!
data:image/s3,"s3://crabby-images/ec21d/ec21d17e24dad988a1fd7fce7cc0da2fb8088476" alt="Orange monotone illustration of a landscape. Trees are in the foreground, a loch and forest is in a valley and in the background a mountain range is visible."
data:image/s3,"s3://crabby-images/abbb2/abbb2df619cf9d544cccbc3363f198035fe75e25" alt=""
Simple Parallax using Scroll Driven Animations
What is Parallax?
Addressing the "Parallaxed Elephant in the room"
🔭
❌
🪄
3D transforms with CSS perspective
JavaScript implementations or libraries
CSS scroll driven animations
Chrome post: accud.io/css-parallax
My post: accud.io/new-site-1
The next few slides!
@keyframes scroll-parallax {
from { transform: translateY(0); }
to {
transform: translateY(calc(100vh * var(--offset, 0)));
}
}
.layer {
animation: scroll-parallax linear both;
animation-timeline: scroll(block root);
animation-range: 0vh 100vh;
}
@media (prefers-reduced-motion: reduce) {
.layer {
animation: none;
}
}
@keyframes scroll-parallax {
from { transform: translateY(0); }
to {
transform: translateY(calc(100vh * var(--offset, 0)));
}
}
.layer {
animation: scroll-parallax linear both;
animation-timeline: scroll(block root);
animation-range: 0vh 100vh;
}
@media (prefers-reduced-motion: reduce) {
.layer {
animation: none;
}
}
@keyframes scroll-parallax {
from { transform: translateY(0); }
to {
transform: translateY(calc(100vh * var(--offset, 0)));
}
}
.layer {
animation: scroll-parallax linear both;
animation-timeline: scroll(block root);
animation-range: 0vh 100vh;
}
@media (prefers-reduced-motion: reduce) {
.layer {
animation: none;
}
}
@keyframes scroll-parallax {
from { transform: translateY(0); }
to {
transform: translateY(calc(100vh * var(--offset, 0)));
}
}
.layer {
animation: scroll-parallax linear both;
animation-timeline: scroll(block root);
animation-range: 0vh 100vh;
}
@media (prefers-reduced-motion: reduce) {
.layer {
animation: none;
}
}
@keyframes scroll-parallax {
from { transform: translateY(0); }
to {
transform: translateY(calc(100vh * var(--offset, 0)));
}
}
.layer {
animation: scroll-parallax linear both;
animation-timeline: scroll(block root);
animation-range: 0vh 100vh;
}
@media (prefers-reduced-motion: reduce) {
.layer {
animation: none;
}
}
<div class="landscape"
role="img" aria-label="Equivalent to an img alt attribute">
<div class="layer" style="--offset:0.04">...</div>
<div class="layer" style="--offset:0.08">...</div>
<div class="layer" style="--offset:0.1">...</div>
<div class="layer" style="--offset:0.14">...</div>
<div class="layer" style="--offset:0.17">...</div>
<div class="layer" style="--offset:0.2">...</div>
<div class="layer" style="--offset:0.25">...</div>
<div class="layer" style="--offset:0.6">...</div>
<div class="layer" style="--offset:0.8">...</div>
<div class="layer" style="--offset:1">...</div>
</div>
data:image/s3,"s3://crabby-images/aa901/aa90128dcf9d28ee3e6e7e60da353210afa8fbcd" alt=""
✨ Next Steps ✨
Colour themes with time-syncing 'live' mode
data:image/s3,"s3://crabby-images/4b653/4b65390b1946a144de7a4d20655cb3971aa04f09" alt="an illustration of a layered landscape by the video game Firewatch. It's split into 3 sections: the left is a light blue morning colour scheme with rain; centre is a light orange mid-day colour scheme that's clear; the right is a dark orange evening colour scheme with snow"
Colour theming with CSS Custom Properties
html {
--c0: #f5e5e5;
--c1: #fed4d5;
--c2: #dcbed9;
--c3: #c8aed9;
/* etc */
}
body {
background: var(--c0);
color: var(--c10);
}
Animating or 'live' colour themes with custom properties
Custom implementation
- An animation running in a loop;
- Get the progress through the day;
- Work out the next and previous 'states' and the progress between them;
- With the progress between the states, 'interpolate' between the two states for each colour;
- Update the theme custom properties;
Colour formats and spaces
* {
--colour-hex: #fc813a;
--colour-rgb: rgb(252, 129, 58);
--colour-hsl: hsl(22, 97%, 61%);
--colour-lab: lab(67%, 42, 58);
--colour-lch: lch(67%, 71, 54);
}
HSL
LAB
RGB
LCH
✨ Next Steps ✨
data:image/s3,"s3://crabby-images/4b923/4b9232b868eb0c8d06af42cfa6f4ad2cc6ffa32f" alt="Screenshot of blog post, titled 'SVG Landscape with live colour theming - new site part 2', link in caption"
SVG generative mountain
ridge dividers
Generating unique dividers with code
Terrain generation with Midpoint Displacement
✨ Next Steps ✨
data:image/s3,"s3://crabby-images/63e85/63e8578c07bc13a22625d0d950d0edd587b8a577" alt="Screenshot of blog post, titled 'SVG generative mountain ridge dividers', link in caption"
Wrapping up
You've all got homework! 😱
Look for web inspiration everywhere
Building cool websites is easier than ever
Go make boring
fun websites!
Thank you!
Come find me for stickers!
data:image/s3,"s3://crabby-images/6e8e2/6e8e209741e5203d9cd7a830d37fcdae6247a609" alt=""
data:image/s3,"s3://crabby-images/04254/042540367fa53316322852c01a167d8779ebc727" alt=""
data:image/s3,"s3://crabby-images/10dc4/10dc488ec00e07905b677f3c553d43a561a989eb" alt=""
data:image/s3,"s3://crabby-images/b4d85/b4d8510c01984cd30a5255af796301bb90b2d9a4" alt=""
Creative web: building dynamic websites for work and play
By Alistair Shepherd
Creative web: building dynamic websites for work and play
- 170