From 64b098ed41d802ae729375cc5f2c0c873dc948ac Mon Sep 17 00:00:00 2001 From: Igor V Belousov Date: Thu, 18 Nov 2021 21:20:24 +0300 Subject: [PATCH] Lesson 1 - lissajous.go (gif) --- ch1/lissajous.go | 52 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 ch1/lissajous.go diff --git a/ch1/lissajous.go b/ch1/lissajous.go new file mode 100644 index 0000000..b9f9557 --- /dev/null +++ b/ch1/lissajous.go @@ -0,0 +1,52 @@ +// Lissajous генерирует анимированный gif из случайных +// фигур Лиссажу. +package main + +import ( + "image" + "image/color" + "image/gif" + "io" + "math" + "math/rand" + "os" + "time" +) + +var palette = []color.Color{color.White, color.Black} + +const ( + whiteIndex = 0 // Первый цвет палитры + blackIndex = 1 // Следующий цвет палитры +) + +func main() { + lissajous(os.Stdout) +} + +func lissajous(out io.Writer) { + const ( + cycles = 5 // Количество полных колебаний x + res = 0.001 // Угловое разрешение + size = 100 // Канва изобрадения охватывает [size..+size] + nframes = 64 // Количество кадро анимации + delay = 8 // Задержка между кадрами (единица - 10мс) + ) + rand.Seed(time.Now().UTC().UnixNano()) + 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) +}