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

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

?? techenergy.cpp

?? 股票軟件
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/*
	Cross Platform Core Code.

	Copyright(R) 2001-2002 Balang Software.
	All rights reserved.

*/

#include	"StdAfx.h"
#include	"Stock.h"
#include	"Technique.h"

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

#ifdef	_DEBUG
#define	new	DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
//	CVOLUME
CVOLUME::CVOLUME( )
{
	SetDefaultParameters( );
}

CVOLUME::CVOLUME( CKData * pKData )
	: CTechnique( pKData )
{
	SetDefaultParameters( );
}

CVOLUME::~CVOLUME()
{
	Clear( );
}

void CVOLUME::SetDefaultParameters( )
{
	m_adwMADays.RemoveAll();
	m_adwMADays.Add( 5 );
	m_adwMADays.Add( 10 );
	m_itsDeviateOnBottom	=	ITS_BUYINTENSE;
	m_itsDeviateOnTop		=	ITS_SELLINTENSE;
	m_itsLong				=	ITS_BUY;
	m_itsShort				=	ITS_SELL;
}

void CVOLUME::AttachParameters( CVOLUME & src )
{
	m_adwMADays.Copy( src.m_adwMADays );
	m_itsDeviateOnBottom	=	src.m_itsDeviateOnBottom;
	m_itsDeviateOnTop		=	src.m_itsDeviateOnTop;
	m_itsLong				=	src.m_itsLong;
	m_itsShort				=	src.m_itsShort;
}

BOOL CVOLUME::IsValidParameters( )
{
	STT_VALID_DAYSARRAY( m_adwMADays );
	return ( VALID_ITS(m_itsDeviateOnBottom) && VALID_ITS(m_itsDeviateOnTop)
		&& VALID_ITS(m_itsLong) && VALID_ITS(m_itsShort) );
}

void CVOLUME::Clear( )
{
	CTechnique::Clear( );
}

int CVOLUME::GetSignal( int nIndex, UINT * pnCode )
{
	if( pnCode )	*pnCode	=	ITSC_NOTHING;
	if( !m_pKData || nIndex < 0 || nIndex >= m_pKData->GetSize() )
		return ITS_NOTHING;

	int	nIntensity	=	GetTrendIntensity( nIndex, m_adwMADays, m_itsLong, m_itsShort, pnCode );
	if( ITS_BUY == nIntensity
		&& m_pKData->IsNewValue( nIndex, FALSE, ITS_DAYS_DEVIATE ) )
	{	// 底背離,股價創新低并且成交量趨勢向上
		if( pnCode )	*pnCode	=	ITSC_DEVIATEONBOTTOM;
		return m_itsDeviateOnBottom;
	}
	if( ITS_SELL == nIntensity
		&& m_pKData->IsNewValue( nIndex, TRUE, ITS_DAYS_DEVIATE ) )
	{	// 頂背離,股價創新高并且成交量趨勢向下
		if( pnCode )	*pnCode	=	ITSC_DEVIATEONTOP;
		return m_itsDeviateOnTop;
	}

	return nIntensity;
}

BOOL CVOLUME::GetMinMaxInfo(int nStart, int nEnd,
				   double *pdMin, double *pdMax )
{
	STT_ASSERT_GETMINMAXINFO( m_pKData, nStart, nEnd );

	double	dMin	=	0;
	double	dMax	=	1;
	for( int k=nStart; k<=nEnd; k++ )
	{
		KDATA	& kd	=	m_pKData->ElementAt(k);
		if( dMax < kd.m_fVolume )
			dMax	=	(double)kd.m_fVolume;
	}

	dMax	=	dMax + 1;
	if( dMax - dMin < 3 )
		dMax	=	dMin + 3;

	if( pdMin )		*pdMin	=	dMin;
	if( pdMax )		*pdMax	=	dMax;
	return TRUE;
}

/***
	計算nDays的平均成交量
*/
BOOL CVOLUME::Calculate( double * pValue, int nIndex, int nDays, BOOL bUseLast )
{
	STT_ASSERT_CALCULATE( m_pKData, nIndex, nDays );

	int	nCount	=	0;
	if( nDays > nIndex+1 )
		return FALSE;
	double	dResult	=	0;
	for( int k=nIndex; k>=0; k-- )
	{
		dResult	+=	m_pKData->ElementAt(k).m_fVolume;
		nCount	++;
		if( nCount == nDays )
		{
			if( pValue )
				*pValue	=	dResult / nDays;
			return TRUE;
		}
	}
	return FALSE;
}

