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

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

?? df_positioning.cpp

?? 2002年
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "df_positioning.h"
#include "worldmodel.h"
#include "log.h"
#include "agent.h"

/***********	DF_Arrangement	***********************/
DF_Arrangement::DF_Arrangement(UNum defender, UNum defendee){
	df_size =  Vector(ClientParam::defense_area_length, ClientParam::defense_area_width);
	valid = Arrange_DF_for(defender, defendee);
}


bool DF_Arrangement::getpressposition(UNum My,UNum Opp,Vector &presspos){  //ciwp-0715
	if (FieldInfo.IsBlocked(defendee))
		{
			presspos = situation.NextControlBallPos();
			return true;
		}

		Ray theircourse;
		Vector l_mark,r_mark;
		Vector sectionpost,theirtarget;
		Vector MyPos = MyPlayer(My).pos;
		Vector Opos  = TheirPlayer(Opp).pos;
		PitchInfo.mygoal = Vector(-ServerParam::semi_pitch_length,0.0f);
		Line splitline;
		Line me_Opp;
		me_Opp.LineFromTwoPoints(MyPos,Opos);
		Vector goalpnt = me_Opp.intersection(PitchInfo.SideLines[SL_Left]);
		if (fabs(goalpnt.y) > ServerParam::goal_width/2 * 1.05f)
		{
			l_mark = PitchInfo.l_mygoalpost;
			r_mark = PitchInfo.r_mygoalpost;
		}
		else
		{
			if (goalpnt.y < 0)
			{
				l_mark = PitchInfo.mygoal;
				r_mark = PitchInfo.r_mygoalpost;
			}
			else
			{
				l_mark = PitchInfo.l_mygoalpost;
				r_mark = PitchInfo.mygoal;
			}
		}
		splitline.LineFromTwoPoints((MyPos + Opos)/2,(l_mark + r_mark) /2);
			if (splitline.HalfPlaneTest(Opos) == splitline.HalfPlaneTest(l_mark))
			{
				sectionpost = l_mark;
				theirtarget = r_mark;
			}
			else 
			{
				sectionpost = r_mark;
				theirtarget = l_mark;
			}
		
		Vector midpost = (r_mark + l_mark)/2;
	
		theircourse.SetValues(Opos,(theirtarget - Opos).Angle());
		Line mycourse;
		sectionpost = (sectionpost + Opos) /2; 
		mycourse.LineFromTwoPoints(MyPos,sectionpost);
		if  (!(theircourse.intersection(mycourse,presspos) && 
			PitchInfo.WithInField(presspos)))
		{
			DoLog(LOG_BUG,"no press point 1");
			return false;
		}
		if (presspos.dist(MyPos) *1.1 < presspos.dist(Opos)// && AngleDif((presspos - MyPos).Angle(),(presspos - Opos).Angle()) > 60
			&& presspos.dist(Opos) > 2.5f)
		{
			Opos += Polar2Vector(TheirPlayer(Opp).max_speed * 2,(PitchInfo.mygoal - Opos).Angle());

			splitline.LineFrompline(MyPos,Opos);
			Vector savpresspos = presspos;
			if (!theircourse.intersection(splitline,presspos))
			{
				presspos = savpresspos;
			}
		}
		//consideration of bodyfacing
		if (My == Agent::MyNumber) 
		{
			Line bottomsect;
			Vector bottompoint;
			bottomsect.LineFromTwoPoints(Self.pos,midpost);
			if (!theircourse.intersection(bottomsect,bottompoint))
			{
				DoLog(LOG_BUG,"FT! why no section?");
				return false;
			}
			
			Ray SelfRay(Self.pos,Self.bodyfacing);
			Vector secpoint;
			float secdist;
			float pressdist = theircourse.DistanceFromOrigin(theirtarget);
			if (theircourse.intersection(SelfRay,secpoint))
			{
				secdist = secpoint.dist(presspos);
				if (secdist < 1.5f || Line(theircourse).InBetween(secpoint,Opos,bottompoint))//ciwp-0715
					presspos = secpoint;
			}
		}
		return true;
}

