work on dcc decoder
This commit is contained in:
parent
ed3f739fb8
commit
ce9e1b9958
@ -2,8 +2,10 @@ package dcc
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"fmt"
|
|
||||||
"io"
|
"io"
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/FooSoft/lazarus/streaming"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Sprite struct {
|
type Sprite struct {
|
||||||
@ -51,19 +53,113 @@ type frameHeader struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewFromReader(reader io.ReadSeeker) (*Sprite, error) {
|
func NewFromReader(reader io.ReadSeeker) (*Sprite, error) {
|
||||||
var fileHead fileHeader
|
var header fileHeader
|
||||||
if err := binary.Read(reader, binary.LittleEndian, &fileHead); err != nil {
|
if err := binary.Read(reader, binary.LittleEndian, &header); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
dirOffsets := make([]uint32, fileHead.DirCount)
|
for i := 0; i < int(header.DirCount); i++ {
|
||||||
for i := 0; i < int(fileHead.DirCount); i++ {
|
var offsetDir uint32
|
||||||
if err := binary.Read(reader, binary.LittleEndian, &dirOffsets[i]); err != nil {
|
if err := binary.Read(reader, binary.LittleEndian, &offsetDir); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
offset, err := reader.Seek(0, io.SeekCurrent)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, err := reader.Seek(int64(offsetDir), io.SeekStart); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := readDirection(reader); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, err := reader.Seek(offset, io.SeekStart); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf("%+v\n", fileHead)
|
|
||||||
fmt.Printf("%+v\n", dirOffsets)
|
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func readDirectionHeader(reader io.ReadSeeker) (*directionHeader, error) {
|
||||||
|
r := streaming.NewBitReader(reader)
|
||||||
|
|
||||||
|
codedSize, err := r.ReadBits(32)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
hasRawPixelEncoding, err := r.ReadBits(1)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
compressEqualCells, err := r.ReadBits(1)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
variable0Bits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
widthBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
heightBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
offsetXBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
offsetYBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
optionalBytesBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
codedBytesBits, err := r.ReadBits(4)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
header := directionHeader{
|
||||||
|
CodedSize: uint32(codedSize),
|
||||||
|
HasRawPixelEncoding: hasRawPixelEncoding == 1,
|
||||||
|
CompressEqualCells: compressEqualCells == 1,
|
||||||
|
Variable0Bits: uint32(variable0Bits),
|
||||||
|
WidthBits: uint32(widthBits),
|
||||||
|
HeightBits: uint32(heightBits),
|
||||||
|
OffsetXBits: int32(offsetXBits),
|
||||||
|
OffsetYBits: int32(offsetYBits),
|
||||||
|
OptionalBytesBits: uint32(optionalBytesBits),
|
||||||
|
CodedBytesBits: uint32(codedBytesBits),
|
||||||
|
}
|
||||||
|
|
||||||
|
return &header, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func readDirection(reader io.ReadSeeker) error {
|
||||||
|
header, err := readDirectionHeader(reader)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
log.Printf("%+v\n", header)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -11,7 +11,7 @@ type BitReader struct {
|
|||||||
buffer [1]byte
|
buffer [1]byte
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewReader(reader io.Reader) *BitReader {
|
func NewBitReader(reader io.Reader) *BitReader {
|
||||||
return &BitReader{reader: reader}
|
return &BitReader{reader: reader}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ func TestBitReader(t *testing.T) {
|
|||||||
0xff, // 11111111
|
0xff, // 11111111
|
||||||
}
|
}
|
||||||
|
|
||||||
r := NewReader(bytes.NewReader(data))
|
r := NewBitReader(bytes.NewReader(data))
|
||||||
|
|
||||||
readPass := func(c int, v uint64) {
|
readPass := func(c int, v uint64) {
|
||||||
if value, err := r.ReadBits(c); value != v || err != nil {
|
if value, err := r.ReadBits(c); value != v || err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user