青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

OpenGL紋理

 目 錄
  12.1 基本步驟
  12.2 紋理定義
  12.3 紋理控制
  12.4 映射方式
  12.5 紋理坐標

 

  在三維圖形中,紋理映射(Texture Mapping)的方法運用得很廣,尤其描述具有真實感的物體。比如繪制一面磚墻,就可以用一幅真實的磚墻圖像或照片作為紋理貼到一個矩形上,這樣,一面逼真的磚墻就畫好了。如果不用紋理映射的方法,則墻上的每一塊磚都必須作為一個獨立的多邊形來畫。另外,紋理映射能夠保證在變換多邊形時,多邊形上的紋理圖案也隨之變化。例如,以透視投影方式觀察墻面時,離視點遠的磚塊的尺寸就會縮小,而離視點 較近的就會大些。此外,紋理映射也常常運用在其他一些領(lǐng)域,如飛行仿真中常把一大片植被的圖像映射到一些大多邊形上用以表示地面,或用大理石、木材、布匹等自然物質(zhì)的圖像作為紋理映射到多邊形上表示相應(yīng)的物體。
  紋理映射有許多種情況。例如,任意一塊紋理可以映射到平面或曲面上,且對光亮的物體進行紋理映射,其表面可以映射出周圍環(huán)境的景象;紋理還可按不同的方式映射到曲面上,一是可以直接畫上去(或稱移畫印花法),二是可以調(diào)整曲面顏色或把紋理顏色與曲面顏色混合;紋理不僅可以是二維的,也可以是一維或其它維的。
  本章將詳細介紹OpenGL紋理映射有關(guān)的內(nèi)容:基本步驟、紋理定義、紋理控制、映射方式和紋理坐標等。

12.1 基本步驟
  紋理映射是一個相當復(fù)雜的過程,這節(jié)只簡單地敘述一下最基本的執(zhí)行紋理映射所需的步驟。基本步驟如下:
  1)定義紋理、2)控制濾波、3)說明映射方式、4)繪制場景,給出頂點的紋理坐標和幾何坐標。
  注意:紋理映射只能在RGBA方式下執(zhí)行,不能運用于顏色表方式。下面舉出一個最簡單的紋理映射應(yīng)用例子:

  例12-1 簡單紋理映射應(yīng)用例程texsmpl.c
#include "glos.h"
#include <GL/gl.h>
#include <GL/glu.h>
#include <GL/glaux.h>
 
void myinit(void);
void makeImage(void);
void CALLBACK myReshape(GLsizei w, GLsizei h);
void CALLBACK display(void);
 
/* 創(chuàng)建紋理 */
#define ImageWidth 64
#define ImageHeight 64
GLubyte Image[ImageWidth][ImageHeight][3];
 
void makeImage(void)
{
  int i, j, r,g,b;
 
  for (i = 0; i < ImageWidth; i++)
  {
    for (j = 0; j < ImageHeight; j++)
    {
      r=(i*j)%255;
      g=(4*i)%255;
      b=(4*j)%255;
      Image[i][j][0] = (GLubyte) r;
      Image[i][j][1] = (GLubyte) g;
      Image[i][j][2] = (GLubyte) b;
    }
  }
}
 
void myinit(void)
{
  glClearColor (0.0, 0.0, 0.0, 0.0);
  glEnable(GL_DEPTH_TEST);
  glDepthFunc(GL_LESS);
 
  makeImage();
  glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
 
  /* 定義紋理 */
  glTexImage2D(GL_TEXTURE_2D, 0, 3, ImageWidth,
    ImageHeight, 0, GL_RGB, GL_UNSIGNED_BYTE, &Image[0][0][0]);
 
  /* 控制濾波 */
  glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP);
  glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP);
  glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
  glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
 
  /* 說明映射方式*/
  glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_DECAL);
 
  /* 啟動紋理映射 */
  glEnable(GL_TEXTURE_2D);
 
  glShadeModel(GL_FLAT);
}
 
