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

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

?? face.cpp

?? 3D游戲場景編輯器
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
	f->Tex.DirtyFlag = GE_TRUE;
}

void	Face_Shear(Face *f, const geVec3d *ShearVec, const geVec3d *ShearAxis)
{
	int		i;

	assert(f);
	assert(ShearVec);
	assert(ShearAxis);

	for(i=0;i < f->NumPoints;i++)
	{
		geFloat	dot;

		dot	=geVec3d_DotProduct(&f->Points[i], ShearVec);
		geVec3d_MA(&f->Points[i], dot, ShearAxis, &f->Points[i]);
	}
	{
		geVec3d OldNormal = f->Tex.VecNormal;
		Face_SetPlaneFromFace(f);
		Face_UpdateFaceAngle (f, &OldNormal);
	}
	f->Tex.DirtyFlag = GE_TRUE;
}

void	Face_GetBounds(const Face *f, Box3d *b)
{
	int i;

	assert(f != NULL);
	assert(b != NULL);

	Box3d_SetBogusBounds(b);
	for(i=0;i < f->NumPoints;i++)
	{
		Box3d_AddPoint(b, f->Points[i].X, f->Points[i].Y, f->Points[i].Z);
	}
}

void	Face_GetCenter(const Face *f, geVec3d *pCenter)
{
	Box3d Box;

	assert(f != NULL);
	assert(pCenter != NULL);

	Face_GetBounds(f, &Box);
	Box3d_GetCenter(&Box, pCenter);
}

void	Face_WriteToMap(const Face *f, FILE *wf)
{
	char	szTemp[_MAX_PATH];
	
	assert(f);
	assert(wf);

	{
		int OutputFlags;

		OutputFlags = 0;
		if (f->Flags & FACE_MIRROR)		OutputFlags	|= ffMirror;
		if (f->Flags & FACE_FULLBRIGHT) OutputFlags	|= ffFullBright;
		if (f->Flags & FACE_SKY)		OutputFlags	|= ffSky;
		if (f->Flags & FACE_LIGHT)		OutputFlags	|= ffLight;
		if (f->Flags & FACE_GOURAUD)	OutputFlags	|= ffGouraud;
		if (f->Flags & FACE_FLAT)		OutputFlags	|= ffFlat;
		if (f->Flags & FACE_TRANSPARENT) OutputFlags |= ffTranslucent;
		TypeIO_WriteInt(wf, OutputFlags);
	}

	TypeIO_WriteFloat (wf, f->MipMapBias);
	TypeIO_WriteFloat (wf, f->Translucency);
	TypeIO_WriteFloat (wf, (geFloat)f->LightIntensity);	//engine expects float
	TypeIO_WriteFloat (wf, f->Reflectivity);

	strcpy(szTemp, Face_GetTextureName (f));
	TypeIO_WriteBlock(wf, szTemp, 32);
	{
		#pragma message ("New texture vector output!")
		const TexInfo_Vectors *TVecs = Face_GetTextureVecs (f);
		geVec3d uVec, vVec;
		const geFloat xScale = f->Tex.xScale/f->LightXScale;
		const geFloat yScale = f->Tex.yScale/f->LightYScale;

		/*
		  The texture vectors returned have the entire scale value
		  included.  We need to back out the scale and use the
		  LightScale instead.  The Scale values that we send to
		  the tools will be Scale/LightScale.
		*/
		// Back out original scale and scale by LightScale
		geVec3d_Scale (&TVecs->uVec, xScale, &uVec);
		geVec3d_Scale (&TVecs->vVec, yScale, &vVec);

		// u vector, scale, offset
		TypeIO_WriteVec3d (wf, &uVec);
		TypeIO_WriteFloat (wf, xScale);
		TypeIO_WriteFloat (wf, TVecs->uOffset);

		// v vector, scale, offset
		TypeIO_WriteVec3d (wf, &vVec);
		TypeIO_WriteFloat (wf, yScale);
		TypeIO_WriteFloat (wf, TVecs->vOffset);
	}

	TypeIO_WriteBlock (wf, &f->Face_Plane, sizeof (Plane));
}

void	Face_WriteToQuakeMap(const Face *f, FILE *wf)
{
	int		xShift, yShift;
	geFloat	xScale, yScale, Rotate;
	
	assert(f);
	assert(wf);

	fprintf(wf, "( %f %f %f ) ",
		(f->Points[0].X),
		-(f->Points[0].Z),
		(f->Points[0].Y));
	fprintf(wf, "( %f %f %f ) ",
		(f->Points[1].X),
		-(f->Points[1].Z),
		(f->Points[1].Y));
	fprintf(wf, "( %f %f %f ) ",
		(f->Points[2].X),
		-(f->Points[2].Z),
		(f->Points[2].Y));

	Face_GetTextureShift (f, &xShift, &yShift);
	Face_GetTextureScale (f, &xScale, &yScale);
	Rotate	= Face_GetTextureRotate (f);

	fprintf(wf, Face_GetTextureName (f));
	fprintf(wf, " %d %d %d %f %f\n", Rotate, xShift, yShift, xScale, yScale);
}

geBoolean Face_Write(const Face *f, FILE *wf)
{
	int		i, xShift, yShift, Rotate;
	geFloat xScale, yScale, rot;

	assert(f);
	assert(wf);

	if (fprintf(wf, "\t\tNumPoints %d\n", f->NumPoints) < 0) return GE_FALSE;
	if (fprintf(wf, "\t\tFlags %d\n", f->Flags) < 0) return GE_FALSE;
	if (fprintf(wf, "\t\tLight %d\n", f->LightIntensity) < 0) return GE_FALSE;
	if (fprintf(wf, "\t\tMipMapBias %f\n", f->MipMapBias) < 0) return GE_FALSE;
	if (fprintf(wf, "\t\tTranslucency %f\n", f->Translucency) < 0) return GE_FALSE;
	if (fprintf(wf, "\t\tReflectivity %f\n", f->Reflectivity) < 0) return GE_FALSE;

	for(i=0;i < f->NumPoints;i++)
	{
		if (fprintf(wf, "\t\t\tVec3d %f %f %f\n", f->Points[i].X, f->Points[i].Y, f->Points[i].Z) < 0) return GE_FALSE;
	}

	Face_GetTextureShift (f, &xShift, &yShift);
	Face_GetTextureScale (f, &xScale, &yScale);
	rot		=Face_GetTextureRotate (f);
	Rotate	=Units_Round(rot);

	{
		char QuotedValue[SCANNER_MAXDATA];

		// Quote the texture name
		Util_QuoteString (Face_GetTextureName (f), QuotedValue);
		if (fprintf(wf, "\t\t\tTexInfo Rotate %d Shift %d %d Scale %f %f Name %s\n",
			Rotate, xShift, yShift, xScale, yScale, QuotedValue) < 0) return GE_FALSE;
	}

	if (fprintf(wf, "\t\tLightScale %f %f\n", f->LightXScale, f->LightYScale) < 0) return GE_FALSE;

	if (fprintf (wf, "%s", "\tTransform\t") < 0) return GE_FALSE;	
	if (!TypeIO_WriteXForm3dText (wf, &(f->Tex.XfmFaceAngle))) return GE_FALSE;

	if (fprintf (wf, "%s", "\tPos\t") < 0) return GE_FALSE;	
	if( !TypeIO_WriteVec3dText(wf, &f->Tex.Pos )) return GE_FALSE;

	return GE_TRUE;
}

Face	*Face_CreateFromFile
	(
	  Parse3dt *Parser, 
	  int VersionMajor, 
	  int VersionMinor, 
	  const char **Expected
	)
{
	Face	*f = NULL;
	int		i, flg, NumPnts, xShift, yShift, tempint, Light;
	geFloat MipMapBias, Reflectivity, Translucency;
	geFloat	fVal, xScale, yScale;
	geVec3d	*tmpPnts = NULL;
	geBoolean LoadResult;
	char	szTemp[_MAX_PATH];

	assert(Parser != NULL);

	LoadResult = GE_FALSE;
	if (!Parse3dt_GetInt (Parser, (*Expected = "NumPoints"), &NumPnts)) goto DoneLoad;

	// read face flags and value...
	if((VersionMajor == 1) && (VersionMinor < 8))
	{
		fVal=0.0f;
		flg	=0;
	}
	else
	{
		if (!Parse3dt_GetInt (Parser, (*Expected = "Flags"), &flg)) goto DoneLoad;
		if ((VersionMajor == 1) && (VersionMinor < 25))
		{
			if (!Parse3dt_GetFloat (Parser, (*Expected = "FaceValue"), &fVal)) goto DoneLoad;
			// FaceValue is ignored
			fVal	=0.0f;
		}
	}
	//xlate old flags
	if ((VersionMajor == 1) && (VersionMinor < 13))
	{
		int	flg2	=0;
		if(flg	&	oldLIGHT)		flg2	|=	FACE_LIGHT;
		if(flg	&	oldMIRROR)		flg2	|=	FACE_MIRROR;
		if(flg	&	oldFULLBRIGHT)	flg2	|=	FACE_FULLBRIGHT;
		if(flg	&	oldSKY)			flg2	|=	FACE_SKY;
		flg	=flg2;
	}

	// clear previously unused flag values
	if ((VersionMajor == 1) && (VersionMinor <= 10))
	{
		flg  &= ~(FACE_MIRROR | FACE_FULLBRIGHT | FACE_SKY);
	}
	if ((VersionMajor == 1) && (VersionMinor < 25))
	{
		// clear previously unused shading values
		flg &= ~(FACE_GOURAUD | FACE_FLAT);
	}
	if ((VersionMajor == 1) && (VersionMinor < 30))
	{
		flg &= ~FACE_TRANSPARENT;
	}

	// don't allow selected faces on load
	flg &= ~FACE_SELECTED;

	if ((VersionMajor > 1) || ((VersionMajor == 1) && (VersionMinor >= 13)))
	{
		if (!Parse3dt_GetInt (Parser, (*Expected = "Light"), &Light)) goto DoneLoad;
	}
	else
	{
		Light = FACE_DEFAULT_LIGHT;
	}

	if ((VersionMajor > 1) || ((VersionMajor == 1) && (VersionMinor >= 25)))
	{
		if (!Parse3dt_GetFloat (Parser, (*Expected = "MipMapBias"), &MipMapBias)) goto DoneLoad;
	}
	else
	{
		MipMapBias = FACE_DEFAULT_BIAS;
	}
	if ((VersionMajor > 1) || ((VersionMajor == 1) && (VersionMinor >= 27)))
	{
		if (!Parse3dt_GetFloat (Parser, (*Expected = "Translucency"), &Translucency)) goto DoneLoad;
		if (!Parse3dt_GetFloat (Parser, (*Expected = "Reflectivity"), &Reflectivity)) goto DoneLoad;
	}
	else
	{
		Translucency = FACE_DEFAULT_TRANSLUCENCY;
		Reflectivity = FACE_DEFAULT_REFLECTIVITY;
	}

	tmpPnts	= (geVec3d*)geRam_Allocate(sizeof(geVec3d) * NumPnts);
	if(tmpPnts)
	{
		geFloat	LightXScale = 1.0f;
		geFloat LightYScale = 1.0f;
		if((VersionMajor == 1) && (VersionMinor < 4))
		{
			/*
			  From version 1.3 to 1.4 we changed back to a right-handed coordinate system.
			  So, to load a 1.3 or earlier file, we need to reverse the windings
			  and flip the Z on every point.
			*/
			for(i=NumPnts-1;i >= 0;i--)
			{
				if (!Parse3dt_GetVec3d (Parser, (*Expected = "Vec3d"), &tmpPnts[i])) goto DoneLoad;

				//flip z
				tmpPnts[i].Z	=-tmpPnts[i].Z;
			}
		}
		else
		{
			for(i=0;i < NumPnts;i++)
			{
				if (!Parse3dt_GetVec3d (Parser, (*Expected = "Vec3d"), &tmpPnts[i])) goto DoneLoad;
			}
		}
		f	=Face_Create(NumPnts, tmpPnts, 0);
		geRam_Free (tmpPnts);
		tmpPnts = NULL;

		if(f)
		{
			f->Flags	=flg;
			f->LightIntensity = Light;
			f->MipMapBias = MipMapBias;
			f->Reflectivity = Reflectivity;
			f->Translucency = Translucency;
		}
		if (!Parse3dt_ScanExpectingText (Parser, (*Expected = "TexInfo"))) goto DoneLoad;
		if (!Parse3dt_GetInt (Parser, (*Expected = "Rotate"), &tempint)) goto DoneLoad;
		if (!Parse3dt_GetInt (Parser, (*Expected = "Shift"), &xShift)) goto DoneLoad;
		if (!Parse3dt_GetInt (Parser, NULL, &yShift)) goto DoneLoad;
		if (!Parse3dt_GetFloat (Parser, (*Expected = "Scale"), &xScale)) goto DoneLoad;
		if (!Parse3dt_GetFloat (Parser, NULL, &yScale)) goto DoneLoad;
		if((VersionMajor > 1) || ((VersionMajor == 1) && (VersionMinor >= 24)))
		{
			// Version 1.24 and later we quote the texture names
			if (!Parse3dt_GetLiteral (Parser, (*Expected = "Name"), szTemp)) goto DoneLoad;
		}
		else
		{	
			if (!Parse3dt_GetIdentifier (Parser, (*Expected = "Name"), szTemp)) goto DoneLoad;
		}

		if (!((VersionMajor == 1) && (VersionMinor <= 16)))
		{
			if (!Parse3dt_GetFloat (Parser, (*Expected = "LightScale"), &LightXScale)) goto DoneLoad;
			if (!Parse3dt_GetFloat (Parser, NULL, &LightYScale)) goto DoneLoad;
		}
		if(f)
		{
			Face_InitTexInfo(&f->Tex, &f->Face_Plane.Normal);

			Face_SetTextureName (f, szTemp);
			Face_SetTextureRotate (f, (geFloat)tempint);
			Face_SetTextureShift (f, xShift, yShift);
			Face_SetTextureScale (f, xScale, yScale);
			Face_SetTexturePos (f);

			if ((VersionMajor == 1) && (VersionMinor <= 16))
			{
				f->LightXScale = xScale;
				f->LightYScale = yScale;
			}
			else
			{
				f->LightXScale = LightXScale;
				f->LightYScale = LightYScale;
			}
			if((VersionMajor == 1) && (VersionMinor < 29))
			{
				Face_SetVisible(f, GE_TRUE);
			}
			if (((VersionMajor == 1) && (VersionMinor > 31)))
			{
				if (!Parse3dt_GetXForm3d (Parser, (*Expected = "Transform"), &f->Tex.XfmFaceAngle)) goto DoneLoad;
				if (!Parse3dt_GetVec3d (Parser, (*Expected = "Pos"), &f->Tex.Pos)) goto DoneLoad;
			}
		}
		LoadResult = GE_TRUE;
	}
DoneLoad:
	if (LoadResult == GE_FALSE)
	{
		if (f != NULL)
		{
			Face_Destroy (&f);
		}
		if (tmpPnts != NULL)
		{
			geRam_Free (tmpPnts);
		}
	}
	return f;
}

void	Face_GetSplitInfo(const Face *f, const Plane *p, geFloat *dists, uint8 *sides, uint8 *cnt)
{
	int	i;

	assert(f);
	assert(dists);
	assert(sides);
	assert(cnt);

	cnt[0]=cnt[1]=cnt[2]=0;

	for(i=0;i < f->NumPoints;i++)
	{
		dists[i]=geVec3d_DotProduct(&f->Points[i], &p->Normal)-p->Dist;
		if(dists[i] > ON_EPSILON)
		{
			sides[i]=SIDE_FRONT;
		}
		else if(dists[i] < -ON_EPSILON)
		{
			sides[i]=SIDE_BACK;
		}
		else
		{
			sides[i]=SIDE_ON;
		}
		cnt[sides[i]]++;
	}
	sides[i]=sides[0];
	dists[i]=dists[0];
}

void	Face_Split(const Face	*f,		//original face
				   const Plane	*p,		//split plane
				   Face			**ff,	//front face (null)
				   Face			**bf,	//back face (null)
				   geFloat		*dists,	//plane dists per vert
				   uint8		*sides)	//plane sides per vert
{
	geVec3d	*p1, *p2, mid;
	int		nfp, nbp, i, j;
	geFloat	dot;

	assert(f);
	assert(p);
	assert(ff);
	assert(bf);
	assert(*ff==NULL);
	assert(*bf==NULL);
	assert(dists);
	assert(sides);

	p1	=f->Points;
	for(i=nfp=nbp=0;i < f->NumPoints;i++, p1++)
	{
		if(sides[i]==SIDE_ON)
		{
			geVec3d_Copy(p1, &spf[nfp]);
			geVec3d_Copy(p1, &spb[nbp]);
			nfp++;	nbp++;	//Dont ++ in params!
			continue;
		}
		if(sides[i]==SIDE_FRONT)
		{
			geVec3d_Copy(p1, &spf[nfp]);
			nfp++;
		}
		if(sides[i]==SIDE_BACK)
		{
			geVec3d_Copy(p1, &spb[nbp]);
			nbp++;
		}
		if(sides[i+1]==SIDE_ON || sides[i+1]==sides[i])
			continue;

		p2	=&f->Points[(i+1) % f->NumPoints];
		dot	=dists[i] / (dists[i]-dists[i+1]);
		for(j=0;j<3;j++)
		{
			if(VectorToSUB(p->Normal, j)==1)
			{
				VectorToSUB(mid, j)	=p->Dist;
			}
			else if(VectorToSUB(p->Normal, j)==-1)
			{
				VectorToSUB(mid, j)	=-p->Dist;
			}
			else
			{
				VectorToSUB(mid, j)	=VectorToSUB(*p1, j)+
					dot*(VectorToSUB(*p2, j)	-VectorToSUB(*p1, j));
			}
		}

		//split goes to both sides
		geVec3d_Copy(&mid, &spf[nfp]);
		nfp++;
		geVec3d_Copy(&mid, &spb[nbp]);
		nbp++;
	}
	*ff	=Face_Create(nfp, spf, 0);
	*bf	=Face_Create(nbp, spb, 0);

	if(*ff)
	{
		Face_CopyFaceInfo(f, *ff);
	}
	if(*bf)
	{
		Face_CopyFaceInfo(f, *bf);
	}
}

