78 for (i = dx + h; i > dx; i--) {
79 nsptr = sptr + i * stride + dy * 3;
80 npfptr = pfptr + i * stride + dy * 3;
81 for (j = 0; j < w * 3; j++) {
82 diff |= npfptr[j] ^ nsptr[j];
100 "Input dimensions too large, input must be max 4096x4096 !\n");
105 memset(&s->
zstream, 0,
sizeof(z_stream));
125 int buf_size,
int block_width,
int block_height,
126 uint8_t *previous_frame,
int *I_frame)
130 int h_blocks, v_blocks, h_part, v_part, i, j;
136 put_bits(&pb, 4, block_width / 16 - 1);
138 put_bits(&pb, 4, block_height / 16 - 1);
149 for (j = 0; j < v_blocks + (v_part ? 1 : 0); j++) {
151 int y_pos = j * block_height;
152 int cur_blk_height = (j < v_blocks) ? block_height : v_part;
155 for (i = 0; i < h_blocks + (h_part ? 1 : 0); i++) {
156 int x_pos = i * block_width;
157 int cur_blk_width = (i < h_blocks) ? block_width : h_part;
165 x_pos, cur_blk_height, cur_blk_width,
168 if (res || *I_frame) {
169 unsigned long zsize = 3 * block_width * block_height;
170 ret = compress2(ptr + 2, &zsize, s->
tmpblock,
171 3 * cur_blk_width * cur_blk_height, 9);
176 "error while compressing block %dx%d\n", i, j);
178 bytestream_put_be16(&ptr, zsize);
179 buf_pos += zsize + 2;
183 bytestream_put_be16(&ptr, 0);
199 const AVFrame *pict,
int *got_packet)
206 int opt_w = 4, opt_h = 4;