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

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

?? hyperspectraldatacompressdlg.cpp

?? 改進的JPEG-LS算法
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// HyperspectralDataCompressDlg.cpp : implementation file
//

#include "stdafx.h"
#include <math.h>
#include ".\AdvanceJPEG-LS\AdvanceJPEG-LSCode.h"
#include "HyperspectralImagCode.h"
#include "HyperspectralDataCompress.h"
#include "SmallEdit.h"
#include "HyperspectralDataCompressDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// 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()

/////////////////////////////////////////////////////////////////////////////
// CHyperspectralDataCompressDlg dialog

CHyperspectralDataCompressDlg::CHyperspectralDataCompressDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CHyperspectralDataCompressDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CHyperspectralDataCompressDlg)
	m_AuxDataWidth = 0;
	m_BandNumber = 0;
	m_BitsPerPixel = 0;
	m_BytesPerPixel = 0;
	m_ComperssFileName = _T("");
	m_CompressRateString = _T("");
	m_ImageHeight = 0;
	m_ImageWidth = 0;
	m_InputFileName = _T("");
	m_LinesPerBlock = 0;
	m_MaxErrString = _T("");
	m_NoticeString = _T("");
	m_PSNRString = _T("");
	m_RateString = _T("");
	m_NoticeNumberString = _T("");
	FileNumber=0;
	m_AllowMaxErrorString = _T("");
	//}}AFX_DATA_INIT
	AllowMaxErrBgn=AllowMaxErrEnd=0;
	AllowMaxErrStep=1;
	PureImageFormat=FALSE;
	CompressThreadRun=FALSE;
	m_pCompressThread=NULL;
	TestRelativeThreadRun=FALSE;
	m_pTestRelativeThread=NULL;
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CHyperspectralDataCompressDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CHyperspectralDataCompressDlg)
	DDX_Control(pDX, IDC_COMPRESS_RELATIVE_LIST, m_RelativeList);
	DDX_Text(pDX, IDC_AUX_DATA_WIDTH, m_AuxDataWidth);
	DDX_Text(pDX, IDC_BAND_NUMBER, m_BandNumber);
	DDX_Text(pDX, IDC_BITS_PER_PIXEL, m_BitsPerPixel);
	DDX_Text(pDX, IDC_BYTES_PER_PIXEL, m_BytesPerPixel);
	DDX_Text(pDX, IDC_COMPRESS_FILE_NAME, m_ComperssFileName);
	DDX_Text(pDX, IDC_COMPRESS_RATE_STATIC, m_CompressRateString);
	DDX_Text(pDX, IDC_IMAGE_HEIGHT, m_ImageHeight);
	DDX_Text(pDX, IDC_IMAGE_WIDTH, m_ImageWidth);
	DDX_Text(pDX, IDC_INPUT_FILE_NAME, m_InputFileName);
	DDX_Text(pDX, IDC_LINES_PER_BLOCK, m_LinesPerBlock);
	DDX_Text(pDX, IDC_MAX_ERROR_STATIC, m_MaxErrString);
	DDX_Text(pDX, IDC_NOTICE_STATIC, m_NoticeString);
	DDX_Text(pDX, IDC_PSNR_STATIC, m_PSNRString);
	DDX_Text(pDX, IDC_RATE_STATIC, m_RateString);
	DDX_Text(pDX, IDC_NOTICE_NUMBER_STATIC, m_NoticeNumberString);
	DDX_Text(pDX, IDC_ALLOW_MAS_ERROR, m_AllowMaxErrorString);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CHyperspectralDataCompressDlg, CDialog)
	ON_MESSAGE(WM_USER_SMALL_EDIT, OnSmallEditRecvMessage)
	ON_MESSAGE(WM_USER_HYPERSPECTRAL_COMPRESS_DLG, OnHyperspectralDataCompressRecvMessage)
	//{{AFX_MSG_MAP(CHyperspectralDataCompressDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_DESTROY()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_WM_CLOSE()
	ON_BN_CLICKED(IDC_COMPRESS_CANCEL, OnCompressCancel)
	ON_EN_KILLFOCUS(IDC_COMPRESS_FILE_NAME, OnKillfocusCompressFileName)
	ON_BN_CLICKED(IDC_COMPRESS_OK, OnCompressOk)
	ON_BN_CLICKED(IDC_MULBAND_IMAGE_FILENAME_FIND_BUTTON, OnMulbandImageFilenameFindButton)
	ON_BN_CLICKED(IDC_OMIS_I_PREDICT_BAND, OnOmisIPredictBand)
	ON_BN_CLICKED(IDC_OMIS_II_PREDICT_BAND, OnOmisIiPredictBand)
	ON_BN_CLICKED(IDC_TEST_PREDICT_BAND, OnTestPredictBand)
	ON_EN_KILLFOCUS(IDC_AUX_DATA_WIDTH, OnKillfocusAuxDataWidth)
	ON_EN_KILLFOCUS(IDC_LINES_PER_BLOCK, OnKillfocusLinesPerBlock)
	ON_NOTIFY(NM_DBLCLK, IDC_COMPRESS_RELATIVE_LIST, OnDblclkCompressRelativeList)
	ON_EN_KILLFOCUS(IDC_IMAGE_WIDTH, OnKillfocusImageWidth)
	ON_EN_KILLFOCUS(IDC_ALLOW_MAS_ERROR, OnKillfocusAllowMasError)
	ON_NOTIFY(NM_KILLFOCUS, IDC_COMPRESS_RELATIVE_LIST, OnKillfocusCompressRelativeList)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CHyperspectralDataCompressDlg message handlers
