mirror of
https://github.com/unidoc/unipdf.git
synced 2025-05-05 19:30:30 +08:00

* Prepared skeleton and basic component implementations for the jbig2 encoding. * Added Bitset. Implemented Bitmap. * Decoder with old Arithmetic Decoder * Partly working arithmetic * Working arithmetic decoder. * MMR patched. * rebuild to apache. * Working generic * Decoded full document * Decoded AnnexH document * Minor issues fixed. * Update README.md * Fixed generic region errors. Added benchmark. Added bitmap unpadder. Added Bitmap toImage method. * Fixed endofpage error * Added integration test. * Decoded all test files without errors. Implemented JBIG2Global. * Merged with v3 version * Fixed the EOF in the globals issue * Fixed the JBIG2 ChocolateData Decode * JBIG2 Added license information * Minor fix in jbig2 encoding. * Applied the logging convention * Cleaned unnecessary imports * Go modules clear unused imports * checked out the README.md * Moved trace to Debug. Fixed the build integrate tag in the document_decode_test.go * Applied UniPDF Developer Guide. Fixed lint issues. * Cleared documentation, fixed style issues. * Added jbig2 doc.go files. Applied unipdf guide style. * Minor code style changes. * Minor naming and style issues fixes. * Minor naming changes. Style issues fixed. * Review r11 fixes. * Integrate jbig2 tests with build system * Added jbig2 integration test golden files. * Minor jbig2 integration test fix * Removed jbig2 integration image assertions * Fixed jbig2 rowstride issue. Implemented jbig2 bit writer * Changed golden files logic. Fixes r13 issues.
103 lines
2.8 KiB
Go
103 lines
2.8 KiB
Go
/*
|
|
* This file is subject to the terms and conditions defined in
|
|
* file 'LICENSE.md', which is part of this source code package.
|
|
*/
|
|
|
|
package segments
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/unidoc/unipdf/v3/common"
|
|
|
|
"github.com/unidoc/unipdf/v3/internal/jbig2/bitmap"
|
|
"github.com/unidoc/unipdf/v3/internal/jbig2/reader"
|
|
)
|
|
|
|
// TestDecodeGenericRegion tests the decode process of the jbig2 Generic Region.
|
|
func TestDecodeGenericRegion(t *testing.T) {
|
|
if testing.Verbose() {
|
|
common.SetLogger(common.NewConsoleLogger(common.LogLevelDebug))
|
|
}
|
|
|
|
t.Run("AnnexH", func(t *testing.T) {
|
|
t.Run("S-12th", func(t *testing.T) {
|
|
data := []byte{
|
|
// header
|
|
0x00, 0x00, 0x00, 0x0B, 0x27, 0x00, 0x02, 0x00, 0x00, 0x00, 0x23,
|
|
|
|
// data
|
|
0x00, 0x00, 0x00, 0x36, 0x00, 0x00, 0x00, 0x2C, 0x00, 0x00, 0x00, 0x04,
|
|
0x00, 0x00, 0x00, 0x0B, 0x00, 0x08, 0x03, 0xFF, 0xFD, 0xFF, 0x02, 0xFE,
|
|
0xFE, 0xFE, 0x04, 0xEE, 0xED, 0x87, 0xFB, 0xCB, 0x2B, 0xFF, 0xAC,
|
|
}
|
|
|
|
r := reader.New(data)
|
|
d := &document{}
|
|
h, err := NewHeader(d, r, 0, OSequential)
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, uint32(11), h.SegmentNumber)
|
|
assert.Equal(t, uint64(35), h.SegmentDataLength)
|
|
assert.Equal(t, 2, h.PageAssociation)
|
|
|
|
sg, err := h.GetSegmentData()
|
|
require.NoError(t, err)
|
|
|
|
s, ok := sg.(*GenericRegion)
|
|
require.True(t, ok)
|
|
|
|
assert.Equal(t, 44, s.RegionSegment.BitmapHeight)
|
|
assert.Equal(t, 54, s.RegionSegment.BitmapWidth)
|
|
assert.Equal(t, bitmap.CmbOpOr, s.RegionSegment.CombinaionOperator)
|
|
assert.Equal(t, true, s.IsTPGDon)
|
|
assert.Equal(t, byte(0), s.GBTemplate)
|
|
|
|
bm, err := s.GetRegionBitmap()
|
|
require.NoError(t, err)
|
|
|
|
t.Log(bm.String())
|
|
})
|
|
|
|
t.Run("S-5th", func(t *testing.T) {
|
|
data := []byte{
|
|
// Header
|
|
0x00, 0x00, 0x00, 0x04, 0x27, 0x00, 0x01, 0x00, 0x00, 0x00, 0x2C,
|
|
|
|
// Data part
|
|
0x00, 0x00, 0x00, 0x36, 0x00, 0x00, 0x00, 0x2C, 0x00, 0x00, 0x00,
|
|
0x04, 0x00, 0x00, 0x00, 0x0B, 0x00, 0x01, 0x26, 0xA0, 0x71, 0xCE,
|
|
0xA7, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xF8, 0xF0,
|
|
}
|
|
r := reader.New(data)
|
|
d := &document{}
|
|
h, err := NewHeader(d, r, 0, OSequential)
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, uint32(4), h.SegmentNumber)
|
|
assert.Equal(t, uint64(44), h.SegmentDataLength)
|
|
assert.Equal(t, 1, h.PageAssociation)
|
|
|
|
gs, err := h.GetSegmentData()
|
|
require.NoError(t, err)
|
|
|
|
s, ok := gs.(*GenericRegion)
|
|
require.True(t, ok)
|
|
|
|
assert.Equal(t, 44, s.RegionSegment.BitmapHeight)
|
|
assert.Equal(t, 54, s.RegionSegment.BitmapWidth)
|
|
assert.Equal(t, bitmap.CmbOpOr, s.RegionSegment.CombinaionOperator)
|
|
assert.Equal(t, true, s.IsMMREncoded)
|
|
|
|
b, err := s.GetRegionBitmap()
|
|
require.NoError(t, err)
|
|
|
|
t.Log(b.String())
|
|
})
|
|
})
|
|
}
|