main.go 2.1 KB
Newer Older
1 2
// Copyright 2010 The Freetype-Go Authors. All rights reserved.
// Use of this source code is governed by your choice of either the
3 4
// FreeType License or the GNU General Public License version 2 (or
// any later version), both of which can be found in the LICENSE file.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

package main

import (
	"bufio"
	"exp/draw"
	"fmt"
	"image"
	"image/png"
	"log"
	"os"

	"freetype-go.googlecode.com/hg/freetype/raster"
)

func p(x, y int) raster.Point {
21
	return raster.Point{raster.Fix32(x * 256), raster.Fix32(y * 256)}
22 23 24
}

func clear(m *image.Alpha) {
25 26 27 28 29 30
	b := m.Bounds()
	for y := b.Min.Y; y < b.Max.Y; y++ {
		base := y * m.Stride
		p := m.Pix[base+b.Min.X : base+b.Max.X]
		for i, _ := range p {
			p[i] = image.AlphaColor{0}
31 32 33 34 35 36
		}
	}
}

func main() {
	// Draw a rounded corner that is one pixel wide.
37
	r := raster.NewRasterizer(50, 50)
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
	r.Start(p(5, 5))
	r.Add1(p(5, 25))
	r.Add2(p(5, 45), p(25, 45))
	r.Add1(p(45, 45))
	r.Add1(p(45, 44))
	r.Add1(p(26, 44))
	r.Add2(p(6, 44), p(6, 24))
	r.Add1(p(6, 5))
	r.Add1(p(5, 5))

	// Rasterize that curve multiple times at different gammas.
	const (
		w = 600
		h = 200
	)
	rgba := image.NewRGBA(w, h)
54 55
	draw.Draw(rgba, image.Rect(0, 0, w, h/2), image.Black, image.ZP)
	draw.Draw(rgba, image.Rect(0, h/2, w, h), image.White, image.ZP)
56
	mask := image.NewAlpha(50, 50)
57
	painter := raster.NewAlphaSrcPainter(mask)
58
	gammas := []float{1.0 / 10.0, 1.0 / 3.0, 1.0 / 2.0, 2.0 / 3.0, 4.0 / 5.0, 1.0, 5.0 / 4.0, 3.0 / 2.0, 2.0, 3.0, 10.0}
59 60
	for i, g := range gammas {
		clear(mask)
61
		r.Rasterize(raster.NewGammaCorrectionPainter(painter, g))
62
		x, y := 50*i+25, 25
63
		draw.DrawMask(rgba, image.Rect(x, y, x+50, y+50), image.White, image.ZP, mask, image.ZP, draw.Over)
64
		y += 100
65
		draw.DrawMask(rgba, image.Rect(x, y, x+50, y+50), image.Black, image.ZP, mask, image.ZP, draw.Over)
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
	}

	// Save that RGBA image to disk.
	f, err := os.Open("out.png", os.O_CREAT|os.O_WRONLY, 0600)
	if err != nil {
		log.Stderr(err)
		os.Exit(1)
	}
	defer f.Close()
	b := bufio.NewWriter(f)
	err = png.Encode(b, rgba)
	if err != nil {
		log.Stderr(err)
		os.Exit(1)
	}
	err = b.Flush()
	if err != nil {
		log.Stderr(err)
		os.Exit(1)
	}
	fmt.Println("Wrote out.png OK.")
}