void CALLBACK display(void)
{
  glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
 
  /* 設(shè)置紋理坐標和物體幾何坐標 */
  glBegin(GL_QUADS);
  glTexCoord2f(0.0, 0.0); glVertex3f(-2.0, -1.0, 0.0);
  glTexCoord2f(0.0, 1.0); glVertex3f(-2.0, 1.0, 0.0);
  glTexCoord2f(1.0, 1.0); glVertex3f(0.0, 1.0, 0.0);
  glTexCoord2f(1.0, 0.0); glVertex3f(0.0, -1.0, 0.0);
 
  glTexCoord2f(0.0, 0.0); glVertex3f(1.0, -1.0, 0.0);
  glTexCoord2f(0.0, 1.0); glVertex3f(1.0, 1.0, 0.0);
  glTexCoord2f(1.0, 1.0); glVertex3f(2.41421, 1.0, -1.41421);
  glTexCoord2f(1.0, 0.0); glVertex3f(2.41421, -1.0, -1.41421);
  glEnd();
 
  glFlush();
}
 
void CALLBACK myReshape(GLsizei w, GLsizei h)
{
  glViewport(0, 0, w, h);
  glMatrixMode(GL_PROJECTION);
  glLoadIdentity();
  gluPerspective(60.0, 1.0*(GLfloat)w/(GLfloat)h, 1.0, 30.0);
  glMatrixMode(GL_MODELVIEW);
  glLoadIdentity();
  glTranslatef(0.0, 0.0, -3.6);
}
 
void main(void)
{
  auxInitDisplayMode (AUX_SINGLE | AUX_RGBA);
  auxInitPosition (0, 0, 500, 500);
  auxInitWindow ("Simple Texture Map");
  myinit();
  auxReshapeFunc (myReshape);
  auxMainLoop(display);
}
 
圖12-1 簡單紋理映射

  以上程序運行結(jié)果是將一塊紋理映射到兩個正方形上去。這兩個正方形都是按透視投影方式繪制,其中一個正對觀察者,另一個向后傾斜45度角。圖形的紋理是由函數(shù)makeImage()產(chǎn)生的,并且所有紋理映射的初始化工作都在程序myinit()中進行。由glTexImage2d()說明了一個全分辨率的圖像,其參數(shù)指出了圖像的尺寸、圖像類型、圖像位置和圖像的其它特性;下面連續(xù)調(diào)用函數(shù)glTexParameter*()說明紋理怎樣纏繞物體和當象素與紋理數(shù)組中的單個元素(texel,暫稱紋素)不能精確匹配時如何過濾顏色;接著用函數(shù)glTexEnv*()設(shè)置畫圖方式為GL_DECAL,即多邊形完全用紋理圖像中的顏色來畫,不考慮多邊形在未被紋理映射前本身的顏色;最后,調(diào)用函數(shù)glEnable()啟動紋理映射。子程序display()畫了兩個正方形,其中紋理坐標與幾何坐標一起說明,glTexCoord*()函數(shù)類似于glNormal*()函數(shù),不過它是設(shè)置紋理坐標,之后任何頂點都把這個紋理坐標與頂點坐標聯(lián)系起來,直到再次調(diào)用 glTexCoord*()改變當前紋理坐標。

12.2、紋理定義

  12.2.1 二維紋理定義的函數(shù)
 
