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

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

?? volumeoutmaster.cpp

?? nettalk
?? CPP
字號(hào):
//NetTalk
/*------------------------------------------------------------------------------*\
 =============================
   模塊名稱: VolumeOutMaster.cpp
 =============================
 //Download by http://www.codefans.net
 [版權(quán)]
 
   2000-2002  115軟件工廠  版權(quán)所有
                                              
\*------------------------------------------------------------------------------*/

#include <Windows.h>

#include "VolumeOutMaster.h"
/*------------------------------------------------------------------------------*/
/////////////////////////////////////////////////////////////////////////////
// 		Defines
#define	BAD_DWORD	(DWORD)-1
#define	WND_CLASS_NAME	"Master Output Volume Msg Wnd Class"
#define	WND_NAME		"Master Output Volume Msg Wnd"
/*------------------------------------------------------------------------------*/
/////////////////////////////////////////////////////////////////////////////
// 		Globals
PCVolumeOutMaster g_pThis = NULL;
/*------------------------------------------------------------------------------*/
////////////////////////////////////////////////////////////
/*------------------------------------------------------------------------------*/
//{{{ Audio specific functions
#define AUDFREQ			22050	// Frequency
#define AUDCHANNELS		1		// Number of channels
#define AUDBITSMPL		16		// Number of bits per sample
/*------------------------------------------------------------------------------*/
inline
void SetDeviceType( WAVEFORMATEX* pwfe )
{
	memset( pwfe, 0, sizeof(WAVEFORMATEX) );
	WORD  nBlockAlign = (AUDCHANNELS*AUDBITSMPL)/8;
	DWORD nSamplesPerSec = AUDFREQ;
	pwfe->wFormatTag = WAVE_FORMAT_PCM;
	pwfe->nChannels = AUDCHANNELS;
	pwfe->nBlockAlign = nBlockAlign;
	pwfe->nSamplesPerSec = nSamplesPerSec;
	pwfe->wBitsPerSample = AUDBITSMPL;
	pwfe->nAvgBytesPerSec = nSamplesPerSec*nBlockAlign;
}
//}}} Audio specific functions
/*------------------------------------------------------------------------------*/
/////////////////////////////////////////////////////////////////////////////
// 		Implementation
//////////////
CVolumeOutMaster::CVolumeOutMaster()
	:	m_bOK(false),
		m_bInitialized(false),
		m_bAvailable(false),

		m_uMixerID(0L),
		m_dwMixerHandle(0L),
		m_hWnd(NULL),

		m_dwMinimalVolume(BAD_DWORD),
		m_dwMaximalVolume(BAD_DWORD),

		m_pfUserSink(NULL),
		m_dwUserValue(0L)
{
	if ( m_bOK = Init() )
	{
		g_pThis = this;
		if ( !Initialize() )
		{
			Done();
			g_pThis = NULL;
		}
	}
}
/*------------------------------------------------------------------------------*/
//////////////
CVolumeOutMaster::~CVolumeOutMaster()
{
	if ( m_bOK )
		Done();
	g_pThis = NULL;
}
/*------------------------------------------------------------------------------*/
//////////////
bool CVolumeOutMaster::Init()
{
	if ( !mixerGetNumDevs() )
		return false;
	// Getting Mixer ID
	HWAVEOUT hwaveOut;
	MMRESULT mmResult;
	WAVEFORMATEX WaveFmt;
	SetDeviceType( &WaveFmt );
	mmResult = waveOutOpen( &hwaveOut, WAVE_MAPPER, &WaveFmt, 0L, 0L, CALLBACK_NULL );
	if ( mmResult != MMSYSERR_NOERROR )
	{
		
		return false;
	} else {
		mmResult = mixerGetID( (HMIXEROBJ)hwaveOut, &m_uMixerID, MIXER_OBJECTF_HWAVEOUT );
		waveOutClose( hwaveOut );
		if ( mmResult != MMSYSERR_NOERROR )
		{
		
			return false;
		}
	}
	// Exposing Window to Mixer
	WNDCLASSEX wcx;
	memset( &wcx, 0, sizeof(WNDCLASSEX) );	
	wcx.cbSize = sizeof(WNDCLASSEX);
	wcx.lpszClassName = WND_CLASS_NAME;
	wcx.lpfnWndProc = (WNDPROC)MixerWndProc;
	::RegisterClassEx(&wcx);
	m_hWnd = CreateWindow(	WND_CLASS_NAME,
							WND_NAME,
							WS_POPUP | WS_DISABLED,
							0, 0, 0, 0,
							NULL, NULL, NULL, NULL );
	if ( !m_hWnd )
	{
		
		return false;
	}
	::ShowWindow(m_hWnd, SW_HIDE);
	mmResult = mixerOpen( (LPHMIXER)&m_dwMixerHandle, m_uMixerID, (DWORD)m_hWnd, 0L, CALLBACK_WINDOW );
	if ( mmResult != MMSYSERR_NOERROR )
	{
	
		::DestroyWindow( m_hWnd );
		return false;
	}
	return true;
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::Done()
{
	if ( mixerClose( (HMIXER)m_dwMixerHandle ) != MMSYSERR_NOERROR )
	{
		
	}
	::DestroyWindow( m_hWnd );
	m_bInitialized = false;
	m_bOK = false;
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::OnControlChanged( DWORD dwControlID )
{
	if ( m_dwVolumeControlID == dwControlID )
	{
		DWORD dwVolume = GetCurrentVolume();
		if ( (dwVolume!=BAD_DWORD) && (m_pfUserSink) )
		{
			(*m_pfUserSink)( dwVolume, m_dwUserValue );
		}
	}
}
/*------------------------------------------------------------------------------*/
//////////////
bool CVolumeOutMaster::Initialize()
{
	MMRESULT mmResult;
	if ( !m_bOK )
		return false;

	MIXERLINE MixerLine;
	memset( &MixerLine, 0, sizeof(MIXERLINE) );
	MixerLine.cbStruct = sizeof(MIXERLINE);
	MixerLine.dwComponentType = MIXERLINE_COMPONENTTYPE_DST_SPEAKERS;
	mmResult = mixerGetLineInfo( (HMIXEROBJ)m_dwMixerHandle, &MixerLine, MIXER_GETLINEINFOF_COMPONENTTYPE );
	if ( mmResult != MMSYSERR_NOERROR )
	{
		
		return false;
	}

	MIXERCONTROL Control;
	memset( &Control, 0, sizeof(MIXERCONTROL) );
	Control.cbStruct = sizeof(MIXERCONTROL);

	MIXERLINECONTROLS LineControls;
	memset( &LineControls, 0, sizeof(MIXERLINECONTROLS) );
	LineControls.cbStruct = sizeof(MIXERLINECONTROLS);

	LineControls.dwControlType = MIXERCONTROL_CONTROLTYPE_VOLUME;
	LineControls.dwLineID = MixerLine.dwLineID;
	LineControls.cControls = 1;
	LineControls.cbmxctrl = sizeof(MIXERCONTROL);
	LineControls.pamxctrl = &Control;
	mmResult = mixerGetLineControls( (HMIXEROBJ)m_dwMixerHandle, &LineControls, MIXER_GETLINECONTROLSF_ONEBYTYPE );
	if ( mmResult == MMSYSERR_NOERROR )
	{
		if ( !(Control.fdwControl & MIXERCONTROL_CONTROLF_DISABLED) )
		{
			m_bAvailable = true;
		} else {
		}
	} else {
	}

	m_nChannelCount = MixerLine.cChannels;
	m_dwLineID = LineControls.dwLineID;
	m_dwVolumeControlID = Control.dwControlID;
	m_dwMinimalVolume = Control.Bounds.dwMinimum;
	m_dwMaximalVolume = Control.Bounds.dwMaximum;
	m_dwVolumeStep = Control.Metrics.cSteps;

	m_bInitialized = true;
	return true;
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::EnableLine( bool bEnable )
{
	if ( !m_bInitialized )
		return;
	bool bAnyEnabled = false;
	MMRESULT mmResult;

	MIXERLINE lineDestination;
	memset( &lineDestination, 0, sizeof(MIXERLINE) );
	lineDestination.cbStruct = sizeof(MIXERLINE);
	lineDestination.dwLineID = m_dwLineID;
	mmResult = mixerGetLineInfo( (HMIXEROBJ)m_dwMixerHandle, &lineDestination, MIXER_GETLINEINFOF_LINEID );
	if ( mmResult != MMSYSERR_NOERROR )
	{
		if ( bEnable )
		{
		} else {
		}
		return;
	}
	// Getting all line's controls
	int nControlCount = lineDestination.cControls;
	int nChannelCount = lineDestination.cChannels;
	MIXERLINECONTROLS LineControls;
	memset( &LineControls, 0, sizeof(MIXERLINECONTROLS) );
	MIXERCONTROL* aControls = (MIXERCONTROL*)malloc( nControlCount * sizeof(MIXERCONTROL) );
	if ( !aControls )
	{
		if ( bEnable )
		{
		} else {
		}
		return;
	}
	memset( &aControls[0], 0, sizeof(nControlCount * sizeof(MIXERCONTROL)) );
	for ( int i = 0; i < nControlCount; i++ )
	{
		aControls[i].cbStruct = sizeof(MIXERCONTROL);
	}
	LineControls.cbStruct = sizeof(MIXERLINECONTROLS);
	LineControls.dwLineID = lineDestination.dwLineID;
	LineControls.cControls = nControlCount;
	LineControls.cbmxctrl = sizeof(MIXERCONTROL);
	LineControls.pamxctrl = &aControls[0];
	mmResult = mixerGetLineControls( (HMIXEROBJ)m_dwMixerHandle, &LineControls, MIXER_GETLINECONTROLSF_ALL );
	if ( mmResult == MMSYSERR_NOERROR )
	{
		for ( i = 0; i < nControlCount; i++ )
		{
			LONG lValue;
			bool bReadyToSet = false;
			switch (aControls[i].dwControlType)
			{
			case MIXERCONTROL_CONTROLTYPE_MUTE:
				lValue = (BOOL)!bEnable;
				bReadyToSet = true;
				break;
			case MIXERCONTROL_CONTROLTYPE_SINGLESELECT:
				lValue = (BOOL)bEnable;
				bReadyToSet = true;
				break;
			case MIXERCONTROL_CONTROLTYPE_MUX:
				lValue = (BOOL)bEnable;
				bReadyToSet = true;
				break;
			case MIXERCONTROL_CONTROLTYPE_MULTIPLESELECT:
				lValue = (BOOL)bEnable;
				bReadyToSet = true;
				break;
			case MIXERCONTROL_CONTROLTYPE_MIXER:
				lValue = (BOOL)bEnable;
				bReadyToSet = true;
				break;
			}
			if ( bReadyToSet )
			{
				MIXERCONTROLDETAILS_BOOLEAN* aDetails = NULL;
				int nMultipleItems = aControls[i].cMultipleItems;
				int nChannels = nChannelCount;
				// MIXERCONTROLDETAILS
				MIXERCONTROLDETAILS ControlDetails;
				memset( &ControlDetails, 0, sizeof(MIXERCONTROLDETAILS) );
				ControlDetails.cbStruct = sizeof(MIXERCONTROLDETAILS);
				ControlDetails.dwControlID = aControls[i].dwControlID;
				if ( aControls[i].fdwControl & MIXERCONTROL_CONTROLF_UNIFORM )
				{
					nChannels = 1;
				}
				if ( aControls[i].fdwControl & MIXERCONTROL_CONTROLF_MULTIPLE )
				{
					nMultipleItems = aControls[i].cMultipleItems;
					aDetails = (MIXERCONTROLDETAILS_BOOLEAN*)malloc(nMultipleItems*nChannels*sizeof(MIXERCONTROLDETAILS_BOOLEAN));
					if ( !aDetails )
					{
						if ( bEnable )
						{
						} else {
						}
						continue;
					}
					for ( int nItem = 0; nItem < nMultipleItems; nItem++ )
					{
						/*
						if ( ( aControls[i].dwControlType & MIXERCONTROL_CONTROLTYPE_SINGLESELECT )
						  && ( nItem > 0 ) )
						{
							lValue = (LONG)!((BOOL)lValue);
						}
						*/
						for ( int nChannel = 0; nChannel < nChannels; nChannel++ )
						{
							aDetails[nItem+nChannel].fValue = lValue;
						}
					}
				} else {
					nMultipleItems = 0;
					aDetails = (MIXERCONTROLDETAILS_BOOLEAN*)malloc(nChannels*sizeof(MIXERCONTROLDETAILS_BOOLEAN));
					if ( !aDetails )
					{
						if ( bEnable )
						{
						} else {
						}
						continue;
					}
					for ( int nChannel = 0; nChannel < nChannels; nChannel++ )
					{
						aDetails[nChannel].fValue = (LONG)lValue;
					}
				}
				ControlDetails.cChannels = nChannels;
				ControlDetails.cMultipleItems = nMultipleItems;
				ControlDetails.cbDetails = sizeof(MIXERCONTROLDETAILS_BOOLEAN);
				ControlDetails.paDetails = &aDetails[0];
				mmResult = mixerSetControlDetails( (HMIXEROBJ)m_dwMixerHandle, &ControlDetails, 0L );
				if ( mmResult == MMSYSERR_NOERROR )
				{
					if ( bEnable )
					{
					} else {
					}
					bAnyEnabled = true;
				}
				free( aDetails );
			}
		}
	} else {
		if ( bEnable )
		{
		} else {
		}
	}
	free( aControls );
	if ( !bAnyEnabled )
	{
		if ( bEnable )
		{
		} else {
		}
	}
}
/*------------------------------------------------------------------------------*/
//////////////////////////////////////////////
// IVolume interface
//////////////
bool CVolumeOutMaster::IsAvailable()
{
	return m_bAvailable;
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::Enable()
{
	EnableLine( true );
}
/*------------------------------------------------------------------------------*/
void CVolumeOutMaster::Disable()
{
	EnableLine( false );
}
/*------------------------------------------------------------------------------*/
//////////////
DWORD CVolumeOutMaster::GetVolumeMetric()
{
	if ( !m_bAvailable )
		return BAD_DWORD;
	return m_dwVolumeStep;
}
/*------------------------------------------------------------------------------*/
//////////////
DWORD CVolumeOutMaster::GetMinimalVolume()
{
	if ( !m_bAvailable )
		return BAD_DWORD;
	return m_dwMinimalVolume;
}
/*------------------------------------------------------------------------------*/
//////////////
DWORD CVolumeOutMaster::GetMaximalVolume()
{
	if ( !m_bAvailable )
		return BAD_DWORD;
	return m_dwMaximalVolume;
}
/*------------------------------------------------------------------------------*/
//////////////
DWORD CVolumeOutMaster::GetCurrentVolume()
{
	if ( !m_bAvailable )
		return BAD_DWORD;
	MIXERCONTROLDETAILS_UNSIGNED* aDetails = (MIXERCONTROLDETAILS_UNSIGNED*)malloc(m_nChannelCount*sizeof(MIXERCONTROLDETAILS_UNSIGNED));
	if ( !aDetails )
		return BAD_DWORD;
	MIXERCONTROLDETAILS ControlDetails;
	memset( &ControlDetails, 0, sizeof(MIXERCONTROLDETAILS) );
	ControlDetails.cbStruct = sizeof(MIXERCONTROLDETAILS);
	ControlDetails.dwControlID = m_dwVolumeControlID;
	ControlDetails.cChannels = m_nChannelCount;
	ControlDetails.cMultipleItems = 0;
	ControlDetails.cbDetails = sizeof(MIXERCONTROLDETAILS_UNSIGNED);
	ControlDetails.paDetails = &aDetails[0];
	MMRESULT mmResult = mixerGetControlDetails( (HMIXEROBJ)m_dwMixerHandle, &ControlDetails, MIXER_GETCONTROLDETAILSF_VALUE );
	DWORD dw = aDetails[0].dwValue;
	free( aDetails );
	if ( mmResult != MMSYSERR_NOERROR )
	{
		return BAD_DWORD;
	}
	return dw;
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::SetCurrentVolume( DWORD dwValue )
{
	if ( !m_bAvailable || (dwValue<m_dwMinimalVolume) || (dwValue>m_dwMaximalVolume) )
		return;
	MIXERCONTROLDETAILS_UNSIGNED* aDetails = (MIXERCONTROLDETAILS_UNSIGNED*)malloc(m_nChannelCount*sizeof(MIXERCONTROLDETAILS_UNSIGNED));
	if ( !aDetails )
		return;
	for ( int i = 0; i < m_nChannelCount; i++ )
	{
		aDetails[i].dwValue = dwValue;
	}
	MIXERCONTROLDETAILS ControlDetails;
	memset( &ControlDetails, 0, sizeof(MIXERCONTROLDETAILS) );
	ControlDetails.cbStruct = sizeof(MIXERCONTROLDETAILS);
	ControlDetails.dwControlID = m_dwVolumeControlID;
	ControlDetails.cChannels = m_nChannelCount;
	ControlDetails.cMultipleItems = 0;
	ControlDetails.cbDetails = sizeof(MIXERCONTROLDETAILS_UNSIGNED);
	ControlDetails.paDetails = &aDetails[0];
	MMRESULT mmResult = mixerSetControlDetails( (HMIXEROBJ)m_dwMixerHandle, &ControlDetails, MIXER_SETCONTROLDETAILSF_VALUE );
	free( aDetails );
	if ( mmResult != MMSYSERR_NOERROR )
	{
	}
}
/*------------------------------------------------------------------------------*/
//////////////
void CVolumeOutMaster::RegisterNotificationSink( PONMICVOULUMECHANGE pfUserSink, DWORD dwUserValue )
{
	m_pfUserSink = pfUserSink;
	m_dwUserValue = dwUserValue;
}
/*------------------------------------------------------------------------------*/
////////////////////////////////////////////////////////////////////////
LRESULT CALLBACK CVolumeOutMaster::MixerWndProc( HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
{
	if ( uMsg == MM_MIXM_CONTROL_CHANGE )
	{
		if ( g_pThis )
		{
			g_pThis->OnControlChanged( (DWORD)lParam );
		}
	}
	return ::DefWindowProc( hwnd, uMsg, wParam, lParam);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美高清视频在线高清观看mv色露露十八 | 青青草国产成人av片免费| 国产成人久久精品77777最新版本| 欧美高清一级片在线| 1区2区3区国产精品| 国产呦精品一区二区三区网站| 91精品国产综合久久国产大片| 一区二区三区**美女毛片| 91网上在线视频| 亚洲制服丝袜av| 欧美精品v日韩精品v韩国精品v| 夜夜亚洲天天久久| 欧美一级二级在线观看| 国产精品一卡二卡| 1024亚洲合集| 777欧美精品| 久久激情五月激情| 一区二区三区四区在线播放 | 欧美成人艳星乳罩| 国产精品一区二区三区网站| 亚洲欧美激情在线| 91精品国产色综合久久ai换脸 | 一区二区不卡在线视频 午夜欧美不卡在 | 国产精品国产三级国产普通话99 | 一区二区三区在线免费视频| 欧美美女一区二区在线观看| 激情文学综合网| 亚洲影视资源网| 中文在线资源观看网站视频免费不卡 | 亚洲高清免费观看| 久久久99精品免费观看| 欧洲精品一区二区三区在线观看| 亚洲成人精品在线观看| 亚洲成人黄色影院| 久久影院午夜论| 欧美日韩久久久久久| 99久久精品国产一区| 国产一区999| 日韩专区欧美专区| 亚洲aaa精品| 自拍偷拍欧美激情| 国产欧美日韩在线观看| 337p日本欧洲亚洲大胆精品| 欧美一区二区性放荡片| 色久优优欧美色久优优| 91在线精品一区二区| 狠狠色丁香久久婷婷综合丁香| 亚洲超丰满肉感bbw| 亚洲一区二区成人在线观看| 亚洲人妖av一区二区| 日本一二三四高清不卡| 久久久99精品免费观看不卡| 久久嫩草精品久久久精品| xf在线a精品一区二区视频网站| 日韩欧美电影一区| 精品国产乱子伦一区| 精品国产91久久久久久久妲己| 日韩一区二区三区视频在线观看| 555www色欧美视频| 久久久国产精华| 亚洲免费伊人电影| 日韩精品高清不卡| 麻豆91精品91久久久的内涵| 国产剧情一区在线| 91蝌蚪porny| 91麻豆精品国产自产在线观看一区| 欧美精品黑人性xxxx| 亚洲国产精品激情在线观看| 亚洲欧美在线高清| 亚洲成人免费观看| 欧美色窝79yyyycom| 欧美一区二区成人| 18欧美乱大交hd1984| 日韩精品福利网| 91小视频免费看| 精品国产精品一区二区夜夜嗨| 国产农村妇女精品| 免费观看在线综合色| 99热这里都是精品| 精品久久久久一区二区国产| 亚洲欧洲av在线| 国产一区二区中文字幕| 欧美日韩1区2区| 亚洲视频免费观看| 风间由美一区二区三区在线观看| 欧美日韩另类国产亚洲欧美一级| 欧美国产精品一区| 久久丁香综合五月国产三级网站| 91国产丝袜在线播放| 亚洲精品自拍动漫在线| 成人的网站免费观看| 国产精品每日更新在线播放网址| 免费观看在线综合色| 69堂精品视频| 日韩精品亚洲一区| 欧洲精品中文字幕| 亚洲欧洲成人av每日更新| 国产激情视频一区二区在线观看| 日韩欧美不卡一区| 亚洲v精品v日韩v欧美v专区| 欧美艳星brazzers| 亚洲国产欧美另类丝袜| 欧美亚洲图片小说| 亚洲成av人片| 欧美一级一级性生活免费录像| 亚洲综合视频在线观看| 欧美性大战久久久| 偷拍日韩校园综合在线| 日韩欧美国产综合| 国产精品18久久久久久久久久久久 | 自拍偷拍国产精品| 99精品在线免费| 洋洋成人永久网站入口| 欧美日韩成人一区| 国产一区二区三区久久久| 国产午夜精品久久久久久免费视| 国产精品资源网站| 一区二区三区四区国产精品| 欧美一卡在线观看| 国产91在线观看| 樱桃国产成人精品视频| 欧美另类久久久品| 国产成a人亚洲精品| 亚洲一区二区高清| 国产欧美一区二区精品性色超碰| 成人动漫av在线| 免费人成在线不卡| 亚洲人xxxx| 国产日韩精品一区| 欧美色电影在线| 日韩女优电影在线观看| 欧美在线一二三四区| 国产精品系列在线| 51久久夜色精品国产麻豆| 国内一区二区在线| ...av二区三区久久精品| 在线一区二区观看| 欧美猛男gaygay网站| 69久久99精品久久久久婷婷| 欧美日韩在线播放一区| 日韩一区二区麻豆国产| 国产欧美精品一区| 亚洲日本一区二区| 全部av―极品视觉盛宴亚洲| 久久99精品一区二区三区三区| 亚洲成av人在线观看| 国产精品网站在线观看| 精品国产乱码久久久久久久久| 国产馆精品极品| 懂色av中文字幕一区二区三区| 三级一区在线视频先锋| 久久久久国产精品麻豆| 色综合久久综合网| 国产成人免费在线观看不卡| 亚洲五码中文字幕| 亚洲成人激情综合网| 免费成人美女在线观看| 国产精品丝袜一区| 国产精品黄色在线观看 | 欧美日韩一级视频| 国产电影一区二区三区| 成人午夜精品在线| 国产传媒欧美日韩成人| 日本欧美韩国一区三区| 久久久国产综合精品女国产盗摄| 精品成人在线观看| 国产福利一区二区三区视频| 中文字幕综合网| 夜夜嗨av一区二区三区| ...av二区三区久久精品| 国产精品白丝在线| 日韩毛片在线免费观看| 国产一区二区三区蝌蚪| 日韩一区二区三区三四区视频在线观看 | 亚洲欧洲日韩女同| 国产98色在线|日韩| 欧美色综合网站| 色哟哟在线观看一区二区三区| 欧美另类变人与禽xxxxx| 中文一区二区在线观看| 日韩激情视频网站| 成人毛片视频在线观看| 日韩欧美一级二级三级久久久| 中文一区一区三区高中清不卡| 另类专区欧美蜜桃臀第一页| 色天天综合久久久久综合片| 国产精品久久久久久久久免费樱桃| 丝袜亚洲另类欧美综合| 91麻豆精品在线观看| 欧美国产一区视频在线观看| 狠狠久久亚洲欧美| 欧美一区三区二区| 美女性感视频久久| 久久久精品国产99久久精品芒果 | 亚洲在线免费播放| 亚洲品质自拍视频| 日韩va欧美va亚洲va久久| 欧美三级日韩三级国产三级| 久久人人97超碰com| 日韩电影免费一区|