-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmask.go
48 lines (41 loc) · 1.09 KB
/
mask.go
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
package raster
import (
"image"
"image/color"
"unsafe"
)
// Renders the mask to the canvas
func DrawSolidRGBA(dest *image.RGBA, mask *image.Alpha, rgba color.RGBA) {
rect := dest.Bounds().Intersect(mask.Bounds())
minX := uint32(rect.Min.X)
minY := uint32(rect.Min.Y)
maxX := uint32(rect.Max.X)
maxY := uint32(rect.Max.Y)
pixColor := *(*uint32)(unsafe.Pointer(&rgba))
cs1 := pixColor & 0xff00ff
cs2 := (pixColor >> 8) & 0xff00ff
stride1 := uint32(dest.Stride)
stride2 := uint32(mask.Stride)
maxY *= stride1
var pix, pixm []uint8
var pixelx uint32
var x, y1, y2 uint32
for y1, y2 = minY*stride1, minY*stride2; y1 < maxY; y1, y2 = y1+stride1, y2+stride2 {
pix = dest.Pix[y1:]
pixm = mask.Pix[y2:]
pixelx = minX * 4
for x = minX; x < maxX; x++ {
alpha := uint32(pixm[x])
p := (*uint32)(unsafe.Pointer(&pix[pixelx]))
if alpha != 0 {
invAlpha := 0xff - alpha
ct1 := (*p & 0xff00ff) * invAlpha
ct2 := ((*p >> 8) & 0xff00ff) * invAlpha
ct1 = ((ct1 + cs1*alpha) >> 8) & 0xff00ff
ct2 = (ct2 + cs2*alpha) & 0xff00ff00
*p = ct1 + ct2
}
pixelx += 4
}
}
}