久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

OCCT 基础2

發布時間:2023/12/18 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 OCCT 基础2 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

OpenCASCADE 基礎

一直在用OCC作項目,但這方面的中文資料很少,看來OCC在中國還不是十分普及;

后來,項目中使用OCC和DirectX結合使用,取得了很好的效果;

隨著OCC6.3版本的推出,Open CASCADE在速度方面已有了很大的改變。以下為一些OCC的基礎知識,愿與各位OCC愛好者共同學習;

一:OCC中的基礎類:

gp_Pnt

在OCC中,gp_Pnt表示一個頂點,gp_Vec表示一個向量,可以用兩個頂點來生成一個向量。

比如:

gp_Pnt P1(0,0,0);?

gp_Pnt P2(5,0,0);?

gp_Vec V1 (P1,P2);

向量有一個方法.IsOpposite(),可以用來測試兩個向量的方向是相對還是平行;

比如:?

gp_Pnt P3(-5,0,2);

gp_Vec V2 (P1,P3);?

Standard_Boolean result =V1.IsOpposite(V2,Precision::Angular());

另外向量還有一些重要方法:

--Standard_Real Magnitude() const;計算向量的大小;

--Standard_Real SquareMagnitude() const;計算向量的平方;

--向量的加減乘除操作;

--向量的單位化;

--通過一個點,線,面得出其鏡像的向量;

--向量的旋轉,平移,縮放;

具體的函數名稱可以看OCC的頭文件說明;

有時需要決定一組空間點是位于一個點;一條直線,或一個平面,或一個空間:

OCC中提供了相應的算法;

比如:

TColgp_Array1OfPnt array (1,5); // sizing array?

array.SetValue(1,gp_Pnt(0,0,1));?

array.SetValue(2,gp_Pnt(1,2,2));?

array.SetValue(3,gp_Pnt(2,3,3));?

array.SetValue(4,gp_Pnt(4,4,4));?

array.SetValue(5,gp_Pnt(5,5,5));?

GProp_PEquation PE (array,1.5 );?

if (PE.IsPoint()){?? } //是否是同一個點?

gp_Lin L;?

if (PE.IsLinear()) {? L = PE.Line();? } //是否位于一條直線上;?

if (PE.IsPlanar()){?? }? //是否在一個平面內;?

if (PE.IsSpace()) {?? }?

gp_Dir類:

此類用來描述3D空間中的一個單位向量;

常用方法:

(1):IsEqual(const gp_Dir& Other,const Standard_Real AngularTolerance) const;兩個單位向量是否相等;

(2):IsNormal(const gp_Dir& Other,const Standard_Real AngularTolerance) const;兩個單位向量的夾角是否是PI/2;

(3):IsOpposite(const gp_Dir& Other,const Standard_Real AngularTolerance) const;兩個單位向量是否方向相反;

(4):IsParallel(const gp_Dir& Other,const Standard_Real AngularTolerance) const;兩個單位向量夾角O或PI;

(5):Angle(const gp_Dir& Other) const;求兩個向量之間的夾角;

(6):void CrossCross(const gp_Dir& V1,const gp_Dir& V2) ;計算三個向量之間的叉積;

(7):Standard_Real Dot(const gp_Dir& Other) const;計算點積;

(8):Standard_Real DotCross(const gp_Dir& V1,const gp_Dir& V2) const;計算叉積再點積;

(9):gp_Dir Reversed() const;得到反方向,

在OCC中用 gp_Lin2d 類,來生成一個二維空間的直線,有它的原點和單位向量;

gp_Ax2d類:

通過原點和X方向單位和Y方向單位建立一個二維坐標系;利用sense參數可以決定是右手系還是左手系;

可以利用平移、旋轉、縮放、鏡像來更改坐標系;

類似地,gp_Ax3類:

用來描述一個3D空間的坐標系。而gp_Ax2類用來表示一個二維空間坐標系;可以為右手系,也可以是左手系;

二、曲線類

GeomAPIGeomConvert包:

GeomAPI開發包提供了一個幾何體的可編程應用程序接口;

比如:

求點P和曲線C的距離D:

D = GeomAPI_ProjectPointOnCurve(P,C);

或者

GeomAPI_ProjectPointOnCurve PonC(P,C);

D = PonC.LowerDistance();

GeomConvert包提供了一些全局函數,可以用來實現轉化一個Geom曲線為BSpline曲線等;

比如:

Handle(Geom_BSplineSurface) aPipeSurface =?

Handle(Geom_BSplineSurface)::DownCast(aPipe.Surface());?

Handle(Geom_BSplineSurface) anotherBSplineSurface =?

GeomConvert::SplitBSplineSurface(aPipeSurface,1,2,3,6);

OCC中三維幾何曲線的類型有:

--線

--園

--橢圓

--二次曲線

--拋物線

--Bezier曲線

--BSpline曲線

可以將一個二維的幾何曲線轉化為某個平面內的一個三維曲線:

比如:

Standard_Real radius = 5;?

gp_Ax2d ax2d(gp_Pnt2d(2,3),gp_Dir2d(1,0));?

//生成一個二維園?

Handle(Geom2d_Circle) circ2d = new Geom2d_Circle(ax2d,radius);?

gp_Ax2d circ2dXAxis = circ2d->XAxis();?

// 然后,在這個平面里轉化為三維曲線;?

Handle(Geom_Curve) C3D = GeomAPI::To3d(circ2d,gp_Pln(gp_Ax3(gp::XOY())));?

Handle(Geom_Circle) C3DCircle = Handle(Geom_Circle)::DownCast(C3D);?

gp_Ax1 C3DCircleXAxis = C3DCircle->XAxis();?

另外,可以以將一個三維曲線,投影到一個平面內,從而生成一個二維曲線

gp_Pln ProjectionPlane(gp_Pnt(1,1,0),gp_Dir( 1,1,1 ));?

Handle(Geom2d_Curve) C2D = GeomAPI::To2d(C3D,ProjectionPlane);?

Handle(Geom2d_Circle) C2DCircle =Handle(Geom2d_Circle)::DownCast(C2D);?

gp_Ax2d C2DCircleXAxis = C2DCircle->XAxis();

將一個基本幾何圖形進行空間變換可以使用它自帶的函數:

比如:

Handle(Geom_Geometry) aRotatedEntity? = circle->Rotated(gp::OZ(),PI/4);

如果想獲取圖形的類型名稱:?

Standard_CString aRotatedEntityTypeName = aRotatedEntity->DynamicType()->Name();

gp_Parab2d類:

描述一個平面內的拋物線;

示例:

gp_Pnt2d P(2,3);?

gp_Dir2d D(4,5);?

gp_Ax22d A(P,D);?

gp_Parab2d Para(A,6);

GCE2d_MakeParabola類:

生成一個拋物線圖形;

Geom2d_BSplineCurve類:

描述樣條曲線;

Geom2dAPI_Interpolate類:

通過一組點來修改一個樣條曲線;

FairCurve_Batten類:

用一個常量或線性增加的值來構造曲線;可以用來設計木紋或塑料板條;圖形為二維的,可以模擬物理樣條或板條.

Geom2d_TrimmedCurve類:

此類通過兩個值,定義曲線的一部分,

--可以用來計算曲線的參數值和點坐標;

--可以得到曲線的一般特征,比如連續的等級,封閉特點,周期性,邊界參數;

--當用一個矩陣應用于曲線或原始曲線轉化后進行相應參數的改變;

所有的曲線必須幾何連續,曲線至少一階可導。一般來說,在生成一個曲線時,要先檢查一下所應用的參數是否可以生成一個光滑曲線;否則會出現錯誤;

另外注意一點:不可以構造空長度的曲線或自相交的曲線;

此類的基類是Geom2d_BoundedCurve類:

它是一個抽象類;描述二維空間中的邊界曲線的一般行為;除了Geom2d_TrimmedCurve是它的一個派生類外,它還有二個派生類:

- Geom2d_BezierCurve

- Geom2d_BSplineCurve

Geom2d_BoundedCurve類的基類是Geom2d_Curve類:

Geom2d_Curve:抽象類;此抽象類描述了2D空間的曲線的一般特征;派生出的類有多個:包括直線,園,二次曲線,Bizier,BSpline曲線等;這些曲線的特點是可以參數化;

Geom2d_Curve類的基類是Geom2d_Geometry類;

此抽象類主要定義了曲線的變換,平移,旋轉,縮放及拷貝等方法;

Geom2d_Geometry類的基類是MMgt_TShared類;

此抽象類為管理對象的基類,可以引用計數,及刪除方法;

Standard_Transient:此抽象類為所有類共同的基類;

Geom2dAPI_InterCurveCurve類:

此類用來實現二維曲線的相交;

一種情況是曲線與曲線的相交,另外一種情況是曲線自身的相交;

主要方法有:

--Standard_Integer NbPoints() const;相交點數;

--Standard_Integer NbSegments() const;切線相交數;

--void Segment(const Standard_Integer Index,Handle(Geom2d_Curve)& Curve1,Handle(Geom2d_Curve)& Curve2)

const;返回其中一個線段;

下面的示例是兩個曲線相交的例子:

首先,生成第一個曲線,在這里,應用點數組來生成一個曲線;

--定義數組

Handle(TColgp_HArray1OfPnt2d) harray =? new TColgp_HArray1OfPnt2d (1,5); // sizing harray?

--輸入點數組的值

harray->SetValue(1,gp_Pnt2d (0,0));?

harray->SetValue(2,gp_Pnt2d (-3,1));?

harray->SetValue(3,gp_Pnt2d (-2,5));?

harray->SetValue(4,gp_Pnt2d (2,9));?

harray->SetValue(5,gp_Pnt2d (-4,14));?

--檢測一下點與點之間是否為同一點;0.01為公差值,依實際需要可以更改此參數;?

Geom2dAPI_Interpolate anInterpolation(harray,Standard_False,0.01);?

--生成曲線

anInterpolation.Perform();?

Handle(Geom2d_BSplineCurve) SPL = anInterpolation.Curve();?

--第二個曲線用兩點來生成?

gp_Pnt2d P1(-1,-2);gp_Pnt2d P2(0,15);gp_Dir2d V1 = gp::DY2d();?

Handle(Geom2d_TrimmedCurve) TC1=? GCE2d_MakeSegment(P1,V1,P2);?

--下面進行曲線的求交?

Standard_Real tolerance = Precision::Confusion();?

Geom2dAPI_InterCurveCurve ICC (SPL,TC1,tolerance);?

--得到交點?

Standard_Integer NbPoints =ICC.NbPoints();?

gp_Pnt2d PK;?

for (Standard_Integer k = 1;k<=NbPoints;k++)?

{

PK = ICC.Point(k);?

// 針對每個交點,進行相應處理;?

}?

Geom2d_OffsetCurve類:

此類用來實現偏移曲線;

比如:

--生成一個曲線

TColgp_Array1OfPnt2d array (1,5); // sizing array?

array.SetValue(1,gp_Pnt2d (-4,0)); array.SetValue(2,gp_Pnt2d (-7,2));?

array.SetValue(3,gp_Pnt2d (-6,3)); array.SetValue(4,gp_Pnt2d (-4,3));?

array.SetValue(5,gp_Pnt2d (-3,5));?

Handle(Geom2d_BSplineCurve) SPL1 = Geom2dAPI_PointsToBSpline(array);?

--生成一個偏移曲線?

Standard_Real dist = 1;?

Handle(Geom2d_OffsetCurve) OC =?

new Geom2d_OffsetCurve(SPL1,dist);?

Standard_Boolean result = OC->IsCN(2);?

GccAna_Pnt2dBisec類

此類實現兩點之間的等分線.

示例:

gp_Pnt2d P1(1,2);?

gp_Pnt2d P2(4,5);?

gp_Lin2d L;?

GccAna_Pnt2dBisec B(P1,P2);?

if (B.IsDone())?

{ L = B.ThisSolution(); }

因為所生成的為直線,所以顯示時要轉化為線段:

if (B.IsDone())

{

Handle(Geom2d_TrimmedCurve) aLine = GCE2d_MakeSegment(L,-8,8);

Handle(ISession2D_Curve) aCurve = new ISession2D_Curve(aLine);

aDoc->GetISessionContext()->Display(aCurve, Standard_False);

}

gce_MakeCirc2d類

用來創建園:創建園的方法很多,主要構造方法有:

--園心和通過的一點;

--通過一個園和一個距離值,創建一個同心園;

--三點決定一個園;

--園心和半徑;

gp_Elips2d類:

可以生成一個橢園,也可以生成橢園上的一段園弧;

比如:

Standard_Real major = 12;?

Standard_Real minor = 4;?

gp_Ax2d axis = gp::OX2d();?

gp_Elips2d EE(axis,major,minor);;?

Handle(Geom2d_TrimmedCurve) arc = GCE2d_MakeArcOfEllipse(EE,0.0,PI/4);?
上面是利用長短軸的方法構造橢圓,也可以用二次方程的方式來構造橢園;

其中橢園類中方法可以求出焦點1和焦點2的位置,兩焦點之間的位置,離心率;旋轉,平移,縮放等操作.

三、關于面的類

gp_Pln:

定義一個平面,構造的方法可以是點法式,或通過ABCD系數;

另外,還提供了一些常用的方法,比如:

--求點到平面,線到平面,平面與平面的距離及平方距離;

--點是否在平面內,線是否在平面內;

--通過一個點,一個軸的鏡像平面;

--平面的旋轉,縮放與平移;

Geom_ElementarySurface類:

此類用來描述一個表面,此類的派生類有:

平面;園柱面;錐面;球面;園環面;

它的基類是Geom_Surface,是一個抽象類;

Geom_Surface類的基類是Geom_Geometry類;

Geom_RectangularTrimmedSurface類:

用來生成一個有邊界的平面;

比如:

Handle(Geom_Plane) aProjectionPlane = GC_MakePlane(ProjectionPlane).Value();

Handle(Geom_RectangularTrimmedSurface) aProjectionPlaneSurface=

new Geom_RectangularTrimmedSurface(aProjectionPlane,-8.,8.,-12.,12.);?

DisplaySurface(aDoc,aProjectionPlaneSurface);

此類的基類是Geom_BoundedSurface類;

此類的兄弟類還有

- Geom_BezierSurface,

- Geom_BSplineSurface

ConicalSurface類:用來創建一個園錐表面;

構造表面的方法有:

--已知一個園錐表面,和空間一點,過此點的平行于已知園錐表面;

--已知一個園錐表面,和一個距離,創建一個平行于已知園錐表面的園錐表面;

--通過四個點構造一個園錐表面;

--通過一個軸和兩個點;

--通過兩個點和兩個半徑;

GeomAPI_IntCS類:

此類用來計算一個園弧和和一個表面的交點或相交線段;

GeomFill_BSplineCurves類:

此類用來構造一個可以填充的BSpline表面,構造它可以用兩個三個或四個BSpline曲線作為邊界;

填充類型有三種:

enum GeomFill_FillingStyle {

GeomFill_StretchStyle,

GeomFill_CoonsStyle,

GeomFill_CurvedStyle

};

以下示例為用兩個樣條曲線生成一個表面:

GeomFill_FillingStyle Type = GeomFill_StretchStyle;?

GeomFill_BSplineCurves aGeomFill1(SPL1,SPL2,Type);?

Handle(Geom_BSplineSurface)? aBSplineSurface1 = aGeomFill1.Surface();

GeomFill_Pipe類:

此類用來構造一個pipe,沿著一個路徑sweep一個截面,這兩個都是曲線類型;一般來說,結果是一個BSpline表面;

常見的有幾種方法:

--給定一個路徑和一個半徑,截面是個園,位置是路徑的第一個點,

比如:

GeomFill_Pipe aPipe(SPL1,1);?

aPipe.Perform();?

Handle(Geom_Surface) aSurface= aPipe.Surface();?

Standard_CString aSurfaceEntityTypeName="Not Computed";?

if (!aSurface.IsNull())?

aSurfaceEntityTypeName = aSurface->DynamicType()->Name();

--給定一個路徑和一個截面。

比如:

Handle(Geom_Ellipse) E = GC_MakeEllipse( gp::XOY() ,3,1).Value();?

GeomFill_Pipe aPipe2(SPL1,E);?

aPipe2.Perform();?

Handle(Geom_Surface) aSurface2= aPipe2.Surface();?

Standard_CString aSurfaceEntityTypeName2="Not Computed";?

if (!aSurface2.IsNull())? {?

aSurfaceEntityTypeName2 = aSurface2->DynamicType()->Name();?

aSurface2->Translate(gp_Vec(5,0,0));? }

--給定一個路徑和兩個截面,中間截面為過度線;

示例:

Handle(Geom_TrimmedCurve) TC1 =?

GC_MakeSegment(gp_Pnt(1,1,1),gp_Pnt(5,5,5));?

Handle(Geom_TrimmedCurve) TC2 =?

GC_MakeSegment(gp_Pnt(1,1,0),gp_Pnt(4,5,6));?

GeomFill_Pipe aPipe3(SPL1,TC1,TC2);?

aPipe3.Perform();?

Handle(Geom_Surface) aSurface3 = aPipe3.Surface();?

Standard_CString aSurfaceEntityTypeName3="Not Computed";?

if (!aSurface3.IsNull())?

{?

aSurfaceEntityTypeName3 = aSurface3->DynamicType()->Name();?

aSurface3->Translate(gp_Vec(10,0,0));?

}?

--給定一個路徑和N個截面,中間為過渡線;

