Taking The Web
off the screen
@charlotte_dann
Why use computers for art?
Physical
Design
Build
Test
Learn
CSS Generative Art
.grid {
display: grid;
grid-template-columns: repeat(10, 1fr);
}
.grid__item {
width: 100%;
height: 100%;
background: white;
position: relative;
overflow: hidden;
}
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
data:image/s3,"s3://crabby-images/10d9a/10d9a7015d90143d10907932d989951f96cb7adc" alt=""
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
.grid__item:nth-child(2n):before {
right: 0;
}
data:image/s3,"s3://crabby-images/7c15b/7c15b5afae5d4205ea7522ac3f29780d60cde968" alt=""
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
.grid__item:nth-child(3n):before {
right: 0;
}
data:image/s3,"s3://crabby-images/cd775/cd7751dd9703ad030a1e995d7c1a22f658891022" alt=""
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
.grid__item:nth-child(3n):before {
right: 0;
}
.grid__item:nth-child(2n):before {
bottom: 0;
}
data:image/s3,"s3://crabby-images/c339a/c339aab4fc9cf3c5beee6613a40669bcb56ebb71" alt=""
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
.grid__item:nth-child(2n):before {
right: 0;
}
.grid__item:nth-child(3n):before {
bottom: 0;
}
data:image/s3,"s3://crabby-images/db032/db03244577dd9f09c5c603b587817735650cec77" alt=""
.grid__item:before {
content: '';
display: block;
position: absolute;
width: 200%;
height: 200%;
border-radius: 50%;
background: black;
}
.grid__item:nth-child(3n):before {
right: 0;
}
.grid__item:nth-child(4n):before {
bottom: 0;
}
data:image/s3,"s3://crabby-images/3930c/3930cca6a6ff1006a6738162c664451276fc5e5b" alt=""
data:image/s3,"s3://crabby-images/26c59/26c59faf75106340fe72f381b9b85a75011e356b" alt=""
data:image/s3,"s3://crabby-images/b65f0/b65f0469c407da65bb37cb6caffb66cdb85dd240" alt=""
Pen Plotting
data:image/s3,"s3://crabby-images/622fa/622fabf6f3e3dcfac919edab805c3333e1f97f3a" alt=""
data:image/s3,"s3://crabby-images/c4b01/c4b01a10a145188b996fdafbce98385c08a4d6db" alt=""
data:image/s3,"s3://crabby-images/8fb62/8fb629f80cfba7521b98d395456f7d355b74bb7e" alt=""
data:image/s3,"s3://crabby-images/22e02/22e0232dd6c4eec76a473a5603ec52b91dfdc069" alt=""
Test everything on crappy paper first
data:image/s3,"s3://crabby-images/7cbff/7cbffd90f31c89603986e227f3f576aa491ae759" alt=""
Use canvas2svg for
easy vector outputs from canvas drawings
data:image/s3,"s3://crabby-images/22e02/22e0232dd6c4eec76a473a5603ec52b91dfdc069" alt=""
const size = 1000
const canvas = document.createElement('canvas')
canvas.width = size
canvas.height = size
document.body.appendChild(canvas)
const context = canvas.getContext('2d')
context.strokeStyle = '#fff'
context.lineWidth = 5
context.lineCap = 'round'
const u = size / 20
context.beginPath()
for (let i = 0; i < 100; i++) {
const x = i%10
const y = Math.floor(i/10)
const rotations = (i%3 === 0 && 1) + (i%4 === 0 && 2)
context.save()
context.translate(u+x*u*2, u+y*u*2)
context.rotate(rotations * Math.PI / 2)
context.moveTo(-u, u)
context.quadraticCurveTo(-u, -u, u, -u)
context.restore()
}
context.stroke()
data:image/s3,"s3://crabby-images/f8e4e/f8e4ed84236900431afda5ad35321cde6cdb94e2" alt=""
const size = 1000
import saveAs from 'file-saver'
import C2S from 'canvas2svg'
const context = new C2S(size, size)
context.strokeStyle = '#fff'
context.lineWidth = 5
context.lineCap = 'round'
const u = size / 20
context.beginPath()
for (let i = 0; i < 100; i++) {
const x = i%10
const y = Math.floor(i/10)
rotations = (i%3 === 0 && 1) + (i%4 === 0 && 2)
context.save()
context.translate(u+x*u*2, u+y*u*2)
context.rotate(rotations * Math.PI / 2)
context.moveTo(-u, u)
context.quadraticCurveTo(-u, -u, u, -u)
context.restore()
}
context.stroke()
const blob = new Blob([context.getSerializedSvg()], {
type: 'text/plain',
})
saveAs(blob, 'pattern.svg')
data:image/s3,"s3://crabby-images/f8e4e/f8e4ed84236900431afda5ad35321cde6cdb94e2" alt=""
Laser Cutting
abstractpuzzl.es
abstractpuzzl.es
data:image/s3,"s3://crabby-images/e14b3/e14b38caab390c58abb16fc42016af16845c4c59" alt=""
data:image/s3,"s3://crabby-images/1bed2/1bed2ded7157abe1ea763647a8027044b9ede027" alt=""
data:image/s3,"s3://crabby-images/64e75/64e75750839297edb44eeebaac08f36c10a2e058" alt=""
Get access at a Hackspace, university, or pay-by-the-hour facilities
Figure out the right settings with material testing first
data:image/s3,"s3://crabby-images/22e02/22e0232dd6c4eec76a473a5603ec52b91dfdc069" alt=""
3D Printing
data:image/s3,"s3://crabby-images/1f420/1f4204ddaa2e0a2edb5c5b7a1c7593cdb25736d9" alt=""
Generative Gestaltung
data:image/s3,"s3://crabby-images/77a09/77a09a5322e0330218a36aaa3b8176dc3918218c" alt=""
data:image/s3,"s3://crabby-images/c33b0/c33b0676e1e14b709ac6830bd4b66695336c9163" alt=""
data:image/s3,"s3://crabby-images/6e9df/6e9dfedbf479cb43527a0d32e826001eb6052813" alt=""
data:image/s3,"s3://crabby-images/53e0a/53e0ace6eb282cacfa764592871b8365110584aa" alt=""
data:image/s3,"s3://crabby-images/62a24/62a244bd31c0cab736d6700ea16e9babe8818d4c" alt=""
data:image/s3,"s3://crabby-images/2aac1/2aac1776d206dc4689a6073f190941a9ba1e7d72" alt=""
You can export STL
files from ThreeJS
data:image/s3,"s3://crabby-images/22e02/22e0232dd6c4eec76a473a5603ec52b91dfdc069" alt=""
data:image/s3,"s3://crabby-images/081db/081db03a48c63deba7f468a75a1331f1395c9709" alt=""
data:image/s3,"s3://crabby-images/3a52e/3a52eac93081295761309e11869d37be9fbd9e25" alt=""
data:image/s3,"s3://crabby-images/5286c/5286c43a3f64c1a3a971c9b3a6a1334784aabd5f" alt=""
data:image/s3,"s3://crabby-images/82dd2/82dd20df67b7b4911d91d774d1b0a48802bba510" alt=""
data:image/s3,"s3://crabby-images/816ee/816ee19c296886749993043697a1e4e0d2434d29" alt=""
data:image/s3,"s3://crabby-images/e95e4/e95e44b6185a4a3615a49bdaaa1e07e3acdaf045" alt=""
data:image/s3,"s3://crabby-images/081db/081db03a48c63deba7f468a75a1331f1395c9709" alt=""
data:image/s3,"s3://crabby-images/3a52e/3a52eac93081295761309e11869d37be9fbd9e25" alt=""
data:image/s3,"s3://crabby-images/5286c/5286c43a3f64c1a3a971c9b3a6a1334784aabd5f" alt=""
data:image/s3,"s3://crabby-images/82dd2/82dd20df67b7b4911d91d774d1b0a48802bba510" alt=""
data:image/s3,"s3://crabby-images/816ee/816ee19c296886749993043697a1e4e0d2434d29" alt=""
data:image/s3,"s3://crabby-images/e95e4/e95e44b6185a4a3615a49bdaaa1e07e3acdaf045" alt=""
data:image/s3,"s3://crabby-images/081db/081db03a48c63deba7f468a75a1331f1395c9709" alt=""
data:image/s3,"s3://crabby-images/3a52e/3a52eac93081295761309e11869d37be9fbd9e25" alt=""
data:image/s3,"s3://crabby-images/5286c/5286c43a3f64c1a3a971c9b3a6a1334784aabd5f" alt=""
data:image/s3,"s3://crabby-images/82dd2/82dd20df67b7b4911d91d774d1b0a48802bba510" alt=""
data:image/s3,"s3://crabby-images/816ee/816ee19c296886749993043697a1e4e0d2434d29" alt=""
data:image/s3,"s3://crabby-images/e95e4/e95e44b6185a4a3615a49bdaaa1e07e3acdaf045" alt=""
data:image/s3,"s3://crabby-images/c73e3/c73e376da772aac87927d3d700455e337b0b308f" alt=""
data:image/s3,"s3://crabby-images/081db/081db03a48c63deba7f468a75a1331f1395c9709" alt=""
data:image/s3,"s3://crabby-images/3a52e/3a52eac93081295761309e11869d37be9fbd9e25" alt=""
data:image/s3,"s3://crabby-images/5286c/5286c43a3f64c1a3a971c9b3a6a1334784aabd5f" alt=""
data:image/s3,"s3://crabby-images/82dd2/82dd20df67b7b4911d91d774d1b0a48802bba510" alt=""
data:image/s3,"s3://crabby-images/816ee/816ee19c296886749993043697a1e4e0d2434d29" alt=""
data:image/s3,"s3://crabby-images/e95e4/e95e44b6185a4a3615a49bdaaa1e07e3acdaf045" alt=""
data:image/s3,"s3://crabby-images/c73e3/c73e376da772aac87927d3d700455e337b0b308f" alt=""
data:image/s3,"s3://crabby-images/071f0/071f06b4b5e4eb04660e871192b31ab485167079" alt=""
data:image/s3,"s3://crabby-images/9ecea/9ecea2916cfe3629f8e3a0a76c43654aa4eb2380" alt=""
data:image/s3,"s3://crabby-images/b251a/b251acbe8f25b1000f4a9fdffa32253664e26746" alt=""
data:image/s3,"s3://crabby-images/4f647/4f647765a447fad3237614470508434a2eb835ad" alt=""
data:image/s3,"s3://crabby-images/b3704/b3704d5b5546f476a18ff5ff68ee844a7a647631" alt=""
data:image/s3,"s3://crabby-images/101c2/101c21c1da5c0a09410f17a41ea0cea97e11cf7c" alt=""
data:image/s3,"s3://crabby-images/68c34/68c34c13cf84bfbdaa533c18656f659eba84d9cb" alt=""
data:image/s3,"s3://crabby-images/5cad3/5cad37bddbae042374887064dea198181aa8c57d" alt=""
data:image/s3,"s3://crabby-images/b877c/b877cb61906bab4323511057eea8f6a6e0d63f42" alt=""
data:image/s3,"s3://crabby-images/27f54/27f5425b8fd8082b2281138e0b82033854da2b49" alt=""
data:image/s3,"s3://crabby-images/7ffea/7ffeabb8b9b866aff0c79190c40696c3db003b4f" alt=""
data:image/s3,"s3://crabby-images/53a56/53a56cc76ef52e3515069ac03d69b52eab64d26a" alt=""
data:image/s3,"s3://crabby-images/448a7/448a7c0af33b26de8394a31561583779424bc4b6" alt=""
data:image/s3,"s3://crabby-images/dc6a9/dc6a911eb98662421c1626e51eb87cd9efab78e0" alt=""
data:image/s3,"s3://crabby-images/8e633/8e6335e727f81222b2aeaf95bd2f0d972ba28960" alt=""
data:image/s3,"s3://crabby-images/657bc/657bca68a08fa52fe89aa777bdff220c02c539df" alt=""
Reaction Diffusion Coral Cup,
Nervous System
data:image/s3,"s3://crabby-images/04d89/04d89bd4cf47e3b530180da4ac57a27adb587167" alt=""
Mass customisation, unmade
data:image/s3,"s3://crabby-images/971e8/971e8af615b1f50f66411ab6e604e6ecde8f1a2f" alt=""
data:image/s3,"s3://crabby-images/ab49f/ab49fd459a9f7ee060fca1457488796993e91e5d" alt=""
3d-printed glass,
mit glass lab
data:image/s3,"s3://crabby-images/f281b/f281bd2d3df387455c366e1eba505c02fef044dd" alt=""
data:image/s3,"s3://crabby-images/60326/60326b79333b3118589c1ebd5e0ad84dc0ea602b" alt=""
data:image/s3,"s3://crabby-images/1f360/1f360e5ca4238ae3473c825df384bbfbdf1092eb" alt=""
thank you
@charlotte_dann
FFConf 2019 - Taking The Web Off The Screen
By Charlotte Dann
FFConf 2019 - Taking The Web Off The Screen
The rise of generative art has brought a whole new wave of creativity to the web; this talk is about the myriad of ways we can use all that coding knowledge to make cool art in the physical realm.
- 1,402