bool DF_Arrangement::getblockposition(UNum My, UNum Opp, Vector &blockpos){ //ciwp
	if (!Player::IsTheirPlayer(Opp) || !Player::IsMyPlayer(My)) return false;
	float cycles = 0.0f;
	Vector opppos;
	if (situation.BallFree){
		opppos = TheirPlayer(Opp).IT_inf.IT_point;
		cycles = TheirPlayer(Opp).IT_inf.IT_cycles;
	}
	else{
		opppos = TheirPlayer(Opp).pos;
		cycles = 0.0f;
	}
	float my_block_speed = ServerParam::player_speed_max;
	//generally their attacking speeds are slower because of dribbling
	float their_break_speed = ServerParam::player_speed_max * 0.8f;
 	/*if (!getblockpoint(opppos, MyPlayer(My).pos, cycles, my_block_speed, their_break_speed, blockpos))
		return false; by Criver*/

	/*if (!PitchInfo.WithInField(blockpos)) return false; by Criver*/
	
	getblockpoint(opppos, MyPlayer(My).pos, cycles, my_block_speed, their_break_speed, blockpos);
	
	/* Allow larger error of bodyfacing generally the error of 8-15
	   is allowed, here we allow a maximum error of 25            */
	   
	if (My == Agent::MyNumber){
		float targetbdfc = (blockpos - Self.pos).Angle();
		if (fabs(NormalizeAngle(targetbdfc-Self.bodyfacing)) < 25.0f){
			Ray SelfRay(Self.pos, Self.bodyfacing);
			float dist = Self.pos.dist(blockpos) + 2.0f;
			blockpos = SelfRay.GetPoint(dist);
			//trick patch by yjy
		}
	}
	
	/*if (My == Agent::MyNumber)
	{
		Ray blockRay(opppos,blockpos);
		Ray SelfRay(Self.pos,Self.bodyfacing);
		Vector secpoint;
		if (blockRay.intersection(SelfRay,secpoint))
		{
			if (blockRay.DistanceFromOrigin(secpoint) > blockRay.DistanceFromOrigin(blockpos)
				&& secpoint.dist(blockpos) < 0.1f * opppos.dist(PitchInfo.mygoal) && secpoint.dist(blockpos) < Self.pos.dist(blockpos))
			{
				DoLog(LOG_POSITIONING,"Adjust Block (%.1f %.1f) ->(%.1f,%.1f)",blockpos.x,blockpos.y,secpoint.x,secpoint.y);
				blockpos = secpoint;
			}
		}
	} by Criver*/
	return true;
}

bool DF_Arrangement::getblockpoint(Vector opp_IT_pos, Vector selfpos, float opp_IT_cycles, float myspeed, float oppspeed, Vector& blockpos){
	float predis = Max(myspeed * opp_IT_cycles,ClientParam::block_margin);//ciwp-0715

	float disleft = opp_IT_pos.dist(PitchInfo.l_mygoalpost);
	float ratio = disleft/(disleft + opp_IT_pos.dist(PitchInfo.r_mygoalpost));
	Vector opttarget = Vector(-ServerParam::pitch_length/2, ServerParam::goal_width * (ratio - 0.5f));
	Vector opponent_pos = (opttarget - opp_IT_pos);
	opponent_pos.Normalize();
	opponent_pos = opp_IT_pos + opponent_pos * ClientParam::block_margin;
	

	Vector vec_me_opt = selfpos - opponent_pos ;
	float dis_me_opt = vec_me_opt.mod();

	if(dis_me_opt <= predis || oppspeed < 1e-2){
		blockpos = opponent_pos;
		return true;
	}
	
	float ratio_speed = myspeed / oppspeed;
	
	AngleDeg goalstrechangle = AngleDif((PitchInfo.l_mygoalpost - opponent_pos).Angle(),(PitchInfo.r_mygoalpost - opponent_pos).Angle());//ciwp
	if(AngleDif(vec_me_opt.Angle(),(opttarget-opponent_pos).Angle())<goalstrechangle/4
		&& AngleDif(vec_me_opt.Angle(),(opttarget-opponent_pos).Angle()) < 10)
		return getsubpoint(opttarget,opponent_pos,selfpos,ratio_speed,predis,blockpos);

	return getsubpoint(opttarget,opponent_pos,selfpos,ratio_speed,predis,blockpos);
}