//////////////////////////////////////////////////////////////////////
//	CNVI
CNVI::CNVI( )
{
	SetDefaultParameters( );
}

CNVI::CNVI( CKData * pKData )
	: CTechnique( pKData )
{
	SetDefaultParameters( );
}

CNVI::~CNVI()
{
	Clear( );
}

void CNVI::SetDefaultParameters( )
{
	m_nMADays	=	25;
	m_itsGoldenFork			=	ITS_BUY;
	m_itsDeadFork			=	ITS_SELL;
}

void CNVI::AttachParameters( CNVI & src )
{
	m_nMADays	=	src.m_nMADays;
	m_itsGoldenFork			=	src.m_itsGoldenFork;
	m_itsDeadFork			=	src.m_itsDeadFork;
}

BOOL CNVI::IsValidParameters( )
{
	return ( VALID_DAYS( m_nMADays ) && VALID_ITS(m_itsGoldenFork) && VALID_ITS(m_itsDeadFork) );
}

void CNVI::Clear( )
{
	CTechnique::Clear( );
}

int CNVI::GetSignal( int nIndex, UINT * pnCode )
{
	PrepareCache( 0, -1, FALSE );
	// 金叉死叉
	return GetForkSignal( nIndex, m_itsGoldenFork, m_itsDeadFork, pnCode );
}

BOOL CNVI::GetMinMaxInfo(int nStart, int nEnd, double *pdMin, double *pdMax )
{
	return AfxGetMinMaxInfo2( nStart, nEnd, pdMin, pdMax, this );
}

/***
	NVI初值 = 100
	如果今天成交量比昨日小 NVI = 前一日NVI + 100 * 漲跌幅 否則,NVI = 前一天NVI
*/
BOOL CNVI::Calculate( double * pValue, double *pMA, int nIndex, BOOL bUseLast )
{
	STT_ASSERT_CALCULATE1( m_pKData, nIndex );

	// Calculate
	if( m_nMADays > nIndex+1 )
		return FALSE;

	if( LoadFromCache( nIndex, pValue, pMA ) )
		return TRUE;

	double	dValueNew = 0, dMANew = 0;
	if( bUseLast && pValue && pMA )
	{
		if( 0 == nIndex )
			dValueNew	=	100;
		else if( m_pKData->ElementAt(nIndex).m_fVolume < m_pKData->ElementAt(nIndex-1).m_fVolume
				&& m_pKData->MaindataAt(nIndex-1) > 1e-4 && m_pKData->MaindataAt(nIndex) > 1e-4 )
			dValueNew	=	(*pValue) * m_pKData->MaindataAt(nIndex) / m_pKData->MaindataAt(nIndex-1);
		else
			dValueNew	=	*pValue;
		dMANew	=	(*pMA) * (m_nMADays-1) / (m_nMADays+1) + dValueNew * 2 / (m_nMADays+1);
		StoreToCache( nIndex, &dValueNew, &dMANew );
	}
	else
	{
		for( int k=0; k<=nIndex; k++ )
		{
			if( 0 == k )
				dValueNew	=	100;
			else if( m_pKData->ElementAt(k).m_fVolume < m_pKData->ElementAt(k-1).m_fVolume
					&& m_pKData->MaindataAt(k-1) > 1e-4 && m_pKData->MaindataAt(k) > 1e-4 )
				dValueNew	=	dValueNew * m_pKData->MaindataAt(k) / m_pKData->MaindataAt(k-1);

			if( 0 == k )
				dMANew	=	dValueNew;
			else
				dMANew	=	dMANew * (m_nMADays-1) / (m_nMADays+1) + dValueNew * 2 / (m_nMADays+1);
			
			StoreToCache( k, &dValueNew, &dMANew );
		}
	}

	if( pValue )	*pValue	=	dValueNew;
	if( pMA )		*pMA	=	dMANew;
	return TRUE;
}

//////////////////////////////////////////////////////////////////////
//	CPVI
CPVI::CPVI( )
{
	SetDefaultParameters( );
}

