outrun/outrun.rkt

85 lines
2.7 KiB
Racket
Raw Normal View History

2019-12-27 18:18:24 +01:00
#lang racket
(require pict3d
pict3d/universe
2019-12-27 19:00:00 +01:00
"pict3d-lib.rkt"
"noise.rkt")
2019-12-27 18:18:24 +01:00
(struct scene-state
(done? dx dy sun-dir)
#:transparent)
(define init-scene-state
(scene-state #f 0 0 (dir 1 (- 3) 0)))
2019-12-27 18:27:27 +01:00
(current-material (material #:ambient 0.1
#:diffuse 0.6
#:specular 0.3
#:roughness 0.5))
2019-12-27 18:18:24 +01:00
2019-12-27 19:00:00 +01:00
(define (mesh t)
(let* ([lines
(for*/list ([i (in-range -10 10)]
[j (in-range 0 10)])
(with-color (rgba-hex "05ffa1")
2019-12-27 18:27:27 +01:00
(move (cylinder (pos (- 0.1) (- 0.1) -5)
(pos 0.1 0.1 10))
2019-12-27 19:00:00 +01:00
(dir i 0 j))))]
[lines-frozen (freeze (apply combine lines))]
[spheres (for*/list ([i (in-range -10 10)]
[j (in-range -1 10)])
2019-12-27 19:18:26 +01:00
(let ([x i]
[z j]
[y (scale-number
(perlin (scale-number i -10 10 -1 1)
(scale-number j -1 10 -1 1)
(scale-number t 0 2000 -1 1))
-1 1
0 4)]
[alpha (scale-number
(simplex (scale-number i -10 10 -1 1)
(scale-number j -1 10 -1 1)
(scale-number t 0 2000 -1 1))
-1 1
0.1 0.8)])
(with-emitted (emitted-hex "ff71ce" alpha) (sphere (pos x y z) 0.2))))])
2019-12-27 19:00:00 +01:00
(combine lines-frozen
spheres
(move (rotate-y lines-frozen 90)
(dir -7 0 5)))))
2019-12-27 18:18:24 +01:00
(define scene
(rotate-y (cube (pos 0 0 0) 1) 30))
(define (make-sunlight d)
(sunlight
d
(emitted "white" 1/2)))
(define (on-draw s n t)
(combine (basis 'camera
(point-at (pos 0 4 -6) origin))
(make-sunlight (scene-state-sun-dir s))
2019-12-27 19:00:00 +01:00
(mesh t)
;; (move-y (rotate-x scene (/ t 20)) 2)
))
2019-12-27 18:18:24 +01:00
(define (on-key s n t k)
(case k
[("escape" "q") (struct-copy scene-state s [done? #t])]
[("right") (struct-copy scene-state s
[sun-dir (dir+ +x (scene-state-sun-dir s))])]
[("left") (struct-copy scene-state s
[sun-dir (dir+ -x (scene-state-sun-dir s))])]
[else s]))
(define (stop-state? s n t) (scene-state-done? s))
(big-bang3d init-scene-state
#:on-draw on-draw
#:on-key on-key
#:stop-state? stop-state?
2019-12-27 19:18:26 +01:00
#:name "sketch"
#:width 800
#:height 600)
2019-12-27 18:18:24 +01:00