代码拉取完成,页面将自动刷新
package psd
import (
"compress/zlib"
"errors"
"image"
"io"
)
// CompressionMethod represents compression method that is used in psd file.
type CompressionMethod int16
// These compression methods are defined in this document.
//
// http://www.adobe.com/devnet-apps/photoshop/fileformatashtml/#50577409_pgfId-1054855
const (
CompressionMethodRaw = CompressionMethod(0)
CompressionMethodRLE = CompressionMethod(1)
CompressionMethodZIPWithoutPrediction = CompressionMethod(2)
CompressionMethodZIPWithPrediction = CompressionMethod(3)
)
var (
errBrokenPackBits = errors.New("psd: compressed image data seems broken")
)
// Decode decodes the compressed image data from r.
//
// You can pass 0 to sizeHint if unknown, but in this case may read more data than necessary from r.
func (cm CompressionMethod) Decode(dest []byte, r io.Reader, sizeHint int64, rect image.Rectangle, depth int, channels int, large bool) (read int, err error) {
switch cm {
case CompressionMethodRaw:
return io.ReadFull(r, dest)
case CompressionMethodRLE:
var width int
if depth == 1 {
width = (rect.Dx() + 7) >> 3
} else {
width = rect.Dx()
}
return decodePackBits(dest, r, width, rect.Dy()*channels, large)
case CompressionMethodZIPWithoutPrediction:
return decodeZLIB(dest, r, sizeHint)
case CompressionMethodZIPWithPrediction:
if read, err = decodeZLIB(dest, r, sizeHint); err != nil {
return read, err
}
decodeDelta(dest, rect.Dx(), depth)
return read, err
}
return 0, errors.New("psd: compression method " + itoa(int(cm)) + " is not implemented")
}
// decodeZLIB decodes compressed data by zlib.
// You can pass 0 to length if unknown,
// but in that case may read more data than necessary from r.
func decodeZLIB(dest []byte, r io.Reader, length int64) (read int, err error) {
N := length
if N == 0 {
N = 0x7fffffffffffffff
}
lr := &io.LimitedReader{R: r, N: N}
zr, err := zlib.NewReader(lr)
if err != nil {
return 0, err
}
if _, err = io.ReadFull(zr, dest); err != nil {
zr.Close()
return int(N - lr.N), err
}
if err = zr.Close(); err != nil {
return int(N - lr.N), err
}
return int(N - lr.N), nil
}
func decodeDelta(buf []byte, width int, depth int) {
switch depth {
case 16:
var d uint16
for i := 0; i < len(buf); {
d = 0
for j := 0; j < width; j++ {
d += readUint16(buf, i)
writeUint16(buf, d, i)
i += 2
}
}
case 32:
var d uint32
for i := 0; i < len(buf); {
d = 0
for j := 0; j < width; j++ {
d += readUint32(buf, i)
writeUint32(buf, d, i)
i += 4
}
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。