CPVI::CPVI( CKData * pKData )
	: CTechnique( pKData )
{
	SetDefaultParameters( );
}

CPVI::~CPVI()
{
	Clear( );
}

void CPVI::SetDefaultParameters( )
{
	m_nMADays	=	25;
	m_itsGoldenFork			=	ITS_BUY;
	m_itsDeadFork			=	ITS_SELL;
}

void CPVI::AttachParameters( CPVI & src )
{
	m_nMADays	=	src.m_nMADays;
	m_itsGoldenFork			=	src.m_itsGoldenFork;
	m_itsDeadFork			=	src.m_itsDeadFork;
}

BOOL CPVI::IsValidParameters( )
{
	return ( VALID_DAYS( m_nMADays ) && VALID_ITS(m_itsGoldenFork) && VALID_ITS(m_itsDeadFork) );
}

void CPVI::Clear( )
{
	CTechnique::Clear( );
}

int CPVI::GetSignal( int nIndex, UINT * pnCode )
{
	PrepareCache( 0, -1, FALSE );
	// 金叉死叉
	return GetForkSignal( nIndex, m_itsGoldenFork, m_itsDeadFork, pnCode );
}

BOOL CPVI::GetMinMaxInfo(int nStart, int nEnd, double *pdMin, double *pdMax )
{
	return AfxGetMinMaxInfo2( nStart, nEnd, pdMin, pdMax, this );
}

/***
	PVI初值100
	如果今天成交量比昨日大 PVI = 前一日PVI + 100 * 漲跌幅 否則,PVI = 前一日PVI
*/
BOOL CPVI::Calculate( double * pValue, double *pMA, int nIndex, BOOL bUseLast )
{
	STT_ASSERT_CALCULATE1( m_pKData, nIndex );

	// Calculate
	if( m_nMADays > nIndex+1 )
		return FALSE;

	if( LoadFromCache( nIndex, pValue, pMA ) )
		return TRUE;

	double	dValueNew = 0, dMANew = 0;
	if( bUseLast && pValue && pMA )
	{
		if( 0 == nIndex )
			dValueNew	=	100;
		else if( m_pKData->ElementAt(nIndex).m_fVolume > m_pKData->ElementAt(nIndex-1).m_fVolume
				&& m_pKData->MaindataAt(nIndex-1) > 1e-4 && m_pKData->MaindataAt(nIndex) > 1e-4 )
			dValueNew	=	(*pValue) * m_pKData->MaindataAt(nIndex) / m_pKData->MaindataAt(nIndex-1);
		else
			dValueNew	=	*pValue;
		dMANew	=	(*pMA) * (m_nMADays-1) / (m_nMADays+1) + dValueNew * 2 / (m_nMADays+1);
		StoreToCache( nIndex, &dValueNew, &dMANew );
	}
	else
	{
		for( int k=0; k<=nIndex; k++ )
		{
			if( 0 == k )
				dValueNew	=	100;
			else if( m_pKData->ElementAt(k).m_fVolume > m_pKData->ElementAt(k-1).m_fVolume
					&& m_pKData->MaindataAt(k-1) > 1e-4 && m_pKData->MaindataAt(k) > 1e-4 )
				dValueNew	=	dValueNew * m_pKData->MaindataAt(k) / m_pKData->MaindataAt(k-1);

			if( 0 == k )
				dMANew	=	dValueNew;
			else
				dMANew	=	dMANew * (m_nMADays-1) / (m_nMADays+1) + dValueNew * 2 / (m_nMADays+1);
			StoreToCache( k, &dValueNew, &dMANew );
		}
	}

	if( pValue )	*pValue	=	dValueNew;
	if( pMA )		*pMA	=	dMANew;
	return TRUE;
}

//////////////////////////////////////////////////////////////////////
//	CVR
CVR::CVR( )
{
	SetDefaultParameters( );
}

CVR::CVR( CKData * pKData )
	: CTechnique( pKData )
{
	SetDefaultParameters( );
}

CVR::~CVR()
{
	Clear( );
}

void CVR::SetDefaultParameters( )
{
	m_nDays		=	12;
	m_itsLong			=	ITS_BUY;
	m_itsShort			=	ITS_SELL;
}

