init
This commit is contained in:
commit
f7443bbab9
30 changed files with 271 additions and 0 deletions
BIN
lisajous/hello.gif
Normal file
BIN
lisajous/hello.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 216 KiB |
BIN
lisajous/lisajous
Executable file
BIN
lisajous/lisajous
Executable file
Binary file not shown.
49
lisajous/lisajous.go
Normal file
49
lisajous/lisajous.go
Normal 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
0
lisajous/lisajous.go~
Normal file
BIN
lisajous/out.gif
Normal file
BIN
lisajous/out.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 224 KiB |
Reference in a new issue