github.com/riscv/riscv-go@v0.0.0-20200123204226-124ebd6fcc8e/src/image/draw/example_test.go (about)

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