bool DF_Arrangement::getsubpoint(Vector opttarget, Vector opponent_pos, Vector selfpos, float ratio_speed,float predis, Vector& blockpos){
	Vector vec_me_opt = selfpos - opponent_pos ;
	float dis_me_opt = vec_me_opt.mod();

	float interangle = vec_me_opt.Angle()-(opttarget-opponent_pos).Angle();
	float tempf,tempc;
	float tempa = 1.0f - ratio_speed * ratio_speed;
	if(fabs(tempa)<1e-2){
		tempf = predis + dis_me_opt * Cos(interangle);

		if(tempf <= 1e-2){//ciwp-0715 --undo
			blockpos = (opponent_pos + opttarget)/2;
			return false;
		}

		tempc = 0.5f*(dis_me_opt * dis_me_opt - predis*predis) / tempf;
	}
	else{
		tempf = 2*predis*ratio_speed + 2*dis_me_opt * Cos(interangle);
		float tempz = tempf * tempf - 4 * tempa*(dis_me_opt*dis_me_opt-predis*predis);
		if(tempz < 0){
			blockpos = (opponent_pos+opttarget)/2;
			return false;
		}
		tempz = (float)sqrt(tempz);
		float tempx1 = 0.5f * (-tempz + tempf)/tempa;
		float tempx2 = 0.5f * (tempz + tempf)/tempa;
		if(tempx1 < 0 && tempx2 < 0){
			blockpos = (opponent_pos + opttarget)/2;
			return false;
		}
		else if(tempx1 > 0 && tempx2 > 0) tempc = Min(tempx1, tempx2);
		else tempc = Max(tempx1,tempx2);	
	}
	float odist = opponent_pos.dist(opttarget);

	if(tempc >= odist + 1e-2){
		 blockpos = (opponent_pos + opttarget)/2;
		 return false;
	}
	
	float ratio = tempc / odist;

	blockpos = (opponent_pos * (1-ratio) + opttarget * ratio);
	
	return true;
}

bool DF_Arrangement::getmarkposition(UNum My, UNum Opp, Vector ballpos, Vector& markpos){ //ciwp
//here global numbering scheme is assumed
	if (!Player::IsTheirPlayer(Opp) || !Player::IsMyPlayer(My)) return false;
	Vector dir1, dir2;
	Vector OppPos = TheirPlayer(Opp).pos;
	Vector target = ballpos.y>0 ? PitchInfo.r_mygoalpost : PitchInfo.l_mygoalpost;
	float dispersion =TheirPlayer(Opp).ActiveRadius(situation.CurrentTime) + TheirPlayer(Opp).max_speed;
	if (AngleDif((target - OppPos).Angle(),(target - Self.pos).Angle()) > 90)
		dispersion += 1.0f;
	pose_limitation(dispersion,0.0f,5.0f);

	float tmp_ = 2*(FieldInfo.GetDefensiveSensitivity(OppPos) -0.5f);
	float sensfactor;
	if(tmp_ < 0.05f)
		sensfactor = 0.2f;
	else if(tmp_ < 0.7f)
		sensfactor = 0.2f + 0.3f*(tmp_ - 0.05f)/0.65f;
	else if (tmp_< 0.9f)
		sensfactor = 0.5f + 1.0f*(tmp_-0.7f);
	else
		sensfactor = 0.7f + 1.0f*(tmp_-0.9f);

	pose_limitation(sensfactor,0,1);
	Vector predopos1 = OppPos + Polar2Vector(dispersion* (1 - sensfactor),(target - OppPos).Angle());	
	Vector predopos2 = OppPos.y > Self.pos.y ? Polar2Vector((float)sqrt(dispersion),90) : Polar2Vector((float)sqrt(dispersion),-90);
	predopos2 += OppPos;
	Line balltrace1,balltrace2;
	balltrace1.LineFromTwoPoints(situation.NextControlBallPos(),predopos1);
	balltrace2.LineFromTwoPoints(situation.NextControlBallPos(),predopos2);
	float odist1 = balltrace1.dist(Self.pos) - 1.0f;
	float odist2 = balltrace2.dist(Self.pos) - 1.0f;
	if (odist1 <=0.1f) odist1 = 0.1f;
	if (odist2 <=0.1f) odist2 = 0.1f;
	if (!balltrace2.InBetween(Self.pos,OppPos,situation.NextControlBallPos()))
		odist2 = 0;
	predopos1 -= OppPos;
	predopos2 -= OppPos;
	OppPos += (predopos1 * odist1 + predopos2 * odist2) / (odist1 + odist2);
	
	//OppPos = predopos1;
	dir1 = ballpos - OppPos;
	dir1.Normalize();
	dir2 = PitchInfo.mygoal - OppPos;
	dir2.Normalize();
	dir1 *= sensfactor;
	dir2 *= 1 - sensfactor;
	//markdist = Min(MyPlayer(My).pos.dist(TheirPlayer(Opp).pos), ClientParam::mark_dist);
	float	markdist = ClientParam::mark_dist;
	if(MyPlayer(My).IsRoleKnown()){
	//if a player's aggressiveness is high, he may act more aggressively when marking the opponent.
	//for instance, he will stand just in front of the opponent
		if (MyPlayer(My).aggressiveness >= 0.7f){
			markpos = dir1;
		}
		else{
			markpos = dir1 * 0.5f + dir2 * 0.5f;
		}
	}
	else{
		markpos = dir1;
	}

	markpos.Normalize();
	markpos *= markdist;
	if (My == Agent::MyNumber)
	{
		//consider body facing
		Ray markRay(OppPos,markpos);
		Ray SelfRay(Self.pos,Self.bodyfacing);
		Vector secpoint;
		float secdist;
		float balldist = ballpos.dist(OppPos);
		if (markRay.intersection(SelfRay,secpoint))
		{
			secpoint -=OppPos;
			secdist = secpoint.dist(markpos);
			if (secdist < 0.5f || secdist < 0.2f * Self.pos.dist(OppPos))
				markpos = secpoint;
		}
	}
	markpos += OppPos;
	return true;
}

void DF_Arrangement::setpriority(){ 
	switch(df_type){
	case DF_Block:
		  priority = blockpriority = getblockpriority();
		  break;
	case DF_Formation:
		  priority = formationpriority = getformationpriority();
		  break;
	case DF_Mark:
		  priority = markpriority = getmarkpriority();
		  break;
	case DF_Press:
		if (FieldInfo.IsBlocked(defendee))
			presspriority = getblockpriority();
		else
			presspriority = getpresspriority();
			blockpriority = getblockpriority();
		priority = blockpriority;
		break;
	default:
		break;
	}
}

float DF_Arrangement::QueryPriority(bool block_applied){ 
	if (df_type == DF_Press && block_applied)
	{
		return presspriority;
	}
	else
		return priority;
}
float DF_Arrangement::getformationpriority(){
	double input,output;
	pos_dist = df_point.dist(MyPlayer(defender).pos);
	deviation_dist = df_point.dist(fm_pos);
	input = FieldInfo.GetDefensiveSensitivity(fm_pos);
	Agent::positioning.FM_Priority_Net.SimulateNet(&input,&output);
	return (float)output;
}
float DF_Arrangement::getblockpriority(){
/*
	double input[3], output;
	pos_dist = TheirPlayer(defendee).pos.dist(MyPlayer(defender).pos);
	deviation_dist = Min(TheirPlayer(defendee).pos.dist(fm_pos), df_point.dist(fm_pos));
	// enhance the block priority by Criver
	deviation_dist /= 1.3f;
	pos_dist /= 1.3f;
	input[0] = threat;
	input[1] = deviation_dist / ClientParam::deviation_max;
	input[2] = pos_dist / ClientParam::deviation_max;
	Agent::motion.Block_Net.SimulateNet(&input[0], &output);
	output = (output - 0.1) * 1.25;
	if	(MyPlayer(defender).IsForward())
			output =0.5 + (output + TheirPlayer(defendee).GetOffsensitivity())/4;
	return (float)output;
}//*/
	double input[3], output;
	pos_dist = TheirPlayer(defendee).pos.dist(MyPlayer(defender).pos);
	deviation_dist = Min(TheirPlayer(defendee).pos.dist(fm_pos), df_point.dist(fm_pos));
	/* enhance the block priority by Criver*/
	deviation_dist /= 1.2f;
	pos_dist /= 1.2f;

	/*remedy for back block, give it punishment*/
	Vector pos_diff = TheirPlayer(defendee).pos - MyPlayer(defender).pos;
	if (pos_diff.x < 0){
		float factor = 100.0f;
		if (fabs(TheirPlayer(defendee).pos.y) < 5.5f){
			factor = 1.3f + 0.3f * float(fabs(TheirPlayer(defendee).pos.y)) / 5.5f;
		}else{
			factor = 1.6f + 8.4f * float(fabs(TheirPlayer(defendee).pos.y)) / 20.f;
		}
		pos_dist += float(fabs(pos_diff.x / factor));
	}
	/* END OF REMEDY */

	input[0] = threat;
	input[1] = deviation_dist / ClientParam::deviation_max;
	input[2] = pos_dist / ClientParam::deviation_max;
	Agent::positioning.Block_Net.SimulateNet(&input[0], &output);
	output = (output - 0.1) * 1.25;
	if	(MyPlayer(defender).IsForward())
			output =0.5 + (output + TheirPlayer(defendee).GetOffsensitivity())/4;
	return (float)output;
}