LRESULT CHyperspectralDataCompressDlg::OnHyperspectralDataCompressRecvMessage(WPARAM wParam, LPARAM lParam)
{
	int i;
	DWORD dwStatus;
	CString s;
	if(wParam==0)
	{
		i=lParam;
		m_NoticeNumberString.Format(_T("完成 %d%%"),i);
		UpdateData(FALSE);
	}
	else if(wParam==1)
	{
		if(CompressThreadRun==FALSE)
		{
			if (m_pCompressThread != NULL)
			{
				VERIFY(::GetExitCodeThread(m_pCompressThread->m_hThread, &dwStatus));
				if (dwStatus != STILL_ACTIVE)
				{
					m_NoticeString=_T("");
					m_NoticeNumberString=_T("");
					GetDlgItem(IDC_COMPRESS_CANCEL)->SetWindowText(_T("取消"));
					GetDlgItem(IDC_COMPRESS_OK)->EnableWindow(TRUE);
					GetDlgItem(IDC_COMPRESS_FILE_NAME)->EnableWindow(TRUE);
					GetDlgItem(IDC_MULBAND_IMAGE_FILENAME_FIND_BUTTON)->EnableWindow(TRUE);
					GetDlgItem(IDC_OMIS_I_PREDICT_BAND)->EnableWindow(TRUE);
					GetDlgItem(IDC_OMIS_II_PREDICT_BAND)->EnableWindow(TRUE);
					GetDlgItem(IDC_TEST_PREDICT_BAND)->EnableWindow(TRUE);
					GetDlgItem(IDC_AUX_DATA_WIDTH)->EnableWindow(TRUE);
					GetDlgItem(IDC_LINES_PER_BLOCK)->EnableWindow(TRUE);
					GetDlgItem(IDC_COMPRESS_RELATIVE_LIST)->EnableWindow(TRUE);
					GetDlgItem(IDC_INPUT_FILE_NAME)->EnableWindow(TRUE);
					GetDlgItem(IDC_ALLOW_MAS_ERROR)->EnableWindow(TRUE);
					GetDlgItem(IDC_COMPRESS_FILE_NAME)->EnableWindow(TRUE);
					if(PureImageFormat==TRUE)
					{
						GetDlgItem(IDC_BITS_PER_PIXEL)->EnableWindow(TRUE);
						GetDlgItem(IDC_BYTES_PER_PIXEL)->EnableWindow(TRUE);
						GetDlgItem(IDC_IMAGE_HEIGHT)->EnableWindow(TRUE);
						GetDlgItem(IDC_IMAGE_WIDTH)->EnableWindow(TRUE);
					}
					delete m_pCompressThread;
					m_pCompressThread = NULL;
					if(CompressComplete==TRUE)
					{
						CompressComplete=FALSE;
						if((m_AllowMaxErr+AllowMaxErrStep)<=AllowMaxErrEnd)
						{
							m_AllowMaxErr+=AllowMaxErrStep;
							m_ComperssFileName=GetCompressFileName(m_InputFileName);
							UpdateData(FALSE);
							PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,4,0);
						}
						else 
						{
							UpdateData(FALSE);
							if(AllowReport==TRUE)
							{
								OutString(Report);
							}
						}
					}
					else
					{
						UpdateData(FALSE);
						if(AllowReport==TRUE)
						{
							OutString(Report);
						}
					}
				}
				else PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,1,lParam);
			}
		}
		else
		{
			CompressThreadRun=FALSE;
			PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,1,lParam);
			//消息處理過程可為別的線程提供運行的機會。
		}
	}
	else if(wParam==2)
	{
		i=lParam;
		m_NoticeNumberString.Format(_T("完成 %d%%"),i);
		UpdateData(FALSE);
	}
	else if(wParam==3)
	{
		if(TestRelativeThreadRun==FALSE)
		{
			if (m_pTestRelativeThread != NULL)
			{
				VERIFY(::GetExitCodeThread(m_pTestRelativeThread->m_hThread, &dwStatus));
				if (dwStatus != STILL_ACTIVE)
				{
					m_NoticeString=_T("");
					m_NoticeNumberString=_T("");
					UpdateData(FALSE);
					GetDlgItem(IDC_COMPRESS_CANCEL)->SetWindowText(_T("取消"));
					if(TestRelativeComplate==TRUE)
					{
						UpdateControlList(FALSE);
						if(AllowReport==TRUE)m_ComperssFileName=GetCompressFileName(m_InputFileName);
					}
					delete m_pTestRelativeThread;
					m_pTestRelativeThread = NULL;
				}
				else PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,3,lParam);
			}
		}
		else
		{
			TestRelativeThreadRun=FALSE;
			PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,3,lParam);
			//消息處理過程可為別的線程提供運行的機會。
		}
	}
	else if(wParam==4)
	{
		OnCompressOk();
	}
	else if(wParam==5)
	{
		UpdateData(FALSE);
	}
	return 0;
}
void CHyperspectralDataCompressDlg::OutString(CString str,LPCTSTR lpOutFile)
{
	CString OutFile;
	int i;
	TCHAR asc[512],WindowsDir[512];
	GetWindowsDirectory(WindowsDir,512);
	LPSTR lpStr;
	CMapFile DMF;
	if(lpOutFile==NULL)
	{
		strcpy(asc,(LPCTSTR)m_ComperssFileName);
		for(i=m_ComperssFileName.GetLength()-1;i>=0&&asc[i]!='.'&&asc[i]!='\\'&&asc[i]!=':';i--);
		if(asc[i]=='.')asc[i-3]='\0';
		OutFile=asc;
		OutFile+=_T(".txt");
	}
	else OutFile=lpOutFile;
	CString windpath;
	windpath=WindowsDir;
	windpath+=_T("\\NOTEPAD ");
	windpath+=OutFile;
	if(DMF.CreateFileMap((LPCTSTR)OutFile,
				PAGE_READWRITE,
				str.GetLength()+1,
				NULL,
				CREATE_ALWAYS)!=NULL)
	{//輸出產(chǎn)生的結(jié)果
		lpStr=(LPSTR)DMF.MapOfFile(0,str.GetLength()+1);
		MoveMemory(lpStr,str.GetBuffer(str.GetLength()),str.GetLength());
		lpStr[str.GetLength()]='\0';
		DMF.Close();
	}
	WinExec( (LPCTSTR)windpath,SW_SHOWNORMAL); 
}

BOOL CHyperspectralDataCompressDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// 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);
		}
	}

	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	Report.Empty();
	AllowReport=FALSE;
	AllowMaxErrBgn=AllowMaxErrEnd=0;
	AllowMaxErrStep=1;

	GetDlgItem(IDC_IMAGE_WIDTH)->EnableWindow(FALSE);
	GetDlgItem(IDC_BITS_PER_PIXEL)->EnableWindow(FALSE);
	GetDlgItem(IDC_BYTES_PER_PIXEL)->EnableWindow(FALSE);
	GetDlgItem(IDC_IMAGE_HEIGHT)->EnableWindow(FALSE);
	AllowMaxErrBgn=AllowMaxErrEnd=m_AllowMaxErr=24;
	m_AllowMaxErrorString=_T("24");
	m_AuxDataWidth=0;

	CRect ListRect;
	LV_COLUMN lvc;

	lvc.mask = LVCF_TEXT | LVCF_SUBITEM | LVCF_WIDTH;

	GetDlgItem(IDC_COMPRESS_RELATIVE_LIST)->GetWindowRect(&ListRect);
	int ControlWidth=ListRect.right-ListRect.left-20;

	lvc.iSubItem =0;
	lvc.pszText = _T("波段");
	lvc.cx = ControlWidth/2;
	m_RelativeList.InsertColumn(0,&lvc);

	lvc.iSubItem =1;
	lvc.pszText = _T("預(yù)測");
	lvc.cx = ControlWidth/2;
	m_RelativeList.InsertColumn(1,&lvc);
	DWORD ExStyle;
	ExStyle=m_RelativeList.GetExtendedStyle();
	m_RelativeList.SetExtendedStyle(ExStyle|
									LVS_EX_FULLROWSELECT);
	
	UpdateData(FALSE);
	return TRUE;  // return TRUE  unless you set the focus to a control
}

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

