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

天行健 君子當自強而不息

像素著色器入門(2)

新建網頁 1

18.4 HLSL采樣器對象

在像素著色器中使用HLSL的內建函數tex*XXXX給紋理采樣。注意:采樣時引用紋理上圖素的坐標索引和采樣器狀態來生成像素。

通常這些函數需要我們做2件事:

使用紋理中的索引建立(u, v)紋理坐標。

給特定的紋理中編入索引。

將紋理坐標(u, v)輸入到像素著色器,在一個指定的HLSL對象中的像素著色器中,我們想編入索引的紋理是在像素著色器中被定義過的,在HLSL中叫作采樣器。(The particular texture that we want to index into is identified in the pixel shader by a special HLSL object called a sampler.),我們可以把采樣器對象想象成定義紋理和采樣器階段的對象。例如:假如我們使用3張紋理,這意味著我們需要在像素著色器里能夠引用3個階段中的每個一個。在像素著色器中我們這樣寫:

                
        

        sampler FirstTex;

        

        sampler SecondTex;

        

        sampler ThirdTex;

Direct3D將給每個采樣器對象連接一個唯一的紋理級別(stage),在應用程序中我們找出與采樣器對象相關聯的階段,并設置相應的紋理和采樣器狀態給該階段。下列代碼將舉例說明如何在應用程序中設置紋理并把采樣器狀態設置為FirstTex

       
    

        //         創建

        IDirect3DTexture9* Tex;

        D3DXCreateTextureFromFile(Device, "tex.bmp", &Tex);

        

        … …

        

        //         取得常量FirstTex的句柄

        FirstTexHandle = MultiTexCT->GetConstantByName(0, "FirstTex");

                

        //         取得常量的描述

        D3DXCONSTANT_DESC FirstTexDesc;

        

        UINT         count;

        MultiTexCT->GetConstantDesc(FirstTexHandle, &FirstTexDesc, &count);

        

         … …

        

        //         FirstTex設置紋理和采樣器狀態.        

        

        // We identify the stage FirstTex is associated with from the           D3DXCONSTANT_DESC::RegisterIndex member:

        

        Device->SetTexture(FirstTexDesc.RegisterIndex, Tex);

        

        Device->SetSamplerState(FirstTexDesc.RegisterIndex,  D3DSAMP_MAGFILTER,      D3DTEXF_LINEAR);

        

        Device->SetSamplerState(FirstTexDesc.RegisterIndex,  D3DSAMP_MINFILTER,       D3DTEXF_LINEAR);

        

        Device->SetSamplerState(FirstTexDesc.RegisterIndex,  D3DSAMP_MIPFILTER,       D3DTEXF_LINEAR);

注意:作為選擇,替換使用采樣器類型,你可以使用更多特殊的、強大的類型,如:sampler1Dsampler2Dsampler3D,和samplerCube類型,這些類型更安全并且它們只使用tex*函數。例如:一個sampler2D對象只使用tex2D*函數,同樣一個sampler3D對象只使用tex3D*函數。

 

 

18.5例子程序:Multitexturing in a Pixel Shader

這章中的例子演示了在像素著色器中使用多紋理,這個例子渲染的目標是一個木箱紋理,一個聚光燈紋理,和一個包含字符串的紋理。這就是例子程序:Pixel Shader

 

這個例子可以不使用像素著色器來實現,但實現這個程序是簡單直接,它允許我們示范如何編寫,創建,而且使用像素著色器實現一些特效不必使用那些復雜的算法。

雖然在這個例子中一次只使用3張紋理,檢查采樣器對象的成員以確定每個像素著色器能夠使用的版本,這是值得的。換句話說,我們一次能使用多少紋理,這依賴于使用的像素著色器的版本:

像素著色器的版本ps_1_1 ps_1_3支持4個紋理采樣器。

像素著色器的版本ps_1_4支持6個紋理采樣器。

像素著色器的版本ps_2_0 ps_3_0支持16個紋理采樣器。

 

     /******************************************************************************
      Pixel shader that does multi texturing.
     ******************************************************************************/

    
    sampler g_base_texture;
    sampler g_spotlight_texture;
    sampler g_string_texture;
    
    