void glTexImage2D(GLenum target,GLint level,GLint components,
GLsizei width, glsizei height,GLint border,
GLenum format,GLenum type, const GLvoid *pixels);

  定義一個二維紋理映射。其中參數(shù)target是常數(shù)GL_TEXTURE_2D。參數(shù)level表示多級分辨率的紋理圖像的級數(shù),若只有一種分辨率,則level設(shè)為0。
  參數(shù)components是一個從1到4的整數(shù),指出選擇了R、G、B、A中的哪些分量用于調(diào)整和混合,1表示選擇了R分量,2表示選擇了R和A兩個分量,3表示選擇了R、G、B三個分量,4表示選擇了R、G、B、A四個分量。
  參數(shù)width和height給出了紋理圖像的長度和寬度,參數(shù)border為紋理邊界寬度,它通常為0,width和height必須是2m+2b,這里m是整數(shù),長和寬可以有不同的值,b是border的值。紋理映射的最大尺寸依賴于OpenGL,但它至少必須是使用64x64(若帶邊界為66x66),若width和height設(shè)置為0,則紋理映射有效地關(guān)閉。
  參數(shù)format和type描述了紋理映射的格式和數(shù)據(jù)類型,它們在這里的意義與在函數(shù)glDrawPixels()中的意義相同,事實上,紋理數(shù)據(jù)與glDrawPixels()所用的數(shù)據(jù)有同樣的格式。參數(shù)format可以是GL_COLOR_INDEX、GL_RGB、GL_RGBA、GL_RED、GL_GREEN、GL_BLUE、GL_ALPHA、GL_LUMINANCE或GL_LUMINANCE_ALPHA(注意:不能用GL_STENCIL_INDEX和GL_DEPTH_COMPONENT)。類似地,參數(shù)type是GL_BYPE、GL_UNSIGNED_BYTE、GL_SHORT、 GL_UNSIGNED_SHORT、GL_INT、GL_UNSIGNED_INT、GL_FLOAT或GL_BITMAP。
  參數(shù)pixels包含了紋理圖像數(shù)據(jù),這個數(shù)據(jù)描述了紋理圖像本身和它的邊界。

  12.2 一維紋理定義的函數(shù)
 

void glTexImage1D(GLenum target,GLint level,GLint components,GLsizei width,
GLint border,GLenum format,GLenum type,const GLvoid *pixels);

  定義一個一維紋理映射。除了第一個參數(shù)target應(yīng)設(shè)置為GL_TEXTURE_1D外,其余所有的參數(shù)與函數(shù)TexImage2D()的一致,不過紋理圖像是一維紋素數(shù)組,其寬度值必須是2的冪,若有邊界則為2m+2。

12.3、紋理控制
  OpenGL中的紋理控制函數(shù)是
 

void glTexParameter{if}[v](GLenum target,GLenum pname,TYPE param);
  控制紋素映射到片元(fragment)時怎樣對待紋理。第一個參數(shù)target可以是GL_TEXTURE_1D或GL_TEXTURE_2D,它指出是為一維或二維紋理說明參數(shù);后兩個參數(shù)的可能值見表12-1所示。

 
參數(shù)
GL_TEXTURE_WRAP_S GL_CLAMP
GL_REPEAT
GL_TEXTURE_WRAP_T GL_CLAMP
GL_REPEAT
GL_TEXTURE_MAG_FILTER GL_NEAREST
GL_LINEAR
GL_TEXTURE_MIN_FILTER GL_NEAREST
GL_LINEAR
GL_NEAREST_MIPMAP_NEAREST
GL_NEAREST_MIPMAP_LINEAR
GL_LINEAR_MIPMAP_NEAREST
GL_LINEAR_MIPMAP_LINEAR
表12-1 放大和縮小濾波方式

  12.3.1 濾波
  一般來說,紋理圖像為正方形或長方形。但當它映射到一個多邊形或曲面上并變換到屏幕坐標時,紋理的單個紋素很少對應(yīng)于屏幕圖像上的象素。根據(jù)所用變換和所用紋理映射,屏幕上單個象素可以對應(yīng)于一個紋素的一小部分(即放大)或一大批紋素(即縮小)。下面用函數(shù)glTexParameter*()說明放大和縮小的方法:
glTexParameter*(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_NEAREST);
glTexParameter*(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_NEAREST);

  實際上,第一個參數(shù)可以是GL_TEXTURE_1D或GL_TEXTURE_2D,即表明所用的紋理是一維的還是二維的;第二個參數(shù)指定濾波方法,其中參數(shù)值GL_TEXTURE_MAG_FILTER指定為放大濾波方法,GL_TEXTURE_MIN_FILTER指定為縮小濾波方法;第三個參數(shù)說明濾波方式,其值見表12-1所示。
  若選擇GL_NEAREST則采用坐標最靠近象素中心的紋素,這有可能使圖像走樣;若選擇GL_LINEAR則采用最靠近象素中心的四個象素的加權(quán)平均值。GL_NEAREST所需計算比GL_LINEAR要少,因而執(zhí)行得更快,但GL_LINEAR提供了比較光滑的效果。

  12.3.2 重復(fù)與約簡
  紋理坐標可以超出(0, 1)范圍,并且在紋理映射過程中可以重復(fù)映射或約簡映射。在重復(fù)映射的情況下,紋理可以在s,t方向上重復(fù),即:

glTexParameterfv(GL_TEXTURE_2D,GL_TEXTURE_WRAP_S,GL_REPEAT);
glTexParameterfv(GL_TEXTURE_2D,GL_TEXTURE_WRAP_T,GL_REPEAT);

  若將參數(shù)GL_REPEAT改為GL_CLAMP,則所有大于1的紋素值都置為1,所有小于0的值都置為0。參數(shù)設(shè)置參見表12-1。

12.4、映射方式
  在本章的第一個例程中,紋理圖像是直接作為畫到多邊形上的顏色。實際上,可以用紋理中的值來調(diào)整多邊形(曲面)原來的顏色,或用紋理圖像中的顏色與多邊形(曲面)原來的顏色進行混合。因此,OpenGL提供了三種紋理映射的方式,這個函數(shù)是:
 

void glTexEnv{if}[v](GLenum target,GLenum pname,TYPE param);

  設(shè)置紋理映射方式。參數(shù)target必須是GL_TEXTURE_ENV;若參數(shù)pname是GL_TEXTURE_ENV_MODE,則參數(shù)param可以是GL_DECAL、GL_MODULATE或GL_BLEND,以說明紋理值怎樣與原來表面顏色的處理方式;若參數(shù)pname是GL_TEXTURE_ENV_COLOR,則參數(shù)param是包含四個浮點數(shù)(分別是R、G、B、A分量)的數(shù)組,這些值只在采用GL_BLEND紋理函數(shù)時才有用。

12.5、紋理坐標

  12.5.1 坐標定義
  在繪制紋理映射場景時,不僅要給每個頂點定義幾何坐標,而且也要定義紋理坐標。經(jīng)過多種變換后,幾何坐標決定頂點在屏幕上繪制的位置,而紋理坐標決定紋理圖像中的哪一個紋素賦予該頂點。并且頂點之間的紋理坐標插值與基礎(chǔ)篇中所講的平滑著色插值方法相同。
  紋理圖像是方形數(shù)組,紋理坐標通常可定義成一、二、三或四維形式,稱為s,t,r和q坐標,以區(qū)別于物體坐標(x, y, z, w)和其他坐標。一維紋理常用s坐標表示,二維紋理常用(s, t)坐標表示,目前忽略r坐標,q坐標象w一樣,一半值為1,主要用于建立齊次坐標。OpenGL坐標定義的函數(shù)是:
 

void gltexCoord{1234}{sifd}[v](TYPE coords);

  設(shè)置當前紋理坐標,此后調(diào)用glVertex*()所產(chǎn)生的頂點都賦予當前的紋理坐標。對于gltexCoord1*(),s坐標被設(shè)置成給定值,t和r設(shè)置為0,q設(shè)置為1;用gltexCoord2*()可以設(shè)置s和t坐標值,r設(shè)置為0,q設(shè)置為1;對于gltexCoord3*(),q設(shè)置為1,其它坐標按給定值設(shè)置;用gltexCoord4*()可以給定所有的坐標。使用適當?shù)暮缶Y(s,i,f或d)和TYPE的相應(yīng)值(GLshort、GLint、glfloat或GLdouble)來說明坐標的類型。注意:整型紋理坐標可以直接應(yīng)用,而不是象普通坐標那樣被映射到[-1, 1]之間。

  12.5.2 坐標自動產(chǎn)生
  在某些場合(環(huán)境映射等)下,為獲得特殊效果需要自動產(chǎn)生紋理坐標,并不要求為用函數(shù)gltexCoord*()為每個物體頂點賦予紋理坐標值。OpenGL提供了自動產(chǎn)生紋理坐標的函數(shù),其如下:
 

void glTexGen{if}[v](GLenum coord,GLenum pname,TYPE param);

  自動產(chǎn)生紋理坐標。第一個參數(shù)必須是GL_S、GL_T、GL_R或GL_Q,它指出紋理坐標s,t,r,q中的哪一個要自動產(chǎn)生;第二個參數(shù)值為GL_TEXTURE_GEN_MODE、GL_OBJECT_PLANE或 GL_EYE_PLANE;第三個參數(shù)param是一個定義紋理產(chǎn)生參數(shù)的指針,其值取決于第二個參數(shù)pname的設(shè)置,當pname為GL_TEXTURE_GEN_MODE時,param是一個常量,即GL_OBJECT_LINEAR、GL_EYE_LINEAR或GL_SPHERE_MAP,它們決定用哪一個函數(shù)來產(chǎn)生紋理坐標。對于pname的其它可能值,param是一個指向參數(shù)數(shù)組的指針。下面是一個運用自動產(chǎn)生紋理坐標函數(shù)的實例:

  例12-1 紋理坐標自動產(chǎn)生例程texpot.c
 

#include "glos.h"
#include <GL/gl.h>
#include <GL/glu.h>
#include <GL/glaux.h>
 
void myinit(void);
void makeStripeImage(void);
void CALLBACK display(void);
void CALLBACK myReshape(GLsizei w, GLsizei h);
 
#define stripeImageWidth 64
GLubyte stripeImage[3*stripeImageWidth];
 
void makeStripeImage(void)
{
  int j;
 
  for (j = 0; j < stripeImageWidth; j++)
  {
    stripeImage[3*j] = 255;
    stripeImage[3*j+1] =255-2*j;
    stripeImage[3*j+2] =255;
  }
}
 
/* 參數(shù)設(shè)置 */
 
GLfloat sgenparams[] = {1.0, 1.0, 1.0, 0.0};
 
void myinit(void)
{
  glClearColor (0.0, 0.0, 0.0, 0.0);
 
  makeStripeImage();
  glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
  glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
  glTexParameterf(GL_TEXTURE_1D, GL_TEXTURE_WRAP_S, GL_REPEAT);
  glTexParameterf(GL_TEXTURE_1D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
  glTexParameterf(GL_TEXTURE_1D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
  glTexImage1D(GL_TEXTURE_1D, 0, 3, stripeImageWidth, 0, GL_RGB, GL_UNSIGNED_BYTE, stripeImage);
 
  glTexGeni(GL_S, GL_TEXTURE_GEN_MODE, GL_OBJECT_LINEAR);
  glTexGenfv(GL_S, GL_OBJECT_PLANE, sgenparams);
 
  glEnable(GL_DEPTH_TEST);
  glDepthFunc(GL_LESS);
  glEnable(GL_TEXTURE_GEN_S);
  glEnable(GL_TEXTURE_1D);
  glEnable(GL_CULL_FACE);
  glEnable(GL_LIGHTING);
  glEnable(GL_LIGHT0);
  glEnable(GL_AUTO_NORMAL);
  glEnable(GL_NORMALIZE);
  glFrontFace(GL_CW);
  glCullFace(GL_BACK);
  glMaterialf (GL_FRONT, GL_SHININESS, 64.0);
}
 
void CALLBACK display(void)
{
  glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
  glPushMatrix ();
  glRotatef(25.0, 1.0, 0.0, 0.0);
  auxSolidTeapot(1.5);
  glPopMatrix ();
  glFlush();
}
 
void CALLBACK myReshape(GLsizei w, GLsizei h)
{
  float a=3.5;
 
  glViewport(0, 0, w, h);
  glMatrixMode(GL_PROJECTION);
  glLoadIdentity();
  if (w <= h)
    glOrtho (-a, a, -a*(GLfloat)h/(GLfloat)w, a*(GLfloat)h/(GLfloat)w, -a, a);
  else
    glOrtho (-a*(GLfloat)w/(GLfloat)h, a*(GLfloat)w/(GLfloat)h, -a, a, -a, a);
  glMatrixMode(GL_MODELVIEW);
  glLoadIdentity();
}
 
void main(void)
{
  auxInitDisplayMode (AUX_SINGLE | AUX_RGBA);
  auxInitPosition (0, 0, 500, 500);
  auxInitWindow (" Teapot TextureMapping");
  myinit();
  auxReshapeFunc (myReshape);
  auxMainLoop(display);
}
  以上程序運行結(jié)果是在屏幕上顯示一個帶條狀紋理的茶壺。其中用到了前面所講的一維紋理映射定義,以及本節(jié)的紋理坐標自動產(chǎn)生。

 
圖12-2 貼紋理的茶壺

posted on 2006-01-17 01:07 zmj 閱讀(11169) 評論(2)  編輯 收藏 引用

評論

# re: OpenGL紋理 2008-01-04 17:51 張明

我想加入OpenGL群23186719 不知道怎么可以加進去 小弟現(xiàn)在有一個問題急需要解決 請樓主幫幫忙   回復(fù)  更多評論   

# re: OpenGL紋理 2009-12-26 16:27 blizmax

試了試你得代碼 我在xp 下運行
補上
//#include "glos.h"
#include <windows.h>

#include <GL/gl.h>
#pragma comment(lib,"opengl32.lib")
#include <GL/glu.h>
#pragma comment(lib,"glu32.lib")
#include <GL/glaux.h>
#pragma comment(lib,"glaux.lib")


咔咔 希望多些交流 QQ314535875  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美一区二区在线观看| 影院欧美亚洲| 久久精品亚洲一区| 午夜国产精品视频免费体验区| 日韩一区二区久久| 亚洲视频在线观看| 亚洲一区二区三区精品动漫| 欧美一区三区三区高中清蜜桃| 欧美在线亚洲一区| 久久精品盗摄| 欧美激情欧美激情在线五月| 国产精品xxxxx| 激情综合网址| 一区二区三区不卡视频在线观看| 亚洲在线电影| 麻豆91精品| 一本色道久久88亚洲综合88| 性欧美1819sex性高清| 久久亚洲精品一区二区| 欧美视频免费| 在线观看亚洲a| 亚洲一区二区3| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品一区二区三区不| 欧美一区二区成人6969| 欧美精品一区二区三| 国产欧美一区二区精品婷婷| 亚洲成在线观看| 欧美尤物巨大精品爽| 欧美黄色网络| 欧美一级理论片| 欧美日韩妖精视频| 在线观看亚洲精品| 欧美在线视频不卡| 亚洲人成人一区二区在线观看| 亚洲欧美一区二区三区久久| 欧美激情免费在线| 亚洲成人在线免费| 久久9热精品视频| 日韩视频亚洲视频| 欧美第一黄网免费网站| 亚洲欧美日韩精品久久| 免费的成人av| 国产亚洲午夜高清国产拍精品| 欧美激情无毛| 国模精品一区二区三区色天香| 国产真实久久| 亚洲综合视频在线| 亚洲日本中文| 老司机午夜精品视频| 国产一区99| 先锋a资源在线看亚洲| 最新69国产成人精品视频免费| 久久久久综合网| 激情自拍一区| 女女同性精品视频| 久久大逼视频| 国内精品久久久久久| 午夜影院日韩| 亚洲一区二区三区在线观看视频| 男人的天堂亚洲在线| 在线成人www免费观看视频| 欧美在线一二三| 亚洲综合丁香| 国产欧美午夜| 久久婷婷人人澡人人喊人人爽| 亚洲男人第一av网站| 国产精品一二三| 欧美影院成人| 欧美一区二区视频在线| 国产亚洲成人一区| 久久亚洲国产精品一区二区| 午夜欧美大片免费观看| 国产一区二区按摩在线观看| 久久久久久久久久久久久女国产乱 | 狠狠入ady亚洲精品| 久久亚洲色图| 美国十次成人| 一区二区三区欧美亚洲| 亚洲欧美国产精品桃花| 伊甸园精品99久久久久久| 欧美freesex交免费视频| 欧美激情视频一区二区三区不卡| 一本大道av伊人久久综合| 一级成人国产| 国产一级精品aaaaa看| 亚洲第一福利在线观看| 欧美性猛交99久久久久99按摩 | 玖玖综合伊人| 欧美福利专区| 久久av一区二区| 欧美xx69| 久久成人18免费观看| 国产一区二区三区四区| 国产精品成人在线| 久久久久国产免费免费| 欧美激情1区| 国产综合久久久久久| 亚洲二区三区四区| 欧美三级电影网| 久久午夜视频| 国产精品久久91| 美女福利精品视频| 国产精品日韩电影| 亚洲第一在线| 狠狠久久婷婷| 一区二区三区视频观看| 一区二区亚洲欧洲国产日韩| 99天天综合性| 亚洲高清二区| 欧美一区二区大片| 亚洲午夜日本在线观看| 美女日韩在线中文字幕| 亚洲欧美精品| 欧美激情一级片一区二区| 久久免费国产| 国产精品日韩在线一区| 亚洲欧洲免费视频| 在线看国产日韩| 欧美影院视频| 欧美资源在线观看| 国产精品海角社区在线观看| 亚洲国产精品一区| 在线看片一区| 亚洲视频碰碰| 欧美专区在线播放| av成人毛片| 亚洲三级视频在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 精品福利电影| 亚洲人久久久| 国户精品久久久久久久久久久不卡| 在线综合亚洲| 欧美一区二区三区在线视频 | 精品999在线播放| 精品999网站| 国产酒店精品激情| 欧美视频免费在线| 欧美日韩影院| 欧美亚洲视频| 久久视频国产精品免费视频在线 | 欧美国产视频在线| 99精品欧美一区二区三区综合在线 | 欧美女人交a| 欧美不卡激情三级在线观看| 欧美久久九九| 久久久久久久高潮| 欧美精品三级| 亚洲激情校园春色| 日韩亚洲欧美高清| 欧美日韩亚洲一区二| 亚洲视频在线观看三级| 久久国产精品黑丝| 禁断一区二区三区在线| 美腿丝袜亚洲色图| 亚洲激情综合| 亚洲一区二区三区色| 国产伦精品一区二区三区免费迷| 亚洲字幕一区二区| 亚洲欧洲三级| 91久久精品美女高潮| 午夜欧美理论片| 欧美国产一区二区| 欧美大片一区| 欧美视频在线不卡| 91久久精品日日躁夜夜躁欧美| 国产免费成人在线视频| 国产精品视频| 亚洲欧美日本伦理| 亚洲一区二区三区久久| 欧美日韩国产专区| 亚洲欧美激情视频在线观看一区二区三区| 久久综合色88| 欧美激情亚洲视频| 亚洲精品乱码久久久久久黑人 | 国产欧美精品在线| 免费在线亚洲欧美| 国产精品日韩久久久| 久久精品女人天堂| 久久一二三国产| 国产欧美日韩中文字幕在线| 麻豆国产精品777777在线| 国产一区二区久久| 亚洲成人原创| 欧美视频一区二| 亚洲激情校园春色| 国产一区二区主播在线| 国产精品对白刺激久久久| 亚洲人精品午夜| 欧美日韩国产综合网| 欧美麻豆久久久久久中文| 欧美视频在线观看免费网址| 亚洲欧美精品中文字幕在线| 中日韩午夜理伦电影免费| 9i看片成人免费高清| 国产精品99久久久久久白浆小说| 欧美mv日韩mv国产网站| 久久久之久亚州精品露出| 久热精品视频在线| 欧美福利电影在线观看|