一般情況下,所生結果為:NURBS,但是,在一些特殊的情況下,可以生成平面,園柱,球,園錐等;

參數,U,沿著截面的方向,V沿著路徑方向;

Geom_BezierSurface類:

生成一個Bezier表面;

Geom_OffsetSurface類:

用來偏移一個表面;

比如:

Standard_Real offset = 1;?

Handle(Geom_OffsetSurface) GOS = new Geom_OffsetSurface(aGeomSurface, offset);

Geom_SweptSurface類:

有兩個派生類,分別用來生成一個回轉體表面和一個延展體表面;

Geom_SurfaceOfLinearExtrusion:用來描述一個線性延展表面;

它的基類是:Geom_Surface類

比如:

Handle(Geom_BSplineCurve) aCurve =GeomAPI_PointsToBSpline(array).Curve();?

gp_Dir aDir(1,2,3);?

Handle(Geom_SurfaceOfLinearExtrusion) SOLE =new Geom_SurfaceOfLinearExtrusion(aCurve,aDir);?

Handle(Geom_RectangularTrimmedSurface) aTrimmedSurface =new Geom_RectangularTrimmedSurface(SOLE,-10,10,false);

Geom_SurfaceOfRevolution類,表示一個回轉體表面;

比如:

Handle(Geom_BSplineCurve) aCurve = GeomAPI_PointsToBSpline(array).Curve();?

Handle(Geom_SurfaceOfRevolution) SOR =new Geom_SurfaceOfRevolution(aCurve,gp::OX());?

1:利用一個二維數組來生成曲面的方法:

TColgp_Array2OfPnt array3 (1,5,1,5);?

array3.SetValue(1,1,gp_Pnt (-4,-4,5));

...

array3.SetValue(2,1,gp_Pnt (-2,-4,4));

...

Handle(Geom_BSplineSurface) aSurf2 =GeomAPI_PointsToBSplineSurface(array3).Surface();

2:GeomAPI_ExtremaSurfaceSurface類:

計算兩個表面之間的極值點;

主要方法:

(1):Quantity_Length LowerDistance() const;計算兩個表面的最短距離;

(2):Standard_EXPORT? void LowerDistanceParameters(Quantity_Parameter& U1,Quantity_Parameter& V1,Quantity_Parameter& U2,Quantity_Parameter& V2) const;

得到第一個表面上的極值點的UV參數和第二個表面上的極值點的UV參數;

(3):void NearestPoints(gp_Pnt& P1,gp_Pnt& P2) const;得到第一個表面上的極值點和第二個表面上的極值點;

(4): Quantity_Length Distance(const Standard_Integer Index) const;得到第N個極值點的距離;

(5):Standard_Integer NbExtrema() const;極值的數目;

......

示例:

GeomAPI_ExtremaSurfaceSurface ESS(aSurf1,aSurf2);

Quantity_Length dist = ESS.LowerDistance();

gp_Pnt P1,P2;

ESS.NearestPoints(P1,P2);

gp_Pnt P3,P4;

Handle(Geom_Curve) aCurve;

Standard_Integer NbExtrema = ESS.NbExtrema();

for(Standard_Integer k=1;k<=NbExtrema;k++){

ESS.Points(k,P3,P4);?

aCurve= GC_MakeSegment(P3,P4).Value();

DisplayCurve(aDoc,aCurve,Quantity_NOC_YELLOW3,false);

}

一些OCC的基礎知識,愿與各位OCC愛好者共同學習;mail:tongabcd@yeah.net

一:關于體的類

BRepBuilderAPI_MakeVertex

創建點;

BRepBuilderAPI_MakeEdge

此類用來創建邊;

比如,由直線生成邊:

gp_Lin line(gp_Ax1(gp_Pnt(10,10,10),gp_Dir(1,0,0)));

WhiteEdge = BRepBuilderAPI_MakeEdge(line,-20,10);

下面為生成四分之一園邊:

gp_Elips Elips(gp_Ax2(gp_Pnt(10,0,0),gp_Dir(1,1,1)),60,30);

RedEdge = BRepBuilderAPI_MakeEdge(Elips,0,PI/2);

下面是由曲線生成邊:

Handle (Geom_BezierCurve) curve = new Geom_BezierCurve(array);

BRepBuilderAPI_MakeEdge ME (curve);

GreenEdge = ME;

V3 = ME.Vertex1();

V4 = ME.Vertex2();

BRepBuilderAPI_MakeWire

用來創建一個Wire類;

用一個Wire和一個邊來生成一個新的Wire:

ExistingWire = BRepBuilderAPI_MakeWire(Edge2);

Edge3 = BRepBuilderAPI_MakeEdge(gp_Pnt(-300,0,-80),gp_Pnt(-90,20,-30));

BRepBuilderAPI_MakeWire MW1(ExistingWire,Edge3);

if (MW1.IsDone()) {YellowWire = MW1;}

用一個Wire和添加邊的方法來生成Wire:

BRepBuilderAPI_MakeWire MW;

MW.Add(ExistingWire2);

MW.Add(Edge5);

MW.Add(Edge6);

MW.Add(Edge7);

if (MW.IsDone()) {

WhiteWire = MW.Wire();

LastEdge = MW.Edge();

LastVertex = MW.Vertex();

}

BRepBuilderAPI_MakeFace

生成一個面;有多種生成面的方法;

--通過一個封閉曲線生成面:

BRepBuilderAPI_MakeFace(curve);

--通過一個Wire生成面:

BrownFace = BRepBuilderAPI_MakeFace(YellowWire);

Bnd_Box2d:

定義一個二維空間的邊界盒,可以得出邊界盒各個點的值,有時,在某個方向是無限大,這種情況下,稱為在此方向上是開放的;

示例:

Bnd_Box2d aCBox;?

Geom2dAdaptor_Curve GACC (C);?

BndLib_Add2dCurve::Add (GACC,Precision::Approximation(),aCBox);

Bnd_Box:

定義一個三維空間的邊界盒,可以擴大或縮小邊界盒,也可以合并兩個軸對齊邊界盒;

BRepPrimAPI_MakeBox

用來生成一個立方體;

構造一個立方體可以是兩個對角點,一個角點及三個方向長度,可以是非軸對稱的:

TopoDS_Shape B2 = BRepPrimAPI_MakeBox (gp_Ax2(gp_Pnt(-200.,-80.,-70.), gp_Dir(1.,2.,1.)),? 80.,90.,120.);

使用方法

TopoDS_Face& BottomFace() ;.可以得到立方體的底面;同樣,用其它類似的方法可以獲得頂面等;

方法TopoDS_Solid& Solid() ;可以將box轉化為一個Solid;

方法TopoDS_Shell& Shell() ;可以將box轉化為一個shell;

BRepPrimAPI_MakeCylinder

用來生成一個園柱體或園柱體的一部分;

比如:?

TopoDS_Shape C2 = BRepPrimAPI_MakeCylinder (gp_Ax2(gp_Pnt(200.,0.,200.), gp_Dir(0.,1.,0.)),40.,110.,210.*PI180);

BRepPrimAPI_MakeCone

生成一個園錐或園錐的一部分;

BRepPrimAPI_MakeSphere

生成球體或球體的一部分,可以是U方向切一部分或V方向切一部分;

BRepPrimAPI_MakeTorus

生成環或環的一部分;

BRepPrimAPI_MakeWedge

生成一個楔塊或楔塊的一部分;

BRepPrimAPI_MakePrism

生成一個線性的swept,稱為Prisms;它的基類是BRepPrimAPI_MakeSweep類;BRepPrimAPI_MakeSweep類的基類是

BRepBuilderAPI_MakeShape類

注意,原始基本圖形不可以包含任何實體:

應用此類時:

--頂點“推移”成邊:

TopoDS_Vertex V1 = BRepBuilderAPI_MakeVertex(gp_Pnt(-200.,-200.,0.));

Handle(AIS_Shape) ais1 = new AIS_Shape(V1);?

TopoDS_Shape S1 = BRepPrimAPI_MakePrism(V1,gp_Vec(0.,0.,100.));

Handle(AIS_Shape) ais2 = new AIS_Shape(S1);

--邊“推移”成面:.

TopoDS_Edge E = BRepBuilderAPI_MakeEdge(gp_Pnt(-150.,-150,0.), gp_Pnt(-50.,-50,0.));

Handle(AIS_Shape) ais3 = new AIS_Shape(E);

myAISContext->Display(ais3,Standard_False);

TopoDS_Shape S2 = BRepPrimAPI_MakePrism(E,gp_Vec(0.,0.,100.));

--Wires “推移”成Shells.

TopoDS_Edge E1 = BRepBuilderAPI_MakeEdge(gp_Pnt(0.,0.,0.), gp_Pnt(50.,0.,0.));

TopoDS_Edge E2 = BRepBuilderAPI_MakeEdge(gp_Pnt(50.,0.,0.), gp_Pnt(50.,50.,0.));

TopoDS_Edge E3 = BRepBuilderAPI_MakeEdge(gp_Pnt(50.,50.,0.), gp_Pnt(0.,0.,0.));

TopoDS_Wire W = BRepBuilderAPI_MakeWire(E1,E2,E3);

TopoDS_Shape S3 = BRepPrimAPI_MakePrism(W,gp_Vec(0.,0.,100.));

--Faces “推移”成Solids.

TopoDS_Face F = BRepBuilderAPI_MakeFace(gp_Pln(gp::XOY()),Wc);

Handle(AIS_Shape) ais7 = new AIS_Shape(F);

myAISContext->Display(ais7,Standard_False);

TopoDS_Shape S4 = BRepPrimAPI_MakePrism(F,gp_Vec(0.,0.,100.));

--Shells “推移”成復合實體

BRepPrimAPI_MakeRevol

一個回轉sweep體;

類繼承關系和前面類似:BRepBuilderAPI_MakeShape--〉BRepPrimAPI_MakeSweep-->BRepPrimAPI_MakeRevol

,對于角度而言,范圍是[0,2PI],默認值是2PI,生成規則:

- Vertex -> Edge.

- Edge -> Face.

- Wire -> Shell.

- Face-> Solid.

- Shell-> CompSolid.

BRepOffsetAPI_MakePipe

可以生成一個管道

類繼承關系是:BRepBuilderAPI_MakeShape--〉BRepPrimAPI_MakeSweep-->BRepOffsetAPI_MakePipe

以下為生成一個管道的示例過程:

--利用生成一個WIRE,作為管道的路徑:

Handle(Geom_BezierCurve) curve = new Geom_BezierCurve(CurvePoles);

TopoDS_Edge E = BRepBuilderAPI_MakeEdge(curve);

TopoDS_Wire W = BRepBuilderAPI_MakeWire(E);

--生成一個面,作為生成管道的截面:

gp_Circ c = gp_Circ(gp_Ax2(gp_Pnt(0.,0.,0.),gp_Dir(0.,1.,0.)),10.);

TopoDS_Edge Ec = BRepBuilderAPI_MakeEdge(c);

TopoDS_Wire Wc = BRepBuilderAPI_MakeWire(Ec);

TopoDS_Face F = BRepBuilderAPI_MakeFace(gp_Pln(gp::ZOX()),Wc);

--利用前兩步生成的路徑和截面來生成pipe:

TopoDS_Shape S = BRepOffsetAPI_MakePipe(W,F);

Handle(AIS_Shape) ais2 = new AIS_Shape(S);

BRepOffsetAPI_ThruSections

此類繼承自BRepBuilderAPI_MakeShape:創建一個loft,通過一組給定的sections,生成一個shell或一個solid;通常,section是wire;但是第一個和最后一個section可以是

vertices;

比如:

BRepOffsetAPI_ThruSections generator(Standard_False,Standard_True);

generator.AddWire(W1);

generator.AddWire(W2);

generator.AddWire(W3);

generator.AddWire(W4);

generator.Build();

TopoDS_Shape S1 = generator.Shape();

Handle(AIS_Shape) ais1 = new AIS_Shape(S1);

BRepBuilderAPI_MakePolygon

創建一個polygonal wires,可以通過一組點或向量生成,也可以先生成一個空的對象,再添加點。

示例1:

BRepBuilderAPI_MakePolygon P;

P.Add(gp_Pnt(0.,0.,0.));

P.Add(gp_Pnt(200.,0.,0.));

P.Add(gp_Pnt(200.,200.,0.));

P.Add(gp_Pnt(0.,200.,0.));

P.Add(gp_Pnt(0.,0.,0.));

TopoDS_Wire W = P.Wire();

示例2:

TopoDS_Wire wprof = BRepBuilderAPI_MakePolygon(gp_Pnt(0.,0.,0.),gp_Pnt(-60.,-60.,-200.));

BRepOffsetAPI_MakeEvolved

創建一個可展圖形,它是通過一個planar spine (face or wire)和一個rofile (wire)來生成的,它是一個非循環的sweep (pipe),用profile沿著spline;自相交點將被移除;

比如:

--沿著一個spline,sweep一個profile;

Standard_EXPORT BRepOffsetAPI_MakeEvolved(const TopoDS_Face& Spine,const TopoDS_Wire& Profil,const GeomAbs_JoinType Join = GeomAbs_Arc,const Standard_Boolean

AxeProf = Standard_True,const Standard_Boolean Solid = Standard_False,const Standard_Boolean ProfOnSpine = Standard_False,const Standard_Real Tol = 0.0000001);

AxeProf參數如果為true,R是0,X,Y,Z;如果solid為真,結果為一個solid或復合的solids;

示例:

TopoDS_Shape

S = BRepOffsetAPI_MakeEvolved(W,wprof,GeomAbs_Arc,Standard_True,Standard_False,Standard_True,0.0001);

BRepBuilderAPI_ModifyShape

當使用BRepTools來創建一個修改類,主要有以下派生類:

--BRepBuilderAPI_Copy:處理一個圖形的拷貝;

--BRepBuilderAPI_Transform 和BRepBuilderAPI_GTransform:用來對一個圖形應用幾何變形;

--BRepBuilderAPI_NurbsConvert:用來將一個圖形轉化為NURBS幾何體;

--BRepOffsetAPI_DraftAngle:創建一個tapered圖形;

BRepOffsetAPI_DraftAngle

創建一個tapered圖形;一般過程是:

--初始化構造算法;

--輸入要taper的特征面;

--實現算法;

--生成結果;

示例:

TopoDS_Shape S = BRepPrimAPI_MakeBox(200.,300.,150.);

BRepOffsetAPI_DraftAngle adraft(S);

TopExp_Explorer Ex;

for (Ex.Init(S,TopAbs_FACE); Ex.More(); Ex.Next()) {

TopoDS_Face F = TopoDS::Face(Ex.Current());

Handle(Geom_Plane) surf = Handle(Geom_Plane)::DownCast(BRep_Tool::Surface(F));

gp_Pln apln = surf->Pln();

gp_Dir dirF = apln.Axis().Direction();

if (dirF.IsNormal(gp_Dir(0.,0.,1.),Precision::Angular()))

adraft.Add(F, gp_Dir(0.,0.,1.), 15.*PI180, gp_Pln(gp::XOY()));

}

ais1->Set(adraft.Shape());

二:關于布爾等實體修改操作相關

BRepAlgoAPI_BooleanOperation

此類的基類是BRepBuilderAPI_MakeShape類,它是一個抽象類;

可以應用的操作有:BOP_SECTION 、BOP_COMMON、BOP_FUSE、BOP_CUT、BOP_CUT21

有時會產生錯誤,無法達到想要的結果,根據返回值,可以得到錯誤信息,含義是:

0:OK

1: 對象創建完成,但結果為空;

2:源圖形為空;

3:參數類型檢查錯誤;

4:不能為DSFiller分配內存;

5:此種類型參數的Builder無法工作;

6:不允許的操作;

7:不能為Builder分配內存;

>100 參見Builder錯誤信息;

相關的方法介紹:

--TopTools_ListOfShape& SectionEdges()方法:返回一組截面的邊,它們在布爾操作過程中生成;

--Standard_Boolean HasDeleted()方法:如果至少一個圖形對象被刪除了,返回為真;

--Standard_Boolean HasGenerated()方法:如果至少生成了一個圖形,返回為真;

--Standard_Boolean HasModified()方法:如果至少一個圖形被修改了,返回為真;

--TopTools_ListOfShape& Generated(const TopoDS_Shape& S) 方法:返回生成以后的圖形的集合;

--TopTools_ListOfShape& Modified2(const TopoDS_Shape& aS)方法:返回修改后的圖形的集合;

--Standard_Boolean IsDeleted(const TopoDS_Shape& aS)方法:如果圖形S已經被刪除,返回為真,即結果圖形中不包括圖形S;

-BOP_Operation Operation()方法:返回布爾操作的類型;

布爾操作類

包括有BRepAlgoAPI_Cut類, BRepAlgoAPI_Fuse類,BRepAlgoAPI_Common類:布爾交集;

BRepAlgoAPI_Section

計算兩個圖形或幾何體的截面,幾何對象可以是平面的表面,轉化為face.

示例:

給定兩個圖形S1和S2,計算在S1和S2上的邊,在新曲線上生成近似值,結果在第一部分上而不在第二部分上:

Standard_Boolean PerformNow = Standard_False;

BRepBoolAPI_Section S(S1,S2,PerformNow);

S.ComputePCurveOn1(Standard_True);

S.Approximation(Standard_True);

S.Build();

TopoDS_Shape R = S.Shape();

如果結果為空,調用NotDone();

常見方法:

--BRepAlgoAPI_Section(const Handle(Geom_Surface)& Sf1,const Handle(Geom_Surface)& Sf2,const Standard_Boolean

PerformNow = Standard_True);

