亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? jpeg.cpp

?? 簡(jiǎn)易的jpeg解碼程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號(hào):

// simplejpeg.cpp : Defines the entry point for the console application.
//
//header file
//#include "bmp.h"
//*************************************************************************************
//#include "jpeg.h"
#pragma pack(1)
#define M_SOF0  0xc0
#define M_DHT   0xc4
#define M_EOI   0xd9
#define M_SOS   0xda
#define M_DQT   0xdb
#define M_DRI   0xdd
#define M_APP0  0xe0

static int Zig_Zag[8][8]={{0,1,5,6,14,15,27,28},
{2,4,7,13,16,26,29,42},
{3,8,12,17,25,30,41,43},
{9,11,18,24,37,40,44,53},
{10,19,23,32,39,45,52,54},
{20,22,33,38,46,51,55,60},
{21,34,37,47,50,56,59,61},
{35,36,48,49,57,58,62,63}
};

#define W1 2841 /* 2048*sqrt(2)*cos(1*pi/16) */
#define W2 2676 /* 2048*sqrt(2)*cos(2*pi/16) */
#define W3 2408 /* 2048*sqrt(2)*cos(3*pi/16) */
#define W5 1609 /* 2048*sqrt(2)*cos(5*pi/16) */
#define W6 1108 /* 2048*sqrt(2)*cos(6*pi/16) */
#define W7 565  /* 2048*sqrt(2)*cos(7*pi/16) */


//*************************************************************************************
typedef char CHAR;
typedef short SHORT;
typedef long LONG;



typedef unsigned long       DWORD;
typedef int                 BOOL;
typedef unsigned char       BYTE;
typedef unsigned short      WORD;



typedef int HFILE;
typedef CHAR *LPSTR, *PSTR;

#define FALSE 0
#define TRUE 1

typedef struct tagBITMAPINFOHEADER{
	DWORD      biSize;
	LONG       biWidth;
	LONG       biHeight;
	WORD       biPlanes;
	WORD       biBitCount;
	DWORD      biCompression;
	DWORD      biSizeImage;
	LONG       biXPelsPerMeter;
	LONG       biYPelsPerMeter;
	DWORD      biClrUsed;
	DWORD      biClrImportant;
} BITMAPINFOHEADER, * LPBITMAPINFOHEADER,*PBITMAPINFOHEADER;

typedef struct tagBITMAPFILEHEADER {
	WORD    bfType;
	DWORD   bfSize;
	WORD    bfReserved1;
	WORD    bfReserved2;
	DWORD   bfOffBits;
}  BITMAPFILEHEADER,  * LPBITMAPFILEHEADER,*PBITMAPFILEHEADER;

/* constants for the biCompression field */
#define BI_RGB        0L
#define BI_RLE8       1L
#define BI_RLE4       2L
#define BI_BITFIELDS  3L

typedef struct tagRGBQUAD {
	BYTE    rgbBlue;
	BYTE    rgbGreen;
	BYTE    rgbRed;
	BYTE    rgbReserved;
} RGBQUAD;
typedef RGBQUAD * LPRGBQUAD;

#define MAKEWORD(a, b)      ((WORD)(((BYTE)(a)) | ((WORD)((BYTE)(b))) << 8))
#define MAKELONG(a, b)      ((LONG)(((WORD)(a)) | ((DWORD)((WORD)(b))) << 16))
#define LOWORD(l)           ((WORD)(l))
#define HIWORD(l)           ((WORD)(((DWORD)(l) >> 16) & 0xFFFF))
#define LOBYTE(w)           ((BYTE)(w))
#define HIBYTE(w)           ((BYTE)(((WORD)(w) >> 8) & 0xFF))

//---yk--- add