struct sPixelInput
    {
        float2 
base         : TEXCOORD0;
        float2 spotlight : TEXCOORD1;
        float2 text         : TEXCOORD2;
    };
    
    
struct sPixelOutput
    {
        vector diffuse : COLOR0;
    };
    
    
    /////////////////////////////////////////////////////////////////////////////////
    

    sPixelOutput main(sPixelInput input)
    {
        sPixelOutput output = (sPixelOutput) 0;
    
        
// sample appropriate textures
    
        vector base_color       = tex2D(g_base_texture,        input.base);
        vector spotlight_color = tex2D(g_spotlight_texture, input.spotlight);
        vector text_color       = tex2D(g_string_texture,    input.text);
    
        
// combine texel colors
    
        vector color = base_color * spotlight_color + text_color;
    
        
// increase the intensity of the pixel slightly
    
    color += 0.1f;
    
        
// save the resulting pixel color
    
    output.diffuse = color;
    
        
return output;
    }

tex2D的函數使用說明如下:

There are two overloaded tex2D texture lookup functions:

  • 2D texture lookup
  •     
  • 2D texture lookup with partial derivatives     

2D texture lookup

This function performs a 2D texture lookup.

Syntax

                 
ret tex2D(s, t)

Where:

                                                                                                                                                                                                                      
NameIn/OutTemplate TypeComponent TypeSize
sinobjectsampler2D1
tinvectorfloat2
retoutvectorfloat4

2D texture lookup with partial derivatives

This function performs a 2D texture lookup also, but also uses the partial derivatives to help pick the LOD.

Syntax

                 
ret tex2D(s, t, ddx, ddy)

Where:

                                                                                                                                                                                                                                                                                                                                    
NameIn/OutTemplate TypeComponent TypeSize
sinobjectsampler2D1
tinvectorfloat2
ddxinvectorfloat2
ddyinvectorfloat2
retoutvectorfloat4

 

首先像素著色器定義了3sampler對象,要渲染的每個紋理,接下來定義是inputoutput結構。注意:我們沒有將任何的顏色值輸入到像素著色器中,這是因為我們使用紋理自己的顏色和光照;即BaseTex保存表面的顏色,SpotLightTex是光照圖。像素著色器輸出只一個簡顏色值,指定了我們計算過的這個特定像素的顏色。

Main函數使用tex2D函數采樣3個紋理,即它取得每個紋理的圖素,計算映射到的像素,這通常依賴于指定的紋理坐標和采樣器對象。然后我們混合圖素的顏色用公式:c = b * s + t。接下來我們讓全部的像素變亮一個bit,給每個部分增加0.1f。最后我們保存結果像素顏色并返回它。

執行程序:

     /**************************************************************************************************
      Deomstrates multi-texturing using a pixel shader.  You will have to switch to the REF 
      device to run this sample if your hardware doesn't support pixel shaders.
     **************************************************************************************************/

    
    #include "d3dUtility.h"
    
    #pragma warning(disable : 4100)
    
    
struct sMultiTextureVertex
    {
        sMultiTextureVertex(
float x, float y, float z,
                            
float u0, float v0,
                            
float u1, float v1,
                            
float u2, float v2)
        {
            _x =  x;  _y =  y; _z = z;
            _u0 = u0; _v0 = v0; 
            _u1 = u1; _v1 = v1;
            _u2 = u2, _v2 = v2;
        }
    
        
float _x, _y, _z;
        
float _u0, _v0;
        
float _u1, _v1;
        
float _u2, _v2;
    };
    
    
const DWORD MULTI_TEXTURE_VERTEX_FVF = D3DFVF_XYZ | D3DFVF_TEX3; 
    
    
    /////////////////////////////////////////////////////////////////////////////////////////////
    

    
const int WIDTH  = 640;
    