用來生成線:

--兩個圖形SH1和SH2;

--圖形SH和平面P1;

--表面SF和圖形SH;

--兩個表面SF1和SF2;

參數PerformNow如果為真,將直接計算結果,如果為假,表示后面將通過Build()這個函數來計算結果;

生成后的圖形是由方法Shape()得出的;

這些相交的邊是獨立的,不在一個鏈表上,也不在一個wire上,如果不存在一個相交邊,返回結果為空;

示例:

--計算相交的基本邊--利用這些基本邊創建一個相交線--決定相交線在兩個圖形的哪個圖形的參數空間;

TopoDS_Shape S1 = ... , S2 = ... ;

Standard_Boolean PerformNow = Standard_False;

BRepAlgoAPI_Section S ( S1, S2, PerformNow );

S.ComputePCurveOn1 (Standard_True);

S.Approximation (Standard_True);

S.Build();

TopoDS_Shape R = S.Shape();

BRepFilletAPI_LocalOperation

基類是BRepBuilderAPI_MakeShape;

構造在一個shell的邊的園角;常用方法有

--void Add(const TopoDS_Edge& E)? = 0;在builder上添加一個輪廓線;

--void ResetContour(const Standard_Integer IC)? = 0;重置索引為IC的輪廓線;

--Standard_Integer NbContours() const = 0;返回輪廓線的數目;

--Standard_Integer Contour(const TopoDS_Edge& E) const = 0;返回邊E的輪廓線的索引,如果邊E不在輪廓線內,返回為O;

--Standard_Integer NbEdges(const Standard_Integer I) const = 0;返回在輪廓線I中的邊數;

--void Remove(const TopoDS_Edge& E)? = 0;移除一個邊;

--Standard_Real Length(const Standard_Integer IC) const = 0;得到某個輪廓線的長度;

--TopoDS_Vertex FirstVertex(const Standard_Integer IC) const = 0;返回某個輪廓線的第一個頂點;LastVertex方法返回最后一個頂點;

--Abscissa方法,返回某個頂點的橫坐標;

--Standard_Boolean ClosedAndTangent(const Standard_Integer IC) const如果某個輪廓線是封閉切線,返回為真;

--Standard_Boolean Closed(const Standard_Integer IC) const = 0;如果某個輪廓線是封閉,返回為真;

--Reset()? = 0;重置所有;

BRepFilletAPI_MakeFillet

創建一個園角;

示例一:

對一個BOX園角:

BRepFilletAPI_MakeFillet fillet(Box);

for (TopExp_Explorer ex(Box,TopAbs_EDGE); ex.More(); ex.Next()) {

TopoDS_Edge Edge =TopoDS::Edge(ex.Current());

fillet.Add(20,Edge);

}

示例二:

兩個BOX,合并后園角;

TopoDS_Shape fusedShape = BRepAlgoAPI_Fuse(S1,S2);

BRepFilletAPI_MakeFillet fill(fusedShape);

for (TopExp_Explorer ex1(fusedShape,TopAbs_EDGE); ex1.More(); ex1.Next()) {

TopoDS_Edge E =TopoDS::Edge(ex1.Current());

fill.Add(E);

}

for (Standard_Integer i = 1;i<=fill.NbContours();i++) {

Standard_Real longueur(fill.Length(i));

Standard_Real Rad(0.15*longueur);

fill.SetRadius(Rad,i, 1);

}

TopoDS_Shape blendedFusedSolids = fill.Shape();

Handle(AIS_Shape) aBlend = new AIS_Shape(blendedFusedSolids);

示例三:

只園角其中一條邊:

BRepFilletAPI_MakeFillet Rake(theBox);

TopExp_Explorer ex(theBox,TopAbs_EDGE);

ex.Next();

ex.Next();

ex.Next();

ex.Next();

Rake.Add(8,50,TopoDS::Edge(ex.Current()));

Rake.Build();

if (Rake.IsDone() ){

TopoDS_Shape evolvedBox = Rake.Shape();

ais1->Set(evolvedBox);

}

示例四:

園角一個園柱:

BRepFilletAPI_MakeFillet fillet(theCylinder);

TColgp_Array1OfPnt2d TabPoint2(1,20);

for (Standard_Integer i=0; i<=19; i++) {

gp_Pnt2d Point2d(i*2*PI/19,60*cos(i*PI/19-PI/2)+10);

TabPoint2.SetValue(i+1,Point2d);

}

TopExp_Explorer exp2(theCylinder,TopAbs_EDGE);

fillet.Add(TabPoint2,TopoDS::Edge(exp2.Current()));

fillet.Build();

if (fillet.IsDone() ){

TopoDS_Shape LawEvolvedCylinder = fillet.Shape();

ais3->Set(LawEvolvedCylinder);

myAISContext->Redisplay(ais3,Standard_False);

myAISContext->SetCurrentObject(ais3,Standard_False);

}

BRepFilletAPI_MakeChamfer

創建一個倒角;

基類:BRepFilletAPI_LocalOperation;

可以設置相關參數,比如倒角兩個距離,角度等參數;

示例:

BRepFilletAPI_MakeChamfer MC(theBox);

// add all the edges to chamfer

TopTools_IndexedDataMapOfShapeListOfShape M;

TopExp::MapShapesAndAncestors(theBox,TopAbs_EDGE,TopAbs_FACE,M);

for (Standard_Integer i = 1;i<=M.Extent();i++) {

TopoDS_Edge E = TopoDS::Edge(M.FindKey(i));

TopoDS_Face F = TopoDS::Face(M.FindFromIndex(i).First());

MC.Add(5,5,E,F);

}

BRepBuilderAPI_MakeShell

生成一個表面的外殼,注意,一個圖形的外殼,不是一個由表面和厚度定義的實體模型,如果想要創建這種殼,需要使用BRepOffsetAPI_MakeOffsetShape,一個外殼是由一系列相互通過普通的邊連接起來的面;如果表面是C2連續的,外殼將只有一個面;如果表面不是C2連續的,將把一些面細分成所有的面都是C2連續的,結果是外殼包含所有這些面;通過一個非C2連續的表面來生成一個外殼,一般過程是:--構造一個外殼對象--實現算法--生成結果;

注意:表面分解的這些C2面并沒有縫合在一起,需要使用BRepOffsetAPI_Sewing,如果想實現帶厚度的外殼,需要使用BRepOffsetAPI_MakeOffsetShape類;

BRepBuilderAPI_Sewing

將多個鄰近圖形“縫合”成為一個圖形;同時有多個邊的情況下無法縫合;

一般操作過程是:

--創建一個空對象;

缺省的公差是1.E-06;

面分析;

縫合操作;

根據需要作剪操作;

--定義公差;

--添加要縫合的對象;

--計算生成;

--輸出結果圖形;

--如果需要可以輸出自由邊;

--如果需要可以輸出多個邊;

--輸出其它問題;

主要方法:

--構造函數:

option1 如果為假表示只控制;

option2:分析退化的圖形;

option3:為自由邊的剪操作;

option4:未復制處理;

BRepBuilderAPI_Sewing(const Standard_Real tolerance = 1.0e-06,const Standard_Boolean option1 = Standard_True,const Standard_Boolean option2 = Standard_True,const Standard_Boolean option3 = Standard_True,const Standard_Boolean option4 = Standard_False);

如果必要,可以初始化參數;

void Init(const Standard_Real tolerance = 1.0e-06,const Standard_Boolean option1 = Standard_True,const Standard_Boolean option2 = Standard_True,const Standard_Boolean option3 = Standard_True,const Standard_Boolean option4 = Standard_False) ;

--添加一個要縫合的圖形的方法是;

void Add(const TopoDS_Shape& shape) ;

--生成圖形方法是:

void Perform() ;

--得到縫合后的圖形方法是:

TopoDS_Shape& SewedShape() const;

--得到自由邊(只被一個面共享的邊)的數量方法是:

Standard_Integer NbFreeEdges() const;

--得到一個自由邊的方法是:

const TopoDS_Edge& FreeEdge(const Standard_Integer index) const;

--得到復合邊(被兩個及以上面共享的邊)的數量:

Standard_Integer NbMultipleEdges() const;

--得到其中的一個復合邊:

const TopoDS_Edge& MultipleEdge(const Standard_Integer index) const;

--得到鄰近邊的數量:

Standard_Integer NbContigousEdges() const;

--得到其中一個鄰近邊:

const TopoDS_Edge& ContigousEdge(const Standard_Integer index) const;

--得到有一個鄰近邊的邊的集合(截面);

const TopTools_ListOfShape& ContigousEdgeCouple(const Standard_Integer index) const;

--一個截面是否是有邊界的(使用SectionToBoundary方法之前):

Standard_Boolean IsSectionBound(const TopoDS_Edge& section) const;

--得到成為截面的原始邊。記住,截面是由普通邊所組成的,這個信息對于控制來說是很重要的,因為通過原始邊可以找到被附加的截面的表面;

const TopoDS_Edge& SectionToBoundary(const TopoDS_Edge& section) const;

--得到每一個退化的圖形:

const TopoDS_Shape& DegeneratedShape(const Standard_Integer index) const;

--此圖形是否是退化的圖形:

Standard_Boolean IsDegenerated(const TopoDS_Shape& shape) const;

--此圖形是否已被修改過:

Standard_Boolean IsModified(const TopoDS_Shape& shape) const;

--得到一個修改后的圖形:

const TopoDS_Shape& Modified(const TopoDS_Shape& shape) const;

--子圖形是否被修改過:

Standard_Boolean IsModifiedSubShape(const TopoDS_Shape& shape) const;

--得到一個修改過的子圖形:

TopoDS_Shape ModifiedSubShape(const TopoDS_Shape& shape) const;

--得到每一個被刪除的面:

const TopoDS_Face& DeletedFace(const Standard_Integer index) const;

--void Dump() const;打印相關信息;

--得到一個修改后的圖形:

TopoDS_Face WhichFace(const TopoDS_Edge& theEdg,const Standard_Integer index = 1) const;

示例:

BRepOffsetAPI_Sewing aMethod;

aMethod.Add(FirstShape);?

aMethod.Add(SecondShape);

aMethod.Perform();

TopoDS_Shape sewedShape = aMethod.SewedShape();

Handle(AIS_Shape) result = new AIS_Shape(sewedShape);

BRep_Tool

提供了處理BRep圖形幾何對象的一些方法;

如果S是一個Solid,Shell,或Compound.返回為真;

Standard_Boolean IsClosed(const TopoDS_Shape& S) ;

返回在位置L處的幾何表面:

Handle_Geom_Surface& Surface(const TopoDS_Face& F,TopLoc_Location& L) ;

返回面的幾何表面,如果有一個位置可以是一個拷貝;

Handle_Geom_Surface Surface(const TopoDS_Face& F) ;

返回面的多邊三角形,如果沒有三角形返回一個空句柄:

const Handle_Poly_Triangulation& Triangulation(const TopoDS_Face& F,TopLoc_Location& L) ;

返加面的公差值:

Standard_Real Tolerance(const TopoDS_Face& F) ;

返回面的自然約束標志:

Standard_Boolean NaturalRestriction(const TopoDS_Face& F) ;

如果E是一個3D曲線或表面上的一個曲線,返回為真;

Standard_Boolean IsGeometric(const TopoDS_Edge& E) ;

返回邊的3D曲線,可以是NULL,返回L位置,及參數范圍;

Handle_Geom_Curve& Curve(const TopoDS_Edge& E,TopLoc_Location& L,Standard_Real& First,Standard_Real& Last) ;

返回邊的3D多邊形,返回多邊形的位置L;

Handle_Poly_Polygon3D& Polygon3D(const TopoDS_Edge& E,TopLoc_Location& L)

TopLoc_Location

一個Location 是一個復合的平移;對象類型是TopLoc_Datum3D;

常見方法:

--TopLoc_Location();

構造一個空的局部坐標系統對象;注意,這種被構造的缺省的數據為空;、

--TopLoc_Location(const gp_Trsf& T);

通過T構造一個局部坐標系統;

--TopLoc_Location(const Handle(TopLoc_Datum3D)& D);

通過3D datum D來構造一個局部坐標系統,如果平移T不能表達一個局部坐標系統,會引發構造異常;

--Standard_Boolean IsIdentity() const;如果此位置等于一個單位化平移,返回為真;

-- void Identity() ;設置位置為單位化平移;

--Handle_TopLoc_Datum3D& FirstDatum() 得到位置的第一個基礎數據;

-- const TopLoc_Location& NextLocation() const;

另外,具有加減乘除,是否相等方法;

示例:

炸開一個立方體的六個面:

for (TopExp_Explorer exp (aBox,TopAbs_FACE);exp.More();exp.Next()) {

TopoDS_Face aCurrentFace = TopoDS::Face(exp.Current());

//測試當前面的方向

TopAbs_Orientation orient = aCurrentFace.Orientation();

//重新生成幾何平面

TopLoc_Location location;

Handle (Geom_Surface) aGeometricSurface = BRep_Tool::Surface(aCurrentFace,location);

Handle (Geom_Plane) aPlane = Handle (Geom_Plane)::DownCast(aGeometricSurface);

//Build an AIS_Shape with a new color

//創建一個新的AIS_Shape

Handle(AIS_Shape) theMovingFace = new AIS_Shape(aCurrentFace);

Quantity_NameOfColor aCurrentColor = (Quantity_NameOfColor)j;

myAISContext->SetColor(theMovingFace,aCurrentColor,Standard_False);

myAISContext->SetMaterial(theMovingFace,Graphic3d_NOM_PLASTIC,Standard_False);?

//查找每個面的法向量

gp_Pln agpPlane = aPlane->Pln();

gp_Ax1 norm = agpPlane.Axis();

gp_Dir dir = norm.Direction();

gp_Vec move(dir);

TopLoc_Location aLocation;

Handle (AIS_ConnectedInteractive) theTransformedDisplay = new AIS_ConnectedInteractive();

theTransformedDisplay->Connect(theMovingFace, aLocation);

// = myAISContext->Location(theMovingFace);

Handle (Geom_Transformation) theMove = new Geom_Transformation(aLocation.Transformation());

for (Standard_Integer i=1;i<=30;i++) {

theMove->SetTranslation(move*i);

if (orient==TopAbs_FORWARD) myAISContext->SetLocation(theTransformedDisplay,TopLoc_Location(theMove->Trsf()));

else myAISContext->SetLocation(theTransformedDisplay,TopLoc_Location(theMove->Inverted()->Trsf()));

myAISContext->Redisplay(theTransformedDisplay,Standard_False);

}

j+=15;

}

BRepAlgo

BRepAlgo提供了一些布爾操作的服務;

注意,在BrepAlgoAPI包中提供了新的布爾操作,代替了舊的布爾操作;

方法:

--static? Standard_Boolean IsValid(const TopoDS_Shape& S) ;檢測圖形是否合法;

--Standard_EXPORT static? Standard_Boolean IsValid(const TopTools_ListOfShape& theArgs,const TopoDS_Shape&

theResult,const Standard_Boolean closedSolid = Standard_False,const Standard_Boolean GeomCtrl = Standard_True) ;

檢查在結果圖形中所生成和修改后的面是否合法,參數theArgs可以為空,表示所有的面都被檢查;如果closedSolid 為真,表示只有封閉的圖形合法,如果參數GeomCtrl為假,幾何體的頂點和邊不檢查,自相交的新的wire也不檢查;

--Standard_Boolean IsTopologicallyValid(const TopoDS_Shape& S) ;

也是檢查圖形是否合法,和前一個不同的是,檢查 no? geometric contols (intersection? of wires, pcurve validity) are

performed.

GProp_GProps

計算圖元的屬性;

gp_Trsf

定義一個矩陣變換的類

--可以定義平移、旋轉、縮放的矩陣;

--可以對稱于一個點,一條線,一個平面;

示例一:

對稱于一個點:

gp_Trsf theTransformation;

gp_Pnt PntCenterOfTheTransformation(110,60,60);

theTransformation.SetMirror(PntCenterOfTheTransformation);

示例二:

繞一個軸旋轉:

gp_Trsf theTransformation;

gp_Ax1 axe = gp_Ax1(gp_Pnt(200,60,60),gp_Dir(0.,1.,0.));

theTransformation.SetRotation(axe,30*PI/180);

示例三:

縮放:

gp_Trsf theTransformation;

gp_Pnt theCenterOfScale(200,60,60);

theTransformation.SetScale(theCenterOfScale,0.5);

示例四:

平移:

gp_Trsf theTransformation;

gp_Vec theVectorOfTranslation(-6,-6,6);

theTransformation.SetTranslation(theVectorOfTranslation);

示例五:

Displacement:

TopoDS_Shape S = BRepPrimAPI_MakeWedge(60.,100.,80.,20.);

gp_Trsf theTransformation;

gp_Ax3 ax3_1(gp_Pnt(0,0,0),gp_Dir(0,0,1));

gp_Ax3 ax3_2(gp_Pnt(60,60,60),gp_Dir(1,1,1));

theTransformation.SetDisplacement(ax3_1,ax3_2);

BRepBuilderAPI_Transform myBRepTransformation(S,theTransformation);

TopoDS_Shape TransformedShape = myBRepTransformation.Shape();

示例六:

變形

gp_GTrsf theTransformation;

gp_Mat rot(1, 0, 0, 0, 0.5, 0, 0, 0, 1.5);

theTransformation.SetVectorialPart(rot);