void CVR::AttachParameters( CVR & src )
{
	m_nDays		=	src.m_nDays;
	m_itsLong		=	src.m_itsLong;
	m_itsShort		=	src.m_itsShort;
}

BOOL CVR::IsValidParameters( )
{
	return ( VALID_DAYS(m_nDays) && VALID_ITS(m_itsLong) && VALID_ITS(m_itsShort) );
}

void CVR::Clear( )
{
	CTechnique::Clear( );
}

int CVR::GetSignal( int nIndex, UINT * pnCode )
{
	if( pnCode )	*pnCode	=	ITSC_NOTHING;
	if( !m_pKData || nIndex < 0 || nIndex >= m_pKData->GetSize() )
		return ITS_NOTHING;

	int	nMaxDays	=	m_nDays;
	double	dLiminalLow = 0, dLiminalHigh = 0;
	if( !IntensityPrepare( nIndex, pnCode, nMaxDays, ITS_GETMINMAXDAYRANGE, &dLiminalLow, &dLiminalHigh, 0.309, 0.682 ) )
		return ITS_NOTHING;

	double	dNowClose	=	m_pKData->ElementAt(nIndex).m_fClose;

	double	dVRNow;
	if( !Calculate( &dVRNow, nIndex, FALSE ) )
		return ITS_NOTHING;

	int	nIntensity	=	GetTrendIntensity1( nIndex, m_itsLong, m_itsShort, pnCode );
	if( dVRNow < dLiminalLow && nIntensity == m_itsLong )
	{	// 低位趨勢向上
		if( pnCode )	*pnCode	=	ITSC_LONG;
		return m_itsLong;
	}
	if( dVRNow > dLiminalHigh && nIntensity == m_itsShort )
	{	// 高位趨勢向下
		if( pnCode )	*pnCode	=	ITSC_SHORT;
		return m_itsShort;
	}
	return	ITS_NOTHING;
}

BOOL CVR::GetMinMaxInfo(int nStart, int nEnd, double *pdMin, double *pdMax )
{
	return AfxGetMinMaxInfo1( nStart, nEnd, pdMin, pdMax, this );
}

/***
	     n日中上漲日成交量+1/2最近n日總成交量
	VR = ————————————---------—- ×100
	     n日中下跌日成交量+1/2最近n日總成交量
*/
BOOL CVR::Calculate( double * pValue, int nIndex, BOOL bUseLast )
{
	STT_ASSERT_CALCULATE1( m_pKData, nIndex );

	if( m_nDays > nIndex )
		return FALSE;
	if( LoadFromCache( nIndex, pValue ) )
		return TRUE;

	double	dINTV = 0, dDETV = 0, dTV = 0;
	int	nCount	=	0;
	for( int k=nIndex; k>=1; k-- )
	{
		double	dAmount	=	m_pKData->ElementAt(k).m_fVolume;
		if( m_pKData->MaindataAt(k) > m_pKData->MaindataAt(k-1) )
			dINTV	+=	dAmount;
		if( m_pKData->MaindataAt(k) < m_pKData->MaindataAt(k-1) )
			dDETV	+=	dAmount;
		dTV	+=	dAmount;

		nCount	++;
		if( nCount == m_nDays )
		{
			if( dDETV + dTV/2 < 1e-4 )
				return FALSE;
			if( pValue )	*pValue	=	(dINTV + dTV/2) * 100 /(dDETV + dTV/2);
			StoreToCache( nIndex, pValue );
			return TRUE;
		}
	}

	return FALSE;
}

//////////////////////////////////////////////////////////////////////
//	CVROC
CVROC::CVROC( )
{
	SetDefaultParameters( );
}

CVROC::CVROC( CKData * pKData )
	: CTechnique( pKData )
{
	SetDefaultParameters( );
}

CVROC::~CVROC()
{
	Clear( );
}

void CVROC::SetDefaultParameters( )
{
	m_nDays		=	10;
	m_nMADays	=	10;
	m_itsDeviateOnBottom	=	ITS_BUY;
	m_itsDeviateOnTop		=	ITS_SELL;
}

void CVROC::AttachParameters( CVROC & src )
{
	m_nDays		=	src.m_nDays;
	m_nMADays	=	src.m_nMADays;
	m_itsDeviateOnBottom	=	src.m_itsDeviateOnBottom;
	m_itsDeviateOnTop		=	src.m_itsDeviateOnTop;
}

BOOL CVROC::IsValidParameters( )
{
	return ( VALID_DAYS(m_nDays) && VALID_DAYS(m_nMADays)
		&& VALID_ITS(m_itsDeviateOnBottom) && VALID_ITS(m_itsDeviateOnTop) );
}

void CVROC::Clear( )
{
	CTechnique::Clear( );
}

int CVROC::GetSignal( int nIndex, UINT * pnCode )
{
	if( pnCode )	*pnCode	=	ITSC_NOTHING;

	int	nMaxDays	=	m_nDays+m_nMADays;
	double	dLiminalLow = 0, dLiminalHigh = 0;
	if( !IntensityPrepare( nIndex, pnCode, nMaxDays, ITS_GETMINMAXDAYRANGE, &dLiminalLow, &dLiminalHigh ) )
		return ITS_NOTHING;

	if( IsDeviateOnBottom( nIndex, m_pdCache1, m_pdCache2 ) )
	{	// 底背離
		if( pnCode )	*pnCode	=	ITSC_DEVIATEONBOTTOM;
		return m_itsDeviateOnBottom;
	}
	if( IsDeviateOnTop( nIndex, m_pdCache1, m_pdCache2 ) )
	{	// 頂背離
		if( pnCode )	*pnCode	=	ITSC_DEVIATEONTOP;
		return m_itsDeviateOnTop;
	}

	return	ITS_NOTHING;
}

BOOL CVROC::GetMinMaxInfo(int nStart, int nEnd, double *pdMin, double *pdMax )
{
	return AfxGetMinMaxInfo2( nStart, nEnd, pdMin, pdMax, this );
}