const int HEIGHT = 480;
    
    IDirect3DDevice9*        g_device;
    IDirect3DPixelShader9*    g_pixel_shader;
    ID3DXConstantTable*        g_constant_table;
    IDirect3DVertexBuffer9*    g_vertex_buffer;
    
    IDirect3DTexture9*        g_base_texture;
    IDirect3DTexture9*        g_spotlight_texture;
    IDirect3DTexture9*        g_string_texture;
    
    D3DXHANDLE                g_base_texture_handle;
    D3DXHANDLE                g_spotlight_texture_handle;
    D3DXHANDLE                g_string_texture_handle;
    
    D3DXCONSTANT_DESC        g_base_texture_desc;
    D3DXCONSTANT_DESC        g_spotlight_texture_desc;
    D3DXCONSTANT_DESC        g_string_texture_desc;
    
    
    ////////////////////////////////////////////////////////////////////////////////////////////////////
    

    
bool setup()
    {    
        
// create geometry
    

        g_device->CreateVertexBuffer(6 * 
sizeof(sMultiTextureVertex), D3DUSAGE_WRITEONLY,
            MULTI_TEXTURE_VERTEX_FVF, D3DPOOL_MANAGED, &g_vertex_buffer, NULL);
    
        sMultiTextureVertex* v;
    
        g_vertex_buffer->Lock(0, 0, (
void**)&v, 0);
    
        v[0] = sMultiTextureVertex(-10.0f, -10.0f, 5.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f);
        v[1] = sMultiTextureVertex(-10.0f,  10.0f, 5.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f);
        v[2] = sMultiTextureVertex( 10.0f,  10.0f, 5.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f);
    
        v[3] = sMultiTextureVertex(-10.0f, -10.0f, 5.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f);
        v[4] = sMultiTextureVertex( 10.0f,  10.0f, 5.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f);
        v[5] = sMultiTextureVertex( 10.0f, -10.0f, 5.0f, 1.0f, 1.0f, 1.0f, 1.0f, 1.0f, 1.0f);
    
        g_vertex_buffer->Unlock();
    
        
// compile shader
    

        ID3DXBuffer*    shader_buffer;
        ID3DXBuffer*    error_buffer;
    
        HRESULT hr = D3DXCompileShaderFromFile("MultiTextureShader.cxx", NULL, NULL, "main", "ps_2_0", D3DXSHADER_DEBUG,
                                               &shader_buffer, &error_buffer, &g_constant_table);
    
        
// output any error messages
    
    if(error_buffer)
        {
            MessageBox(NULL, (
char*) error_buffer->GetBufferPointer(), "ERROR", MB_OK);
            safe_release<ID3DXBuffer*>(error_buffer);
        }
    
        
if(FAILED(hr))
        {
            MessageBox(NULL, "D3DXCompileShaderFromFile() - FAILED", "ERROR", MB_OK);
            
return false;
        }
    
        hr = g_device->CreatePixelShader((DWORD*) shader_buffer->GetBufferPointer(), &g_pixel_shader);
    
        
if(FAILED(hr))
        {
            MessageBox(NULL, "CreatePixelShader - FAILED", "ERROR", MB_OK);
            
return false;
        }
    
        safe_release<ID3DXBuffer*>(shader_buffer);
    
        
// load textures
    
        D3DXCreateTextureFromFile(g_device, "crate.bmp",     &g_base_texture);
        D3DXCreateTextureFromFile(g_device, "spotlight.bmp", &g_spotlight_texture);
        D3DXCreateTextureFromFile(g_device, "text.bmp",         &g_string_texture);
    
        
// get handles
    
        g_base_texture_handle        = g_constant_table->GetConstantByName(NULL, "g_base_texture");
        g_spotlight_texture_handle    = g_constant_table->GetConstantByName(NULL, "g_spotlight_texture");
        g_string_texture_handle        = g_constant_table->GetConstantByName(NULL, "g_string_texture");
    
        
// set constant descriptions
    

        UINT count;
    
        g_constant_table->GetConstantDesc(g_base_texture_handle,      &g_base_texture_desc,         &count);
        g_constant_table->GetConstantDesc(g_spotlight_texture_handle, &g_spotlight_texture_desc, &count);
        g_constant_table->GetConstantDesc(g_string_texture_handle,      &g_string_texture_desc,     &count);    
    
        g_constant_table->SetDefaults(g_device);
    
        
// set the projection matrix
    
    D3DXMATRIX proj;
        D3DXMatrixPerspectiveFovLH(&proj, D3DX_PI/4.0f, (
float)WIDTH/HEIGHT, 1.0f, 1000.0f);
        g_device->SetTransform(D3DTS_PROJECTION, &proj);
        
        
//g_device->SetRenderState(D3DRS_FILLMODE, D3DFILL_WIREFRAME);
    
    
        
return true;
    }
    
    
    ///////////////////////////////////////////////////////////////////////////////////////////////////////
    

    