#include "memory.h"
#include "math.h"
#include "stdio.h"
#include "stdlib.h"
//macro definition
#define WIDTHBYTES(i)    ((i+31)/32*4)//??????????
#define PI 3.1415926535
//define return value of function
#define FUNC_OK 0
#define FUNC_MEMORY_ERROR 1
#define FUNC_FILE_ERROR 2
#define FUNC_FORMAT_ERROR 3

//////////////////////////////////////////////////
//Jpeg functions
BOOL LoadJpegFile(char *BmpFileName);
void showerror(int funcret);
int  InitTag();
void InitTable();
int  Decode();
int  DecodeMCUBlock();
int  HufBlock(BYTE dchufindex,BYTE achufindex);
int  DecodeElement();
void IQtIZzMCUComponent(short flag);
void IQtIZzBlock(short  *s ,int * d,short flag);
void GetYUV(short flag);
void StoreBuffer();
BYTE ReadByte();
void Initialize_Fast_IDCT();
void Fast_IDCT(int * block);
void idctrow(int * blk);
void idctcol(int * blk);
//////////////////////////////////////////////////
//global variable declaration
BITMAPFILEHEADER   bf;
BITMAPINFOHEADER   bi;
//HPALETTE           hPalette=NULL;
//HBITMAP            hBitmap=NULL;
char *            hImgData=NULL;
DWORD              NumColors;
DWORD              LineBytes;
DWORD              ImgWidth=0 , ImgHeight=0;
char*             lpPtr;
//////////////////////////////////////////////////
//variables used in jpeg function
short   SampRate_Y_H,SampRate_Y_V;
short   SampRate_U_H,SampRate_U_V;
short   SampRate_V_H,SampRate_V_V;
short   H_YtoU,V_YtoU,H_YtoV,V_YtoV;
short   Y_in_MCU,U_in_MCU,V_in_MCU;
unsigned char   *lpJpegBuf;
unsigned char   *lp;
short   qt_table[3][64];
short   comp_num;
BYTE   comp_index[3];
BYTE      YDcIndex,YAcIndex,UVDcIndex,UVAcIndex;
BYTE   HufTabIndex;
short      *YQtTable,*UQtTable,*VQtTable;
BYTE   And[9]={0,1,3,7,0xf,0x1f,0x3f,0x7f,0xff};
short      code_pos_table[4][16],code_len_table[4][16];
unsigned short code_value_table[4][256];
unsigned short huf_max_value[4][16],huf_min_value[4][16];
short   BitPos,CurByte;
short   rrun,vvalue;
short   MCUBuffer[10*64];
int    QtZzMCUBuffer[10*64];
short   BlockBuffer[64];
short   ycoef,ucoef,vcoef;
BOOL   IntervalFlag;
short   interval=0;
int    Y[4*64],U[4*64],V[4*64];
DWORD      sizei,sizej;
short    restart;
static  long iclip[1024];
static  long *iclp;