void	Face_Clip(Face *f, const Plane *p, geFloat *dists, uint8 *sides)
{
	geVec3d	*p1, *p2, mid;
	int		nfp, nbp, i, j;
	geFloat	dot;

	assert(f);
	assert(p);
	assert(dists);
	assert(sides);

	p1	=f->Points;
	for(i=nfp=nbp=0;i < f->NumPoints;i++, p1++)
	{
		if(sides[i]==SIDE_ON)
		{
			geVec3d_Copy(p1, &spb[nbp]);
			nbp++;
			continue;
		}
		if(sides[i]==SIDE_BACK)
		{
			geVec3d_Copy(p1, &spb[nbp]);
			nbp++;
		}
		if(sides[i+1]==SIDE_ON || sides[i+1]==sides[i])
			continue;

		p2	=&f->Points[(i+1) % f->NumPoints];
		dot	=dists[i] / (dists[i]-dists[i+1]);
		for(j=0;j<3;j++)
		{
			if(VectorToSUB(p->Normal, j)==1)
			{
				VectorToSUB(mid, j)	=p->Dist;
			}
			else if(VectorToSUB(p->Normal, j)==-1)
			{
				VectorToSUB(mid, j)	=-p->Dist;
			}
			else
			{
				VectorToSUB(mid, j)	=VectorToSUB(*p1, j)+
					dot*(VectorToSUB(*p2, j)	-VectorToSUB(*p1, j));
			}
		}
		geVec3d_Copy(&mid, &spb[nbp]);
		nbp++;
	}
	geRam_Free (f->Points);
	f->NumPoints	=nbp;
	f->Points		=(geVec3d *) geRam_Allocate(sizeof(geVec3d)*nbp);
	memcpy(f->Points, spb, sizeof(geVec3d)*nbp);
}

