mirror of
				https://github.com/ossrs/srs.git
				synced 2025-03-09 15:49:59 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			111 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * MJPEG encoder
 | |
|  * Copyright (c) 2000, 2001 Fabrice Bellard
 | |
|  * Copyright (c) 2003 Alex Beregszaszi
 | |
|  * Copyright (c) 2003-2004 Michael Niedermayer
 | |
|  *
 | |
|  * Support for external huffman table, various fixes (AVID workaround),
 | |
|  * aspecting, new decode_frame mechanism and apple mjpeg-b support
 | |
|  *                                  by Alex Beregszaszi
 | |
|  *
 | |
|  * This file is part of FFmpeg.
 | |
|  *
 | |
|  * FFmpeg is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2.1 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * FFmpeg is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with FFmpeg; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @file
 | |
|  * MJPEG encoder.
 | |
|  */
 | |
| 
 | |
| #ifndef AVCODEC_MJPEGENC_H
 | |
| #define AVCODEC_MJPEGENC_H
 | |
| 
 | |
| #include <stdint.h>
 | |
| 
 | |
| #include "mjpeg.h"
 | |
| #include "mpegvideo.h"
 | |
| #include "put_bits.h"
 | |
| 
 | |
| /**
 | |
|  * Buffer of JPEG frame data.
 | |
|  *
 | |
|  * Optimal Huffman table generation requires the frame data to be loaded into
 | |
|  * a buffer so that the tables can be computed.
 | |
|  * There are at most mb_width*mb_height*12*64 of these per frame.
 | |
|  */
 | |
| typedef struct MJpegHuffmanCode {
 | |
|     // 0=DC lum, 1=DC chrom, 2=AC lum, 3=AC chrom
 | |
|     uint8_t table_id; ///< The Huffman table id associated with the data.
 | |
|     uint8_t code;     ///< The exponent.
 | |
|     uint16_t mant;    ///< The mantissa.
 | |
| } MJpegHuffmanCode;
 | |
| 
 | |
| /**
 | |
|  * Holds JPEG frame data and Huffman table data.
 | |
|  */
 | |
| typedef struct MJpegContext {
 | |
|     //FIXME use array [3] instead of lumi / chroma, for easier addressing
 | |
|     uint8_t huff_size_dc_luminance[12];     ///< DC luminance Huffman table size.
 | |
|     uint16_t huff_code_dc_luminance[12];    ///< DC luminance Huffman table codes.
 | |
|     uint8_t huff_size_dc_chrominance[12];   ///< DC chrominance Huffman table size.
 | |
|     uint16_t huff_code_dc_chrominance[12];  ///< DC chrominance Huffman table codes.
 | |
| 
 | |
|     uint8_t huff_size_ac_luminance[256];    ///< AC luminance Huffman table size.
 | |
|     uint16_t huff_code_ac_luminance[256];   ///< AC luminance Huffman table codes.
 | |
|     uint8_t huff_size_ac_chrominance[256];  ///< AC chrominance Huffman table size.
 | |
|     uint16_t huff_code_ac_chrominance[256]; ///< AC chrominance Huffman table codes.
 | |
| 
 | |
|     /** Storage for AC luminance VLC (in MpegEncContext) */
 | |
|     uint8_t uni_ac_vlc_len[64 * 64 * 2];
 | |
|     /** Storage for AC chrominance VLC (in MpegEncContext) */
 | |
|     uint8_t uni_chroma_ac_vlc_len[64 * 64 * 2];
 | |
| 
 | |
|     // Default DC tables have exactly 12 values
 | |
|     uint8_t bits_dc_luminance[17];   ///< DC luminance Huffman bits.
 | |
|     uint8_t val_dc_luminance[12];    ///< DC luminance Huffman values.
 | |
|     uint8_t bits_dc_chrominance[17]; ///< DC chrominance Huffman bits.
 | |
|     uint8_t val_dc_chrominance[12];  ///< DC chrominance Huffman values.
 | |
| 
 | |
|     // 8-bit JPEG has max 256 values
 | |
|     uint8_t bits_ac_luminance[17];   ///< AC luminance Huffman bits.
 | |
|     uint8_t val_ac_luminance[256];   ///< AC luminance Huffman values.
 | |
|     uint8_t bits_ac_chrominance[17]; ///< AC chrominance Huffman bits.
 | |
|     uint8_t val_ac_chrominance[256]; ///< AC chrominance Huffman values.
 | |
| 
 | |
|     size_t huff_ncode;               ///< Number of current entries in the buffer.
 | |
|     MJpegHuffmanCode *huff_buffer;   ///< Buffer for Huffman code values.
 | |
| } MJpegContext;
 | |
| 
 | |
| /**
 | |
|  * Enum for the Huffman encoding strategy.
 | |
|  */
 | |
| enum HuffmanTableOption {
 | |
|     HUFFMAN_TABLE_DEFAULT = 0, ///< Use the default Huffman tables.
 | |
|     HUFFMAN_TABLE_OPTIMAL = 1, ///< Compute and use optimal Huffman tables.
 | |
|     NB_HUFFMAN_TABLE_OPTION = 2
 | |
| };
 | |
| 
 | |
| static inline void put_marker(PutBitContext *p, enum JpegMarker code)
 | |
| {
 | |
|     put_bits(p, 8, 0xff);
 | |
|     put_bits(p, 8, code);
 | |
| }
 | |
| 
 | |
| int  ff_mjpeg_encode_init(MpegEncContext *s);
 | |
| void ff_mjpeg_encode_close(MpegEncContext *s);
 | |
| void ff_mjpeg_encode_mb(MpegEncContext *s, int16_t block[12][64]);
 | |
| 
 | |
| #endif /* AVCODEC_MJPEGENC_H */
 |