theTransformation.SetTranslationPart(gp_XYZ(5,5,5));

BRepBuilderAPI_GTransform myBRepTransformation(S,theTransformation);

TopoDS_Shape S2 = myBRepTransformation.Shape();

BuilderAPI_MakeEdge

定義一生成一個邊;此類有多個構造函數,現舉其中一個介紹如下:

Standard_EXPORT BRepBuilderAPI_MakeEdge(const Handle(Geom2d_Curve)& L,const Handle(Geom_Surface)& S,const TopoDS_Vertex& V1,const TopoDS_Vertex& V2,const Standard_Real p1,const Standard_Real p2);

其參數含義是:

頂點V1和V2用來限制曲線(定義邊的約束),值p1和p2為頂點的參數;

曲線可以定義成在一個表面的2D曲線,應用缺省的公差;

參數規則:

對于曲線來說:

--句柄不能為空;

--如果曲線是一個trimmed曲線,使用基礎曲線;

對于頂點來說:

--可以為空,表示此參數為無限大;靜態方法 Precision::Infinite()用來定義一個無限大的數;

--兩個頂點如果位于同一位置,必須一樣,當曲線是封閉時使用相同的頂點;

對于參數來說:

--參數為必須在曲線參數范圍內,如果曲線是trimmed,使用基礎曲線;如果邊的條件不滿足,返回BRepAPI_ParameterOutOfRange錯誤;

--參數值不能相等,如果條件不滿足,邊無法創建,返回BRepAPI_LineThroughIdenticPoints錯誤;

--參數值可以這樣給出C->FirstParameter()

--如果參數值需要切換,比如第一個頂點的參數為P2,第二個頂點的參數為P1,邊的方向可以“reversed”;

--對于一個周期曲線,值P1和P2可以通過加或減周期來得到;

--參數值可以無限大,在對應的方向上邊是開放的。然而,對應的頂點必須是空圖形,如果條件不滿足,邊無法創建,返回BRepAPI_PointWithInfiniteParameter錯誤;

--參數值可以被忽略,將通過曲線上的投影進行計算;

--可以給定空間三維點;

BRepFeat_MakePipe

基類為:BRepFeat_Form;

通過基本圖形生成一個Pipe;

BRepFeat_MakeLinearForm?

基類為:BRepFeat_RibSlot

在一個平面表面上建一個肋或開凹槽;

BRepFeat_Gluer

粘合兩個實體為一個實體;

示例:

(1):創建兩個BOX,并找到要粘合的面;

(2):創建要粘合的對象:

BRepFeat_Gluer glue2(S4,S3);

(3):用兩個面粘合對象;

glue2.Bind(F4,F3);

(4):重新生成對象:

LocOpe_FindEdges CommonEdges(F4,F3);

for (CommonEdges.InitIterator(); CommonEdges.More(); CommonEdges.Next())

glue2.Bind(CommonEdges.EdgeFrom(),CommonEdges.EdgeTo());

TopoDS_Shape res2 = glue2.Shape();

myAISContext->Erase(ais3,Standard_False,Standard_False);

ais4->Set(res2);

myAISContext->Redisplay(ais4,Standard_False);

Graphic2d_Polyline

創建一個多邊形.

常見方法:

--Length()得到線的點數;

--void Values(const Standard_Integer aRank,Quantity_Length& X,Quantity_Length& Y) const;得到序號為aRank的點;

--void DrawElement(const Handle(Graphic2d_Drawer)& aDrawer,const Standard_Integer anIndex) ;繪制多邊形的一條邊;

--void DrawVertex(const Handle(Graphic2d_Drawer)& aDrawer,const Standard_Integer anIndex) ;繪制多邊形的一個頂點;

--Standard_Boolean Pick(const Standard_ShortReal X,const Standard_ShortReal Y,const Standard_ShortReal aPrecision,const Handle(Graphic2d_Drawer)& aDrawer) ;得到此多邊形是否被拾取,注意:PickIndex()方法得到的是最后拾取的點,如果拾取點在線的內部,返回0;

Graphic2d_Line

是Polyline, Circle ... 等圖元的基類;

常見方法:

--SetWidthIndex(const Standard_Integer anIndex) ;得到在width map中的寬度的索引;設定對應的線寬值;

--SetTypeIndex(const Standard_Integer anIndex) ;設置線型;

--SetInteriorColorIndex(const Standard_Integer anIndex) ;設置顏色;

--void SetDrawEdge(const Standard_Boolean aDraw) ;設置邊是否繪出,注意,這種情況下,polygon的類型必須為:

Graphic2d_TOPF_FILLED 或者 Graphic2d_TOPF_PATTERNED;

--SetInteriorPattern(const Standard_Integer anIndex) ;定義封閉線的內部圖案,polygon的填充類型必須是:Graphic2d_TOPF_PATTERNED;

--SetTypeOfPolygonFilling(const Graphic2d_TypeOfPolygonFilling aType) ;定義封閉線的圖案,TypeOfPolygonFilling可選類型有:

- Graphic2d_TOPF_EMPTY - Graphic2d_TOPF_FILLED - Graphic2d_TOPF_PATTERNED ;

--Standard_Integer InteriorColorIndex() const;得到顏色索引;

--Standard_Integer InteriorPattern() const;得到所使用的圖案索引;

--Graphic2d_TypeOfPolygonFilling TypeOfPolygonFilling() const;得到多邊形填充模式;

Graphic2d_Primitive

是Graphic2d_Line類的基類,

常見方法:

--得到及獲取顏色索引;

--得到圖元元素的數量和頂點的數量:

Standard_Integer NumOfElemIndices() const;

Standard_Integer NumOfVertIndices() const;

--Standard_Integer PickedIndex() const;得到最后拾取的圖元元素的索引值;

--void Highlight(const Standard_Integer anIndex = 0) ;高亮顯示圖元或圖元的一部分,當anIndex=0表示所有的圖元高亮顯示,>0為當所要求的圖元元素高亮顯示時,<0為所要求的頂點高亮顯示時;

--void Unhighlight() ;禁止圖元高亮顯示;

-- Standard_Boolean IsHighlighted() const;圖元是否高亮顯示;

--Handle_TColStd_HSequenceOfInteger HighlightIndices() const;得到圖元高亮顯示的索引序列;

--void SetDisplayMode(const Standard_Integer aMode) ;設置圖元顯示的模式;

--Standard_Integer DisplayMode() const;得到圖元顯示的模式;

--Standard_Boolean Graphic2d_GraphicObject::Pick(const Standard_Real X,const Standard_Real Y,const Standard_Real aPrecision,const Handle(Graphic2d_Drawer)& aDrawer) ;

用一個矩形框拾取圖形對象,如果圖形對象被拾取,返回為真,通過方法Graphic2d_View::Pick調用;

--Standard_Boolean Graphic2d_GraphicObject::PickByCircle(const Standard_Real X,const Standard_Real Y,const Standard_Real Radius,const Handle(Graphic2d_Drawer)& aDrawer) ;

用一個園來拾取圖形對象,如果圖形對象被拾取,返回為真,通過方法Graphic2d_View::PickByCircle調用;

--Standard_Boolean Graphic2d_GraphicObject::Pick(const Standard_Real Xmin,const Standard_Real Ymin,const Standard_Real Xmax,const Standard_Real Ymax,const Handle(Graphic2d_Drawer)& aDrawer,const Graphic2d_PickMode aPickMode) ;

以下情況下返回值為真:

包括在矩形內:included in rectangle (),

不在矩形內:excluded from rectangle (),

相交于矩形框:intersected by rectangle (),

通過 Xmin, Ymin, Xmax, Ymax定義矩形框。

--得到所有在圖元內的markers的最小最大值,注意,如果me為空,或未顯示,或沒有markers返回為假,

Minx = Miny = RealFirst () ;Maxx = Maxy = RealLast ()

Standard_EXPORT? Standard_Boolean Graphic2d_GraphicObject::MarkerMinMax(Quantity_Length& Minx,Quantity_Length& Maxx,Quantity_Length& Miny,Quantity_Length& Maxy) const;

--移除圖元;Standard_EXPORT? void Graphic2d_GraphicObject::RemovePrimitive(const Handle(Graphic2d_Primitive)& aPrimitive) ;

--繪制圖元,以默認的圖元屬性繪制;void Graphic2d_TransientManager::Draw(const Handle(Graphic2d_Primitive)& aPrimitive) ;

AIS2D_InteractiveObject

使用顯示和選擇服務,來可視化和選擇機制,交互式對象常用來顯示數據,曲線,圖形,markers,尺寸標注等。

常用方法:

--獲取及設置屬性

Handle_Prs2d_Drawer Attributes() const;

void SetAttributes(const Handle(Prs2d_Drawer)& aDrawer) ;

--通過Aspect設置屬性,到所有圖元分配這個Aspect.

Standard_EXPORT? void SetAspect(const Handle(Prs2d_AspectRoot)& anAspect) ;

--通過Aspect設置屬性,到所有通過InteractiveContext被鏈接的圖元對象;

Standard_EXPORT? void SetAspect(const Handle(Prs2d_AspectRoot)& anAspect,const Handle(Graphic2d_Primitive)& aPrimitive) ;

--得到圖元的Aspect;

Standard_EXPORT? Handle_Prs2d_AspectRoot GetAspect(const Handle(Graphic2d_Primitive)& aPrimitive) const;

--如果圖元用一個aspect鏈接的話返回為真;

Standard_EXPORT? Standard_Boolean HasAspect(const Handle(Graphic2d_Primitive)& aPrimitive) const;

--指出交互對象是否有一個交互上下文設備;

Standard_EXPORT? Standard_Boolean HasInteractiveContext() const;

--得到交互對象的上下文設備;?

Standard_EXPORT? Handle_AIS2D_InteractiveContext GetContext() const;

Graphic2d_GraphicObject

是AIS2D_InteractiveObject類的基類;在一個view內創建一個圖形對象,一個圖形對象管理一系列圖元;默認值為:空,可輸出,可繪制,可拾取,不顯示,不高亮,優先權為0;

主要方法:

設置視圖,設置一個變形,設置獲取圖層,設置獲取優先權,禁用/使用輸出,是否可輸出,禁用/使用Draw.是否可顯示,Erase,高亮顯示,顏色,拾取等;

Graphic2d_ImageFile

定義一個圖像,以圖像的中心位置作為插入點,X,Y定義在模型空間的位置,adx,ady 定義在設備空間的偏移量.ascale定義一個縮放系數;

Aspect_WidthMap

定義一個WidthMap集合對象;

主要方法有,

--添加一個入口:

Standard_Integer AddEntry(const Aspect_WidthOfLine aStyle) ;

void AddEntry(const Aspect_WidthMapEntry& AnEntry) ;

Standard_Integer AddEntry(const Quantity_Length aStyle) ;

--根據索引得到一個入口:

Aspect_WidthMapEntry Entry(const Standard_Integer AnIndex) const;

示例:

--定義private :

Handle(Aspect_WidthMap) myWidthMap;

--遍歷:

for(int i =1;i<=myWidthMap->Size();i++)

{

Aspect_WidthMapEntry aWidthMapEntry = myWidthMap->Entry(i);

}

--得到一個入口:? Aspect_WidthMapEntry aWidthMapEntry = myWidthMap->Entry(CurrentSelectionIndex);

Aspect_TypeMap

定義一個線型集合對象:

Aspect_MarkMap

定義一個MarkMap集合對象;

Aspect_FontMap

定義一個字體集合對象;

Aspect_ColorMap

定義一個顏色集合對象;

GGraphic2d_SetOfCurves

基類是:Graphic2d_Line;

定義一圖元為由多個curves 的集合;主要方法有添加一個curves, 得到curves的數量,得到其中一個curves等;只繪制其中一個元素,是否為拾取狀態;

示例:

Handle(Prs2d_AspectLine) aLineAspect = new Prs2d_AspectLine;?

aLineAspect->SetTypeOfFill(Graphic2d_TOPF_EMPTY);

aLineAspect->SetTypeIndex(...);

aLineAspect->SetColorIndex(...);

aLineAspect->SetWidthIndex(...);

Handle(Graphic2d_SetOfCurves) segment;

segment = new Graphic2d_SetOfCurves(this);

segment->Add(myGeom2dCurve);

將此曲線集合應用所定義的線型線寬等;

SetAspect(aLineAspect, segment);

創建交互式對象相關的類介紹

AIS_Line

此類的繼承關系是:

Standard_Transient->MMgt_TShared->PrsMgr_PresentableObject-->SelectMgr_SelectableObject-->AIS_InteractiveObject->AIS_Line

Standard_Transient:抽象類,主要定義分配空間,得到類型,引用計數等;

MMgt_TShared:抽象類,主要用來管理對象的內存;

PrsMgr_PresentableObject類:表示一個可表達的二維或三維圖形對象;主要方法有設置位置,更新,圖形類型等;

此類的派生類類型有:

-AIS_InteractiveObject

-AIS_ConnectedInteractive

-AIS_MultipleConnectedInteractive

-AIS_Shape

SelectMgr_SelectableObject類:表示一個可選擇的對象;

AIS_LineAIS_Circle等類

定義一個直線,園等;主要方法有,返回對象的類型,設置線寬,線型,顏色等;

示例:

GC_MakeCircle C(gp_Pnt(-100.,-300.,0.),gp_Pnt(-50.,-200.,0.),gp_Pnt(-10.,-250.,0.));

Handle(AIS_Circle) anAISCirc = new AIS_Circle(C.Value());

myAISContext->Display(anAISCirc);

AIS_InteractiveContext

交互式設備類,可以用它來管理交互式圖形對象,可以在一個或多個視圖中。如果圖形對象已經裝入交互式設備,可以直接調用交互式對象的方法。

使用設備時必須區分兩種狀態:

-沒有打開本地設備。也稱為不確定點;

-打開了一個或多個設備;

有的方法可以使用在打開的設備中,有的方法用在關閉的設備中,有的方法與設備狀態無關;

--當想工作在一個入口類型上,應設置選項UseDisplayedObjects為假,可顯示對象可以重新可視化交互對象;

--當使用缺省的選項來打開一個設備時,注意:

:可視化的交互對象在缺省選擇模式下是活動的,必須分離那些不想使用的對象;

:交互式對象可以自動分解為子圖形;

:“臨時的”交互對象不會自動計入總數,,如果想使用它,必須手動裝載它;

使用過程是:

--用正確的選項打開設備;

--裝載/顯示對象;

--如果需要,激活標準模式;

--創建一個過濾器,添加到設備中;

--查找/選擇/重置所需的入口;

--根據索引關閉設備;

--創建一個交互設備編輯器很有用,可以設置不同的設備用不用的選擇/表達方式;

常見方法:

--如果沒有設備打開,交互對象沒有顯示模式,缺省的顯示模式是0,如果一個設備是打開的并且更新為假,對象不會更新顯示。

void Display(const Handle(AIS_InteractiveObject)& anIobj,const Standard_Integer amode,const Standard_Integer

aSelectionMode,const Standard_Boolean updateviewer = Standard_True,const Standard_Boolean allowdecomposition =

Standard_True) ;

--使用給定的選擇模式載入一個交互對象:

void Load(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Integer SelectionMode = -1,const Standard_Boolean

AllowDecomp = Standard_False) ;

--擦除一個對象:如果putinCollector為假,對象被擦除但不放入集合中;

void Erase(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Boolean updateviewer = Standard_True,const

Standard_Boolean PutInCollector = Standard_True) ;

--擦除視圖集合中的每個對象;

void EraseAll(const Standard_Boolean PutInCollector = Standard_True,const Standard_Boolean updateviewer = Standard_True) ;

--從集合中顯示所有對象;

void DisplayAll(const Standard_Boolean OnlyFromCollector = Standard_True,const Standard_Boolean updateviewer =

Standard_True) ;

--從集合中顯示一個對象;

void DisplayFromCollector(const Handle(AIS_InteractiveObject)& anIObj,const Standard_Boolean updateviewer = Standard_True)

--擦除選擇的對象;

void EraseSelected(const Standard_Boolean PutInCollector = Standard_True,const Standard_Boolean updateviewer =

Standard_True) ;

--改變臨時對象的狀態,

Standard_Boolean KeepTemporary(const Handle(AIS_InteractiveObject)& anIObj,const Standard_Integer InWhichLocal = -1) ;

--從所有的視圖中移除交互對象;

void Clear(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Boolean updateviewer = Standard_True) ;

--從每個視圖中移除對象; 

void Remove(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Boolean updateviewer = Standard_True) ;

--從所有打開的設備中移除所有對象;

void RemoveAll(const Standard_Boolean updateviewer = Standard_True) ;

--通過鼠標動態檢測,感知的圖元被高亮顯示。缺省的鼠標移過時的顏色為白色。

void Hilight(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Boolean updateviewer = Standard_True) ;

--改變視圖中線的顏色;

void HilightWithColor(const Handle(AIS_InteractiveObject)& aniobj,const Quantity_NameOfColor aCol,const Standard_Boolean updateviewer = Standard_True) ;

--從入口對象中移除高亮;更新視圖;

void Unhilight(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Boolean updateviewer = Standard_True) ;

--設置顯示的優先權;

void SetDisplayPriority(const Handle(AIS_InteractiveObject)& anIobj,const Standard_Integer aPriority) ;

--設置所看到的交互對象的顯示模式;

void SetDisplayMode(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Integer aMode,const Standard_Boolean

updateviewer = Standard_True) ;

--設置/移除交互對象的選擇模式:

void SetSelectionMode(const Handle(AIS_InteractiveObject)& aniobj,const Standard_Integer aMode) ;

void UnsetSelectionMode(const Handle(AIS_InteractiveObject)& aniobj) ;

--設置感知的精度:

void SetSensitivity(const Standard_Real aPrecision) ;

--定義當前選擇感知的像素:

void SetSensitivity(const Standard_Integer aPrecision = 4) ;

--設置/重置初始圖形的位置;如果有一個位置返回為真;

void SetLocation(const Handle(AIS_InteractiveObject)& aniobj,const TopLoc_Location& aLocation) ;

void ResetLocation(const Handle(AIS_InteractiveObject)& aniobj) ;

Standard_Boolean HasLocation(const Handle(AIS_InteractiveObject)& aniobj) const;

得到實體對象的位置;

const TopLoc_Location& Location(const Handle(AIS_InteractiveObject)& aniobj) const;

--改變當前面的模式;缺省模式是Aspect_TOFM_TWO_SIDE。意味著屬性在前面和后面都應用;

void SetCurrentFacingModel(const Handle(AIS_InteractiveObject)& aniobj,const Aspect_TypeOfFacingModel aModel =

Aspect_TOFM_BOTH_SIDE) ;

--設置/獲得三角形的尺寸,缺省值是100mm.

void SetTrihedronSize(const Standard_Real aSize,const Standard_Boolean updateviewer = Standard_True) ;

Standard_Real TrihedronSize() const;

--設置/獲取平面的尺寸:

Standard_EXPORT? void SetPlaneSize(const Standard_Real aSizeX,const Standard_Real aSizeY,const Standard_Boolean

updateviewer = Standard_True) ;

--得到實體對象的顯示狀態;

AIS_DisplayStatus DisplayStatus(const Handle(AIS_InteractiveObject)& anIobj) const;

--得到實體對象的顯示模式的列表:

const TColStd_ListOfInteger& DisplayedModes(const Handle(AIS_InteractiveObject)& aniobj) const;

--關于繪制隱藏線相關的一些函數,通過名稱就可以知道函數的意思;

EnableDrawHiddenLine();

DisableDrawHiddenLine();

Standard_Boolean DrawHiddenLine();

--設置/得到UV等高參數;等高參數是否可用;

Standard_Integer IsoNumber(const AIS_TypeOfIso WhichIsos = AIS_TOI_Both) ;

--設置/添加/移除當前對象.....

InitCurrent() ;MoreCurrent();NextCurrent();

Standard_Boolean IsCurrent(const Handle(AIS_InteractiveObject)& aniobj) const;

Handle_AIS_InteractiveObject Current() const;

Handle_AIS_InteractiveObject FirstCurrentObject() ;

void HilightCurrents(const Standard_Boolean updateviewer = Standard_True) ;

void UnhilightCurrents(const Standard_Boolean updateviewer = Standard_True) ;

void ClearCurrents(const Standard_Boolean updateviewer = Standard_True) ;

轉載于:https://www.cnblogs.com/xyb617/p/10795042.html

總結

