| // Copyright 2015 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 provides image composition functions. |
| // |
| // See "The Go image/draw package" for an introduction to this package: |
| // http://golang.org/doc/articles/image_draw.html |
| // |
| // This package is a superset of and a drop-in replacement for the image/draw |
| // package in the standard library. |
| package draw |
| |
| // This file just contains the API exported by the image/draw package in the |
| // standard library. Other files in this package provide additional features. |
| |
| import ( |
| "image" |
| "image/color" |
| "image/draw" |
| ) |
| |
| // Draw calls DrawMask with a nil mask. |
| func Draw(dst Image, r image.Rectangle, src image.Image, sp image.Point, op Op) { |
| draw.Draw(dst, r, src, sp, draw.Op(op)) |
| } |
| |
| // DrawMask aligns r.Min in dst with sp in src and mp in mask and then |
| // replaces the rectangle r in dst with the result of a Porter-Duff |
| // composition. A nil mask is treated as opaque. |
| func DrawMask(dst Image, r image.Rectangle, src image.Image, sp image.Point, mask image.Image, mp image.Point, op Op) { |
| draw.DrawMask(dst, r, src, sp, mask, mp, draw.Op(op)) |
| } |
| |
| // Drawer contains the Draw method. |
| type Drawer interface { |
| // Draw aligns r.Min in dst with sp in src and then replaces the |
| // rectangle r in dst with the result of drawing src on dst. |
| Draw(dst Image, r image.Rectangle, src image.Image, sp image.Point) |
| } |
| |
| // FloydSteinberg is a Drawer that is the Src Op with Floyd-Steinberg error |
| // diffusion. |
| var FloydSteinberg Drawer = floydSteinberg{} |
| |
| type floydSteinberg struct{} |
| |
| func (floydSteinberg) Draw(dst Image, r image.Rectangle, src image.Image, sp image.Point) { |
| draw.FloydSteinberg.Draw(dst, r, src, sp) |
| } |
| |
| // Image is an image.Image with a Set method to change a single pixel. |
| type Image interface { |
| image.Image |
| Set(x, y int, c color.Color) |
| } |
| |
| // Op is a Porter-Duff compositing operator. |
| type Op int |
| |
| const ( |
| // Over specifies ``(src in mask) over dst''. |
| Over Op = Op(draw.Over) |
| // Src specifies ``src in mask''. |
| Src Op = Op(draw.Src) |
| ) |
| |
| // Draw implements the Drawer interface by calling the Draw function with |
| // this Op. |
| func (op Op) Draw(dst Image, r image.Rectangle, src image.Image, sp image.Point) { |
| (draw.Op(op)).Draw(dst, r, src, sp) |
| } |
| |
| // Quantizer produces a palette for an image. |
| type Quantizer interface { |
| // Quantize appends up to cap(p) - len(p) colors to p and returns the |
| // updated palette suitable for converting m to a paletted image. |
| Quantize(p color.Palette, m image.Image) color.Palette |
| } |