⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 user_data.h

📁 这是我做的毕业设计
💻 H
字号:
//#include "user_def.h"
////*RGB表*/
 typedef struct tagRGBTRIPLE {        //位图阵列格式定义
	BYTE pRed;   	//定义红色
	BYTE pGreen; 	//定义绿色
	BYTE pBlue;    	//定义蓝色
	} BGR[16][16],RGBTRIPLE;       //构成一个3字节的RGBTRIPLE。
  /*YcrCb表*/
typedef struct tagYCC
	{int Y;
	int Cb;
	int Cr;
	}YCC[16][16],lastblk;
	
short  Cb[8][8],Cr[8][8], Y1[8][8],Y2[8][8],Y3[8][8],Y4[8][8];

short int yDC,uDC,vDC;     //Y,U,V 信号的当前块的DC,uDC vDC

typedef struct tagHUFFCODE
{
 WORD code;  // huffman 码字
 BYTE length;  // 编码长度
 WORD val;   // 码字对应的值
}HUFFCODE;

typedef struct tagACSYM
{
 BYTE zeroLen;  //0行程
 BYTE codeLen;  //幅度编码长度
 short int amplitude;//振幅
}ACSYM;

typedef struct tagSYM2
{
 short int amplitude;//振幅
 BYTE codeLen;  //振幅长度(二进制形式的振幅数据的位数)
}SYM2;

/////////////////////////////////////////////////////
//解码数据
typedef struct dehufftab
  {UINT32 	decodeval;    ///huffman 码字
   BYTE 	len;          ///编码长度
   UINT32  	huffstd_val;  ///码字对应的值STD_VALUE
  }deHUFFCODE;

volatile unsigned short de_bytepos; //当前解码的位置
volatile unsigned int de_CodeLen;   //已经解码的字节数

deHUFFCODE deSTD_DC_Y_HT[12];
deHUFFCODE deSTD_DC_UV_HT[12];
deHUFFCODE deSTD_AC_Y_HT[256];
deHUFFCODE deSTD_AC_UV_HT[256];

deHUFFCODE currhuff;        //中间变量

//////////////////////////////////////////////////////
#pragma DATA_SECTION(VLI_TAB,".VLITAB")
BYTE  VLI_TAB[4096];
BYTE* pVLITAB;  

HUFFCODE STD_DC_Y_HT[12];
HUFFCODE STD_DC_UV_HT[12];
HUFFCODE STD_AC_Y_HT[256];
HUFFCODE STD_AC_UV_HT[256];

volatile unsigned int CodeLen;   //编码数据的字节数
static BYTE bytenew=0; // The byte that will be written in the JPEG file
static char bytepos=7; //bit position in the byte we write (bytenew)

static  int AC_MAX_QUANTED = 1023;   //量化后AC的最大值
static  int AC_MIN_QUANTED = -1024;   //量化后AC的最小值
static  int DC_MAX_QUANTED = 2047;   //量化后DC的最大值
static  int DC_MIN_QUANTED = -2048;   //量化后DC的最小值

static unsigned short int mask[16]={1,2,4,8,16,32,64,128,256,512,1024,2048,4096,8192,16384,32768};

/////////量化表//亮度量化表                       
short		qlum[64]={
			16, 11, 10, 16, 24, 40, 51, 61,  
			12, 12, 14, 19, 26, 58, 60, 55, 
			14, 13, 16, 24, 40, 57, 69, 56,
			14, 17, 22, 29, 51, 87, 80, 62,
			18, 22, 37, 56, 68, 109, 103, 77,
			24, 35, 55, 64, 81, 104, 113, 92,
			49, 64, 78, 87, 103, 121, 120, 101, 
			72, 92, 95, 98, 112, 100, 103, 99};//'//JPEG标准量化表(亮度);Q=75 
		//	q = Val(Text1) //'75=JPEG标准质量 95=数码相机标准质量 97=数码相机精细质量 
/*色度量化表*/
short qchr[64]={17 ,18 ,24, 47 ,99 ,99 ,99 ,99,
			18 ,21 ,26 ,66  ,99 ,99 ,99 ,99,
			24 ,26 ,56 ,99  ,99 ,99 ,99 ,99,
			47 ,66 ,99 ,99  ,99 ,99 ,99 ,99,
			99 ,99 ,99 ,99  ,99 ,99 ,99 ,99,
			99 ,99 ,99 ,99  ,99 ,99 ,99 ,99,
			99 ,99 ,99 ,99  ,99 ,99 ,99 ,99,
			99 ,99 ,99 ,99  ,99 ,99 ,99 ,99,};
