func main() { flag.Parse() font, err := loadFont() if err != nil { log.Println(err) return } fontHeight := int(createContext(font).PointToFix32(*size) >> 8) // two points to output the text and its shadow ptA := freetype.Pt(*indent+1, *indent+1+fontHeight) ptB := freetype.Pt(*indent, *indent+fontHeight) proxy := goproxy.NewProxyHttpServer() proxy.OnResponse().Do(goproxy_image.HandleImage(func(img image.Image, ctx *goproxy.ProxyCtx) image.Image { outImage := image.NewRGBA(img.Bounds()) draw.Copy(outImage, image.ZP, img, img.Bounds(), nil) text := fmt.Sprintf("%dx%d", img.Bounds().Dx(), img.Bounds().Dy()) fontContext := createContext(font) fontContext.SetClip(img.Bounds()) fontContext.SetDst(outImage) drawString(image.White, fontContext, ptA, text) drawString(image.Black, fontContext, ptB, text) return outImage })) proxy.Verbose = *verbose log.Fatal(http.ListenAndServe(":"+*port, proxy)) }
func addBounds(img image.Image) image.Image { imgWidth := img.Bounds().Dx() + 16 imgHeight := img.Bounds().Dy() + 16 newImg := image.NewRGBA(image.Rect(0, 0, imgWidth, imgHeight)) draw.Draw(newImg, newImg.Bounds(), &image.Uniform{color.RGBA{255, 255, 255, 255}}, image.ZP, draw.Src) draw.Copy(newImg, image.Pt(8, 8), img, img.Bounds(), draw.Src, nil) return newImg }
func generateLogoThumbnail(m image.Image) (image.Image, error) { dst := image.NewRGBA(image.Rect(0, 0, 128, 128)) resized := resize.Resize(128, 0, m, resize.Bicubic) // resize to width 128, preserve aspect ratio p := image.Point{ (dst.Bounds().Dx() - resized.Bounds().Dx()) / 2.0, (dst.Bounds().Dy() - resized.Bounds().Dy()) / 2.0, } draw.Copy(dst, p, resized, resized.Bounds(), draw.Src, nil) return dst, nil }
func ExampleDraw() { fSrc, err := os.Open("../testdata/blue-purple-pink.png") if err != nil { log.Fatal(err) } defer fSrc.Close() src, err := png.Decode(fSrc) if err != nil { log.Fatal(err) } sr := src.Bounds() dst := image.NewRGBA(image.Rect(0, 0, 400, 300)) qs := []draw.Interpolator{ draw.NearestNeighbor, draw.ApproxBiLinear, draw.CatmullRom, } const cos60, sin60 = 0.5, 0.866025404 t := &f64.Aff3{ +2 * cos60, -2 * sin60, 100, +2 * sin60, +2 * cos60, 100, } draw.Copy(dst, image.Point{20, 30}, src, sr, nil) for i, q := range qs { q.Scale(dst, image.Rect(200+10*i, 100*i, 600+10*i, 150+100*i), src, sr, nil) } draw.NearestNeighbor.Transform(dst, t, src, sr, nil) // Change false to true to write the resultant image to disk. if false { fDst, err := os.Create("out.png") if err != nil { log.Fatal(err) } defer fDst.Close() err = png.Encode(fDst, dst) if err != nil { log.Fatal(err) } } fmt.Printf("dst has bounds %v.\n", dst.Bounds()) // Output: // dst has bounds (0,0)-(400,300). }
func (sq *Square) Draw(glctx gl.Context, sz size.Event, major, minor string) { if sq == nil { return } draw.Copy(sq.img1.RGBA, image.ZP, image.NewUniform(colornames.Map["deepskyblue"]), sq.img1.RGBA.Bounds(), draw.Src, nil) ftctx := sq.ftctx ftctx.SetFontSize(12) ftctx.DrawString(major, fixed.Point26_6{X: 100, Y: 7000}) ftctx.SetFontSize(10) ftctx.DrawString(minor, fixed.Point26_6{X: 100, Y: 11000}) b := sq.img1.RGBA.Bounds() sq.img1.Upload() sq.img1.Draw(sz, geom.Point{X: 0, Y: 0}, geom.Point{X: geom.Pt(b.Max.X) / 4, Y: 0}, geom.Point{X: 0, Y: geom.Pt(b.Max.Y) / 4}, sq.img1.RGBA.Bounds()) }
func ExampleDraw() { fSrc, err := os.Open("../testdata/blue-purple-pink.png") if err != nil { log.Fatal(err) } defer fSrc.Close() src, err := png.Decode(fSrc) if err != nil { log.Fatal(err) } dst := image.NewRGBA(image.Rect(0, 0, 400, 300)) green := image.NewUniform(color.RGBA{0x00, 0x1f, 0x00, 0xff}) draw.Copy(dst, image.Point{}, green, dst.Bounds(), draw.Src, nil) qs := []draw.Interpolator{ draw.NearestNeighbor, draw.ApproxBiLinear, draw.CatmullRom, } const cos60, sin60 = 0.5, 0.866025404 t := f64.Aff3{ +2 * cos60, -2 * sin60, 100, +2 * sin60, +2 * cos60, 100, } draw.Copy(dst, image.Point{20, 30}, src, src.Bounds(), draw.Over, nil) for i, q := range qs { q.Scale(dst, image.Rect(200+10*i, 100*i, 600+10*i, 150+100*i), src, src.Bounds(), draw.Over, nil) } draw.NearestNeighbor.Transform(dst, t, src, src.Bounds(), draw.Over, nil) red := image.NewNRGBA(image.Rect(0, 0, 16, 16)) for y := 0; y < 16; y++ { for x := 0; x < 16; x++ { red.SetNRGBA(x, y, color.NRGBA{ R: uint8(x * 0x11), A: uint8(y * 0x11), }) } } red.SetNRGBA(0, 0, color.NRGBA{0xff, 0xff, 0x00, 0xff}) red.SetNRGBA(15, 15, color.NRGBA{0xff, 0xff, 0x00, 0xff}) ops := []draw.Op{ draw.Over, draw.Src, } for i, op := range ops { dr := image.Rect(120+10*i, 150+60*i, 170+10*i, 200+60*i) draw.NearestNeighbor.Scale(dst, dr, red, red.Bounds(), op, nil) t := f64.Aff3{ +cos60, -sin60, float64(190 + 10*i), +sin60, +cos60, float64(140 + 50*i), } draw.NearestNeighbor.Transform(dst, t, red, red.Bounds(), op, nil) } dr := image.Rect(0, 0, 128, 128) checkerboard := image.NewAlpha(dr) for y := dr.Min.Y; y < dr.Max.Y; y++ { for x := dr.Min.X; x < dr.Max.X; x++ { if (x/20)%2 == (y/20)%2 { checkerboard.SetAlpha(x, y, color.Alpha{0xff}) } } } sr := image.Rect(0, 0, 16, 16) circle := image.NewAlpha(sr) for y := sr.Min.Y; y < sr.Max.Y; y++ { for x := sr.Min.X; x < sr.Max.X; x++ { dx, dy := x-10, y-8 if d := 32 * math.Sqrt(float64(dx*dx)+float64(dy*dy)); d < 0xff { circle.SetAlpha(x, y, color.Alpha{0xff - uint8(d)}) } } } cyan := image.NewUniform(color.RGBA{0x00, 0xff, 0xff, 0xff}) draw.NearestNeighbor.Scale(dst, dr, cyan, sr, draw.Over, &draw.Options{ DstMask: checkerboard, SrcMask: circle, }) // Change false to true to write the resultant image to disk. if false { fDst, err := os.Create("out.png") if err != nil { log.Fatal(err) } defer fDst.Close() err = png.Encode(fDst, dst) if err != nil { log.Fatal(err) } } fmt.Printf("dst has bounds %v.\n", dst.Bounds()) // Output: // dst has bounds (0,0)-(400,300). }