geFloat	Face_PlaneDistance(const Face *f, geVec3d *pos)
{
	assert(f);
	assert(pos);

	return	(geVec3d_DotProduct(&f->Face_Plane.Normal, pos)
				-f->Face_Plane.Dist);
}

void	Face_MostlyOnSide(const Face *f, const Plane *p, geFloat *max, int *side)
{
	int		i;
	geFloat	d;

	for(i=0;i < f->NumPoints;i++)
	{
		d	=geVec3d_DotProduct(&f->Points[i], &p->Normal) - p->Dist;
		if(d > *max)
		{
			*max	=d;
			*side	=SIDE_FRONT;
		}
		if(-d > *max)
		{
			*max	=-d;
			*side	=SIDE_BACK;
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲老司机在线| 国产精品网曝门| 中文字幕制服丝袜一区二区三区 | 最新不卡av在线| 美美哒免费高清在线观看视频一区二区| 99这里只有久久精品视频| 精品久久久久一区二区国产| 亚洲综合激情小说| 成人av网址在线| 精品国产制服丝袜高跟| 午夜精品久久久久影视| 色综合色综合色综合色综合色综合 | 不卡一二三区首页| 久久综合九色综合欧美98| 日韩和欧美一区二区| 在线免费观看一区| 日韩码欧中文字| 成人教育av在线| 国产亚洲一本大道中文在线| 精品一区二区三区香蕉蜜桃| 欧美理论在线播放| 亚洲福利视频一区| 色婷婷激情综合| 亚洲美女淫视频| 91色porny| 日韩久久一区二区| av不卡一区二区三区| 国产精品久久久久天堂| 顶级嫩模精品视频在线看| 久久精品亚洲一区二区三区浴池| 狠狠色狠狠色综合系列| 久久精品无码一区二区三区| 暴力调教一区二区三区| 91福利在线观看| 国产精品二区一区二区aⅴ污介绍| 精品一区二区免费看| 欧美刺激午夜性久久久久久久| 蜜臀久久久99精品久久久久久| 欧美巨大另类极品videosbest | 蜜臂av日日欢夜夜爽一区| 欧美日韩精品电影| 亚洲国产成人av好男人在线观看| 色av综合在线| 亚洲午夜激情av| 欧美亚洲一区二区在线| 亚洲成人你懂的| 欧美肥胖老妇做爰| 看片的网站亚洲| 久久久久久久久免费| 高清国产一区二区三区| 国产精品三级在线观看| 99riav久久精品riav| 一区二区三区精品| 91精品久久久久久蜜臀| 精品在线一区二区| 国产欧美精品一区二区色综合| 国产99久久久国产精品免费看| 国产精品无码永久免费888| www.亚洲免费av| 亚洲与欧洲av电影| 91麻豆精品国产91久久久资源速度| 日本亚洲最大的色成网站www| 日韩免费观看高清完整版在线观看| 久久97超碰色| 欧美激情综合在线| 日本乱码高清不卡字幕| 日韩av一区二区三区四区| 精品国产免费人成电影在线观看四季 | 日韩电影在线免费观看| 日韩欧美美女一区二区三区| 国产成人av电影| 亚洲男女毛片无遮挡| 欧美精品亚洲二区| 国产成人综合网站| 亚洲一区在线视频观看| 日韩一级高清毛片| 豆国产96在线|亚洲| 一二三四区精品视频| 日韩精品亚洲专区| 久久精品视频网| 91精品办公室少妇高潮对白| 麻豆精品久久精品色综合| 中文字幕欧美三区| 欧美三级欧美一级| 国产成人精品综合在线观看| 伊人婷婷欧美激情| 精品国产乱码久久久久久夜甘婷婷 | 狠狠色狠狠色综合系列| 亚洲人被黑人高潮完整版| 91精品啪在线观看国产60岁| 国产成人免费视频网站| 亚洲成人在线免费| 国产午夜亚洲精品不卡| 精品视频在线视频| 大陆成人av片| 青娱乐精品视频| 亚洲色图一区二区| 精品日韩一区二区三区| 在线精品视频免费观看| 国产精品影视网| 日韩avvvv在线播放| 成人欧美一区二区三区小说| 精品久久一区二区三区| 欧美午夜影院一区| 成人av资源在线| 久久www免费人成看片高清| 亚洲一区视频在线观看视频| 久久免费的精品国产v∧| 欧美日韩精品欧美日韩精品| www.色综合.com| 国产麻豆精品95视频| 首页国产丝袜综合| 亚洲激情图片一区| 国产三级精品三级在线专区| 3d成人h动漫网站入口| 91网站在线观看视频| 国产一区二区看久久| 日日夜夜精品视频天天综合网| 综合欧美一区二区三区| 精品国产免费人成电影在线观看四季 | av电影在线观看一区| 久久精品国产亚洲5555| 婷婷六月综合亚洲| 亚洲色欲色欲www在线观看| 亚洲国产精品成人综合| 欧美大片在线观看一区| 欧美日韩情趣电影| 色网综合在线观看| 99久久99久久综合| 成人在线视频首页| 国产美女av一区二区三区| 免费高清不卡av| 日本不卡不码高清免费观看| 亚洲一区二区av在线| 亚洲男人的天堂在线观看| 国产精品理论片| 亚洲国产精品成人综合| 国产婷婷色一区二区三区四区| 日韩欧美久久久| 日韩一区二区精品在线观看| 欧美日本免费一区二区三区| 欧美在线观看禁18| 在线观看日韩av先锋影音电影院| 99re视频这里只有精品| www.视频一区| 91视频xxxx| 91久久精品一区二区三区| 91蜜桃在线免费视频| 色综合久久99| 色视频欧美一区二区三区| 色综合久久久久综合体桃花网| 97精品国产露脸对白| caoporn国产一区二区| 成人v精品蜜桃久久一区| 不卡的av网站| 91麻豆精品秘密| 在线一区二区视频| 欧美亚洲国产怡红院影院| 欧美日韩综合在线免费观看| 欧美日韩国产中文| 欧美一区二区三区视频免费播放| 日韩午夜激情视频| 精品美女在线播放| 国产欧美日韩卡一| 中文字幕精品一区二区三区精品| 国产精品久99| 亚洲激情五月婷婷| 视频一区二区三区在线| 麻豆精品视频在线观看免费| 国产精品一区二区在线看| 国产成人在线色| 91视频在线观看| 欧美视频在线一区二区三区 | 国产视频一区不卡| 国产精品视频yy9299一区| 成人免费小视频| 亚洲自拍另类综合| 日产精品久久久久久久性色| 国产一区二区三区av电影 | 免费精品视频最新在线| 韩国午夜理伦三级不卡影院| 成人网在线播放| 色av成人天堂桃色av| 51精品久久久久久久蜜臀| 日韩精品一区二区在线观看| 国产亚洲欧美在线| 亚洲激情欧美激情| 日韩激情一二三区| 国产福利一区二区| 91成人免费在线| 日韩欧美资源站| 中文文精品字幕一区二区| 亚洲国产视频在线| 久久99精品国产.久久久久| 成人av电影在线| 欧美精品乱码久久久久久| 国产色婷婷亚洲99精品小说| 亚洲一区二区免费视频| 韩国理伦片一区二区三区在线播放| 成人国产一区二区三区精品|