/*亮度标准 量化表
unsigned char   qlum1[64]={0x8 ,0x6 ,0x6 ,0x7 ,0x6 ,0x5 ,0x8 ,0x7 ,
                          0x7 ,0x7 ,0x9 ,0x9 ,0x8 ,0xa ,0xc ,0x14,
                          0xd ,0xc ,0xb ,0xb ,0xc ,0x19,0x12,0x13,
                          0xf ,0x14,0x1d,0x1a,0x1f,0x1e,0x1d,0x1a,
                          0x1c,0x1c,0x20,0x24,0x2e,0x27,0x20,0x22,
                          0x2c,0x23,0x1c,0x1c,0x28,0x37,0x29,0x2c,
                          0x30,0x31,0x34,0x34,0x34,0x1f,0x27,0x39,
                          0x3d,0x38,0x32,0x3c,0x2e,0x33,0x34,0x32};*/     
/*  标准量化表(色度)
unsigned char   qchr1[64]={0x9 ,0x9 ,0x9 ,0xc ,0xb ,0xc ,0x18,0xd ,
                          	0xd ,0x18,0x32,0x21,0x1c,0x21,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32,
							0x32,0x32,0x32,0x32,0x32,0x32,0x32,0x32};*/

////	 HUFFMAN 数据定义块
static BYTE STD_DC_Y_NRCODES[17]={0,0,1,5,1,1,1,1,1,1,0,0,0,0,0,0,0};
static BYTE STD_DC_Y_VALUES[12]={0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};

static BYTE STD_DC_UV_NRCODES[17]={0,0,3,1,1,1,1,1,1,1,1,1,0,0,0,0,0};
static BYTE STD_DC_UV_VALUES[12]={0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};

static BYTE STD_AC_Y_NRCODES[17]={0,0,2,1,3,3,2,4,3,5,5,4,4,0,0,1,0X7D };
static BYTE STD_AC_Y_VALUES[162]= {
 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
  0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
  0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
  0x23, 0x42, 0xb1, 0xc1, 0x15, 0x52, 0xd1, 0xf0,
  0x24, 0x33, 0x62, 0x72, 0x82, 0x09, 0x0a, 0x16,
  0x17, 0x18, 0x19, 0x1a, 0x25, 0x26, 0x27, 0x28,
  0x29, 0x2a, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39,
  0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49,
  0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59,
  0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69,
  0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79,
  0x7a, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89,
  0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98,
  0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
  0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6,
  0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5,
  0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2, 0xd3, 0xd4,
  0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xe1, 0xe2,
  0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea,
  0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
  0xf9, 0xfa };

 static BYTE STD_AC_UV_NRCODES[17]={0,0,2,1,2,4,4,3,4,7,5,4,4,0,1,2,0X77};
 static BYTE STD_AC_UV_VALUES[162]={
  0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
   0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
   0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
   0xa1, 0xb1, 0xc1, 0x09, 0x23, 0x33, 0x52, 0xf0,
   0x15, 0x62, 0x72, 0xd1, 0x0a, 0x16, 0x24, 0x34,
   0xe1, 0x25, 0xf1, 0x17, 0x18, 0x19, 0x1a, 0x26,
   0x27, 0x28, 0x29, 0x2a, 0x35, 0x36, 0x37, 0x38,
   0x39, 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
   0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
   0x59, 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
   0x69, 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
   0x79, 0x7a, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
   0x88, 0x89, 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96,
   0x97, 0x98, 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5,
   0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4,
   0xb5, 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3,
   0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2,
   0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda,
   0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9,
   0xea, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
   0xf9, 0xfa };  
   
////Z~Z扫描
unsigned short zigzag[64]={ 0, 1, 8,16, 9, 2, 3,10,
                          17,24,32,25,18,11, 4, 5,
                          12,19,26,33,40,48,41,34,
                          27,20,13, 6, 7,14,21,28,
                          35,42,49,56,57,50,43,36,
                          29,22,15,23,30,37,44,51,
                          58,59,52,45,38,31,39,46,
                          53,60,61,54,47,55,62,63
                          };

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -