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

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

?? imageprocessing.cpp

?? 車牌定位c++源碼,本人編輯的地方車輛號(hào)牌識(shí)別.
?? CPP
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
#include "stdafx.h"
#include <windows.h>
#include <math.h>
#include <malloc.h>
#include "resource.h"


void HorzMirror(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int x,y;
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	for(y=0;y<nHeight;y++)
	{
		for(x=0;x<nWidth;x++)
		{
			lpOutput[x*3+y*nByteWidth]=lpInput[(nWidth-1-x)*3+y*nByteWidth];
			lpOutput[x*3+1+y*nByteWidth]=lpInput[(nWidth-1-x)*3+1+y*nByteWidth];
			lpOutput[x*3+2+y*nByteWidth]=lpInput[(nWidth-1-x)*3+2+y*nByteWidth];
		}
		Progress(y);
	}
}

void VertMirror(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int x,y;
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	for(y=0;y<nHeight;y++)
	{
		for(x=0;x<nByteWidth;x++)
		{
			lpOutput[x+y*nByteWidth]=lpInput[x+(nHeight-y-1)*nByteWidth];
		}
		Progress(y);
	}
}

void CornerMirror(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int x,y;
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	for(y=0;y<nHeight;y++)
	{
		for(x=0;x<nWidth;x++)
		{
			lpOutput[x*3+y*nByteWidth]=lpInput[(nWidth-1-x)*3+(nHeight-y-1)*nByteWidth];
			lpOutput[x*3+1+y*nByteWidth]=lpInput[(nWidth-1-x)*3+1+(nHeight-y-1)*nByteWidth];
			lpOutput[x*3+2+y*nByteWidth]=lpInput[(nWidth-1-x)*3+2+(nHeight-y-1)*nByteWidth];
		}
		Progress(y);
	}
}

#define Point(x,y) lpPoints[(x)+(y)*nWidth]
#define Point1(x,y) lpPoints1[(x)+(y)*nWidth]

//get the pixels from lbBits to lpPoints
BYTE GetPoints(int nWidth,int nHeight,BYTE *lpBits,BYTE *lpPoints)
{

	int Gmax=0;
	int Gmin=0;

	int x,y,p;
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	for(y=0;y<nHeight;y++)
	{
		for(x=0;x<nWidth;x++)
		{
			p=x*3+y*nByteWidth;
			lpPoints[x+y*nWidth]=(BYTE)(0.299*(float)lpBits[p+2]+0.587*(float)lpBits[p+1]+0.114*(float)lpBits[p]+0.1);

			if(lpPoints[x+y*nWidth]>Gmax)
				Gmax=lpPoints[x+y*nWidth];
			if(lpPoints[x+y*nWidth]<Gmin)
				Gmin=lpPoints[x+y*nWidth];
		}
	}

	return Gmax-2*(Gmax-Gmin)/3;
}

void PutPoints(int nWidth,int nHeight,BYTE *lpBits,BYTE *lpPoints)
{
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	int x,y,p,p1;
	for(y=0;y<nHeight;y++)
	{
		for(x=0;x<nWidth;x++)
		{
			p=x*3+y*nByteWidth;
			p1=x+y*nWidth;
			lpBits[p]=lpPoints[p1];
			lpBits[p+1]=lpPoints[p1];
			lpBits[p+2]=lpPoints[p1];
		}
	}
}


void HistogramEq1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput)
{
	int x,y;
	BYTE *lpPoints=new BYTE[nWidth*nHeight];
	GetPoints(nWidth,nHeight,lpInput,lpPoints);

	
	int r[256],s[256];
	ZeroMemory(r,1024);
	ZeroMemory(s,1024);
	for(y=0;y<nHeight;y++){
		for(x=0;x<nWidth;x++){
			r[Point(x,y)]++;
		}
	}
	s[0]=r[0];
	for(y=1;y<256;y++)
	{
		s[y]=s[y-1];
		s[y]+=r[y];
	}
	for(y=0;y<nHeight;y++){
		for(x=0;x<nWidth;x++){
			Point(x,y)=s[Point(x,y)]*255/nWidth/nHeight;
		}
	}

	PutPoints(nWidth,nHeight,lpOutput,lpPoints);
	delete lpPoints;
}

//3x3中值濾波
void Med1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int x,y;

	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	BYTE p[9],s;
	int i,j;
	for(y=1;y<nHeight-1;y++)
	{
		for(x=3;x<nWidth*3-3;x++)
		{
			p[0]=lpInput[x-3+(y-1)*nByteWidth];
			p[1]=lpInput[x+(y-1)*nByteWidth];
			p[2]=lpInput[x+3+(y-1)*nByteWidth];
			p[3]=lpInput[x-3+y*nByteWidth];
			p[4]=lpInput[x+y*nByteWidth];
			p[5]=lpInput[x+3+y*nByteWidth];
			p[6]=lpInput[x-3+(y+1)*nByteWidth];
			p[7]=lpInput[x+(y+1)*nByteWidth];
			p[8]=lpInput[x+3+(y+1)*nByteWidth];
			for(j=0;j<5;j++)
			{
				for(i=j+1;i<9;i++)
				{
					if (p[j]>p[i])
					{
						s=p[j];
						p[j]=p[i];
						p[i]=s;
					}
				}
			}
			lpOutput[x+y*nByteWidth]=p[4];
		}
		Progress(y);
	}
}

void Mean1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int x,y,x1,y1,p;
//	BYTE *lpPoints=new BYTE[nWidth*nHeight];
//	GetPoints(nWidth,nHeight,lpInput,lpPoints);

	int sr,sg,sb;
	int nByteWidth=nWidth*3;
	if (nByteWidth%4) nByteWidth+=4-(nByteWidth%4);
	for(y=1;y<nHeight-1;y++)
	{
		for(x=1;x<nWidth-1;x++)
		{
			p=x*3+y*nByteWidth;
			sb=0;
			sg=0;
			sr=0;
			for(y1=-1;y1<=1;y1++)
			for(x1=-1;x1<=1;x1++)
			{
				sb+=lpInput[(y+y1)*nByteWidth+(x+x1)*3];
				sg+=lpInput[(y+y1)*nByteWidth+(x+x1)*3+1];
				sr+=lpInput[(y+y1)*nByteWidth+(x+x1)*3+2];
			}
			lpOutput[p+2]=sr/9;
			lpOutput[p+1]=sg/9;
			lpOutput[p]=sb/9;
		}
		Progress(y);
	}
//	PutPoints(nWidth,nHeight,lpOutput,lpPoints);
//	delete lpPoints;
}


#define pi (double)3.14159265359

/*復(fù)數(shù)定義*/
typedef struct
{
	double re;
	double im;
}COMPLEX;

/*復(fù)數(shù)加運(yùn)算*/
COMPLEX Add(COMPLEX c1, COMPLEX c2)
{
	COMPLEX c;
	c.re=c1.re+c2.re;
	c.im=c1.im+c2.im;
	return c;
}

/*復(fù)數(shù)減運(yùn)算*/
COMPLEX Sub(COMPLEX c1, COMPLEX c2)
{
	COMPLEX c;
	c.re=c1.re-c2.re;
	c.im=c1.im-c2.im;
	return c;
}

/*復(fù)數(shù)乘運(yùn)算*/
COMPLEX Mul(COMPLEX c1, COMPLEX c2)
{
	COMPLEX c;
	c.re=c1.re*c2.re-c1.im*c2.im;
	c.im=c1.re*c2.im+c2.re*c1.im;
	return c;
}

/*快速付里哀變換
TD為時(shí)域值,FD為頻域值,power為2的冪數(shù)*/
void FFT(COMPLEX * TD, COMPLEX * FD, int power)
{
	int count;
	int i,j,k,bfsize,p;
	double angle;
	COMPLEX *W,*X1,*X2,*X;

	/*計(jì)算付里哀變換點(diǎn)數(shù)*/
	count=1<<power;
	/*分配運(yùn)算所需存儲(chǔ)器*/
	W=(COMPLEX *)malloc(sizeof(COMPLEX)*count/2);
	X1=(COMPLEX *)malloc(sizeof(COMPLEX)*count);
	X2=(COMPLEX *)malloc(sizeof(COMPLEX)*count);
	/*計(jì)算加權(quán)系數(shù)*/
	for(i=0;i<count/2;i++)
	{
		angle=-i*pi*2/count;
		W[i].re=cos(angle);
		W[i].im=sin(angle);
	}
	/*將時(shí)域點(diǎn)寫入存儲(chǔ)器*/
	memcpy(X1,TD,sizeof(COMPLEX)*count);
	/*蝶形運(yùn)算*/
	for(k=0;k<power;k++)
	{
		for(j=0;j<1<<k;j++)
		{
			bfsize=1<<(power-k);
			for(i=0;i<bfsize/2;i++)
			{
				p=j*bfsize;
				X2[i+p]=Add(X1[i+p],X1[i+p+bfsize/2]);
				X2[i+p+bfsize/2]=Mul(Sub(X1[i+p],X1[i+p+bfsize/2]),W[i*(1<<k)]);
			}
		}
		X=X1;
		X1=X2;
		X2=X;
	}
	/*重新排序*/
	for(j=0;j<count;j++)
	{
		p=0;
		for(i=0;i<power;i++)
		{
			if (j&(1<<i)) p+=1<<(power-i-1);
		}
		FD[j]=X1[p];
	}
	/*釋放存儲(chǔ)器*/
	free(W);
	free(X1);
	free(X2);
}

/*快速離散余弦變換,利用快速付里哀變換
f為時(shí)域值,F為變換域值,power為2的冪數(shù)*/
void DCT(double *f, double *F, int power)
{
	int i,count;
	COMPLEX *X;
	double s;

	/*計(jì)算離散余弦變換點(diǎn)數(shù)*/
	count=1<<power;
	/*分配運(yùn)算所需存儲(chǔ)器*/
	X=(COMPLEX *)malloc(sizeof(COMPLEX)*count*2);
	/*延拓*/
	memset(X,0,sizeof(COMPLEX)*count*2);
	/*將時(shí)域點(diǎn)寫入存儲(chǔ)器*/
	for(i=0;i<count;i++)
	{
		X[i].re=f[i];
	}
	/*調(diào)用快速付里哀變換*/
	FFT(X,X,power+1);
	/*調(diào)整系數(shù)*/
	s=1/sqrt((double)count);
	F[0]=X[0].re*s;
	s*=sqrt((double)2);
	for(i=1;i<count;i++)
	{
		F[i]=(X[i].re*cos(i*pi/(count*2))+X[i].im*sin(i*pi/(count*2)))*s;
	}
	/*釋放存儲(chǔ)器*/
	free(X);
}

/*快速沃爾什-哈達(dá)瑪變換
f為時(shí)域值,F為變換域值,power為2的冪數(shù)*/
void WALh(double *f, double *W, int power)
{
	int count;
	int i,j,k,bfsize,p;
	double *X1,*X2,*X;

	/*計(jì)算快速沃爾什變換點(diǎn)數(shù)*/
	count=1<<power;
	/*分配運(yùn)算所需存儲(chǔ)器*/
	X1=(double *)malloc(sizeof(double)*count);
	X2=(double *)malloc(sizeof(double)*count);
	/*將時(shí)域點(diǎn)寫入存儲(chǔ)器*/
	memcpy(X1,f,sizeof(double)*count);
	/*蝶形運(yùn)算*/
	for(k=0;k<power;k++)
	{
		for(j=0;j<1<<k;j++)
		{
			bfsize=1<<(power-k);
			for(i=0;i<bfsize/2;i++)
			{
				p=j*bfsize;
				X2[i+p]=X1[i+p]+X1[i+p+bfsize/2];
				X2[i+p+bfsize/2]=X1[i+p]-X1[i+p+bfsize/2];
			}
		}
		X=X1;
		X1=X2;
		X2=X;
	}
	/*調(diào)整系數(shù)*/
//	for(i=0;i<count;i++)
//	{
//		W[i]=X1[i]/count;
//	}
	for(j=0;j<count;j++)
	{
		p=0;
		for(i=0;i<power;i++)
		{
			if (j&(1<<i)) p+=1<<(power-i-1);
		}
		W[j]=X1[p]/count;
	}
	/*釋放存儲(chǔ)器*/
	free(X1);
	free(X2);
}


void Fourier1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int w=1,h=1,wp=0,hp=0;
	while(w*2<=nWidth)
	{
		w*=2;
		wp++;
	}
	while(h*2<=nHeight)
	{
		h*=2;
		hp++;
	}
	int x,y;
	BYTE *lpPoints=new BYTE[nWidth*nHeight];
	GetPoints(nWidth,nHeight,lpInput,lpPoints);

	COMPLEX *TD=new COMPLEX[w*h];
	COMPLEX *FD=new COMPLEX[w*h];

	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			TD[x+w*y].re=Point(x,y);
			TD[x+w*y].im=0;
		}
	}

	for(y=0;y<h;y++)
	{
		FFT(&TD[w*y],&FD[w*y],wp);
		Progress(y*nHeight/2/h);
	}
	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			TD[y+h*x]=FD[x+w*y];
//			TD[x+w*y]=FD[x*h+y];
		}
	}
	for(x=0;x<w;x++)
	{
		FFT(&TD[x*h],&FD[x*h],hp);
		Progress(x*nHeight/2/w+nHeight/2);
	}

	memset(lpPoints,0,nWidth*nHeight);
	double m;
	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			m=sqrt(FD[x*h+y].re*FD[x*h+y].re+FD[x*h+y].im*FD[x*h+y].im)/100;
			if (m>255) m=255;
			Point((x<w/2?x+w/2:x-w/2),nHeight-1-(y<h/2?y+h/2:y-h/2))=(BYTE)(m);
		}
	}
	delete TD;
	delete FD;
	PutPoints(nWidth,nHeight,lpOutput,lpPoints);
	delete lpPoints;
}

void Walsh1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int w=1,h=1,wp=0,hp=0;
	while(w*2<=nWidth)
	{
		w*=2;
		wp++;
	}
	while(h*2<=nHeight)
	{
		h*=2;
		hp++;
	}
	int x,y;
	BYTE *lpPoints=new BYTE[nWidth*nHeight];
	GetPoints(nWidth,nHeight,lpInput,lpPoints);

	double *f=new double[w*h];
	double *W=new double[w*h];

	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			f[x+y*w]=Point(x,y);
		}
	}

	for(y=0;y<h;y++)
	{
		WALh(f+w*y,W+w*y,wp);
		Progress(y*nHeight/2/h);
	}
	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			f[x*h+y]=W[x+w*y];
		}
	}
	for(x=0;x<w;x++)
	{
		WALh(f+x*h,W+x*h,hp);
		Progress(x*nHeight/2/w+nHeight/2);
	}
	double a;
	memset(lpPoints,0,nWidth*nHeight);

	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			a=fabs(W[x*h+y]*1000);
			if (a>255) a=255;
			Point(x,nHeight-y-1)=(BYTE)a;
		}
	}
	delete f;
	delete W;
	PutPoints(nWidth,nHeight,lpOutput,lpPoints);
	delete lpPoints;
}

void Dct1(int nWidth,int nHeight,BYTE *lpInput,BYTE *lpOutput,void (* Progress)(int Pos))
{
	int w=1,h=1,wp=0,hp=0;
	while(w*2<=nWidth)
	{
		w*=2;
		wp++;
	}
	while(h*2<=nHeight)
	{
		h*=2;
		hp++;
	}
	int x,y;
	BYTE *lpPoints=new BYTE[nWidth*nHeight];
	GetPoints(nWidth,nHeight,lpInput,lpPoints);

	double *f=new double[w*h];
	double *W=new double[w*h];

	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			f[x+y*w]=Point(x,y);
		}
	}

	for(y=0;y<h;y++)
	{
		DCT(&f[w*y],&W[w*y],wp);
		Progress(y*nHeight/2/h);
	}
	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			f[x*h+y]=W[x+w*y];
		}
	}
	for(x=0;x<w;x++)
	{
		DCT(&f[x*h],&W[x*h],hp);
		Progress(x*nHeight/2/w+nHeight/2);
	}
	double a;
	memset(lpPoints,0,nWidth*nHeight);

	for(y=0;y<h;y++)
	{
		for(x=0;x<w;x++)
		{
			a=fabs(W[x*h+y]);
			if (a>255) a=255;
			Point(x,nHeight-y-1)=(BYTE)(a);
		}
	}
	delete f;
	delete W;
	PutPoints(nWidth,nHeight,lpOutput,lpPoints);
	delete lpPoints;
}

int Conv2(int nWidth,int nHeight,BYTE *lpOutput,BYTE *lpInput,double mask[],int windowX,int windowY);
int Laplacian(int nWidth,int nHeight,BYTE *lpOutput,double *lpInput);
int Zerocross(int nWidth,int nHeight,BYTE *lpOutput,double *lpInput,double thresh);
int LoG(int nWidth,int nHeight,BYTE *lpOutput,BYTE *lpInput,double thresh,double sigma);

#define In(x,y) lpInput[(x)+(y)*nWidth]
#define Out(x,y) lpOutput[(x)+(y)*nWidth]
#define Mediate(x,y) lpMediate[(x)+(y)*nWidth]

#include "NumberDlg.h"
double GetNumber(const char *prompt,double number,double max)
{
	CNumberDlg dlg;
	dlg.m_Prompt=prompt;
	dlg.m_Number=number;
	dlg.DoModal();
	if (dlg.m_Number>max) dlg.m_Number=max;
	return dlg.m_Number;
	return 1;
}

void Gauss1(int nWidth,int nHeight,BYTE *lpIn,BYTE *lpOut,void (* Progress)(int Pos))
{
	double sigma=GetNumber("輸入高斯模糊半徑:",1,10);
	int x,y,xx,xk,yk;
	BYTE *lpInput=new BYTE[nWidth*nHeight];
	BYTE *lpOutput=new BYTE[nWidth*nHeight];
	GetPoints(nWidth,nHeight,lpIn,lpInput);

	int radius,window; //window of the converlutin kernel(window=2*radius+1)
	double dev_inv=0.5/(sigma*sigma);  //1/(2*sigma^2)
	radius = (int)ceil(3*sigma);
	window = radius*2+1;
//fast algorithm
	memcpy(lpOutput,lpInput,nWidth*nHeight);
	double* lpMediate=new double[nWidth*nHeight];

	double* mask=new double[window];
	double sum=0;
	double temp;
	double weight;//sum of weight of mask at edge of the image
//generate mask
	for(x=0;x<radius;x++)
	{
		xx=(x-radius)*(x-radius);
		mask[x]=exp(-xx*dev_inv);
		mask[window-1-x]=mask[x];
		sum+=2*mask[x];
	}
	mask[radius]=1;
	sum+=1;
	for(x=0;x<window;x++)
	{
		mask[x]/=sum;
	}
//row process
	for(y=0;y<nHeight;y++)
	{
		for(x=radius;x<nWidth-radius;x++)
		{
			temp=0;
			for(xk=-radius;xk<radius+1;xk++)
				temp+=In(x+xk,y)*mask[xk+radius];
			Mediate(x,y)=temp;
		}
		for(x=0;x<radius;x++)
		{
			temp=0;
			weight=0;
			for(xk=-x;xk<radius+1;xk++)
			{
				temp+=In(x+xk,y)*mask[xk+radius];
				weight+=mask[xk+radius];
			}
			Mediate(x,y)=temp/weight;
		}
		for(x=nWidth-radius;x<nWidth;x++)
		{
			temp=0;
			weight=0;
			for(xk=-radius;xk<nWidth-x;xk++)
			{
				temp+=In(x+xk,y)*mask[xk+radius];

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久高清一区二区三区| 91精品国产综合久久精品 | 久久精品久久99精品久久| 久久综合久久综合亚洲| 日本韩国欧美一区二区三区| 蜜臀av亚洲一区中文字幕| 中文字幕不卡一区| 宅男噜噜噜66一区二区66| www.欧美.com| 国产在线精品一区二区三区不卡| 亚洲欧美aⅴ...| 国产日韩一级二级三级| 欧美精品日韩综合在线| 91视频你懂的| 国产精品一级黄| 久久国产欧美日韩精品| 亚洲一区在线视频| 国产精品国产三级国产aⅴ无密码| 欧美一区二区三区小说| 欧美亚洲日本国产| 972aa.com艺术欧美| 国产米奇在线777精品观看| 视频一区视频二区中文字幕| ...av二区三区久久精品| 精品毛片乱码1区2区3区| 欧美日韩久久久一区| 99国产精品国产精品毛片| 国产传媒日韩欧美成人| 韩国女主播一区二区三区| 日韩经典一区二区| 五月天中文字幕一区二区| 一区二区三区中文在线| 亚洲欧美偷拍另类a∨色屁股| 国产欧美一区二区精品性色| 久久婷婷久久一区二区三区| 日韩午夜在线观看视频| 91麻豆精品久久久久蜜臀| 欧美三级一区二区| 欧美日韩综合一区| 欧美三级乱人伦电影| 91久久奴性调教| 在线观看日韩国产| 91在线视频播放| 成人激情动漫在线观看| 国产成人精品网址| 成人午夜视频免费看| 成人午夜精品在线| 成av人片一区二区| 在线亚洲一区二区| 欧美调教femdomvk| 欧美日本国产一区| 日韩视频中午一区| 久久综合久久综合久久| 国产日韩一级二级三级| 国产精品美女一区二区三区| 中文字幕中文在线不卡住| 中文无字幕一区二区三区| 国产精品久久久久久久浪潮网站| 欧美国产一区二区| 亚洲人妖av一区二区| 亚洲综合精品自拍| 美女视频网站久久| 国产成人免费在线| 色综合天天视频在线观看| 日本韩国一区二区三区视频| 69精品人人人人| 久久免费国产精品| 一区二区视频在线| 日韩电影免费在线看| 狠狠色丁香久久婷婷综合_中| 国产99久久久国产精品免费看| av一区二区三区| 欧美人与性动xxxx| 国产清纯美女被跳蛋高潮一区二区久久w | 免费看黄色91| 成人午夜av电影| 欧美色爱综合网| 国产日韩欧美高清| 亚洲超丰满肉感bbw| 国产精品中文有码| 91国产免费观看| 精品粉嫩aⅴ一区二区三区四区| 中文字幕av资源一区| 亚洲国产精品久久人人爱蜜臀| 久久国内精品视频| 一本到不卡精品视频在线观看| 91精品久久久久久蜜臀| 中文字幕不卡在线| 免费视频最近日韩| 91首页免费视频| 日韩一级片在线观看| 欧美高清在线一区二区| 香蕉加勒比综合久久| 成人黄色大片在线观看| 欧美日韩成人综合天天影院| 欧美国产1区2区| 日本亚洲一区二区| 91蜜桃免费观看视频| 欧美一区二区三区啪啪| 日韩美女视频一区二区| 麻豆91在线观看| 日本高清不卡在线观看| 久久久久国产精品麻豆| 五月综合激情网| 97成人超碰视| 久久久av毛片精品| 日韩av一区二区在线影视| 99精品欧美一区| 久久久久久电影| 蜜桃久久久久久久| 欧美三级韩国三级日本三斤| 亚洲国产精品高清| 狠狠v欧美v日韩v亚洲ⅴ| 欧美网站大全在线观看| 亚洲日本在线看| 成人黄色片在线观看| 国产无一区二区| 久久福利视频一区二区| 欧美精品日韩精品| 夜夜爽夜夜爽精品视频| yourporn久久国产精品| 久久久久久久综合色一本| 丝袜美腿亚洲一区| 欧美性大战久久久久久久 | 日本欧美在线观看| 欧美色区777第一页| 一区二区在线观看视频| 不卡一二三区首页| 国产精品久久久久精k8| 国产成人h网站| 国产日韩影视精品| 国产成人av一区| 国产亚洲制服色| 国产麻豆成人精品| 久久中文娱乐网| 国产一区二区在线视频| 欧美成人a∨高清免费观看| 美女www一区二区| 欧美大白屁股肥臀xxxxxx| 日韩精品1区2区3区| 69久久99精品久久久久婷婷| 午夜精品在线视频一区| 欧美日韩亚州综合| 午夜精品福利一区二区三区av| 色伊人久久综合中文字幕| 亚洲色图视频网| 一本色道a无线码一区v| 亚洲免费观看视频| 欧美午夜理伦三级在线观看| 一二三区精品视频| 欧美精品久久久久久久久老牛影院| 亚洲香肠在线观看| 欧美日韩激情在线| 蜜臀av一级做a爰片久久| 欧美va亚洲va| 国产成人精品三级| 亚洲美女视频一区| 欧美日韩成人综合在线一区二区 | 成人a免费在线看| 亚洲精品国产高清久久伦理二区| 色综合久久久久| 亚洲福利视频导航| 日韩三级精品电影久久久| 国产一区二区三区观看| 国产精品久久夜| 欧美亚洲动漫制服丝袜| 日本亚洲视频在线| 欧美激情一区在线观看| 91免费视频观看| 日本中文在线一区| 亚洲国产高清不卡| 欧美日韩国产影片| 久久疯狂做爰流白浆xx| 国产精品久久免费看| 欧美日韩中文一区| 国内精品第一页| 亚洲另类在线视频| 日韩情涩欧美日韩视频| 成人在线一区二区三区| 亚洲成人一区在线| 国产偷国产偷亚洲高清人白洁| 91精彩视频在线观看| 久久99精品国产麻豆不卡| 国产精品久久毛片a| 欧美日本一区二区三区| 成人性生交大片免费看中文 | 国产精品无人区| 欧美绝品在线观看成人午夜影视| 国内精品在线播放| 亚洲一区二区在线免费看| 久久日韩精品一区二区五区| 91视视频在线观看入口直接观看www| 日本不卡一区二区| 成人免费一区二区三区视频| 日韩午夜在线观看视频| 在线观看日韩电影| 国产 欧美在线| 麻豆精品久久久| 亚洲欧美视频一区| 国产人成一区二区三区影院|