void cleanup()
    {    
        safe_release<IDirect3DVertexBuffer9*>(g_vertex_buffer);
    
        safe_release<IDirect3DTexture9*>(g_base_texture);
        safe_release<IDirect3DTexture9*>(g_spotlight_texture);
        safe_release<IDirect3DTexture9*>(g_string_texture);
        
        safe_release<IDirect3DPixelShader9*>(g_pixel_shader);
        safe_release<ID3DXConstantTable*>(g_constant_table);
    }
    
    
    ///////////////////////////////////////////////////////////////////////////////////////////////////////
    

    
bool display(float time_delta)
    {    
        
// update the scene: allow user to rotate around scene.
    

        
static float angle  = (3.0f * D3DX_PI) / 2.0f;
        
static float radius = 20.0f;
    
        
if(GetAsyncKeyState(VK_LEFT) & 0x8000f)
            angle -= 0.5f * time_delta;
    
        
if(GetAsyncKeyState(VK_RIGHT) & 0x8000f)
            angle += 0.5f * time_delta;
    
        
if(GetAsyncKeyState(VK_UP) & 0x8000f)
            radius -= 2.0f * time_delta;
    
        
if(GetAsyncKeyState(VK_DOWN) & 0x8000f)
            radius += 2.0f * time_delta;
    
        D3DXVECTOR3 position(cosf(angle) * radius, 0.0f, sinf(angle) * radius);
        D3DXVECTOR3 target(0.0f, 0.0f, 0.0f);
        D3DXVECTOR3 up(0.0f, 1.0f, 0.0f);
    
        D3DXMATRIX view_matrix;
        D3DXMatrixLookAtLH(&view_matrix, &position, &target, &up);
        g_device->SetTransform(D3DTS_VIEW, &view_matrix);
            
        
// render now
    

        g_device->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, 0xFFFFFFFF, 1.0f, 0);
    
        g_device->BeginScene();
    
        g_device->SetPixelShader(g_pixel_shader);
    
        g_device->SetFVF(MULTI_TEXTURE_VERTEX_FVF);
        g_device->SetStreamSource(0, g_vertex_buffer, 0, 
sizeof(sMultiTextureVertex));
    
        
// base texture
    
        g_device->SetTexture(g_base_texture_desc.RegisterIndex, g_base_texture);
        g_device->SetSamplerState(g_base_texture_desc.RegisterIndex, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_base_texture_desc.RegisterIndex, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_base_texture_desc.RegisterIndex, D3DSAMP_MIPFILTER, D3DTEXF_LINEAR);
    
        
// spotlight texture
    
        g_device->SetTexture(g_spotlight_texture_desc.RegisterIndex, g_spotlight_texture);
        g_device->SetSamplerState(g_spotlight_texture_desc.RegisterIndex, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_spotlight_texture_desc.RegisterIndex, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_spotlight_texture_desc.RegisterIndex, D3DSAMP_MIPFILTER, D3DTEXF_LINEAR);
    
        
// string texture
    
        g_device->SetTexture(g_string_texture_desc.RegisterIndex, g_string_texture);
        g_device->SetSamplerState(g_string_texture_desc.RegisterIndex, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_string_texture_desc.RegisterIndex, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
        g_device->SetSamplerState(g_string_texture_desc.RegisterIndex, D3DSAMP_MIPFILTER, D3DTEXF_LINEAR);
    
        g_device->DrawPrimitive(D3DPT_TRIANGLELIST, 0, 2);
        
        g_device->EndScene();
    
        g_device->Present(NULL, NULL, NULL, NULL);
    
        
return true;
    }
    
    
    ///////////////////////////////////////////////////////////////////////////////////////////////////////
    

    LRESULT CALLBACK wnd_proc(HWND hwnd, UINT msg, WPARAM word_param, LPARAM long_param)
    {
        
switch(msg)
        {
        
case WM_DESTROY:
            PostQuitMessage(0);
            
break;
    
        
case WM_KEYDOWN:
            
if(word_param == VK_ESCAPE)
                DestroyWindow(hwnd);
    
            
break;
        }
    
        
return DefWindowProc(hwnd, msg, word_param, long_param);
    }
    
    
    ///////////////////////////////////////////////////////////////////////////////////////////////////////
    

    
int WINAPI WinMain(HINSTANCE inst, HINSTANCE, PSTR cmd_line, int cmd_show)
    {
        
if(! init_d3d(inst, WIDTH, HEIGHT, true, D3DDEVTYPE_HAL, &g_device))
        {
            MessageBox(NULL, "init_d3d() - failed.", 0, MB_OK);
            
return 0;
        }
    
        
if(! setup())
        {
            MessageBox(NULL, "Steup() - failed.", 0, MB_OK);
            
return 0;
        }
    
        enter_msg_loop(display);
    
        cleanup();
        g_device->Release();
    
        
return 0;
    }

setup函數執行下列功能:

填充方形的頂點緩存

編譯著像素色器

創建像素色器

讀取紋理

設置投影矩陣,不使用光照

取得采樣器(sampler)對象的句柄

取得采樣器對象的描述


display函數設置像素著色器,使用2個紋理,并且在渲染方格前設置他們對應的采樣器狀態。


運行截圖:

 

下載源程序


posted on 2008-04-11 13:07 lovedday 閱讀(2770) 評論(0)  編輯 收藏 引用

公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲人成高清| 日韩亚洲国产精品| 日韩亚洲一区二区| 亚洲三级观看| 最新国产精品拍自在线播放| 国产一区二区三区最好精华液| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 麻豆成人综合网| 久久亚洲欧美国产精品乐播| 噜噜噜在线观看免费视频日韩| 免费在线视频一区| 欧美黑人多人双交| 一本色道久久综合亚洲精品不卡 | 亚洲伦伦在线| 亚洲一区二区毛片| 久久aⅴ国产欧美74aaa| 美女免费视频一区| 99综合电影在线视频| 亚洲免费在线视频| 久久一二三国产| 欧美国产日产韩国视频| 国产精品久久九九| 在线免费观看成人网| 日韩手机在线导航| 久久久国产亚洲精品| 欧美激情按摩| 亚洲精品美女在线| 欧美激情精品久久久久久变态| 亚洲第一二三四五区| 亚洲性感激情| 欧美成人中文| 国产免费成人| 亚洲免费成人av电影| 欧美在线高清| 亚洲国产精品久久久久秋霞不卡 | 国产亚洲成av人在线观看导航| 亚洲高清免费在线| 性色一区二区| 亚洲国产视频直播| 欧美一区二区三区在线看| 欧美剧在线免费观看网站| 国产一区二区福利| 亚洲欧美国产va在线影院| 亚洲丶国产丶欧美一区二区三区| 亚洲一区二区免费看| 欧美国产日韩亚洲一区| 国产一区二区剧情av在线| 亚洲午夜激情网页| 亚洲国产欧美久久| 久久免费视频在线| 韩国av一区二区三区| 亚洲欧美一区二区视频| 亚洲精品久久久久久久久久久久久| 欧美一区二区播放| 国产伦精品一区二区三区高清版| 一本不卡影院| 欧美激情在线狂野欧美精品| 久久久久成人精品免费播放动漫| 国产精品一区二区三区免费观看| 亚洲深夜影院| 亚洲伦理在线观看| 欧美日韩国产一区二区三区地区| 亚洲激情视频在线播放| 男人天堂欧美日韩| 久久久久久精| 亚洲黑丝在线| 亚洲高清激情| 欧美精品色网| 亚洲一区日本| 亚洲欧美精品在线观看| 国产资源精品在线观看| 开元免费观看欧美电视剧网站| 久久精品国产2020观看福利| 国产视频久久| 久久夜色精品国产噜噜av| 久久久成人网| 亚洲激情午夜| 久久国产精品99精品国产| 99精品99| 欧美午夜寂寞影院| 欧美一区二区三区啪啪| 亚洲国产精品专区久久| 在线视频精品一| 亚洲毛片在线观看.| 欧美日韩视频在线一区二区| 亚洲亚洲精品在线观看| 亚洲制服av| 国产精品亚洲综合色区韩国| 一区二区三区|亚洲午夜| 亚洲精品中文字| 国产精品久久毛片a| 亚洲婷婷免费| 久久gogo国模裸体人体| 一本久久综合| 亚洲欧美日本在线| 亚洲国产日韩欧美在线动漫| 亚洲精品乱码久久久久久日本蜜臀 | 欧美岛国在线观看| 欧美电影免费观看大全| 亚洲精品乱码久久久久久按摩观 | 亚洲欧美在线高清| 亚洲成色精品| 一区二区三区精品久久久| 国产亚洲精品久久久| 亚洲第一页自拍| 国产精品一区二区三区成人| 欧美成人免费播放| 国产精品美女久久| 免费影视亚洲| 国产精品男女猛烈高潮激情| 欧美国产激情二区三区| 亚洲精品小视频| 国产日韩欧美不卡在线| 亚洲欧洲在线播放| 国内外成人免费激情在线视频网站| 亚洲国产精品第一区二区三区| 国产精品素人视频| 亚洲激情成人| 国产一区亚洲| 亚洲视频一区二区在线观看| 亚洲电影观看| 欧美一区=区| 午夜精彩视频在线观看不卡| 欧美成年人网| 老牛影视一区二区三区| 国产日韩欧美不卡| 一区二区三区免费观看| 亚洲激情网站免费观看| 欧美在线一级va免费观看| 亚洲欧美日韩国产精品| 欧美岛国激情| 极品尤物久久久av免费看| 最新亚洲一区| 亚洲激情社区| 久久精品一区蜜桃臀影院| 亚洲国产精品热久久| 国产欧美精品日韩| 在线视频免费在线观看一区二区| 激情欧美丁香| 亚洲欧美久久久| 亚洲永久免费| 欧美日韩高清在线| 亚洲久久在线| 亚洲精品资源| 欧美激情中文不卡| 欧美福利一区| 亚洲国产精品ⅴa在线观看| 午夜久久福利| 欧美三级午夜理伦三级中视频| 欧美福利视频一区| 亚洲成人在线视频网站| 久久久久久久网| 久久精品国产96久久久香蕉| 欧美三日本三级少妇三2023| 妖精成人www高清在线观看| 亚洲午夜日本在线观看| 国产精品国产三级国产普通话蜜臀| 亚洲欧洲一区| 一级日韩一区在线观看| 欧美日韩国产在线一区| 亚洲先锋成人| 久久亚洲风情| 激情欧美亚洲| 免费亚洲婷婷| 99在线视频精品| 久久精品国产欧美激情| 亚洲国产欧美精品| 欧美午夜精品伦理| 久久高清免费观看| 欧美大片一区二区| 亚洲视频电影在线| 国产亚洲成av人片在线观看桃| 久久婷婷麻豆| 亚洲第一福利视频| 亚洲视频欧美在线| 国产免费观看久久| 农村妇女精品| 亚洲欧美另类综合偷拍| 久久综合九色综合欧美就去吻| 精品999在线观看| 欧美不卡在线| 亚洲专区一二三| 久久综合中文字幕| 亚洲男人的天堂在线观看| 国产在线精品自拍| 欧美成人免费小视频| 亚洲精品一区中文| 美女日韩在线中文字幕| 99国产麻豆精品| 国产日韩一区在线| 欧美国产日韩一区二区| 一区二区三区.www| 欧美激情精品久久久久久| 欧美诱惑福利视频| 99v久久综合狠狠综合久久| 国产乱码精品一区二区三区不卡 | 欧美大色视频| 亚洲午夜高清视频| 亚洲乱码国产乱码精品精天堂 | 99国产精品一区|