liyujie
2025-08-28 d9927380ed7c8366f762049be9f3fee225860833
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright 2016 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
 
package draw_test
 
import (
   "fmt"
   "image"
   "image/color"
   "image/draw"
   "math"
)
 
func ExampleDrawer_floydSteinberg() {
   const width = 130
   const height = 50
 
   im := image.NewGray(image.Rectangle{Max: image.Point{X: width, Y: height}})
   for x := 0; x < width; x++ {
       for y := 0; y < height; y++ {
           dist := math.Sqrt(math.Pow(float64(x-width/2), 2)/3+math.Pow(float64(y-height/2), 2)) / (height / 1.5) * 255
           var gray uint8
           if dist > 255 {
               gray = 255
           } else {
               gray = uint8(dist)
           }
           im.SetGray(x, y, color.Gray{Y: 255 - gray})
       }
   }
   pi := image.NewPaletted(im.Bounds(), []color.Color{
       color.Gray{Y: 255},
       color.Gray{Y: 160},
       color.Gray{Y: 70},
       color.Gray{Y: 35},
       color.Gray{Y: 0},
   })
 
   draw.FloydSteinberg.Draw(pi, im.Bounds(), im, image.ZP)
   shade := []string{" ", "░", "▒", "▓", "█"}
   for i, p := range pi.Pix {
       fmt.Print(shade[p])
       if (i+1)%width == 0 {
           fmt.Print("\n")
       }
   }
}