feat: phase 5 — Tight decoder with zlib streams and sub-palettes
codec/tight.rs: - Full Tight (encoding 7) decoder per ByteColorRFBRenderer.a() line 324 - Control byte: bottom 4 bits = zlib stream reset flags, top 4 bits = subencoding (0-15) - Subencoding 8: solid fill (1-byte color) - Subencoding 15: palette-indexed fill (selector + index) - Subencodings 4-7: filtered data with optional 2-color palette - Subencodings 10-13: reduced bit-depth packed (1/2/4 bpp) - Subencodings 0-3: raw 8bpp data - Data >= 12 bytes uses zlib compression with varint length - 4 persistent zlib streams with reset-on-flag logic - All 4 hardcoded sub-palettes ported as RGB332 indices: PALETTE_BW (2), PALETTE_GRAY4 (4), PALETTE_GRAY16 (16), PALETTE_COLOR16 (16 EGA-like colors) - Bit-depth unpackers: 1bpp, 2bpp, 4bpp (MSB-first) - 5 unit tests Updated examples to request [7, 5, 1, 0, -250] (Tight preferred). Tested against real OmniView: correct rendering with Tight encoding. 32 tests passing. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -53,8 +53,8 @@ fn main() {
|
||||
let cfg = Config::new(host, port, applet_id);
|
||||
println!("Connecting to {}:{}...", cfg.host, cfg.port);
|
||||
|
||||
// Request Hextile (5), CopyRect (1), Raw (0)
|
||||
let mut session = ActiveSession::connect(&cfg, &[5, 1, 0]).expect("connect failed");
|
||||
// Request Tight (7), Hextile (5), CopyRect (1), Raw (0), cursor pseudo (-250)
|
||||
let mut session = ActiveSession::connect(&cfg, &[7, 5, 1, 0, -250]).expect("connect failed");
|
||||
println!(
|
||||
"Connected: {}x{}, recording for {duration_secs}s...",
|
||||
session.framebuffer.width, session.framebuffer.height
|
||||
|
||||
Reference in New Issue
Block a user