This commit is contained in:
Geir Okkenhaug Jerstad 2024-08-13 20:31:39 +02:00
commit f7443bbab9
30 changed files with 271 additions and 0 deletions

BIN
lisajous/hello.gif Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 216 KiB

BIN
lisajous/lisajous Executable file

Binary file not shown.

49
lisajous/lisajous.go Normal file
View file

@ -0,0 +1,49 @@
// Lisajous generates GIF animations of random Lisajous figures.
package main
import (
"image"
"image/color"
"image/gif"
"io"
"math"
"math/rand"
"os"
)
var palette = [] color.Color{color.White, color.Black}
const (
whiteIndex = 0
blackindex = 1
)
func main() {
lisajous(os.Stdout)
}
func lisajous(out io.Writer) {
const (
cycles = 5
res = 0.001
size = 100
nframes = 64
delay = 8
)
freq := rand.Float64() * 3.0
anim := gif.GIF{LoopCount: nframes}
phase := 0.0
for i := 0; i < nframes; i++ {
rect := image.Rect(0, 0, 2*size+1, 2*size+1)
img := image.NewPaletted(rect, palette)
for t := 0.0; t < cycles*2*math.Pi; t += res {
x := math.Sin(t)
y := math.Sin(t*freq + phase)
img.SetColorIndex(size+int(x*size+0.5), size+int(y*size+0.5), blackindex)
}
phase += 0.1
anim.Delay = append(anim.Delay, delay)
anim.Image = append(anim.Image, img)
}
gif.EncodeAll(out, &anim)
}

0
lisajous/lisajous.go~ Normal file
View file

BIN
lisajous/out.gif Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 224 KiB