////////////////////////////////////////////////////////////////
BOOL LoadJpegFile (char *JpegFileName)
{
	FILE*  hfjpg;
	DWORD  ImgSize;
	DWORD  BufSize,JpegBufSize;
	FILE*  hfbmp;
	FILE*  IMGdata;
	void *  hJpegBuf;
	int  funcret;
	DWORD i;
	LPBITMAPINFOHEADER lpImgData;
	
	char * hImgData256;
	
	if((hfjpg=fopen(JpegFileName,"rb"))==NULL)
	{
		showerror(FUNC_FILE_ERROR);
		return FALSE;
	}

	//get jpg file length
	fseek(hfjpg,0L,SEEK_END);
	JpegBufSize=ftell(hfjpg);
	//rewind to the beginning of the file
	fseek(hfjpg,0L,SEEK_SET);
	
	if((hJpegBuf=malloc(JpegBufSize))==NULL)
	{
		fclose(hfjpg);
		showerror(FUNC_MEMORY_ERROR);
		
		return FALSE;
	}
	lpJpegBuf=(unsigned char  *)hJpegBuf;
	fread((unsigned char  *)hJpegBuf,sizeof( char ),JpegBufSize,hfjpg);
	fclose(hfjpg);
	
	InitTable();
	
	if((funcret=InitTag())!=FUNC_OK)
	{
		// GlobalUnlock(hJpegBuf);
		free(hJpegBuf);
		showerror(funcret);
		return FALSE;
	}
	//create new bitmapfileheader and bitmapinfoheader
	memset((char *)&bf,0,sizeof(BITMAPFILEHEADER)); 
	memset((char *)&bi,0,sizeof(BITMAPINFOHEADER));
	
	bi.biSize=(DWORD)sizeof(BITMAPINFOHEADER);
	bi.biWidth=(LONG)(ImgWidth);
	bi.biHeight=(LONG)(ImgHeight);
	bi.biPlanes=1;
	bi.biBitCount=24;
	bi.biClrUsed=0;
	bi.biClrImportant=0;
	bi.biCompression=BI_RGB;
	NumColors=0;
	printf("bi.biWidth is %ld\n",bi.biWidth);
	printf("bi.biBitCount is %ld\n",bi.biBitCount);
	LineBytes=(DWORD)WIDTHBYTES(bi.biWidth*bi.biBitCount);
	printf("LineBytes is %ld\n",LineBytes);
	ImgSize=(DWORD)LineBytes*bi.biHeight;//???????
	printf("size is %ld\n",ImgSize);
	bf.bfType=0x4d42;
	int a= sizeof(BITMAPFILEHEADER);
	int b= sizeof(BITMAPINFOHEADER);
	//注意字節(jié)對(duì)齊問題
	//如果沒有#pragma pack(1),a是16
	int c=NumColors*sizeof(RGBQUAD);
	
	bf.bfSize=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+NumColors*sizeof(RGBQUAD)+ImgSize;
	bf.bfOffBits=54;//(DWORD)(NumColors*sizeof(RGBQUAD)+sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER));
	BufSize=bf.bfSize-sizeof(BITMAPFILEHEADER);
	// printf("size is %ld\n",BufSize);
	if((hImgData=(char*)malloc(BufSize))==NULL)
	{
		//GlobalUnlock(hJpegBuf);
		free(hJpegBuf);
		showerror(FUNC_MEMORY_ERROR);
		showerror(FUNC_MEMORY_ERROR);
		return FALSE;
	}
	// lpImgData=(LPBITMAPINFOHEADER)GlobalLock(hImgData); 
	lpImgData=(LPBITMAPINFOHEADER)hImgData; 
	memcpy(lpImgData,(char *)&bi,sizeof(BITMAPINFOHEADER));
	lpPtr=(char *)lpImgData+sizeof(BITMAPINFOHEADER);
	
	if((SampRate_Y_H==0)||(SampRate_Y_V==0))
	{
		// GlobalUnlock(hJpegBuf);
		free(hJpegBuf);
		//GlobalUnlock(hImgData);
		free(hImgData);
		hImgData=NULL;
		showerror(FUNC_FORMAT_ERROR);
		return FALSE ;
	}
	
	funcret=Decode();
	if(funcret==FUNC_OK)
	{
		//hDc=GetDC(hWnd);
		/*  hBitmap=CreateDIBitmap(hDc, (LPBITMAPINFOHEADER)lpImgData, (LONG)CBM_INIT,
		(LPSTR)lpImgData+sizeof(BITMAPINFOHEADER) +NumColors*sizeof(RGBQUAD),
		(LPBITMAPINFO)lpImgData, DIB_RGB_COLORS);
		*/
		// hfbmp=fopen("c:\\jpeg2-bmp.bmp","Wb");
		
		if((hfbmp=fopen("jpeg2-bmp.bmp","wb"))==NULL)
		{
			showerror(FUNC_FILE_ERROR);
			return FALSE;
		}
		
		// hfbmp=fopen("c:\\jpeg2-bmp.bmp","Wb");
		
		
		
		fwrite((LPSTR)&bf,sizeof(BITMAPFILEHEADER),1,hfbmp); 
		fwrite((LPSTR)lpImgData,sizeof(char),BufSize,hfbmp);
		
		if((IMGdata=fopen("111.txt","wb"))==NULL)
		{
			showerror(FUNC_FILE_ERROR);
			return FALSE;
		}
		DWORD xx = ImgWidth*ImgHeight;
		if(( hImgData256=(char *)malloc(xx))==NULL)
		{
			//GlobalUnlock(hJpegBuf);
			free(hImgData256);
			showerror(FUNC_MEMORY_ERROR);
			showerror(FUNC_MEMORY_ERROR);
			showerror(FUNC_MEMORY_ERROR);
			return FALSE;
		}
		
		char * temp=hImgData256;
		for(i=0; i < xx; i++)
		{
			i;
			char t3=*lpPtr;
			t3 &= 0xE0;
			char t1=*(lpPtr+1);
			t1 = t1>>3;
			t1 &= 0x1c;
			char t2=*(lpPtr+2);
			t2=t2>>6;
			t2 &= 0x03;
			char t4 = t3 + t1 + t2 ;
			*temp++=t4;
			lpPtr=lpPtr+ 3;
			//不能使用temp+=3;
		}
		int count=fwrite(hImgData256,sizeof(char),xx,IMGdata);
		//free((void*)hImgData256);
		fclose(IMGdata);
		
		fclose(hfbmp);
		
		//  ReleaseDC(hWnd,hDc);
		//  GlobalUnlock(hJpegBuf);
		free(hJpegBuf);
		//GlobalUnlock(hImgData);
		return TRUE;
	}
	else
	{
		//GlobalUnlock(hJpegBuf);
		free(hJpegBuf);
		// GlobalUnlock(hImgData);
		free(hImgData);
		hImgData=NULL;
		showerror(funcret);
		return FALSE;
	}
}
/////////////////////////////////////////////////
void showerror(int funcret)
{
	switch(funcret)
	{
	case FUNC_MEMORY_ERROR:
		printf("Error alloc memory\n!");
		break;
	case FUNC_FILE_ERROR:
		printf("File not found!\n");
		break;
	case FUNC_FORMAT_ERROR:
		printf("File format error!\n");
		break;
	}
}
////////////////////////////////////////////////////////////////////////////////
int InitTag()
{
	BOOL finish=FALSE;
	BYTE id;
	short  llength;
	short  i,j,k;
	short  huftab1,huftab2;
	short  huftabindex;
	BYTE hf_table_index;
	BYTE qt_table_index;
	BYTE comnum;
	
	unsigned char  *lptemp;
	short  ccount;
	
	lp=lpJpegBuf+2;
	
	while (!finish){
		id=*(lp+1);
		lp+=2;
		switch (id){
		case M_APP0:
			llength=MAKEWORD(*(lp+1),*lp);
			lp+=llength;
			break;
		case M_DQT:
			llength=MAKEWORD(*(lp+1),*lp);
			qt_table_index=(*(lp+2))&0x0f;
			lptemp=lp+3;
			if(llength<80){
				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
			}
			else{
				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
                qt_table_index=(*(lptemp++))&0x0f;
				for(i=0;i<64;i++)
					qt_table[qt_table_index][i]=(short)*(lptemp++);
			}
			lp+=llength;  
			break;
		case M_SOF0:
			llength=MAKEWORD(*(lp+1),*lp);
			ImgHeight=MAKEWORD(*(lp+4),*(lp+3));
			ImgWidth=MAKEWORD(*(lp+6),*(lp+5));
            comp_num=*(lp+7);
			if((comp_num!=1)&&(comp_num!=3))
				return FUNC_FORMAT_ERROR;
			if(comp_num==3){
				comp_index[0]=*(lp+8);
				SampRate_Y_H=(*(lp+9))>>4;
				SampRate_Y_V=(*(lp+9))&0x0f;
				YQtTable=(short *)qt_table[*(lp+10)];
				
				comp_index[1]=*(lp+11);
				SampRate_U_H=(*(lp+12))>>4;
				SampRate_U_V=(*(lp+12))&0x0f;
				UQtTable=(short *)qt_table[*(lp+13)];
				
				comp_index[2]=*(lp+14);
				SampRate_V_H=(*(lp+15))>>4;
				SampRate_V_V=(*(lp+15))&0x0f;
				VQtTable=(short *)qt_table[*(lp+16)];
			}
			else{
				comp_index[0]=*(lp+8);
				SampRate_Y_H=(*(lp+9))>>4;
				SampRate_Y_V=(*(lp+9))&0x0f;
				YQtTable=(short *)qt_table[*(lp+10)];
				
				comp_index[1]=*(lp+8);
				SampRate_U_H=1;
				SampRate_U_V=1;
				UQtTable=(short *)qt_table[*(lp+10)];
				
				comp_index[2]=*(lp+8);
				SampRate_V_H=1;
				SampRate_V_V=1;
				VQtTable=(short *)qt_table[*(lp+10)];
			}
			lp+=llength;          
			break;
		case M_DHT:             
			llength=MAKEWORD(*(lp+1),*lp);
			if (llength<0xd0){
				huftab1=(short)(*(lp+2))>>4;     //huftab1=0,1
				huftab2=(short)(*(lp+2))&0x0f;   //huftab2=0,1
				huftabindex=huftab1*2+huftab2;
				lptemp=lp+3;
				for (i=0; i<16; i++)
					code_len_table[huftabindex][i]=(short)(*(lptemp++));
				j=0;
				for (i=0; i<16; i++)
					if(code_len_table[huftabindex][i]!=0){
						k=0;
						while(k<code_len_table[huftabindex][i]){
							code_value_table[huftabindex][k+j]=(short)(*(lptemp++));
							k++;
						}
						j+=k; 
					}
				i=0;
				while (code_len_table[huftabindex][i]==0)
					i++;
				for (j=0;j<i;j++){
					huf_min_value[huftabindex][j]=0;
					huf_max_value[huftabindex][j]=0;
				}
				huf_min_value[huftabindex][i]=0;
				huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;
				for (j=i+1;j<16;j++){
					huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;
					huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;
				}
				code_pos_table[huftabindex][0]=0;
				for (j=1;j<16;j++)
					code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];
				lp+=llength;
			}  //if
			else{
				hf_table_index=*(lp+2);
				lp+=2;
				while (hf_table_index!=0xff){
					huftab1=(short)hf_table_index>>4;     //huftab1=0,1
					huftab2=(short)hf_table_index&0x0f;   //huftab2=0,1
					huftabindex=huftab1*2+huftab2;
					lptemp=lp+1;
					ccount=0;
					for (i=0; i<16; i++){
						code_len_table[huftabindex][i]=(short)(*(lptemp++));
						ccount+=code_len_table[huftabindex][i];
					}
					ccount+=17; 
					j=0;
					for (i=0; i<16; i++)
						if(code_len_table[huftabindex][i]!=0){
							k=0;
							while(k<code_len_table[huftabindex][i])
							{
								code_value_table[huftabindex][k+j]=(short)(*(lptemp++));
								k++;
							}
							j+=k;
						}
					i=0;
					while (code_len_table[huftabindex][i]==0)
						i++;
					for (j=0;j<i;j++){
						huf_min_value[huftabindex][j]=0;
						huf_max_value[huftabindex][j]=0;
					}
					huf_min_value[huftabindex][i]=0;
					huf_max_value[huftabindex][i]=code_len_table[huftabindex][i]-1;
					for (j=i+1;j<16;j++){
						huf_min_value[huftabindex][j]=(huf_max_value[huftabindex][j-1]+1)<<1;
						huf_max_value[huftabindex][j]=huf_min_value[huftabindex][j]+code_len_table[huftabindex][j]-1;
					}
					code_pos_table[huftabindex][0]=0;
					for (j=1;j<16;j++)
						code_pos_table[huftabindex][j]=code_len_table[huftabindex][j-1]+code_pos_table[huftabindex][j-1];
					lp+=ccount;
					hf_table_index=*lp;
				}  //while
			}  //else
			break;
		case M_DRI:
			llength=MAKEWORD(*(lp+1),*lp);
			restart=MAKEWORD(*(lp+3),*(lp+2));
			lp+=llength;
			break;
		case M_SOS:
			llength=MAKEWORD(*(lp+1),*lp);
			comnum=*(lp+2);
			if(comnum!=comp_num)
				return FUNC_FORMAT_ERROR;
			lptemp=lp+3;
			for (i=0;i<comp_num;i++){
				if(*lptemp==comp_index[0]){
					YDcIndex=(*(lptemp+1))>>4;   //Y

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人高清视频在线| 亚洲欧洲精品成人久久奇米网| 亚洲视频一区在线观看| 91在线一区二区三区| 成人免费在线播放视频| 91久久精品一区二区三区| 一区二区三区四区国产精品| 在线精品视频免费观看| 日韩中文字幕91| 欧美成人国产一区二区| 国产精品自拍毛片| 国产精品家庭影院| 欧洲精品在线观看| 麻豆中文一区二区| 久久精品亚洲精品国产欧美kt∨| 懂色av一区二区三区免费看| 一区二区三区日韩欧美| 欧美放荡的少妇| 国产一区二区女| 亚洲免费伊人电影| 制服丝袜激情欧洲亚洲| 韩日精品视频一区| 亚洲色图在线看| 欧美一区二区黄| 不卡一区在线观看| 大美女一区二区三区| 日韩一二在线观看| 国产成a人亚洲| 亚洲成人av一区二区三区| 日韩欧美国产高清| 91污在线观看| 久久精品国产精品亚洲综合| 中文字幕亚洲区| 日韩欧美国产电影| 色婷婷香蕉在线一区二区| 蜜臀久久99精品久久久画质超高清| 国产视频亚洲色图| 欧美视频在线播放| 国产成人综合视频| 午夜精品成人在线| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 亚洲黄色片在线观看| 日韩一区二区三区四区| 一本一本久久a久久精品综合麻豆| 香蕉久久夜色精品国产使用方法 | 久久99深爱久久99精品| 伊人一区二区三区| 日本一区二区视频在线| 欧美精品免费视频| 一本一道综合狠狠老| 国产v综合v亚洲欧| 男女性色大片免费观看一区二区 | 亚洲色大成网站www久久九九| 欧美一区二区在线播放| 色综合天天综合网天天看片| 久久综合综合久久综合| 亚洲欧美激情插 | 日韩美女视频一区二区| 精品电影一区二区| 欧美欧美午夜aⅴ在线观看| 99精品在线免费| 国产在线一区二区| 免费观看在线综合| 亚洲va韩国va欧美va精品| 亚洲欧洲精品成人久久奇米网| 久久久久久亚洲综合影院红桃 | 91精品国产色综合久久不卡蜜臀| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产在线精品视频| 奇米精品一区二区三区在线观看一| 一个色妞综合视频在线观看| 国产精品水嫩水嫩| 久久精品亚洲一区二区三区浴池 | 91精品在线麻豆| 欧美日韩另类一区| 欧美日韩亚洲国产综合| 91久久精品一区二区三| 一本色道久久综合亚洲精品按摩| 99久久精品国产观看| 成人av高清在线| av在线综合网| 97久久精品人人澡人人爽| av一区二区三区四区| 成人精品电影在线观看| 91香蕉视频在线| 欧美午夜一区二区| 欧美日韩免费在线视频| 69av一区二区三区| 欧美白人最猛性xxxxx69交| 亚洲精品一线二线三线无人区| 久久蜜臀精品av| 欧美高清在线精品一区| 日韩理论电影院| 亚洲国产精品一区二区久久恐怖片 | 色综合久久中文字幕综合网 | 欧美精品久久天天躁| 欧美男生操女生| 欧美一级一级性生活免费录像| 欧美不卡一二三| 日本一区二区三级电影在线观看| 亚洲婷婷在线视频| 亚洲在线视频网站| 美国三级日本三级久久99| 国产福利91精品一区二区三区| 成人午夜在线播放| 91免费视频网址| 777xxx欧美| 国产亚洲污的网站| 亚洲精品国久久99热| 日韩和的一区二区| 国产精品1区2区| 色av综合在线| 欧美成人精品高清在线播放| 国产精品久久网站| 午夜精品一区二区三区三上悠亚| 蜜桃久久av一区| 欧美三级在线播放| 精品日韩av一区二区| 国产精品久久久久久久久免费桃花 | 国产精品一色哟哟哟| 欧美性色综合网| 欧美激情中文字幕一区二区| 亚洲高清中文字幕| 丰满亚洲少妇av| 91精品黄色片免费大全| 亚洲同性gay激情无套| 久草这里只有精品视频| 色爱区综合激月婷婷| 久久久www成人免费无遮挡大片| 亚洲午夜久久久久中文字幕久| 国模冰冰炮一区二区| 欧美日韩国产小视频| 中文字幕在线观看不卡| 蜜芽一区二区三区| 精品在线观看视频| 国产成人免费av在线| 91精品国产综合久久精品图片 | 日日夜夜精品免费视频| 国产一区二区免费在线| 91福利精品第一导航| 精品欧美一区二区久久| 国产人妖乱国产精品人妖| 全国精品久久少妇| 不卡欧美aaaaa| 日韩精品一区二区三区视频在线观看 | 一区二区在线电影| 成人网男人的天堂| 欧美一级午夜免费电影| 亚洲天堂精品在线观看| 国产在线国偷精品产拍免费yy| 在线观看国产日韩| 91久久精品国产91性色tv| 日韩和欧美的一区| 日韩欧美国产综合一区| 亚洲成人第一页| 欧美一二三四在线| 国产激情精品久久久第一区二区| 99久久99精品久久久久久| 精品福利一二区| 91福利在线播放| 国产精品亚洲一区二区三区在线 | 欧美国产综合一区二区| 久久麻豆一区二区| 国产精品一区二区在线观看不卡 | 99视频在线精品| 欧美精品一区二区三区在线播放 | 精品一区二区影视| 欧美日韩在线三级| 亚洲精品日韩综合观看成人91| 国产成人日日夜夜| 久久美女高清视频| 国产自产2019最新不卡| 欧美一区二区美女| 秋霞国产午夜精品免费视频| 欧美一级淫片007| 日本中文在线一区| 91精品一区二区三区在线观看| 亚洲韩国精品一区| 欧美精品九九99久久| 亚洲 欧美综合在线网络| 欧美亚洲一区二区在线| 亚洲精品免费看| 欧美日韩在线播放一区| 亚洲午夜私人影院| 一本在线高清不卡dvd| 一区二区欧美国产| 在线免费观看日本一区| 亚洲一区二三区| 欧美精三区欧美精三区| 婷婷中文字幕一区三区| 日韩欧美区一区二| 欧美bbbbb| 精品国产一二三| 国产91精品一区二区麻豆网站| 国产欧美日韩综合| 国产伦精品一区二区三区视频青涩 | 天天色天天操综合| 欧美精品久久一区| 国产麻豆精品theporn| 欧美激情一区二区三区四区 |