以上是生活随笔為你收集整理的OCCT 基础2的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产精品久久久久久久9999 | 成熟女人特级毛片www免费 | 装睡被陌生人摸出水好爽 | 亚洲成av人片在线观看无码不卡 | 国产两女互慰高潮视频在线观看 | 99久久精品无码一区二区毛片 | 无码吃奶揉捏奶头高潮视频 | 国产亲子乱弄免费视频 | 秋霞特色aa大片 | 亚洲精品鲁一鲁一区二区三区 | 国产免费无码一区二区视频 | 欧美人与动性行为视频 | 无码人妻久久一区二区三区不卡 | 国产人妻人伦精品 | 青青青爽视频在线观看 | 永久免费观看国产裸体美女 | 久久99精品久久久久久 | 国产精品va在线观看无码 | 2020久久超碰国产精品最新 | 在线观看国产午夜福利片 | 亚洲国产成人av在线观看 | 国产精品对白交换视频 | 国产精品久久国产精品99 | 天天拍夜夜添久久精品大 | 曰韩无码二三区中文字幕 | 国产国语老龄妇女a片 | 精品国产一区二区三区四区在线看 | 好爽又高潮了毛片免费下载 | 免费无码的av片在线观看 | 国产香蕉尹人视频在线 | 欧美人妻一区二区三区 | 影音先锋中文字幕无码 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久久国产一区二区三区 | 亚洲aⅴ无码成人网站国产app | 少妇邻居内射在线 | 中文字幕人成乱码熟女app | 欧美日韩色另类综合 | 成熟妇人a片免费看网站 | 男女超爽视频免费播放 | 熟妇人妻激情偷爽文 | yw尤物av无码国产在线观看 | 99久久精品日本一区二区免费 | 夜先锋av资源网站 | 国产成人精品久久亚洲高清不卡 | 亚洲中文字幕乱码av波多ji | 欧美黑人巨大xxxxx | 装睡被陌生人摸出水好爽 | 中文字幕无码av波多野吉衣 | 久久www免费人成人片 | 色婷婷av一区二区三区之红樱桃 | 亚洲国产精品久久人人爱 | 人妻插b视频一区二区三区 | 免费国产黄网站在线观看 | 成人毛片一区二区 | 成年美女黄网站色大免费全看 | 国产97人人超碰caoprom | 中文字幕无码人妻少妇免费 | 久久久精品人妻久久影视 | 亚洲一区av无码专区在线观看 | 激情国产av做激情国产爱 | 国产9 9在线 | 中文 | 日本肉体xxxx裸交 | 狠狠躁日日躁夜夜躁2020 | 亚洲国产欧美国产综合一区 | 成人欧美一区二区三区黑人 | 亚洲色无码一区二区三区 | 精品 日韩 国产 欧美 视频 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲精品一区二区三区在线观看 | 日韩人妻无码一区二区三区久久99 | 牲交欧美兽交欧美 | 国内精品久久久久久中文字幕 | 日本乱偷人妻中文字幕 | 国产熟妇高潮叫床视频播放 | 午夜理论片yy44880影院 | 狠狠亚洲超碰狼人久久 | 领导边摸边吃奶边做爽在线观看 | 99国产欧美久久久精品 | 久久这里只有精品视频9 | 午夜精品久久久久久久久 | 爽爽影院免费观看 | 少妇愉情理伦片bd | 无遮挡啪啪摇乳动态图 | www国产亚洲精品久久网站 | 97精品国产97久久久久久免费 | 亚洲中文字幕无码中字 | 精品厕所偷拍各类美女tp嘘嘘 | 欧美日韩一区二区综合 | 国产三级久久久精品麻豆三级 | 国产精品亚洲专区无码不卡 | 中文字幕+乱码+中文字幕一区 | 久久久久久国产精品无码下载 | 亚洲日本在线电影 | 中文字幕无码免费久久9一区9 | 国内综合精品午夜久久资源 | 草草网站影院白丝内射 | 奇米影视7777久久精品 | 无码免费一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | 久久99久久99精品中文字幕 | 久久zyz资源站无码中文动漫 | аⅴ资源天堂资源库在线 | 国产精品久久福利网站 | 欧美老妇交乱视频在线观看 | 四虎4hu永久免费 | 欧美国产日韩亚洲中文 | 久久亚洲日韩精品一区二区三区 | 久久久久久久人妻无码中文字幕爆 | 国产人成高清在线视频99最全资源 | 中文字幕人妻无码一夲道 | 狠狠cao日日穞夜夜穞av | 丝袜 中出 制服 人妻 美腿 | 久久精品女人天堂av免费观看 | 少妇高潮一区二区三区99 | 国语自产偷拍精品视频偷 | 亚洲日韩中文字幕在线播放 | 国产免费久久精品国产传媒 | 网友自拍区视频精品 | 午夜无码区在线观看 | 精品国产青草久久久久福利 | 爽爽影院免费观看 | 精品午夜福利在线观看 | 精品国精品国产自在久国产87 | av在线亚洲欧洲日产一区二区 | 亚洲欧美精品伊人久久 | 人人妻人人澡人人爽欧美精品 | 欧美人妻一区二区三区 | 露脸叫床粗话东北少妇 | 国产精品办公室沙发 | 免费观看又污又黄的网站 | 大肉大捧一进一出好爽视频 | 国产激情艳情在线看视频 | 久久久久成人片免费观看蜜芽 | 日日夜夜撸啊撸 | 中文字幕人妻丝袜二区 | 一区二区三区高清视频一 | 97久久精品无码一区二区 | 熟女少妇在线视频播放 | 国产成人人人97超碰超爽8 | 夫妻免费无码v看片 | 国产激情艳情在线看视频 | 亚洲乱码国产乱码精品精 | 日韩欧美群交p片內射中文 | 成人精品一区二区三区中文字幕 | 久久精品一区二区三区四区 | 亚洲一区av无码专区在线观看 | 大肉大捧一进一出视频出来呀 | 天天躁日日躁狠狠躁免费麻豆 | 人人妻人人澡人人爽精品欧美 | 欧美乱妇无乱码大黄a片 | 亚洲爆乳精品无码一区二区三区 | 久久无码专区国产精品s | 国产97人人超碰caoprom | 精品一区二区不卡无码av | 亚洲欧洲日本综合aⅴ在线 | 国产人妻精品一区二区三区不卡 | 九月婷婷人人澡人人添人人爽 | 51国偷自产一区二区三区 | av在线亚洲欧洲日产一区二区 | 亚洲精品欧美二区三区中文字幕 | 真人与拘做受免费视频一 | 人妻少妇精品视频专区 | 在线亚洲高清揄拍自拍一品区 | 亚洲gv猛男gv无码男同 | 奇米影视7777久久精品人人爽 | 亚洲精品成a人在线观看 | 亚洲国精产品一二二线 | 亚洲精品国产第一综合99久久 | 国产口爆吞精在线视频 | 国产精品igao视频网 | 欧美兽交xxxx×视频 | 中文字幕无码日韩专区 | 欧美高清在线精品一区 | 天天爽夜夜爽夜夜爽 | 欧美刺激性大交 | 无码人妻丰满熟妇区五十路百度 | 欧美激情内射喷水高潮 | 风流少妇按摩来高潮 | 日韩少妇白浆无码系列 | 成人无码视频免费播放 | 日产精品99久久久久久 | 曰本女人与公拘交酡免费视频 | 麻豆国产97在线 | 欧洲 | 少妇高潮一区二区三区99 | 婷婷色婷婷开心五月四房播播 | 欧美性猛交内射兽交老熟妇 | 亚洲人成人无码网www国产 | 久青草影院在线观看国产 | 麻豆成人精品国产免费 | 国产又粗又硬又大爽黄老大爷视 | 老头边吃奶边弄进去呻吟 | 国产亚洲精品久久久闺蜜 | 亚洲人交乣女bbw | 欧美日本精品一区二区三区 | 亚洲日韩精品欧美一区二区 | 精品人妻中文字幕有码在线 | 午夜丰满少妇性开放视频 | 女人被男人躁得好爽免费视频 | 噜噜噜亚洲色成人网站 | 青草青草久热国产精品 | 日韩精品无码免费一区二区三区 | 成人亚洲精品久久久久 | 亚洲中文字幕无码中字 | 人人爽人人澡人人人妻 | 国产精品内射视频免费 | 久久99久久99精品中文字幕 | 帮老师解开蕾丝奶罩吸乳网站 | 国产成人亚洲综合无码 | 午夜丰满少妇性开放视频 | 久久综合网欧美色妞网 | 日本xxxx色视频在线观看免费 | 精品乱码久久久久久久 | 久久午夜夜伦鲁鲁片无码免费 | 国产精品久久久久久亚洲影视内衣 | 日韩人妻无码中文字幕视频 | 水蜜桃色314在线观看 | 丝袜 中出 制服 人妻 美腿 | 人妻无码αv中文字幕久久琪琪布 | 纯爱无遮挡h肉动漫在线播放 | 国产在线aaa片一区二区99 | 免费无码的av片在线观看 | 成人精品视频一区二区三区尤物 | 大胆欧美熟妇xx | 婷婷六月久久综合丁香 | 午夜熟女插插xx免费视频 | 少妇高潮一区二区三区99 | 国产成人一区二区三区别 | 欧美 日韩 亚洲 在线 | 欧洲欧美人成视频在线 | 美女黄网站人色视频免费国产 | 日韩精品无码一本二本三本色 | 国产精品久免费的黄网站 | 国产av一区二区三区最新精品 | 东京热男人av天堂 | 亚洲日韩精品欧美一区二区 | 欧美性色19p | 亚洲熟悉妇女xxx妇女av | 亚洲日韩av片在线观看 | 成年美女黄网站色大免费全看 | 欧美成人午夜精品久久久 | 色偷偷人人澡人人爽人人模 | 亚洲人成网站在线播放942 | 久久久婷婷五月亚洲97号色 | 超碰97人人做人人爱少妇 | 偷窥日本少妇撒尿chinese | 色欲av亚洲一区无码少妇 | 日本精品人妻无码免费大全 | 国产亚av手机在线观看 | 在线欧美精品一区二区三区 | 久久久www成人免费毛片 | 亚洲中文字幕乱码av波多ji | 99精品无人区乱码1区2区3区 | 少妇人妻偷人精品无码视频 | 超碰97人人做人人爱少妇 | 蜜臀av无码人妻精品 | 强开小婷嫩苞又嫩又紧视频 | 国产后入清纯学生妹 | 日韩 欧美 动漫 国产 制服 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲人成无码网www | 国产精品18久久久久久麻辣 | 55夜色66夜色国产精品视频 | 精品亚洲韩国一区二区三区 | 丰满岳乱妇在线观看中字无码 | 国产特级毛片aaaaaa高潮流水 | 国产精品久久久久9999小说 | 精品无码成人片一区二区98 | 十八禁视频网站在线观看 | 亚洲欧洲无卡二区视頻 | 欧美zoozzooz性欧美 | 欧美喷潮久久久xxxxx | 国产亲子乱弄免费视频 | 曰韩无码二三区中文字幕 | 又色又爽又黄的美女裸体网站 | 国产精品va在线观看无码 | 国产午夜亚洲精品不卡下载 | 一二三四在线观看免费视频 | 无码乱肉视频免费大全合集 | 欧洲美熟女乱又伦 | 亚洲国产精品久久人人爱 | 性做久久久久久久免费看 | 色一情一乱一伦一区二区三欧美 | 呦交小u女精品视频 | 亚洲一区二区三区在线观看网站 | 内射欧美老妇wbb | 日本乱偷人妻中文字幕 | 成人无码精品1区2区3区免费看 | 国产高清不卡无码视频 | 久久人人爽人人爽人人片ⅴ | 婷婷六月久久综合丁香 | 老头边吃奶边弄进去呻吟 | 欧美老熟妇乱xxxxx | 日韩欧美成人免费观看 | 熟妇激情内射com | 久精品国产欧美亚洲色aⅴ大片 | 性生交大片免费看l | 亚洲经典千人经典日产 | 亚洲区欧美区综合区自拍区 | 亚洲综合伊人久久大杳蕉 | 亚洲男女内射在线播放 | 欧美喷潮久久久xxxxx | 亚洲人亚洲人成电影网站色 | 日本va欧美va欧美va精品 | 中文字幕无码乱人伦 | 精品无码一区二区三区的天堂 | 我要看www免费看插插视频 | 国产成人精品必看 | 国产精品久久国产三级国 | 在线观看欧美一区二区三区 | 未满小14洗澡无码视频网站 | 日日碰狠狠躁久久躁蜜桃 | 国产人妻久久精品二区三区老狼 | 中文字幕人妻无码一区二区三区 | 亚洲日本va中文字幕 | 沈阳熟女露脸对白视频 | 内射爽无广熟女亚洲 | 久久精品国产大片免费观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 免费人成网站视频在线观看 | 野狼第一精品社区 | 无码精品国产va在线观看dvd | 帮老师解开蕾丝奶罩吸乳网站 | 精品久久久久久人妻无码中文字幕 | 在线看片无码永久免费视频 | 亚洲色无码一区二区三区 | 日韩人妻无码中文字幕视频 | 亚洲一区二区三区含羞草 | 樱花草在线社区www | 国产舌乚八伦偷品w中 | 88国产精品欧美一区二区三区 | 性啪啪chinese东北女人 | 又大又硬又爽免费视频 | 欧美黑人乱大交 | 国产亚洲日韩欧美另类第八页 | 亚洲人成影院在线观看 | 中文字幕乱妇无码av在线 | 国产凸凹视频一区二区 | 最近免费中文字幕中文高清百度 | 亚洲日本在线电影 | 一本久久伊人热热精品中文字幕 | 无码纯肉视频在线观看 | 色五月丁香五月综合五月 | 性欧美牲交xxxxx视频 | 午夜精品一区二区三区在线观看 | 色一情一乱一伦一视频免费看 | 国产精品美女久久久 | 国产成人无码专区 | 久久无码专区国产精品s | 久久精品女人的天堂av | 亚洲精品国偷拍自产在线麻豆 | 奇米影视7777久久精品人人爽 | 亚洲精品一区二区三区大桥未久 | 国产av人人夜夜澡人人爽麻豆 | 亚洲精品综合五月久久小说 | 少妇无套内谢久久久久 | 日韩欧美群交p片內射中文 | 国模大胆一区二区三区 | 乱人伦人妻中文字幕无码久久网 | 在线播放无码字幕亚洲 | 无码国产乱人伦偷精品视频 | 成人无码视频在线观看网站 | 国产suv精品一区二区五 | 国精产品一区二区三区 | 国产香蕉尹人综合在线观看 | 青青青爽视频在线观看 | 久久 国产 尿 小便 嘘嘘 | 麻豆国产人妻欲求不满谁演的 | 给我免费的视频在线观看 | 精品一区二区三区无码免费视频 | 久久久久久亚洲精品a片成人 | 国产美女精品一区二区三区 | 亚洲小说春色综合另类 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产亲子乱弄免费视频 | 中文字幕无码av波多野吉衣 | 人人妻人人澡人人爽欧美一区 | 欧美黑人巨大xxxxx | 一本一道久久综合久久 | yw尤物av无码国产在线观看 | 久久久久亚洲精品男人的天堂 | 亚洲熟妇色xxxxx亚洲 | 国产真实乱对白精彩久久 | 奇米影视888欧美在线观看 | 欧美阿v高清资源不卡在线播放 | 少妇性俱乐部纵欲狂欢电影 | 欧美自拍另类欧美综合图片区 | 国内精品久久久久久中文字幕 | 性欧美牲交在线视频 | 欧美午夜特黄aaaaaa片 | 日韩人妻无码一区二区三区久久99 | 国产69精品久久久久app下载 | 国产成人精品必看 | 久久久久久久人妻无码中文字幕爆 | 亚洲自偷自拍另类第1页 | 午夜熟女插插xx免费视频 | 亚洲国产午夜精品理论片 | 成人无码精品一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 成人毛片一区二区 | 少妇人妻偷人精品无码视频 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 99在线 | 亚洲 | 熟妇人妻中文av无码 | 日本xxxx色视频在线观看免费 | 亚洲欧美日韩成人高清在线一区 | 亚洲乱码日产精品bd | 国产特级毛片aaaaaaa高清 | 人人妻人人澡人人爽欧美一区九九 | 天天综合网天天综合色 | 亚洲人成网站色7799 | 性欧美大战久久久久久久 | 国产区女主播在线观看 | 国产美女精品一区二区三区 | aa片在线观看视频在线播放 | 97无码免费人妻超级碰碰夜夜 | 欧美激情一区二区三区成人 | 亚洲日本一区二区三区在线 | 成在人线av无码免费 | 亚洲男女内射在线播放 | 2020久久超碰国产精品最新 | 亚洲精品中文字幕久久久久 | 国产精品久久久久久无码 | 亚洲精品一区二区三区四区五区 | 丁香啪啪综合成人亚洲 | 日日麻批免费40分钟无码 | 国产无遮挡吃胸膜奶免费看 | 中文字幕无码av波多野吉衣 | 人人妻人人澡人人爽人人精品 | 国产亚洲精品久久久ai换 | 日本丰满护士爆乳xxxx | 青青青手机频在线观看 | 欧美熟妇另类久久久久久不卡 | 爱做久久久久久 | 国产午夜无码精品免费看 | 男人扒开女人内裤强吻桶进去 | 熟妇人妻无码xxx视频 | 奇米影视888欧美在线观看 | 人妻无码αv中文字幕久久琪琪布 | aa片在线观看视频在线播放 | 国语精品一区二区三区 | 奇米影视7777久久精品人人爽 | 色情久久久av熟女人妻网站 | 欧美三级a做爰在线观看 | 欧美日韩一区二区综合 | 国産精品久久久久久久 | 国产超级va在线观看视频 | 初尝人妻少妇中文字幕 | 麻豆国产人妻欲求不满 | 久久综合久久自在自线精品自 | 欧美日韩视频无码一区二区三 | 日日天干夜夜狠狠爱 | 欧美精品免费观看二区 | 亚洲日韩av片在线观看 | 日日摸日日碰夜夜爽av | 久久无码中文字幕免费影院蜜桃 | 高潮毛片无遮挡高清免费视频 | 欧美精品一区二区精品久久 | 超碰97人人做人人爱少妇 | 亚洲欧美日韩成人高清在线一区 | 美女毛片一区二区三区四区 | 性欧美牲交在线视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲国产欧美在线成人 | 奇米影视7777久久精品人人爽 | 亚洲a无码综合a国产av中文 | 色五月丁香五月综合五月 | 色情久久久av熟女人妻网站 | a国产一区二区免费入口 | 欧美三级a做爰在线观看 | 三上悠亚人妻中文字幕在线 | 欧美放荡的少妇 | 性开放的女人aaa片 | 捆绑白丝粉色jk震动捧喷白浆 | 久久精品成人欧美大片 | 国产精品国产三级国产专播 | 中文字幕人妻无码一区二区三区 | 国产激情艳情在线看视频 | 久久久久久a亚洲欧洲av冫 | 国产亚洲精品久久久久久久 | 久久精品国产亚洲精品 | 国产成人无码区免费内射一片色欲 | 成人性做爰aaa片免费看 | 玩弄少妇高潮ⅹxxxyw | 久久久精品成人免费观看 | 国产成人综合在线女婷五月99播放 | 高清国产亚洲精品自在久久 | 色欲人妻aaaaaaa无码 | 精品国产一区二区三区四区在线看 | 久久久精品人妻久久影视 | 欧美日韩一区二区三区自拍 | 性欧美牲交在线视频 | 国产亚洲视频中文字幕97精品 | 午夜无码区在线观看 | 免费播放一区二区三区 | 无码乱肉视频免费大全合集 | 激情人妻另类人妻伦 | 国产精品久久福利网站 | 国产午夜福利100集发布 | 精品一二三区久久aaa片 | 亚洲国产精品无码久久久久高潮 | 性欧美videos高清精品 | 巨爆乳无码视频在线观看 | 国产精品人妻一区二区三区四 | 性色欲情网站iwww九文堂 | 99国产精品白浆在线观看免费 | 少妇无码av无码专区在线观看 | 精品一二三区久久aaa片 | 1000部夫妻午夜免费 | 中文字幕无码热在线视频 | 国产免费无码一区二区视频 | 欧美日韩一区二区免费视频 | 天天做天天爱天天爽综合网 | 亚洲va欧美va天堂v国产综合 | 国产成人亚洲综合无码 | 色婷婷久久一区二区三区麻豆 | 国产一区二区三区精品视频 | 精品国产精品久久一区免费式 | 国产精品高潮呻吟av久久 | 丰满人妻被黑人猛烈进入 | 蜜臀aⅴ国产精品久久久国产老师 | 高潮毛片无遮挡高清免费视频 | 成人精品视频一区二区 | 免费人成在线观看网站 | 中文字幕人妻无码一区二区三区 | 国产手机在线αⅴ片无码观看 | 久久精品国产精品国产精品污 | 亚洲欧美综合区丁香五月小说 | 欧美怡红院免费全部视频 | 国产手机在线αⅴ片无码观看 | аⅴ资源天堂资源库在线 | 一区二区三区高清视频一 | 丰满妇女强制高潮18xxxx | 丰满少妇人妻久久久久久 | 国产无遮挡又黄又爽免费视频 | 久久婷婷五月综合色国产香蕉 | 国产97在线 | 亚洲 | 国产欧美精品一区二区三区 | 在线观看国产午夜福利片 | 国产乱人无码伦av在线a | 亚洲の无码国产の无码步美 | 免费国产成人高清在线观看网站 | 久久精品中文字幕大胸 | 国产电影无码午夜在线播放 | 亚洲人成影院在线无码按摩店 | 欧美国产日韩久久mv | 日欧一片内射va在线影院 | 精品成在人线av无码免费看 | 黑人粗大猛烈进出高潮视频 | 极品嫩模高潮叫床 | 亚洲欧洲中文日韩av乱码 | 国产在线无码精品电影网 | 乌克兰少妇性做爰 | 色欲久久久天天天综合网精品 | v一区无码内射国产 | 性欧美熟妇videofreesex | 老熟妇乱子伦牲交视频 | 色噜噜亚洲男人的天堂 | 日本丰满熟妇videos | 成 人影片 免费观看 | 亚洲国产精品无码一区二区三区 | 少妇愉情理伦片bd | 国产激情一区二区三区 | 99国产欧美久久久精品 | 一个人看的视频www在线 | 国产香蕉尹人综合在线观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产成人精品久久亚洲高清不卡 | 亚洲人成无码网www | 一本色道久久综合亚洲精品不卡 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产亚洲精品精品国产亚洲综合 | 精品久久久无码中文字幕 | 亚洲熟悉妇女xxx妇女av | 久久综合九色综合97网 | 色五月五月丁香亚洲综合网 | 国产熟妇另类久久久久 | 国产一区二区三区影院 | 白嫩日本少妇做爰 | 成人三级无码视频在线观看 | 日韩人妻无码一区二区三区久久99 | 国内精品人妻无码久久久影院蜜桃 | 水蜜桃亚洲一二三四在线 | 国产极品美女高潮无套在线观看 | 欧美性生交活xxxxxdddd | 性欧美videos高清精品 | 亚洲色偷偷偷综合网 | 国产精品嫩草久久久久 | 久久无码中文字幕免费影院蜜桃 | 久久精品人妻少妇一区二区三区 | 人人妻人人澡人人爽人人精品浪潮 | 7777奇米四色成人眼影 | 国产内射老熟女aaaa | 国产精品无码一区二区三区不卡 | 日日摸夜夜摸狠狠摸婷婷 | 丰腴饱满的极品熟妇 | 成人无码精品一区二区三区 | www国产精品内射老师 | 国产色在线 | 国产 | 国产一区二区三区精品视频 | 欧美zoozzooz性欧美 | 人人妻人人藻人人爽欧美一区 | 对白脏话肉麻粗话av | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲の无码国产の无码影院 | 黑人粗大猛烈进出高潮视频 | 乱人伦人妻中文字幕无码久久网 | 亚洲熟女一区二区三区 | 精品无码一区二区三区的天堂 | 午夜精品久久久久久久 | av小次郎收藏 | 黑人巨大精品欧美一区二区 | 国产成人精品无码播放 | 国内精品久久久久久中文字幕 | 人妻天天爽夜夜爽一区二区 | 亚洲日本va午夜在线电影 | 伊人久久大香线蕉亚洲 | 精品少妇爆乳无码av无码专区 | 成人无码精品1区2区3区免费看 | 中文字幕无线码 | 欧美成人午夜精品久久久 | 久久精品国产日本波多野结衣 | 国产后入清纯学生妹 | 国产电影无码午夜在线播放 | 亚洲无人区午夜福利码高清完整版 | 久久亚洲中文字幕无码 | 在教室伦流澡到高潮hnp视频 | 麻豆国产97在线 | 欧洲 | 男人和女人高潮免费网站 | 国产精品无码一区二区桃花视频 | 一本精品99久久精品77 | 麻豆av传媒蜜桃天美传媒 | 国产精品无套呻吟在线 | 亚洲人成人无码网www国产 | 少妇无码一区二区二三区 | 黑人玩弄人妻中文在线 | 欧美 丝袜 自拍 制服 另类 | 无码国内精品人妻少妇 | 秋霞特色aa大片 | 99国产欧美久久久精品 | 又粗又大又硬毛片免费看 | 精品国产一区二区三区四区在线看 | 在线天堂新版最新版在线8 | 色欲久久久天天天综合网精品 | 国产精品久久久一区二区三区 | 噜噜噜亚洲色成人网站 | √天堂中文官网8在线 | 欧美变态另类xxxx | 色老头在线一区二区三区 | 欧美老妇交乱视频在线观看 | 亚洲精品鲁一鲁一区二区三区 | 国产精品久久久久久久9999 | 久久www免费人成人片 | 一个人看的www免费视频在线观看 | 白嫩日本少妇做爰 | 国内精品一区二区三区不卡 | 日本一区二区三区免费播放 | 欧美阿v高清资源不卡在线播放 | 高中生自慰www网站 | 国产黑色丝袜在线播放 | 人妻少妇精品无码专区动漫 | 精品aⅴ一区二区三区 | 久久97精品久久久久久久不卡 | 一二三四在线观看免费视频 | 兔费看少妇性l交大片免费 | 亚洲色大成网站www | 国产精品亚洲综合色区韩国 | 精品无人区无码乱码毛片国产 | 玩弄人妻少妇500系列视频 | 国产成人久久精品流白浆 | 国产人妻人伦精品1国产丝袜 | 日本熟妇乱子伦xxxx | 无码人妻精品一区二区三区下载 | 男女作爱免费网站 | 最新国产麻豆aⅴ精品无码 | 黑人玩弄人妻中文在线 | 精品久久久无码中文字幕 | av无码不卡在线观看免费 | 欧美日韩视频无码一区二区三 | 国产成人精品三级麻豆 | 熟妇人妻无码xxx视频 | 最新国产乱人伦偷精品免费网站 | 亚洲色欲久久久综合网东京热 | 国产精品无码永久免费888 | 男女超爽视频免费播放 | 无套内谢的新婚少妇国语播放 | 熟妇女人妻丰满少妇中文字幕 | 高清无码午夜福利视频 | 国产av一区二区精品久久凹凸 | 国产精品对白交换视频 | 久久无码中文字幕免费影院蜜桃 | 少妇人妻大乳在线视频 | 欧美老妇与禽交 | 久久国产劲爆∧v内射 | 四虎国产精品一区二区 | 成人亚洲精品久久久久软件 | 蜜臀aⅴ国产精品久久久国产老师 | 亚洲色欲久久久综合网东京热 | 国产乱子伦视频在线播放 | 一本久道久久综合婷婷五月 | 国产精品久久久久久无码 | 日韩av激情在线观看 | 人妻夜夜爽天天爽三区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 日产国产精品亚洲系列 | 97久久国产亚洲精品超碰热 | 亚洲の无码国产の无码影院 | 国产精品无码永久免费888 | 噜噜噜亚洲色成人网站 | 日本精品人妻无码77777 天堂一区人妻无码 | 日本精品人妻无码免费大全 | 精品亚洲韩国一区二区三区 | 久久精品国产99久久6动漫 | 丰满少妇熟乱xxxxx视频 | 亚洲欧洲日本无在线码 | 在线观看国产一区二区三区 | 色婷婷香蕉在线一区二区 | 国产97在线 | 亚洲 | 国产精品亚洲一区二区三区喷水 | 小sao货水好多真紧h无码视频 | 成人无码精品一区二区三区 | 天堂在线观看www | 欧美性猛交xxxx富婆 | 色情久久久av熟女人妻网站 | 久久国产精品偷任你爽任你 | 波多野结衣乳巨码无在线观看 | 自拍偷自拍亚洲精品10p | 丰满少妇熟乱xxxxx视频 | 免费网站看v片在线18禁无码 | 97夜夜澡人人双人人人喊 | 久久99精品国产麻豆蜜芽 | 国产亚洲tv在线观看 | 亚洲人成影院在线无码按摩店 | 欧美国产日韩亚洲中文 | 女人和拘做爰正片视频 | 欧美人妻一区二区三区 | 久久人人97超碰a片精品 | 免费人成网站视频在线观看 | 99久久婷婷国产综合精品青草免费 | 精品久久久中文字幕人妻 | 久久久久久国产精品无码下载 | 日本一卡二卡不卡视频查询 | 欧美 日韩 亚洲 在线 | 亚洲无人区一区二区三区 | 成人片黄网站色大片免费观看 | 国产av无码专区亚洲awww | 国产精品久久久午夜夜伦鲁鲁 | 人人爽人人爽人人片av亚洲 | 精品无码一区二区三区爱欲 | 国产又爽又猛又粗的视频a片 | 在线成人www免费观看视频 | 国产高潮视频在线观看 | 在线欧美精品一区二区三区 | 国产精品嫩草久久久久 | 成熟人妻av无码专区 | 欧美精品在线观看 | 中文字幕乱码中文乱码51精品 | 日本精品少妇一区二区三区 | 中文字幕亚洲情99在线 | 双乳奶水饱满少妇呻吟 | 免费无码一区二区三区蜜桃大 | 国产色视频一区二区三区 | 国产av无码专区亚洲awww | 久久亚洲a片com人成 | 日韩av激情在线观看 | 久久久久se色偷偷亚洲精品av | 4hu四虎永久在线观看 | 日本一卡2卡3卡四卡精品网站 | 东京无码熟妇人妻av在线网址 | 久久国产自偷自偷免费一区调 | 亚洲区欧美区综合区自拍区 | 亚洲爆乳大丰满无码专区 | 无码一区二区三区在线观看 | 亚洲 欧美 激情 小说 另类 | 国产成人综合色在线观看网站 | 一个人免费观看的www视频 | 亚洲国产日韩a在线播放 | 国产国产精品人在线视 | 午夜精品久久久久久久久 | 鲁鲁鲁爽爽爽在线视频观看 | 日本欧美一区二区三区乱码 | 丰满妇女强制高潮18xxxx | 鲁鲁鲁爽爽爽在线视频观看 | 水蜜桃色314在线观看 | 老司机亚洲精品影院 | 中文字幕乱码人妻无码久久 | 久久午夜无码鲁丝片秋霞 | 国产亲子乱弄免费视频 | 久久亚洲日韩精品一区二区三区 | 国产精品高潮呻吟av久久4虎 | 欧美人与物videos另类 | 国産精品久久久久久久 | 国产成人综合在线女婷五月99播放 | 最近免费中文字幕中文高清百度 | 高潮毛片无遮挡高清免费视频 | 久久99精品国产.久久久久 | 狂野欧美性猛xxxx乱大交 | 中文字幕人妻无码一区二区三区 | 亚洲精品国产a久久久久久 | 亚洲成在人网站无码天堂 | 无码国产色欲xxxxx视频 | 野外少妇愉情中文字幕 | 99久久久无码国产精品免费 | 露脸叫床粗话东北少妇 | 久久精品国产99久久6动漫 | 爽爽影院免费观看 | 国产精品18久久久久久麻辣 | 国产精品理论片在线观看 | 精品国产一区二区三区av 性色 | 日日天干夜夜狠狠爱 | 国产人妻精品一区二区三区 | 波多野结衣aⅴ在线 | 国产在线一区二区三区四区五区 | 精品国产国产综合精品 | 精品人妻人人做人人爽 | 国产精品久久久久久亚洲影视内衣 | 日欧一片内射va在线影院 | 成人无码影片精品久久久 | 亚洲成色在线综合网站 | 国产无av码在线观看 | 高潮毛片无遮挡高清免费视频 | 欧美三级a做爰在线观看 | 无码午夜成人1000部免费视频 | 性开放的女人aaa片 | 亚洲欧美综合区丁香五月小说 | 日本一区二区三区免费播放 | 中文字幕乱码人妻无码久久 | 一二三四社区在线中文视频 | 色五月五月丁香亚洲综合网 | 97无码免费人妻超级碰碰夜夜 | 色综合视频一区二区三区 | 国产精品第一区揄拍无码 | 亚洲码国产精品高潮在线 | 少妇被粗大的猛进出69影院 | 欧美性生交活xxxxxdddd | 无码毛片视频一区二区本码 | 亚洲 日韩 欧美 成人 在线观看 | 国产激情精品一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 国产福利视频一区二区 | 国产在线aaa片一区二区99 | 曰韩少妇内射免费播放 | 亚洲欧美日韩综合久久久 | 三级4级全黄60分钟 | 99久久精品国产一区二区蜜芽 | 精品成人av一区二区三区 | 成人性做爰aaa片免费看 | 中文字幕+乱码+中文字幕一区 | 99久久精品国产一区二区蜜芽 | 88国产精品欧美一区二区三区 | 一二三四社区在线中文视频 | 欧美成人高清在线播放 | 中文字幕无码av激情不卡 | 国产suv精品一区二区五 | 国产成人综合在线女婷五月99播放 | 亚洲a无码综合a国产av中文 | 99久久亚洲精品无码毛片 | 国产精品久久久久影院嫩草 | 欧美日本免费一区二区三区 | 欧美国产日产一区二区 | 丰满少妇女裸体bbw | 久久国内精品自在自线 | 国产精品久久久av久久久 | 色综合久久久久综合一本到桃花网 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 综合人妻久久一区二区精品 | 少妇性俱乐部纵欲狂欢电影 | 亚洲最大成人网站 | 无码播放一区二区三区 | 成人免费视频一区二区 | 国产在线精品一区二区高清不卡 | 天天摸天天碰天天添 | 人人超人人超碰超国产 | 亚洲精品国产a久久久久久 | 成人性做爰aaa片免费看不忠 | 国产国语老龄妇女a片 | 色老头在线一区二区三区 | 午夜精品久久久内射近拍高清 | 久久久久久亚洲精品a片成人 | 天干天干啦夜天干天2017 | 亚洲中文字幕久久无码 | 欧美人妻一区二区三区 | 内射巨臀欧美在线视频 | 久久精品国产99精品亚洲 | 亚洲成在人网站无码天堂 | 纯爱无遮挡h肉动漫在线播放 | 人人澡人摸人人添 | 午夜精品一区二区三区在线观看 | 亚洲精品久久久久中文第一幕 | 国产成人无码av片在线观看不卡 | 一本加勒比波多野结衣 | 久久zyz资源站无码中文动漫 | 黑人玩弄人妻中文在线 | 在线成人www免费观看视频 | 亚洲熟妇色xxxxx欧美老妇 | 无套内射视频囯产 | 天天拍夜夜添久久精品 | 久久久久久国产精品无码下载 | 高潮毛片无遮挡高清免费 | 欧美老熟妇乱xxxxx | 无码帝国www无码专区色综合 | 日日摸夜夜摸狠狠摸婷婷 | 久久国产劲爆∧v内射 | 美女黄网站人色视频免费国产 | 中文字幕无码日韩专区 | 亚洲国产成人av在线观看 | 国产精品高潮呻吟av久久4虎 | 国产精品毛片一区二区 | 日本乱人伦片中文三区 | 一个人看的www免费视频在线观看 | 国产一区二区三区精品视频 | 日本一卡2卡3卡四卡精品网站 | 两性色午夜免费视频 | 伊人色综合久久天天小片 | 两性色午夜免费视频 | 国产成人精品久久亚洲高清不卡 | 无码播放一区二区三区 | a在线观看免费网站大全 | 亚洲精品一区二区三区大桥未久 | 97人妻精品一区二区三区 | 又大又硬又黄的免费视频 | 日日躁夜夜躁狠狠躁 | 四十如虎的丰满熟妇啪啪 | 日本免费一区二区三区最新 | 国产免费无码一区二区视频 | 午夜理论片yy44880影院 | 精品国产青草久久久久福利 | 国产三级精品三级男人的天堂 | 真人与拘做受免费视频一 | 最近的中文字幕在线看视频 | 久久亚洲a片com人成 | 国产精品99久久精品爆乳 | 在线播放亚洲第一字幕 | 麻豆av传媒蜜桃天美传媒 | 日本丰满熟妇videos | 国产午夜福利100集发布 | 亚洲s码欧洲m码国产av | 日日天日日夜日日摸 | 亚洲国产日韩a在线播放 | 黄网在线观看免费网站 | 在线 国产 欧美 亚洲 天堂 | 国产高潮视频在线观看 | 大乳丰满人妻中文字幕日本 | 亚洲国产精品一区二区美利坚 | 人妻夜夜爽天天爽三区 | 国产农村妇女高潮大叫 | 色五月五月丁香亚洲综合网 | 亚洲精品欧美二区三区中文字幕 | 久久国产自偷自偷免费一区调 | 九一九色国产 | 最近的中文字幕在线看视频 | 高潮毛片无遮挡高清免费 | 丰满人妻被黑人猛烈进入 | 欧美日本日韩 | 国内精品一区二区三区不卡 | 一区二区三区高清视频一 | 日韩人妻系列无码专区 | 亚欧洲精品在线视频免费观看 | 丁香啪啪综合成人亚洲 | 99riav国产精品视频 | 婷婷丁香六月激情综合啪 | 国内少妇偷人精品视频 | 亚洲欧洲日本无在线码 | 国产综合在线观看 | 成人无码视频在线观看网站 | 色 综合 欧美 亚洲 国产 | 超碰97人人射妻 | 啦啦啦www在线观看免费视频 | 亚洲人成网站在线播放942 | 精品少妇爆乳无码av无码专区 | 亚洲天堂2017无码中文 | 国产办公室秘书无码精品99 | 清纯唯美经典一区二区 | 天堂亚洲2017在线观看 | 久久精品女人天堂av免费观看 | 免费无码的av片在线观看 | 欧美日韩一区二区免费视频 | 小sao货水好多真紧h无码视频 | 国产va免费精品观看 | 精品久久久无码中文字幕 | 中文无码成人免费视频在线观看 | 亚洲精品国偷拍自产在线观看蜜桃 | 99精品国产综合久久久久五月天 | 亚洲精品国产精品乱码视色 | 人人爽人人澡人人人妻 | 国产极品视觉盛宴 | 大屁股大乳丰满人妻 | 日韩少妇内射免费播放 | 国产av剧情md精品麻豆 | 久久精品女人的天堂av | 男人扒开女人内裤强吻桶进去 | 免费看男女做好爽好硬视频 | 无码国产色欲xxxxx视频 | 丰满少妇弄高潮了www | a片免费视频在线观看 | 亚洲自偷精品视频自拍 | 人妻少妇被猛烈进入中文字幕 | 无码精品国产va在线观看dvd | 欧美喷潮久久久xxxxx | 日日麻批免费40分钟无码 | 久久99精品久久久久久 | 十八禁视频网站在线观看 | 无套内射视频囯产 | 亚洲色偷偷偷综合网 | 精品国产麻豆免费人成网站 | 国产小呦泬泬99精品 | 福利一区二区三区视频在线观看 | 一本久道高清无码视频 | 人妻中文无码久热丝袜 | 77777熟女视频在线观看 а天堂中文在线官网 | 人妻无码久久精品人妻 | 一本久久a久久精品vr综合 | 欧美人与善在线com | 日本精品少妇一区二区三区 | 九九在线中文字幕无码 | 国产办公室秘书无码精品99 | 免费观看黄网站 | 乱中年女人伦av三区 | 国产精品久久久av久久久 | 国产成人精品无码播放 | 熟女体下毛毛黑森林 | 免费无码的av片在线观看 | 国产亚洲精品久久久闺蜜 | 东京无码熟妇人妻av在线网址 | 中文字幕无码日韩专区 | 福利一区二区三区视频在线观看 | 日产国产精品亚洲系列 | 中文字幕乱码人妻二区三区 | 亚洲国产av精品一区二区蜜芽 | 中文字幕精品av一区二区五区 | 男女下面进入的视频免费午夜 | 一本大道久久东京热无码av | 天海翼激烈高潮到腰振不止 | 又大又硬又爽免费视频 | 国产精品亚洲专区无码不卡 | 野外少妇愉情中文字幕 | 无码av中文字幕免费放 | 久久久久久九九精品久 | 婷婷丁香五月天综合东京热 | 美女毛片一区二区三区四区 | 无码帝国www无码专区色综合 | 中文字幕乱码中文乱码51精品 | 少妇被黑人到高潮喷出白浆 | 国产成人综合在线女婷五月99播放 | 久久99精品久久久久婷婷 | 两性色午夜视频免费播放 | 熟妇女人妻丰满少妇中文字幕 | 久久99精品久久久久久动态图 | 亚洲乱码中文字幕在线 | 无码福利日韩神码福利片 | 久久久久se色偷偷亚洲精品av | 成人无码影片精品久久久 | 青青草原综合久久大伊人精品 | 极品尤物被啪到呻吟喷水 | 鲁鲁鲁爽爽爽在线视频观看 | 无码精品人妻一区二区三区av | 成人免费视频一区二区 | 欧美老熟妇乱xxxxx | 人妻天天爽夜夜爽一区二区 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲精品国偷拍自产在线观看蜜桃 | 捆绑白丝粉色jk震动捧喷白浆 | 香蕉久久久久久av成人 | 亚洲a无码综合a国产av中文 | 成人亚洲精品久久久久软件 | 亚洲国产高清在线观看视频 | 亚洲精品成人福利网站 | 少妇愉情理伦片bd | 精品偷自拍另类在线观看 | 精品久久久久久亚洲精品 | 国产精品第一区揄拍无码 | 伦伦影院午夜理论片 | 中文字幕乱妇无码av在线 | 丰满少妇高潮惨叫视频 | 久久天天躁狠狠躁夜夜免费观看 | 澳门永久av免费网站 | 国产熟女一区二区三区四区五区 | 久久成人a毛片免费观看网站 | 欧美自拍另类欧美综合图片区 | 精品亚洲韩国一区二区三区 | 国产成人无码av在线影院 | 麻豆蜜桃av蜜臀av色欲av | www一区二区www免费 | 午夜精品一区二区三区的区别 | 纯爱无遮挡h肉动漫在线播放 | 丰满少妇弄高潮了www | 嫩b人妻精品一区二区三区 | 国内少妇偷人精品视频 | 婷婷六月久久综合丁香 | 国产另类ts人妖一区二区 | 国产莉萝无码av在线播放 | 国产人妻久久精品二区三区老狼 | 国产人妻精品一区二区三区 | 亚洲伊人久久精品影院 | 色综合视频一区二区三区 | 丰满人妻精品国产99aⅴ | 日韩精品a片一区二区三区妖精 | 中文字幕色婷婷在线视频 | 高潮毛片无遮挡高清免费视频 | 久久综合狠狠综合久久综合88 | 久久综合给合久久狠狠狠97色 | 97无码免费人妻超级碰碰夜夜 | 日韩欧美群交p片內射中文 | 俺去俺来也www色官网 | aⅴ亚洲 日韩 色 图网站 播放 | 国模大胆一区二区三区 | 亚洲欧美精品aaaaaa片 | 又粗又大又硬又长又爽 | 宝宝好涨水快流出来免费视频 | 亚洲人成影院在线无码按摩店 | 精品久久久无码中文字幕 | 18精品久久久无码午夜福利 | 亚洲精品成a人在线观看 | 亚洲爆乳大丰满无码专区 | 婷婷丁香五月天综合东京热 | 成人精品视频一区二区 | aⅴ在线视频男人的天堂 | 欧美日韩综合一区二区三区 | 精品国产青草久久久久福利 | 特级做a爰片毛片免费69 | 中文字幕人妻丝袜二区 | 久久精品国产日本波多野结衣 | 精品人人妻人人澡人人爽人人 | 午夜肉伦伦影院 | 黑人玩弄人妻中文在线 | 欧美熟妇另类久久久久久不卡 | 国产高清不卡无码视频 | 狠狠cao日日穞夜夜穞av | 国产精品久久久久久久9999 | 亚洲国产精品一区二区美利坚 | 亚洲国产欧美在线成人 | а√资源新版在线天堂 | 国产亚洲视频中文字幕97精品 | 一个人看的视频www在线 | 天堂亚洲2017在线观看 | 久久久av男人的天堂 | 久久久精品人妻久久影视 | 天天躁夜夜躁狠狠是什么心态 | 日韩av无码中文无码电影 | 亚洲无人区一区二区三区 | 在线视频网站www色 | 久久综合九色综合97网 | 九月婷婷人人澡人人添人人爽 | 久久精品中文闷骚内射 | 色综合久久久无码中文字幕 | 国产精品高潮呻吟av久久 | 人妻无码久久精品人妻 | 亚无码乱人伦一区二区 | 人妻少妇精品无码专区动漫 | 精品久久久中文字幕人妻 | 老子影院午夜精品无码 | 精品一区二区不卡无码av | 亚洲色欲色欲天天天www | 国产精品多人p群无码 | 思思久久99热只有频精品66 | 欧美野外疯狂做受xxxx高潮 | 成年女人永久免费看片 | 日日碰狠狠丁香久燥 | 欧洲美熟女乱又伦 | 天堂久久天堂av色综合 | 国产精品成人av在线观看 | 综合人妻久久一区二区精品 | 免费国产黄网站在线观看 | 呦交小u女精品视频 | 中文字幕日韩精品一区二区三区 | 18禁黄网站男男禁片免费观看 | 国产亚洲人成在线播放 | 日日干夜夜干 | 亚洲精品午夜国产va久久成人 | 免费人成网站视频在线观看 | 久久久久免费精品国产 | 欧美第一黄网免费网站 | 中文字幕av日韩精品一区二区 | 天海翼激烈高潮到腰振不止 | 亚洲国产精品久久久天堂 | 国产精品久久久久久亚洲影视内衣 | 久久久婷婷五月亚洲97号色 | 国产极品视觉盛宴 | 亚洲 日韩 欧美 成人 在线观看 | 鲁一鲁av2019在线 | 成人性做爰aaa片免费看 | 久久精品国产精品国产精品污 | 亚洲日韩乱码中文无码蜜桃臀网站 | 人妻少妇被猛烈进入中文字幕 | 国产情侣作爱视频免费观看 | 欧美日韩久久久精品a片 | 图片小说视频一区二区 | 精品夜夜澡人妻无码av蜜桃 | 亚洲 a v无 码免 费 成 人 a v | 特大黑人娇小亚洲女 | 欧美老熟妇乱xxxxx | 奇米影视888欧美在线观看 | 日韩精品无码一本二本三本色 | 伊人久久婷婷五月综合97色 | 无码av最新清无码专区吞精 | 少妇被粗大的猛进出69影院 | 精品国产av色一区二区深夜久久 | 蜜桃av抽搐高潮一区二区 | 国内老熟妇对白xxxxhd | 久激情内射婷内射蜜桃人妖 | 无码乱肉视频免费大全合集 | 一本久道高清无码视频 | 亚洲国产精华液网站w | 亚洲自偷自偷在线制服 | 欧美日韩一区二区综合 | 欧美自拍另类欧美综合图片区 | 中文字幕+乱码+中文字幕一区 | 丁香啪啪综合成人亚洲 | 成人三级无码视频在线观看 | 国产口爆吞精在线视频 | 久久午夜无码鲁丝片午夜精品 | 精品熟女少妇av免费观看 | 国产精品无码一区二区三区不卡 | 国内精品人妻无码久久久影院 | 色婷婷综合中文久久一本 | 77777熟女视频在线观看 а天堂中文在线官网 | 精品国产成人一区二区三区 | 综合激情五月综合激情五月激情1 | 波多野结衣一区二区三区av免费 | 亚洲欧洲中文日韩av乱码 | 青春草在线视频免费观看 | 亚洲一区二区三区无码久久 | 国产精品亚洲lv粉色 | 女人高潮内射99精品 | 国产两女互慰高潮视频在线观看 | 亚洲人成人无码网www国产 | 俺去俺来也在线www色官网 | 国产精品a成v人在线播放 | 夜先锋av资源网站 | а√天堂www在线天堂小说 | 亚洲男人av香蕉爽爽爽爽 | 最新版天堂资源中文官网 | 波多野结衣一区二区三区av免费 | 成人无码视频在线观看网站 | 欧美国产日产一区二区 | 色婷婷香蕉在线一区二区 | 一个人看的视频www在线 | 久久国产精品精品国产色婷婷 | 日日碰狠狠丁香久燥 | 日韩av无码一区二区三区不卡 | 99精品无人区乱码1区2区3区 | 亚洲国产精品一区二区第一页 | 夜精品a片一区二区三区无码白浆 | 无码午夜成人1000部免费视频 | 六十路熟妇乱子伦 | 国产明星裸体无码xxxx视频 | 日日碰狠狠躁久久躁蜜桃 | 特黄特色大片免费播放器图片 | 国产黄在线观看免费观看不卡 | 无码午夜成人1000部免费视频 | 成人无码精品一区二区三区 | 日本熟妇大屁股人妻 | 成人免费视频视频在线观看 免费 | 日韩亚洲欧美中文高清在线 | 亲嘴扒胸摸屁股激烈网站 | 日本xxxx色视频在线观看免费 | 中文字幕日产无线码一区 | 中文字幕乱妇无码av在线 | 日本精品久久久久中文字幕 | 欧美丰满熟妇xxxx性ppx人交 | 国产女主播喷水视频在线观看 | 伊人久久大香线焦av综合影院 | 亚洲欧洲日本综合aⅴ在线 | 黑人巨大精品欧美一区二区 | 成人欧美一区二区三区黑人免费 | 亚洲精品一区二区三区在线观看 | 国产精品久免费的黄网站 | 正在播放东北夫妻内射 | 国产尤物精品视频 | 性欧美熟妇videofreesex | 亚洲自偷精品视频自拍 | 精品无码一区二区三区的天堂 | 美女毛片一区二区三区四区 | 亚洲中文字幕乱码av波多ji | 丰满人妻一区二区三区免费视频 | 麻豆md0077饥渴少妇 | av无码电影一区二区三区 | 日韩亚洲欧美精品综合 | 久久精品女人天堂av免费观看 | 久久综合给合久久狠狠狠97色 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲精品无码人妻无码 | 国产国产精品人在线视 | 国产精品久久久久久久9999 | 人妻无码久久精品人妻 | 四虎国产精品一区二区 | 亚洲经典千人经典日产 | 在线亚洲高清揄拍自拍一品区 | 国产精品人人爽人人做我的可爱 | 国产精品无码永久免费888 | 女人高潮内射99精品 | 俺去俺来也www色官网 | 日韩av无码一区二区三区不卡 | 亚洲午夜无码久久 | 国产精品福利视频导航 | 欧美人妻一区二区三区 | 波多野结衣 黑人 | 亚洲欧美中文字幕5发布 | 欧洲欧美人成视频在线 | 2020久久香蕉国产线看观看 | 亚洲日韩乱码中文无码蜜桃臀网站 | 成 人 免费观看网站 | 强辱丰满人妻hd中文字幕 | 粉嫩少妇内射浓精videos | 无码免费一区二区三区 | 色五月丁香五月综合五月 | 午夜无码人妻av大片色欲 | 精品久久8x国产免费观看 | 久久精品中文字幕大胸 | 国产人妖乱国产精品人妖 | 性生交片免费无码看人 | 成人av无码一区二区三区 | 中文字幕无码视频专区 | 伊人久久大香线焦av综合影院 | 成熟人妻av无码专区 | 久久久国产一区二区三区 | 国产精品成人av在线观看 | 在线а√天堂中文官网 | 麻豆蜜桃av蜜臀av色欲av | 天天摸天天碰天天添 | 亚洲 另类 在线 欧美 制服 | 国产在线精品一区二区三区直播 | 日日碰狠狠丁香久燥 | 免费视频欧美无人区码 | 精品国产一区二区三区av 性色 | 国产精品美女久久久 | 成人性做爰aaa片免费看不忠 | 国产成人无码av在线影院 | 黑人巨大精品欧美一区二区 | 一个人免费观看的www视频 | 无码人妻av免费一区二区三区 | 一本大道伊人av久久综合 | 日韩精品无码免费一区二区三区 | 强伦人妻一区二区三区视频18 | 性欧美牲交xxxxx视频 | 国产成人综合色在线观看网站 | 特大黑人娇小亚洲女 | 俺去俺来也在线www色官网 | 日日碰狠狠躁久久躁蜜桃 | 99久久久无码国产精品免费 | 成 人 网 站国产免费观看 | 国产亚洲精品久久久久久国模美 | 又大又黄又粗又爽的免费视频 | 特级做a爰片毛片免费69 | 熟女俱乐部五十路六十路av | 一本久久伊人热热精品中文字幕 | 又大又硬又爽免费视频 | 国产精品怡红院永久免费 | 无码任你躁久久久久久久 | 女人被男人躁得好爽免费视频 | 国产精品福利视频导航 | 亚洲综合久久一区二区 | 国产真人无遮挡作爱免费视频 | 国产色xx群视频射精 | 国产精品久久久久久亚洲毛片 | 精品一二三区久久aaa片 | 两性色午夜免费视频 | 国产超级va在线观看视频 | 东京热男人av天堂 | 又粗又大又硬又长又爽 | 97夜夜澡人人爽人人喊中国片 | 精品乱子伦一区二区三区 | 亚洲综合另类小说色区 | 乱码午夜-极国产极内射 | 国产亚洲欧美日韩亚洲中文色 | 日日麻批免费40分钟无码 | v一区无码内射国产 | 色婷婷欧美在线播放内射 | 欧洲极品少妇 | 精品国产一区二区三区四区在线看 | 老熟女重囗味hdxx69 | 日产精品高潮呻吟av久久 | 午夜精品一区二区三区的区别 | 久久 国产 尿 小便 嘘嘘 | 久久综合色之久久综合 | av香港经典三级级 在线 | 熟妇人妻无乱码中文字幕 | 久久午夜无码鲁丝片午夜精品 | 激情内射亚州一区二区三区爱妻 | 日产国产精品亚洲系列 | 国产一精品一av一免费 | 国产精品沙发午睡系列 | 欧洲美熟女乱又伦 | 国产精品国产自线拍免费软件 | 麻花豆传媒剧国产免费mv在线 | 亚洲精品国产精品乱码视色 | 国产午夜亚洲精品不卡下载 | 国产精品无码一区二区桃花视频 | 欧美第一黄网免费网站 | 377p欧洲日本亚洲大胆 | 亚洲自偷自拍另类第1页 | 亚洲狠狠婷婷综合久久 | 久久久久久国产精品无码下载 | 国内少妇偷人精品视频 | av人摸人人人澡人人超碰下载 | 欧美黑人巨大xxxxx | 国产精品二区一区二区aⅴ污介绍 | 亚洲日本va中文字幕 | 亚洲中文字幕在线无码一区二区 | 亚洲熟妇自偷自拍另类 | 国产精品毛多多水多 | 天干天干啦夜天干天2017 | 99久久久国产精品无码免费 | 免费看男女做好爽好硬视频 | 3d动漫精品啪啪一区二区中 | 中文久久乱码一区二区 | ass日本丰满熟妇pics | 无码国内精品人妻少妇 | 亚洲人交乣女bbw | 日韩av激情在线观看 | 荫蒂添的好舒服视频囗交 | 一个人看的www免费视频在线观看 | 亚洲精品一区二区三区在线观看 | 欧美日韩亚洲国产精品 | 天天拍夜夜添久久精品 | 精品国产青草久久久久福利 | 正在播放老肥熟妇露脸 | 中文精品无码中文字幕无码专区 | 精品水蜜桃久久久久久久 | 久久午夜无码鲁丝片午夜精品 | 亚洲精品国偷拍自产在线麻豆 | 成年美女黄网站色大免费全看 | 久久综合久久自在自线精品自 | 免费人成在线观看网站 | 国产成人综合色在线观看网站 | 中国大陆精品视频xxxx | 国产成人综合在线女婷五月99播放 | 成人精品一区二区三区中文字幕 | 久久精品国产大片免费观看 | 色情久久久av熟女人妻网站 | 欧美成人免费全部网站 | 亚洲高清偷拍一区二区三区 | 日韩欧美中文字幕在线三区 | 亚洲一区二区三区偷拍女厕 | 亚洲热妇无码av在线播放 | 国产精品国产三级国产专播 | 日本熟妇人妻xxxxx人hd | 女人被爽到呻吟gif动态图视看 | 在线а√天堂中文官网 | 人人澡人人妻人人爽人人蜜桃 | 精品一区二区三区波多野结衣 | 国产精品无码一区二区三区不卡 | 亚洲七七久久桃花影院 | 亚洲乱码中文字幕在线 | 99精品国产综合久久久久五月天 | 国产精品无码一区二区桃花视频 | 性做久久久久久久久 | 国产精品亚洲专区无码不卡 | 久久午夜无码鲁丝片秋霞 | 日韩人妻少妇一区二区三区 | 免费人成在线观看网站 | 扒开双腿疯狂进出爽爽爽视频 | 玩弄人妻少妇500系列视频 | 一本大道伊人av久久综合 | 欧美黑人性暴力猛交喷水 | 国产99久久精品一区二区 | 人人妻人人澡人人爽欧美精品 | 一个人看的www免费视频在线观看 | 一个人看的www免费视频在线观看 | ass日本丰满熟妇pics | 无码乱肉视频免费大全合集 | 国产精品无码永久免费888 | 精品成在人线av无码免费看 | www一区二区www免费 | 激情五月综合色婷婷一区二区 | 国产精品久久精品三级 | 亚洲va欧美va天堂v国产综合 | 国产精品自产拍在线观看 | 特黄特色大片免费播放器图片 | 娇妻被黑人粗大高潮白浆 | 香蕉久久久久久av成人 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 精品偷拍一区二区三区在线看 | 成人综合网亚洲伊人 | 色窝窝无码一区二区三区色欲 | 在线欧美精品一区二区三区 | 全黄性性激高免费视频 | 又湿又紧又大又爽a视频国产 | 亚洲天堂2017无码中文 | 男人的天堂av网站 | 色欲人妻aaaaaaa无码 | 国产香蕉尹人视频在线 | 亚洲性无码av中文字幕 | 蜜臀aⅴ国产精品久久久国产老师 | 久久99精品久久久久久动态图 | aⅴ亚洲 日韩 色 图网站 播放 | 强开小婷嫩苞又嫩又紧视频 | 亚洲精品中文字幕久久久久 | 亚洲精品午夜国产va久久成人 | 国产精品嫩草久久久久 | 99久久精品国产一区二区蜜芽 | 高潮毛片无遮挡高清免费视频 | 在线播放无码字幕亚洲 | 日韩 欧美 动漫 国产 制服 | 国产av无码专区亚洲awww | 丰满人妻一区二区三区免费视频 | 青草青草久热国产精品 | 久久午夜无码鲁丝片秋霞 | 狠狠亚洲超碰狼人久久 | 鲁一鲁av2019在线 | 国产真人无遮挡作爱免费视频 | 亚洲中文字幕无码一久久区 | 精品久久久无码中文字幕 | 青草视频在线播放 | 国产超碰人人爽人人做人人添 | 伊人久久大香线蕉亚洲 | 久久综合九色综合欧美狠狠 | 丰腴饱满的极品熟妇 | 国产熟妇另类久久久久 | 亚洲自偷精品视频自拍 | 成人免费无码大片a毛片 | 在线观看国产一区二区三区 | 中文字幕人妻无码一区二区三区 | 婷婷五月综合激情中文字幕 | 在线播放免费人成毛片乱码 | 国产真实乱对白精彩久久 | 成人精品视频一区二区 | 无码国产激情在线观看 | 青青青手机频在线观看 | 久久久久久av无码免费看大片 | 荫蒂被男人添的好舒服爽免费视频 | 好屌草这里只有精品 | 奇米影视7777久久精品 | 色综合视频一区二区三区 | 中文亚洲成a人片在线观看 | 亚洲一区二区三区国产精华液 | 国产激情艳情在线看视频 | 成熟妇人a片免费看网站 | 欧美怡红院免费全部视频 | 国产成人精品久久亚洲高清不卡 | 国产激情一区二区三区 | 性欧美熟妇videofreesex | 国产午夜精品一区二区三区嫩草 | 国内精品一区二区三区不卡 | www一区二区www免费 | 成人无码视频在线观看网站 | 成人一在线视频日韩国产 | 日韩av激情在线观看 | 伊人久久大香线蕉av一区二区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲自偷自拍另类第1页 | 国精产品一品二品国精品69xx | 亚洲日本一区二区三区在线 | 亚洲国产精品无码一区二区三区 | 中文字幕乱码亚洲无线三区 | 六月丁香婷婷色狠狠久久 | 日韩精品无码一区二区中文字幕 | 国产熟妇另类久久久久 | 人人爽人人澡人人高潮 | 无套内射视频囯产 | 国内精品久久毛片一区二区 | 成人试看120秒体验区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 无遮无挡爽爽免费视频 | 永久免费观看美女裸体的网站 | 亚洲中文字幕无码中字 | 国产精品亚洲а∨无码播放麻豆 | aⅴ在线视频男人的天堂 | 美女张开腿让人桶 | 国产精品久久久久7777 | 成人一区二区免费视频 | 亚洲理论电影在线观看 | 久久久久久久久蜜桃 | 日韩人妻无码一区二区三区久久99 | 国产成人精品视频ⅴa片软件竹菊 | ass日本丰满熟妇pics | 亚洲区小说区激情区图片区 | 无码一区二区三区在线观看 | aⅴ在线视频男人的天堂 | 曰韩无码二三区中文字幕 | 亚洲精品无码人妻无码 | 亚洲天堂2017无码中文 | 亚洲の无码国产の无码步美 | 欧美野外疯狂做受xxxx高潮 | 欧美成人免费全部网站 | 国産精品久久久久久久 | 在线观看免费人成视频 | 亚洲一区二区三区含羞草 | 国产成人精品无码播放 | 国产精品无码一区二区桃花视频 | 国产农村乱对白刺激视频 | 丰满少妇熟乱xxxxx视频 | 少妇性l交大片欧洲热妇乱xxx | 性欧美牲交xxxxx视频 | 亚洲精品国产第一综合99久久 | 久久精品中文闷骚内射 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲娇小与黑人巨大交 | 国产av剧情md精品麻豆 | 无码国产色欲xxxxx视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产97在线 | 亚洲 | 亚洲另类伦春色综合小说 | 性色欲情网站iwww九文堂 | 色欲综合久久中文字幕网 | 色情久久久av熟女人妻网站 | 女人被爽到呻吟gif动态图视看 | 欧美成人免费全部网站 | 久久久久成人片免费观看蜜芽 | 欧美日韩在线亚洲综合国产人 | 欧美肥老太牲交大战 | 久久久久久九九精品久 | 内射爽无广熟女亚洲 | 亚洲精品www久久久 | 中文精品久久久久人妻不卡 | 久久综合狠狠综合久久综合88 | 日本高清一区免费中文视频 | 黄网在线观看免费网站 | 成人片黄网站色大片免费观看 | 久久精品女人的天堂av | 亚洲一区二区三区国产精华液 | 中文字幕 人妻熟女 | 99在线 | 亚洲 | 久久aⅴ免费观看 | 动漫av网站免费观看 | 国产区女主播在线观看 | 精品人妻人人做人人爽 | 色综合久久久无码中文字幕 | 国产亚洲精品久久久久久久久动漫 | 人妻熟女一区 | 少妇久久久久久人妻无码 | 亚洲狠狠婷婷综合久久 | 香蕉久久久久久av成人 | 亚洲中文字幕在线观看 | 亚洲色www成人永久网址 | 妺妺窝人体色www在线小说 | 国产精品成人av在线观看 | 亚洲色无码一区二区三区 | 乌克兰少妇性做爰 | 国产精品嫩草久久久久 | 中文字幕乱码亚洲无线三区 | 精品无码国产自产拍在线观看蜜 | 国产亚av手机在线观看 | 亚洲中文字幕无码中字 | 亚洲日韩av一区二区三区四区 | 国产亚洲欧美日韩亚洲中文色 | 最近中文2019字幕第二页 | 国产精品嫩草久久久久 | 亚洲国产欧美日韩精品一区二区三区 | 久久久精品国产sm最大网站 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产人成高清在线视频99最全资源 | 色偷偷人人澡人人爽人人模 | 色综合久久久久综合一本到桃花网 | 亚洲春色在线视频 | 国产性生大片免费观看性 | 亚洲日韩精品欧美一区二区 | √天堂中文官网8在线 | 午夜精品一区二区三区的区别 | 在线欧美精品一区二区三区 | 人妻少妇精品无码专区动漫 | 香港三级日本三级妇三级 | 在线观看国产一区二区三区 | 76少妇精品导航 | 天堂在线观看www | 亚洲小说春色综合另类 | 99在线 | 亚洲 | 国产精品二区一区二区aⅴ污介绍 | 成人免费视频视频在线观看 免费 | 精品aⅴ一区二区三区 | 黑人大群体交免费视频 | 特大黑人娇小亚洲女 | 1000部啪啪未满十八勿入下载 | 久久久久久国产精品无码下载 | 国产av剧情md精品麻豆 | 一本久久a久久精品vr综合 | 国产成人无码一二三区视频 | 人妻少妇精品久久 | 色情久久久av熟女人妻网站 | 巨爆乳无码视频在线观看 | 国产精品无套呻吟在线 | 少妇高潮一区二区三区99 | 98国产精品综合一区二区三区 | 国内精品久久毛片一区二区 | 亚洲一区二区三区含羞草 | 色婷婷欧美在线播放内射 |