Commit 03f987c8 authored by Nigel Tao's avatar Nigel Tao

image: tighten Paletted.Opaque to check only those palette entries

in the image, not all palette entries.

R=r
CC=golang-dev
https://golang.org/cl/4672049
parent 07c9a925
...@@ -548,7 +548,7 @@ func NewGray16(w, h int) *Gray16 { ...@@ -548,7 +548,7 @@ func NewGray16(w, h int) *Gray16 {
return &Gray16{pix, w, Rectangle{ZP, Point{w, h}}} return &Gray16{pix, w, Rectangle{ZP, Point{w, h}}}
} }
// A PalettedColorModel represents a fixed palette of colors. // A PalettedColorModel represents a fixed palette of at most 256 colors.
type PalettedColorModel []Color type PalettedColorModel []Color
func diff(a, b uint32) uint32 { func diff(a, b uint32) uint32 {
...@@ -648,7 +648,20 @@ func (p *Paletted) SubImage(r Rectangle) Image { ...@@ -648,7 +648,20 @@ func (p *Paletted) SubImage(r Rectangle) Image {
// Opaque scans the entire image and returns whether or not it is fully opaque. // Opaque scans the entire image and returns whether or not it is fully opaque.
func (p *Paletted) Opaque() bool { func (p *Paletted) Opaque() bool {
for _, c := range p.Palette { var present [256]bool
base := p.Rect.Min.Y * p.Stride
i0, i1 := base+p.Rect.Min.X, base+p.Rect.Max.X
for y := p.Rect.Min.Y; y < p.Rect.Max.Y; y++ {
for _, c := range p.Pix[i0:i1] {
present[c] = true
}
i0 += p.Stride
i1 += p.Stride
}
for i, c := range p.Palette {
if !present[i] {
continue
}
_, _, _, a := c.RGBA() _, _, _, a := c.RGBA()
if a != 0xffff { if a != 0xffff {
return false return false
......
...@@ -10,6 +10,7 @@ import ( ...@@ -10,6 +10,7 @@ import (
type image interface { type image interface {
Image Image
Opaque() bool
Set(int, int, Color) Set(int, int, Color)
SubImage(Rectangle) Image SubImage(Rectangle) Image
} }
...@@ -49,6 +50,10 @@ func TestImage(t *testing.T) { ...@@ -49,6 +50,10 @@ func TestImage(t *testing.T) {
t.Errorf("%T: at (6, 3), want a non-zero color, got %v", m, m.At(6, 3)) t.Errorf("%T: at (6, 3), want a non-zero color, got %v", m, m.At(6, 3))
continue continue
} }
if !m.SubImage(Rect(6, 3, 7, 4)).(image).Opaque() {
t.Errorf("%T: at (6, 3) was not opaque", m)
continue
}
m = m.SubImage(Rect(3, 2, 9, 8)).(image) m = m.SubImage(Rect(3, 2, 9, 8)).(image)
if !Rect(3, 2, 9, 8).Eq(m.Bounds()) { if !Rect(3, 2, 9, 8).Eq(m.Bounds()) {
t.Errorf("%T: sub-image want bounds %v, got %v", m, Rect(3, 2, 9, 8), m.Bounds()) t.Errorf("%T: sub-image want bounds %v, got %v", m, Rect(3, 2, 9, 8), m.Bounds())
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment