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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? wavelet2ddlg.cpp

?? 二維小波變換算法實現壓縮解壓的程序
?? CPP
字號:
// Wavelet2DDlg.cpp : implementation file
//

#include "stdafx.h"
#include "Wavelet2D.h"
#include "Wavelet2DDlg.h"
#include "LiftDwt97.h"
#include "IntDwt97.h"
#include "IntDwt53.h"
#include "Dwt.h"
#include "BinDwt97.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
#define WIDTHBYTES(i,j) ((i*j+31)/32*4)
#define COLORNUMS(i) (1<<i)
/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWavelet2DDlg dialog

CWavelet2DDlg::CWavelet2DDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CWavelet2DDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CWavelet2DDlg)
	m_Level = _T("1");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDI_ICON);
}

void CWavelet2DDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CWavelet2DDlg)
	DDX_Control(pDX, IDC_EDIT1, m_Bmpfile);
	DDX_Control(pDX, IDC_COMBO1, m_SelectWavelet);
	DDX_CBString(pDX, IDC_COMBO2, m_Level);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CWavelet2DDlg, CDialog)
	//{{AFX_MSG_MAP(CWavelet2DDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_WAVELET2D, OnWavelet2D)
	ON_BN_CLICKED(IDC_INVERSEWAVELET2D, OnInverseWavelet2D)
	ON_BN_CLICKED(IDC_READFILE, OnReadfile)
	ON_BN_CLICKED(IDC_OPENIMAGE, OnBrowseBmpFile)
	ON_BN_CLICKED(IDC_COPYRIGHT, OnCopyright)
	ON_BN_CLICKED(IDC_CANCEL, OnCancel)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWavelet2DDlg message handlers

BOOL CWavelet2DDlg::OnInitDialog()
{
	CDialog::OnInitDialog();
    m_lpBuf=NULL;
	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
    //初始化控件
	   
	    m_Bmpfile.SetWindowText(m_strBmpFile);
	   			
		m_SelectWavelet.InsertString(0,"9/7浮點小波分解");
		m_SelectWavelet.SetItemData(0,1);
		m_SelectWavelet.InsertString(1,"5/3整數小波分解");
		m_SelectWavelet.SetItemData(1,2);
    	m_SelectWavelet.InsertString(2,"9/7整數小波分解");
		m_SelectWavelet.SetItemData(2,3);
        m_SelectWavelet.InsertString(3,"9/7提升小波分解");
		m_SelectWavelet.SetItemData(3,4);
		m_SelectWavelet.InsertString(4,"9/7二進制小波分解");
		m_SelectWavelet.SetItemData(4,5);
		m_SelectWavelet.SetCurSel(0);
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CWavelet2DDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CWavelet2DDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CWavelet2DDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}



void CWavelet2DDlg::OnWavelet2D() 
{
	// TODO: Add your control notification handler code here
    
	UpdateData(TRUE);
	
	nIndex = m_SelectWavelet.GetCurSel();   //獲得控件變量的值
    level=atoi(m_Level);                    //將字符串變量轉化成整形變量
    image1=new int[iwidth * iheight];
	image2=new double[iwidth * iheight];

    switch(nIndex)
	{
	   case CB_ERR:
		   {
	           FLOATDWT.Dwt2D(data2,iheight,iwidth,level);    //9/7浮點小波分解
			   memcpy(image2,data2,iwidth*iheight*8);
	           uint8(image2,iheight,iwidth);                  //圖像歸一化
               ShowImage2(iwidth,iheight,image2);
	           break;
		   }
    
        case 0:    
		   {
	           FLOATDWT.Dwt2D(data2,iheight,iwidth,level);    //9/7浮點小波分解
               memcpy(image2,data2,iwidth*iheight*8);
	           uint8(image2,iheight,iwidth);
               ShowImage2(iwidth,iheight,image2);
	           break;
		   }
    
	   case 1:
		   { 
	           INTDWT53.Dwt2D(data1, iheight,iwidth,level);   //5/3整數小波分解
			   memcpy(image1,data1,iwidth*iheight*4);
               uint8(image1,iheight,iwidth);
               ShowImage1(iwidth,iheight,image1);
	           break;
		   }

       case 2:
		   {
	           INTDWT97.Dwt2D(data1, iheight,iwidth,level);   //9/7整數小波分解
               memcpy(image1,data1,iwidth*iheight*4);
			   uint8(image1,iheight,iwidth);             
               ShowImage1(iwidth,iheight,image1);
	           break;
		   }
    
	   case 3:
		   {
	           LIFTNSDWT.Dwt2D(data2, iheight,iwidth,level);  //9/7提升小波分解
			   memcpy(image2,data2,iwidth*iheight*8);
               uint8(image2,iheight,iwidth);
               ShowImage2(iwidth,iheight,image2);
	           break;
		   }
    
	   case 4:
		   {
	           BINDWT.Dwt2D(data1, iheight,iwidth,level);     //9/7二進制小波分解
			   memcpy(image1,data1,iwidth*iheight*4);
               uint8(image1,iheight,iwidth);
               ShowImage1(iwidth,iheight,image1);
	           break;
		   }
	}
	
	UpdateData(FALSE);
	
}


void CWavelet2DDlg::uint8(int *Imagebuffer, int height, int width)
{
	int i,j,max,min;
	
	//搜索最大值和最小值
	max=min=0;
	for(i=0;i<height;i++)
	  for(j=0;j<width;j++)
	  {
		if (*(Imagebuffer+i*width+j)>max)
	    	  max=*(Imagebuffer+i*width+j);
		if (*(Imagebuffer+i*width+j)<min)
		      min=*(Imagebuffer+i*width+j);
	  }
    
	//進行規(guī)一化
    for(i=0;i<iheight;i++)
	    for(j=0;j<iwidth;j++)
         *(Imagebuffer+i*iwidth+j)=(*(Imagebuffer+i*iwidth+j)*255)/(max-min)+128;
	
	  
	//像素幅值控制
	for(i=0;i<height;i++)
    	for(j=0;j<width;j++)
		{
           if(*(Imagebuffer+i*width+j)>255)
		    *(Imagebuffer+i*width+j)=255;
		   if(*(Imagebuffer+i*width+j)<0)
			*(Imagebuffer+i*width+j)=0;	
		}

}

void CWavelet2DDlg::uint8(double *Imagebuffer, int height, int width)
{
	int i,j;
	double max,min;
	max=min=0;
	
	//搜索最大值和最小值
	for(i=0;i<height;i++)
	  for(j=0;j<width;j++)
	  {
		if (*(Imagebuffer+i*width+j)>max)
	    	  max=*(Imagebuffer+i*width+j);
		if (*(Imagebuffer+i*width+j)<min)
		      min=*(Imagebuffer+i*width+j);
	  }

    //進行規(guī)一化
	  for(i=0;i<iheight;i++)
	    for(j=0;j<iwidth;j++)
         *(Imagebuffer+i*iwidth+j)=(*(Imagebuffer+i*iwidth+j)*255)/(max-min)+128;

	//像素幅值控制
	for(i=0;i<height;i++)
    	for(j=0;j<width;j++)
		{
           if(*(Imagebuffer+i*width+j)>255)
		    *(Imagebuffer+i*width+j)=255;
		   if(*(Imagebuffer+i*width+j)<0)
			*(Imagebuffer+i*width+j)=0;	
		}

}

void CWavelet2DDlg::OnCancel() 
{
	// TODO: Add your control notification handler code here
/*	delete []data1;
	delete []data2;
	delete []image1;
	delete []image2;
  	delete []m_lpBuf;
 */	
	OnOK();
	
}

void CWavelet2DDlg::OnInverseWavelet2D() 
{
	// TODO: Add your control notification handler code here
    UpdateData(TRUE);
	
	switch(nIndex)
	{
	   case CB_ERR:
		   {
        	   FLOATDWT.IDwt2D(data2,iheight,iwidth,level);
			   uint8(data2,iheight,iwidth);
               ShowImage2(iwidth,iheight,data2);
			   break;
		   }
    
	   case 0:
		   {
	           FLOATDWT.IDwt2D(data2,iheight,iwidth,level);
			   uint8(data2,iheight,iwidth);
               ShowImage2(iwidth,iheight,data2);
			   break;
		   }

       case 1:
		   {
	           INTDWT53.IDwt2D(data1, iheight,iwidth,level);
			   uint8(data1,iheight,iwidth);
               ShowImage1(iwidth,iheight,data1);
			   break;
		   }

       case 2:
		   {
	           INTDWT97.IDwt2D(data1, iheight,iwidth,level);
			   uint8(data1,iheight,iwidth);
               ShowImage1(iwidth,iheight,data1);
			   break;
		   }
    
	   case 3:
		   {
	           LIFTNSDWT.IDwt2D(data2, iheight,iwidth,level);
			   uint8(data2,iheight,iwidth);
               ShowImage2(iwidth,iheight,data2);
			   break;
		   }
    
	   case 4:
		   {
	           BINDWT.IDwt2D(data1, iheight,iwidth,level);
			   uint8(data1,iheight,iwidth);
               ShowImage1(iwidth,iheight,data1);
			   break;
		   }
	}
	
	   UpdateData(FALSE);
}

void CWavelet2DDlg::OnReadfile() 
{
	// TODO: Add your control notification handler code here
	CFile file;
	if(!file.Open(strPathname,CFile::modeRead))
	{
		MessageBox("請先選擇位圖文件路徑!");
		return;
	}
 
	BITMAPFILEHEADER bmf;
	if(file.Read(&bmf,sizeof(bmf))!=sizeof(bmf))
	{
		file.Close();
		return;
	}
	if(bmf.bfType!=0x4d42)
	{
		file.Close();
		return;
	}
    if(file.Read((LPSTR)&m_bmi,sizeof(m_bmi))!=sizeof(m_bmi))
	{
		file.Close();
		return;
	}
	if(m_bmi.biBitCount!=8)
	{
		MessageBox("只對8位灰度圖進行小波變換");
		file.Close();
		return;
	}
	if(m_bmi.biHeight>256)
	{
		MessageBox("只處理256*256圖");
		file.Close();
		return;
	}

	int nHeapSize=sizeof(m_bmi)+COLORNUMS(m_bmi.biBitCount)*sizeof(RGBQUAD)+
		          WIDTHBYTES(m_bmi.biWidth,m_bmi.biBitCount)*m_bmi.biHeight;
	if(m_lpBuf!=NULL)
	{
		delete m_lpBuf;
		m_lpBuf=NULL;
	}
	m_lpBuf=new BYTE[nHeapSize];
    memcpy(m_lpBuf,&m_bmi,sizeof(m_bmi));
	if(file.Read(m_lpBuf+sizeof(m_bmi),nHeapSize-sizeof(m_bmi))!=(nHeapSize-sizeof(m_bmi)))
	{
		delete m_lpBuf;
		m_lpBuf=NULL;
		file.Close();
		return;
	}
	
	file.Close();
	lpDibBits=m_lpBuf+sizeof(m_bmi)+COLORNUMS(m_bmi.biBitCount)*sizeof(RGBQUAD);//數據區(qū)
	lpImageBuffer=m_lpBuf+sizeof(m_bmi)+COLORNUMS(m_bmi.biBitCount)*sizeof(RGBQUAD);
	CDC* pDC;
	pDC=GetDC();
	SetStretchBltMode(pDC->m_hDC,COLORONCOLOR);
	StretchDIBits(pDC->m_hDC,54,33,256,256,0,0,m_bmi.biWidth,m_bmi.biHeight,lpDibBits,(LPBITMAPINFO)m_lpBuf,DIB_RGB_COLORS,SRCCOPY);
	ReleaseDC(pDC);
    
	
	iwidth=m_bmi.biWidth;
    iheight=m_bmi.biHeight;
	
	data1=new int[iwidth * iheight];
	data2=new double[iwidth * iheight];
		
	for(int i=0;i<iheight;i++)
		for(int j=0;j<iwidth;j++)
		{
		  data1[i*iwidth+j]=GetXY(i,j)-128;
		  data2[i*iwidth+j]=GetXY(i,j)-128;
		}
	m_hasopened=TRUE;
}

void CWavelet2DDlg::OnBrowseBmpFile() 
{
	// TODO: Add your control notification handler code here
	CFileDialog fileopenbox(TRUE,NULL,NULL,OFN_HIDEREADONLY,"files(*.bmp)|*.bmp|",NULL);	
	if(fileopenbox.DoModal()!=IDOK) return;
	strPathname=fileopenbox.GetPathName();         //獲得位圖像文件的當前路徑
	m_strBmpFile=strPathname;
	m_Bmpfile.SetWindowText(m_strBmpFile);
}

void CWavelet2DDlg::OnCopyright() 
{
	// TODO: Add your control notification handler code here
	CAboutDlg aboutDlg;
	aboutDlg.DoModal();	
}



BYTE CWavelet2DDlg::GetXY(int x, int y)
{
   y=m_bmi.biWidth-y-1;
   return lpDibBits[y*m_bmi.biWidth+x];

}



void CWavelet2DDlg::SetXY(int x, int y, BYTE val)
{
	y=m_bmi.biWidth-y-1;
   lpImageBuffer[y*m_bmi.biWidth+x]=val;

}



void CWavelet2DDlg::ShowImage1(int nWidth, int nHeight, int *pImageBuffer)
{
	m_bmi.biWidth=nWidth;
	m_bmi.biHeight=nHeight;
    
	for(int i=0;i<iheight;i++)
	{
		for(int j=0;j<iwidth;j++)
		{
			SetXY(i,j,(BYTE)pImageBuffer[i*iwidth+j]);
		}
	}
	
	CDC* pDC;
	pDC=GetDC();
	SetStretchBltMode(pDC->m_hDC,COLORONCOLOR);
	StretchDIBits(pDC->m_hDC,54,312,256,256,0,0,m_bmi.biWidth,m_bmi.biHeight,lpImageBuffer,(LPBITMAPINFO)m_lpBuf,DIB_RGB_COLORS,SRCCOPY);
	ReleaseDC(pDC);
}

void CWavelet2DDlg::ShowImage2(int nWidth, int nHeight, double *pImageBuffer)
{ 
	m_bmi.biWidth=nWidth;
	m_bmi.biHeight=nHeight;
    
	for(int i=0;i<iheight;i++)
	{
		for(int j=0;j<iwidth;j++)
		{
			SetXY(i,j,(BYTE)pImageBuffer[i*iwidth+j]);
		}
	}
	
	CDC* pDC;
	pDC=GetDC();
	SetStretchBltMode(pDC->m_hDC,COLORONCOLOR);
	StretchDIBits(pDC->m_hDC,54,312,256,256,0,0,m_bmi.biWidth,m_bmi.biHeight,lpImageBuffer,(LPBITMAPINFO)m_lpBuf,DIB_RGB_COLORS,SRCCOPY);
	ReleaseDC(pDC);

}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜视频免费看| 2020国产精品| 欧美高清在线视频| 亚洲一区二区三区影院| 国产成人在线色| 欧美精品色综合| 一区在线观看免费| 国产在线一区观看| 91精品在线一区二区| 亚洲三级电影网站| 国产成人在线视频免费播放| 这里只有精品视频在线观看| 亚洲色欲色欲www| 成人免费毛片嘿嘿连载视频| 精品国产自在久精品国产| 五月天中文字幕一区二区| 色婷婷精品久久二区二区蜜臂av | 捆绑调教一区二区三区| 在线一区二区三区四区五区| 国产精品传媒在线| 国产成人午夜视频| 久久精品一区四区| 国产美女视频91| 久久久不卡网国产精品一区| 日韩专区一卡二卡| 欧美精选一区二区| 天堂资源在线中文精品| 在线观看亚洲a| 亚洲一区二区视频在线观看| 色欲综合视频天天天| 亚洲美腿欧美偷拍| 日本道在线观看一区二区| 亚洲毛片av在线| 色偷偷88欧美精品久久久| 亚洲你懂的在线视频| 色香蕉久久蜜桃| 亚洲电影在线播放| 欧美精品tushy高清| 蜜桃av噜噜一区二区三区小说| 91精品国产欧美一区二区| 久久99最新地址| 欧美激情在线看| 99久久免费视频.com| 亚洲视频一二三| 欧美亚洲动漫另类| 日本视频中文字幕一区二区三区| 日韩欧美在线综合网| 久久电影国产免费久久电影| 欧美精品一区二区三区久久久| 国产乱码一区二区三区| 国产精品久久久久9999吃药| a在线播放不卡| 亚洲国产日韩一级| 欧美成人一区二区三区片免费| 国产精品一区二区视频| 国产欧美精品一区二区三区四区| 91在线观看视频| 日韩精品免费视频人成| 久久久噜噜噜久久人人看| 99国产麻豆精品| 日韩精品欧美精品| 中文字幕高清一区| 欧美偷拍一区二区| 国产麻豆成人传媒免费观看| 中文字幕佐山爱一区二区免费| 欧美日韩1234| 豆国产96在线|亚洲| 亚洲一区二区欧美激情| 久久综合中文字幕| 91国模大尺度私拍在线视频| 国产一区二区三区最好精华液| 国产精品久久久久四虎| 欧美一区二区日韩| 99re66热这里只有精品3直播 | 国产电影精品久久禁18| 一区二区欧美视频| 久久伊99综合婷婷久久伊| 在线观看区一区二| 成人av在线网| 久久丁香综合五月国产三级网站| 亚洲色大成网站www久久九九| 欧美大片免费久久精品三p| 色综合天天综合色综合av | 精品亚洲国产成人av制服丝袜| 国产精品国产a级| 欧美一级生活片| 色婷婷综合久久久中文一区二区 | 中文字幕乱码日本亚洲一区二区| 制服丝袜av成人在线看| 色哟哟国产精品| 成人精品电影在线观看| 韩国欧美国产1区| 蜜桃视频一区二区| 午夜在线电影亚洲一区| 亚洲黄一区二区三区| 国产精品视频看| 久久精品日产第一区二区三区高清版| 欧美日韩国产一级片| 色婷婷狠狠综合| 91尤物视频在线观看| 成人午夜免费视频| 国产一区二区网址| 国产一区二区三区在线观看免费| 婷婷久久综合九色综合绿巨人| 亚洲免费观看高清| 亚洲欧美一区二区三区久本道91| 国产片一区二区| 欧美激情一区二区三区在线| 久久免费精品国产久精品久久久久| 制服丝袜激情欧洲亚洲| 欧美人牲a欧美精品| 欧美日韩在线播放三区| 欧美伦理电影网| 8v天堂国产在线一区二区| 91精品国产综合久久小美女| 欧美日本一区二区三区四区| 欧美性感一区二区三区| 欧美日韩五月天| 日韩欧美一区二区免费| 欧美精品一区二区三| 国产亚洲一区二区在线观看| 久久久精品一品道一区| 国产精品视频线看| 一区二区视频免费在线观看| 亚洲综合激情另类小说区| 日韩精品欧美成人高清一区二区| 日韩精品成人一区二区三区| 久久99精品一区二区三区| 国产自产2019最新不卡| 成人激情小说网站| 欧美图片一区二区三区| 日韩一区二区视频| 久久精品一区二区三区不卡牛牛| 欧美国产精品一区二区三区| 亚洲视频一区在线观看| 午夜亚洲国产au精品一区二区| 久久精品国产免费| 成人黄色av网站在线| 在线免费不卡视频| 欧美刺激脚交jootjob| 日本一区二区成人在线| 一区二区久久久| 日一区二区三区| 国产91清纯白嫩初高中在线观看 | 偷拍与自拍一区| 国产电影一区在线| 欧美日韩一卡二卡三卡| 26uuu亚洲婷婷狠狠天堂| 亚洲欧美乱综合| 久草这里只有精品视频| 色又黄又爽网站www久久| 欧美大度的电影原声| 亚洲码国产岛国毛片在线| 美女免费视频一区二区| 色综合久久天天综合网| 91精品国产综合久久久久| 中文字幕一区二区在线观看| 亚洲国产欧美在线| 成人午夜视频免费看| 欧美一区二区三区四区久久| 国产精品国产自产拍高清av| 日本成人中文字幕| 欧美中文字幕一区| 中文字幕精品一区二区精品绿巨人| 丝袜脚交一区二区| 91高清视频在线| 国产精品国产三级国产aⅴ入口 | 青青草国产精品亚洲专区无| 北条麻妃一区二区三区| 欧美成人女星排行榜| 一区av在线播放| 成人午夜视频网站| 久久嫩草精品久久久久| 捆绑变态av一区二区三区| 色婷婷一区二区| 最新成人av在线| 成人精品视频网站| 久久久亚洲欧洲日产国码αv| 亚洲成人一区二区| 欧美性一级生活| 亚洲另类一区二区| 99re这里只有精品视频首页| 欧美激情在线一区二区三区| 国产在线日韩欧美| 日韩免费看的电影| 免费看欧美美女黄的网站| 欧美久久久久中文字幕| 亚洲欧美国产毛片在线| 99热这里都是精品| 国产精品国产三级国产三级人妇 | 成人免费在线观看入口| 国产成人精品免费网站| 国产亚洲va综合人人澡精品| 国内偷窥港台综合视频在线播放| 日韩欧美亚洲国产另类| 久久99精品国产.久久久久久 | 欧美高清精品3d| 日韩国产在线观看| 欧美电影免费观看高清完整版在线观看| 日韩不卡一区二区三区|