float DF_Arrangement::getpresspriority(){
	double input[3], output;
	input[0] = threat;
	pos_dist = TheirPlayer(defendee).pos.dist(MyPlayer(defender).pos);
	deviation_dist = Min(TheirPlayer(defendee).pos.dist(fm_pos),df_point.dist(fm_pos));
	input[1] = deviation_dist / ClientParam::deviation_max;
	input[2] = pos_dist / ClientParam::deviation_max;
	Agent::positioning.Press_Net.SimulateNet(&input[0], &output);
	output = (output - 0.1) * 1.25;
	if	(MyPlayer(defender).IsForward())
			output =0.5 + (output + TheirPlayer(defendee).GetOffsensitivity() )/4;
	return (float)output;


}

float DF_Arrangement::getmarkpriority(){
	double input[3], output;
	input[0] = threat;
	pos_dist = df_point.dist(MyPlayer(defender).pos);
	deviation_dist = df_point.dist(fm_pos);
	input[1] = deviation_dist / ClientParam::deviation_max;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久久久久久久久久久久久久| 欧美精品一区二区三| 欧美一卡二卡三卡四卡| 日本一区二区三区在线观看| 五月天丁香久久| 国产成人精品免费视频网站| 337p亚洲精品色噜噜狠狠| 国产欧美一区二区精品久导航| 天天操天天干天天综合网| 91麻豆精品在线观看| 久久久久国产精品麻豆| 毛片av一区二区三区| 91麻豆国产精品久久| 欧美激情一区二区三区在线| 久久国产精品色| 欧美精品乱码久久久久久| 国产精品成人一区二区三区夜夜夜| 日本怡春院一区二区| 欧美在线观看一区二区| 中文字幕一区日韩精品欧美| 国产电影一区二区三区| 亚洲精品一线二线三线| 免费的成人av| 精品国产不卡一区二区三区| 免费在线观看成人| 日韩午夜电影在线观看| 天堂在线一区二区| 欧美体内she精高潮| 亚洲精品美国一| 日本高清免费不卡视频| 亚洲欧美日韩国产综合在线| 一本大道久久a久久精二百| 国产精品动漫网站| 国产风韵犹存在线视精品| 国产亚洲人成网站| 国产成人av电影免费在线观看| 久久色视频免费观看| 精品一区二区三区影院在线午夜| 日韩欧美精品三级| 国产一区福利在线| 欧美激情一区二区三区在线| 成人av在线网| 亚洲视频1区2区| 色八戒一区二区三区| 亚洲综合激情另类小说区| 欧美另类一区二区三区| 久久精品999| 中文字幕高清不卡| 99久久精品99国产精品| 一区二区三区不卡在线观看| 欧美日韩免费观看一区三区| 6080午夜不卡| 最新国产成人在线观看| 2023国产精品自拍| 久久免费视频一区| 不卡一区在线观看| 亚洲黄色小视频| 欧美一级日韩免费不卡| 国产福利精品导航| 亚洲日本va午夜在线影院| 在线免费av一区| 麻豆久久久久久久| 国产精品白丝在线| 在线成人av影院| 久草中文综合在线| 欧美日韩高清一区| 波多野结衣在线aⅴ中文字幕不卡| 日韩精品一区二区三区三区免费| 国产女主播视频一区二区| 日韩精品中文字幕在线一区| 欧美一区二区三区成人| 欧美日韩精品福利| 欧美日本韩国一区| 欧美一级生活片| 欧美大片一区二区三区| 日韩精品一区二区三区swag | 亚洲成av人片一区二区| 一区二区三区在线视频免费观看| 亚洲男同性视频| 亚洲制服丝袜av| 午夜精品在线看| 日韩高清不卡一区二区| 蜜桃一区二区三区四区| 久久99热国产| 国产1区2区3区精品美女| 成人激情小说乱人伦| bt欧美亚洲午夜电影天堂| av一区二区不卡| 欧美三级电影网| 欧美日韩国产高清一区二区三区 | 国产农村妇女毛片精品久久麻豆| 久久久精品黄色| 国产精品久久看| 亚洲综合免费观看高清完整版在线 | 亚洲色图欧洲色图婷婷| 亚洲一区二区三区在线| 青椒成人免费视频| 国产精品一区二区在线看| 成人短视频下载| 在线观看91视频| 日韩欧美综合一区| 国产精品日产欧美久久久久| 亚洲一区二区三区四区在线观看| 亚洲成人av资源| 国产综合色视频| 91色视频在线| 欧美大尺度电影在线| 久久精品一级爱片| 亚洲黄色在线视频| 久久99国产精品久久| 99久久99久久免费精品蜜臀| 欧美日韩国产一级二级| 国产视频在线观看一区二区三区| 亚洲人被黑人高潮完整版| 日本不卡视频在线| 91免费看视频| 精品国产一区二区三区久久影院| 国产精品狼人久久影院观看方式| 五月天丁香久久| www.综合网.com| 欧美成人午夜电影| 亚洲精品高清视频在线观看| 久久国产麻豆精品| 欧美性大战久久| 欧美激情一区二区三区不卡| 日韩中文字幕亚洲一区二区va在线| 国产成人免费在线观看不卡| 欧美日韩午夜精品| 国产精品美女www爽爽爽| 免费av网站大全久久| 色呦呦国产精品| 欧美激情一区二区三区全黄| 奇米在线7777在线精品| 91免费看视频| 国产女主播视频一区二区| 日本欧美大码aⅴ在线播放| 一本久久a久久免费精品不卡| 欧美mv日韩mv| 日本在线播放一区二区三区| 99亚偷拍自图区亚洲| 久久综合久久久久88| 奇米一区二区三区| 欧美综合色免费| 亚洲免费观看高清完整版在线观看熊 | 国产精品超碰97尤物18| 国产在线精品不卡| 日韩手机在线导航| 亚洲18影院在线观看| 色婷婷久久久亚洲一区二区三区| 欧美国产一区视频在线观看| 国产又粗又猛又爽又黄91精品| 91精品婷婷国产综合久久| 一区二区三区在线高清| 91丝袜呻吟高潮美腿白嫩在线观看| 国产人成亚洲第一网站在线播放| 久久国产福利国产秒拍| 欧美一级日韩免费不卡| 丝袜亚洲另类丝袜在线| 欧美日韩一二三| 亚洲韩国一区二区三区| 日本大香伊一区二区三区| 亚洲精品国产高清久久伦理二区| 91美女片黄在线观看91美女| 亚洲欧美自拍偷拍| 91小视频在线| 亚洲精品成人a在线观看| 色8久久精品久久久久久蜜 | 亚洲国产色一区| 91九色最新地址| 香蕉乱码成人久久天堂爱免费| 欧美三区免费完整视频在线观看| 一区二区三区蜜桃| 欧美精品在线一区二区三区| 午夜电影久久久| 欧美一级黄色大片| 国内精品视频666| 国产拍欧美日韩视频二区| 9人人澡人人爽人人精品| 亚洲欧洲另类国产综合| 欧美性生活久久| 日本欧美一区二区| 久久久久国产一区二区三区四区| 成人黄色在线看| 亚洲国产精品嫩草影院| 日韩精品一区二区在线| 韩国三级在线一区| 最新成人av在线| 欧美日韩视频一区二区| 久久精品国产亚洲一区二区三区| 26uuu亚洲综合色欧美| 国产成人精品亚洲777人妖| 亚洲免费观看高清完整版在线| 欧美日韩国产不卡| 国产精品自拍网站| 亚洲精品videosex极品| 在线91免费看| 国产aⅴ综合色| 亚洲高清中文字幕| 国产午夜一区二区三区| 日本精品一级二级|