/***
	          今日成交量-n日前成交量

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久九九国产精品| 视频一区二区不卡| 日本视频免费一区| 97aⅴ精品视频一二三区| 日韩欧美美女一区二区三区| 亚洲一区二区三区自拍| 久久se精品一区精品二区| 91精品1区2区| 国产精品网站在线观看| 久久狠狠亚洲综合| 欧美日韩不卡在线| 亚洲乱码国产乱码精品精小说| 久久97超碰色| 日韩精品一区二区三区视频播放 | 欧美性高清videossexo| 国产网站一区二区三区| 蜜桃视频一区二区三区在线观看| 色婷婷久久综合| 国产精品电影一区二区| 国产一区二区福利视频| 欧美哺乳videos| 日本va欧美va精品| 欧美裸体一区二区三区| 亚洲成在人线在线播放| 91国在线观看| 亚洲一区二区在线免费观看视频| 91亚洲国产成人精品一区二三| 精品国产123| 国产麻豆精品视频| 国产亚洲成av人在线观看导航| 精品一区二区三区影院在线午夜| 日韩欧美国产综合| 狠狠色丁香久久婷婷综合_中| 精品国产91久久久久久久妲己| 精品一区二区三区视频在线观看| 日韩欧美在线一区二区三区| 蜜臀久久久久久久| 精品国内二区三区| 国产乱码字幕精品高清av| 国产欧美一区二区精品性色超碰 | 国产高清在线观看免费不卡| 久久影院视频免费| 不卡视频一二三四| 亚洲精品国产第一综合99久久 | 中文字幕在线一区二区三区| www.日韩精品| 一区二区三区日韩欧美精品| 欧美亚洲高清一区| 麻豆免费精品视频| 国产欧美日韩中文久久| 日本韩国精品在线| 日韩av一级片| 国产校园另类小说区| 91免费国产在线| 日韩在线一区二区三区| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 精品国产麻豆免费人成网站| 国产高清亚洲一区| 亚洲综合在线免费观看| 日韩欧美在线不卡| 成人深夜视频在线观看| 亚洲一区在线观看免费| 日韩欧美视频一区| 一本大道综合伊人精品热热 | 国产成人av电影在线| 亚洲麻豆国产自偷在线| 欧美肥妇free| 成人一二三区视频| 日本最新不卡在线| 国产精品免费久久| 制服丝袜一区二区三区| 成人一级片网址| 美腿丝袜一区二区三区| 国产精品久久一级| 日韩欧美不卡在线观看视频| 色欲综合视频天天天| 久久成人羞羞网站| 亚洲电影中文字幕在线观看| 久久久天堂av| 3d动漫精品啪啪一区二区竹菊| 国产精品 日产精品 欧美精品| 亚洲成人av电影在线| 中文字幕精品三区| 欧美精品一区二区三区一线天视频| 99国产精品久久久久久久久久| 美女一区二区三区在线观看| 亚洲自拍欧美精品| 国产精品人人做人人爽人人添 | 国产裸体歌舞团一区二区| 一区二区三区免费| 欧美韩国一区二区| 精品国产一区二区三区四区四| 日本高清不卡在线观看| 99久久久国产精品| 成年人网站91| 丁香婷婷综合激情五月色| 久久精品国产精品亚洲红杏| 亚洲一线二线三线视频| 综合久久综合久久| 中文字幕精品一区二区三区精品| 26uuu国产一区二区三区| 制服丝袜激情欧洲亚洲| 欧美日韩高清影院| 在线视频一区二区三区| 色88888久久久久久影院野外| 97久久超碰精品国产| 99久久夜色精品国产网站| 成人午夜精品在线| 成人av电影在线| 粉嫩蜜臀av国产精品网站| 国产美女主播视频一区| 国模冰冰炮一区二区| 国产精品一卡二卡在线观看| 激情另类小说区图片区视频区| 美女任你摸久久| 极品瑜伽女神91| 国产成人精品1024| 国产成人aaa| 本田岬高潮一区二区三区| jizz一区二区| 91久久香蕉国产日韩欧美9色| 在线亚洲+欧美+日本专区| 欧美日韩国产bt| 精品剧情在线观看| 欧美国产一区在线| 一区二区三区日韩欧美| 亚洲成人1区2区| 国产综合成人久久大片91| 成人午夜精品一区二区三区| 成人av资源下载| 欧美日韩一级二级| 欧美v国产在线一区二区三区| 久久精品视频免费| 亚洲黄色小视频| 免费视频最近日韩| 高清不卡在线观看av| 91国偷自产一区二区三区成为亚洲经典| 在线观看91视频| 精品久久久久久无| 亚洲欧美色一区| 美女高潮久久久| 99免费精品视频| 在线91免费看| 国产精品无人区| 亚洲一区二区三区不卡国产欧美 | 亚洲电影一区二区| 国产一区二区三区av电影| 97精品超碰一区二区三区| 91精品啪在线观看国产60岁| 国产清纯白嫩初高生在线观看91| 一区二区三区在线视频免费观看| 久久超碰97中文字幕| 91同城在线观看| 精品美女被调教视频大全网站| 亚洲免费观看在线观看| 精品一区二区三区免费| 在线看日本不卡| 欧美激情一区在线| 蜜桃在线一区二区三区| 日本韩国精品在线| 国产清纯白嫩初高生在线观看91 | 蜜臀久久99精品久久久久宅男| 成人av一区二区三区| 91精品国产入口在线| 亚洲色图清纯唯美| 国产乱一区二区| 欧美一区二区三区在线看| 自拍偷拍亚洲综合| 国产一区二区美女| 欧美一区二区播放| 亚洲一二三四区不卡| 成人一区在线看| 久久久久成人黄色影片| 久久激五月天综合精品| 欧美精品乱码久久久久久按摩| 一区视频在线播放| 国产一区二区精品久久91| 日韩一区二区三区电影| 亚洲成人www| 在线观看网站黄不卡| 国产精品久久久久久久蜜臀 | 国产一区二区网址| 欧美一区二区三区电影| 亚洲高清免费观看| 欧美无砖专区一中文字| 1区2区3区精品视频| 盗摄精品av一区二区三区| 2欧美一区二区三区在线观看视频| 日韩**一区毛片| 日韩欧美国产精品| 蜜桃视频一区二区三区| 日韩午夜在线影院| 免费日本视频一区| 精品国产91九色蝌蚪| 国内精品免费在线观看| 久久综合狠狠综合久久激情| 精品在线一区二区三区| 26uuu亚洲综合色欧美| 国产凹凸在线观看一区二区| 国产精品沙发午睡系列990531|