void CHyperspectralDataCompressDlg::OnDestroy()
{
	CDialog::OnDestroy();
}

// 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 CHyperspectralDataCompressDlg::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();
	}
}

HCURSOR CHyperspectralDataCompressDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CHyperspectralDataCompressDlg::OnClose() 
{
	// 響應(yīng)窗口關(guān)閉
	
	CDialog::OnClose();
}

void CHyperspectralDataCompressDlg::OnCompressCancel() 
{
	//不作壓縮,退出
	if(CompressThreadRun==TRUE)CompressThreadRun=FALSE;
	else if(TestRelativeThreadRun==TRUE)TestRelativeThreadRun=FALSE;
	else PostMessage(WM_CLOSE,0,0);
}

void CHyperspectralDataCompressDlg::OnKillfocusCompressFileName() 
{
	// 檢測高光譜文件,以確定相關(guān)參數(shù)
	UpdateData(TRUE);
	CFile f;
	LPCTSTR Exfilename;
	Exfilename=((LPCTSTR)m_InputFileName)+m_InputFileName.GetLength()-3;
	if(FileNumber==0)
	{//文件名并不是通過瀏覽得到的,而是直接輸入文件名。
		if(::TestTheFileExist((LPCTSTR)m_InputFileName)==TRUE)
		{
			if(strcmp(Exfilename,_T("raw"))==0||strcmp(Exfilename,_T("RAW"))==0)
			{
				m_BandNumber=1;
				GetDlgItem(IDC_IMAGE_WIDTH)->EnableWindow(TRUE);
				GetDlgItem(IDC_BITS_PER_PIXEL)->EnableWindow(TRUE);
				GetDlgItem(IDC_BYTES_PER_PIXEL)->EnableWindow(TRUE);
				GetDlgItem(IDC_IMAGE_HEIGHT)->EnableWindow(TRUE);
				PureImageFormat=TRUE;
				m_AuxDataWidth=BFILE_AUXDATA_WIDTH;
				m_LinesPerBlock=MAX_LINES_PER_BLOCK;
				InitPredictBandString();
				m_ComperssFileName=GetCompressFileName(m_InputFileName);
				UpdateData(FALSE);
			}
			else if(f.Open((LPCTSTR)m_InputFileName,CFile::modeRead)==TRUE)
			{//打開多波段文件
				stAuxMsg *lpHead=new stAuxMsg;
				f.Read(lpHead,sizeof(stAuxMsg));
				f.Close();
				m_BandNumber=lpHead->iImageBand;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产老肥熟一区二区三区| 国产不卡高清在线观看视频| 欧美大白屁股肥臀xxxxxx| 国产成人一级电影| 亚洲va欧美va人人爽| 精品成人一区二区三区四区| 欧美中文字幕亚洲一区二区va在线 | 亚洲综合精品久久| 国产亚洲自拍一区| 91精品国产欧美一区二区| 色八戒一区二区三区| 国产麻豆视频一区二区| 日韩av一区二区三区四区| 亚洲欧美一区二区视频| 久久久国产午夜精品| 欧美一级在线观看| 欧美午夜精品一区二区三区| 91原创在线视频| 国产福利一区二区| 日韩在线一区二区三区| 一区二区三区免费网站| 国产精品乱码人人做人人爱| 欧美精品一区二区三区很污很色的| 欧美性受xxxx黑人xyx性爽| 欧美在线观看视频一区二区三区| 国产成人自拍在线| 极品美女销魂一区二区三区免费| 奇米影视一区二区三区| 午夜a成v人精品| 亚洲福利电影网| 亚洲综合一区二区三区| 亚洲激情图片一区| 中文字幕一区二| 中文天堂在线一区| 亚洲国产精品成人久久综合一区| www日韩大片| 337p日本欧洲亚洲大胆精品| 精品乱码亚洲一区二区不卡| 欧美mv日韩mv| 精品国产91乱码一区二区三区| 欧美大胆人体bbbb| 精品国精品国产| 久久久激情视频| 欧美国产丝袜视频| 国产精品精品国产色婷婷| 中文字幕第一区| 中文字幕国产一区二区| 国产精品久久久久久亚洲伦| 国产精品国产自产拍高清av王其 | 日韩一区二区三区在线观看| 日韩一区二区精品在线观看| 欧美成va人片在线观看| 久久看人人爽人人| 国产精品久久久久久久久免费丝袜 | 26uuu国产日韩综合| 26uuu亚洲综合色| 国产精品色婷婷| 亚洲裸体xxx| 午夜一区二区三区视频| 日本特黄久久久高潮| 韩国精品在线观看| 粉嫩av一区二区三区| 色综合夜色一区| 欧美日韩精品免费观看视频| 欧美一级一级性生活免费录像| 精品福利av导航| 国产精品国产自产拍高清av | 丁香啪啪综合成人亚洲小说| 成人黄色网址在线观看| 欧美图区在线视频| 日韩女优av电影| 国产精品超碰97尤物18| 一区二区三区久久久| 免费观看在线综合| 成人国产精品视频| 欧美日韩免费不卡视频一区二区三区| 337p亚洲精品色噜噜狠狠| 2017欧美狠狠色| 亚洲欧美另类在线| 麻豆成人综合网| 成人av在线资源网| 91精品国产一区二区人妖| 久久久久久久精| 亚洲一二三四久久| 国产精品一二一区| 在线观看视频一区二区欧美日韩| 日韩欧美国产一区二区三区 | 极品少妇xxxx精品少妇偷拍| 99热99精品| 日韩免费观看2025年上映的电影| 国产精品久久国产精麻豆99网站| 亚洲3atv精品一区二区三区| 国产精品69久久久久水密桃| 欧美三级欧美一级| 国产精品乱人伦| 美国精品在线观看| 欧美性一二三区| 国产精品卡一卡二| 久久99在线观看| 91电影在线观看| 国产欧美1区2区3区| 日韩福利视频网| 91免费看片在线观看| 久久久久久麻豆| 日本女优在线视频一区二区| 一本大道久久a久久精二百| 精品久久久久一区二区国产| 亚洲一区二区三区视频在线| 99久久精品国产网站| 亚洲精品在线电影| 日韩高清在线电影| 欧美曰成人黄网| 国产精品传媒入口麻豆| 国产精品综合在线视频| 日韩欧美综合一区| 午夜欧美2019年伦理| 欧洲亚洲国产日韩| 亚洲免费观看高清完整版在线观看| 国产一区二区三区精品视频| 日韩欧美国产一区二区在线播放| 亚洲成av人影院| 欧美三片在线视频观看| 亚洲精品久久久蜜桃| www.66久久| 中文字幕永久在线不卡| 国产精品123| 国产婷婷精品av在线| 国内精品伊人久久久久av一坑| 欧美一级欧美三级在线观看| 日韩精品亚洲一区二区三区免费| 欧美色国产精品| 亚洲18女电影在线观看| 欧美日韩一区二区在线观看视频 | 久久久久国产精品人| 精品一区二区影视| 日韩免费高清av| 精品亚洲成a人| 亚洲精品一区二区三区香蕉| 精品一二三四在线| 国产日产精品一区| 国产成人午夜高潮毛片| 国产精品毛片久久久久久久| www.日韩在线| 亚洲免费观看高清在线观看| 色婷婷精品久久二区二区蜜臂av| 一区二区三区在线视频观看 | 国产精品婷婷午夜在线观看| 成人一区在线观看| 亚洲视频图片小说| 欧美亚洲日本国产| 日韩精品电影在线观看| 日韩一本二本av| 国产一区二区三区| 国产精品视频九色porn| 91美女精品福利| 亚洲成av人片一区二区| 日韩欧美在线网站| 国产美女久久久久| 国产精品国产a| 欧美日韩一区二区三区视频| 美腿丝袜亚洲综合| 久久久99免费| 91免费看`日韩一区二区| 亚洲国产精品久久久男人的天堂| 日韩亚洲欧美综合| 成人av免费网站| 五月天国产精品| 久久精品欧美日韩精品| 在线观看日韩av先锋影音电影院| 天天影视网天天综合色在线播放| 久久综合色天天久久综合图片| 成人免费黄色在线| 亚洲成年人影院| 亚洲精品一区二区三区蜜桃下载| 91啦中文在线观看| 九九热在线视频观看这里只有精品| 亚洲国产高清在线观看视频| 欧美综合欧美视频| 国产精品18久久久| 性做久久久久久免费观看 | 亚洲一区二区在线观看视频| 日韩精品一区二区三区视频在线观看 | 欧美性色综合网| 国产精品123| 天堂成人国产精品一区| 国产免费久久精品| 6080国产精品一区二区| 国产mv日韩mv欧美| 五月婷婷综合在线| 国产精品久久久久影视| 欧美一级欧美一级在线播放| 色综合久久综合| 国产精品自拍av| 亚洲第一福利一区| 国产精品久久三区| 精品少妇一区二区三区在线视频 | 欧美久久久久久久久| www.亚洲精品| 精品影院一区二区久久久| 亚洲午夜一二三区视频|