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

天行健 君子當自強而不息

網格模型高級技術(18)


cSkinMesh類的設計與實現

cSkinMesh類的實現與cAnimMesh的實現基本相同,區別在以下幾點。

 

首先是在load_from_xfile()中增加了對網格模型骨骼矩陣的保存:

HRESULT cSkinMesh::setup_bone_matrix_pointers(D3DXFRAME* frame)
{    
    HRESULT hr;

    
if(frame == NULL)
        
return S_OK;

    
if(frame->pMeshContainer != NULL)
    {
        hr 
= setup_bone_matrix_pointers_on_mesh(frame->pMeshContainer);

        
if(FAILED(hr))
            
return hr;
    }

    
if(frame->pFrameSibling != NULL)
    {
        hr 
= setup_bone_matrix_pointers(frame->pFrameSibling);

        
if(FAILED(hr))
            
return hr;
    }

    
if(frame->pFrameFirstChild != NULL)
    {
        hr 
= setup_bone_matrix_pointers(frame->pFrameFirstChild);

        
if(FAILED(hr))
            
return hr;
    }
    
    
return S_OK;    
}


HRESULT cSkinMesh::setup_bone_matrix_pointers_on_mesh(D3DXMESHCONTAINER
* base_mesh_container)
{
    
if(base_mesh_container == NULL)
        
return S_OK;

    D3DXMESHCONTAINER_DERIVED
* mesh_container = (D3DXMESHCONTAINER_DERIVED*) base_mesh_container;

    
if(mesh_container->pSkinInfo != NULL)
    {
        UINT num_bones 
= mesh_container->pSkinInfo->GetNumBones();
        mesh_container
->ppBoneMatrices = new D3DXMATRIX*[num_bones];

        
if(mesh_container->ppBoneMatrices == NULL)
            
return E_OUTOFMEMORY;

        
for(UINT i = 0; i < num_bones; i++)
        {
            LPCSTR bone_name 
= mesh_container->pSkinInfo->GetBoneName(i);
            D3DXFRAME_DERIVED
* frame = (D3DXFRAME_DERIVED*) D3DXFrameFind(m_root_frame, bone_name);

            
if(frame == NULL)
                
return E_FAIL;

            mesh_container
->ppBoneMatrices[i] = &frame->CombinedTransformMatrix;
        }
    }

    
return S_OK;
}


HRESULT cSkinMesh::load_from_xfile(CONST WCHAR
* wfilename)
{
    HRESULT hr;

    WCHAR wpath[MAX_PATH];
    DXUTFindDXSDKMediaFileCch(wpath, 
sizeof(wpath) / sizeof(WCHAR), wfilename);

    V_RETURN(D3DXLoadMeshHierarchyFromXW(wpath, D3DXMESH_MANAGED, m_device, m_alloc_hierarchy, NULL, 
&m_root_frame,
                                         
&m_anim_controller));

    V_RETURN(setup_bone_matrix_pointers(m_root_frame));

    V_RETURN(D3DXFrameCalculateBoundingSphere(m_root_frame, 
&m_object_center, &m_object_radius));

    
return S_OK;
}

 

 

接下來是DrawMeshContainer()的實現,該函數負責當前網格容器中具體網格模型的渲染,其實現大致可以分為以下幾個步驟:

【1】如果當前網格模型是蒙皮網格模型

(1)根據當前硬件設備的性能決定是否采用軟件頂點處理模式。

(2)激活索引頂點混合。

(3)設置頂點混合所需要的矩陣索引數量。

(4)渲染索引蒙皮網格模型,在具體渲染時,需要逐個屬性組進行渲染,在渲染每個子網格時,首先需要設置骨骼混合矩陣、材質和數組。

(5)恢復相關渲染狀態。

【2】如果當前網格模型不是蒙皮網格模型,則直接設置組合變換矩陣、材質和紋理,然后進行渲染。

 HRESULT cSkinMesh::draw_mesh_container(CONST D3DXMESHCONTAINER* base_mesh_container, CONST D3DXFRAME* base_frame)
{
    HRESULT hr;

    D3DXMESHCONTAINER_DERIVED
* mesh_container = (D3DXMESHCONTAINER_DERIVED*) base_mesh_container;
    D3DXFRAME_DERIVED
* frame = (D3DXFRAME_DERIVED*) base_frame;

    
if(mesh_container->pSkinInfo != NULL)
    {
        
if(mesh_container->UseSoftwareVP)
        {
            V_RETURN(m_device
->SetSoftwareVertexProcessing(TRUE));
        }
        
        
if(mesh_container->MaxBonesInflPerVertex)
            m_device
->SetRenderState(D3DRS_INDEXEDVERTEXBLENDENABLE, TRUE);

        
if(mesh_container->MaxBonesInflPerVertex == 1)
            m_device
->SetRenderState(D3DRS_VERTEXBLEND, D3DVBF_0WEIGHTS);
        
else if(mesh_container->MaxBonesInflPerVertex == 2)
            m_device
->SetRenderState(D3DRS_VERTEXBLEND, D3DVBF_1WEIGHTS);
        
else if(mesh_container->MaxBonesInflPerVertex == 3)
            m_device
->SetRenderState(D3DRS_VERTEXBLEND, D3DVBF_2WEIGHTS);
        
else
            m_device
->SetRenderState(D3DRS_VERTEXBLEND, D3DVBF_3WEIGHTS);

        D3DXBONECOMBINATION
* bone_comb = (D3DXBONECOMBINATION*) mesh_container->pBoneCombBuffer->GetBufferPointer();

        
for(UINT attr_index = 0; attr_index < mesh_container->NumAttrGroups; attr_index++)
        {
            
// setup vertex index blending world matrix for every mesh group
            for(UINT palette_index = 0; palette_index < mesh_container->NumMatrixPalettes; palette_index++)
            {
                UINT matrix_index 
= bone_comb[attr_index].BoneId[palette_index];

                
if(matrix_index != UINT_MAX)
                {
                    D3DXMATRIX mat_palette;

                    D3DXMatrixMultiply(
&mat_palette,
                                       mesh_container
->ppBoneOffsetMatrices[matrix_index],
                                       mesh_container
->ppBoneMatrices[matrix_index]);

                    m_device
->SetTransform(D3DTS_WORLDMATRIX(palette_index), &mat_palette);
                }
            }

            DWORD attr_id 
= bone_comb[attr_index].AttribId;

            m_device
->SetMaterial(&mesh_container->pMaterials[attr_id].MatD3D);
            m_device
->SetTexture(0, mesh_container->ppTextures[attr_id]);

            mesh_container
->MeshData.pMesh->DrawSubset(attr_index);
        }

        
// restore render state

        m_device
->SetRenderState(D3DRS_INDEXEDVERTEXBLENDENABLE, FALSE);
        m_device
->SetRenderState(D3DRS_VERTEXBLEND, D3DVBF_DISABLE);

        
if(mesh_container->UseSoftwareVP)
        {
            V_RETURN(m_device
->SetSoftwareVertexProcessing(FALSE));
        }
    }
    
else
    {
        m_device
->SetTransform(D3DTS_WORLD, &frame->CombinedTransformMatrix);

        
for(UINT i = 0; i < mesh_container->NumMaterials; i++)
        {
            m_device
->SetMaterial(&mesh_container->pMaterials[i].MatD3D);
            m_device
->SetTexture(0, mesh_container->ppTextures[i]);

            mesh_container
->MeshData.pMesh->DrawSubset(i);
        }
    }

    
return S_OK;
}

 

 

蒙皮骨骼動畫網格模型類的使用

首先需要修改頂點處理模式,如果當前Direct3D設備使用純硬件頂點處理模式,則改為混合頂點處理模式:

// If video card does not support hardware transform and light, then uses sofaware mode.
if((pCaps->DevCaps & D3DDEVCAPS_HWTRANSFORMANDLIGHT) == 0)
pDeviceSettings->BehaviorFlags = D3DCREATE_SOFTWARE_VERTEXPROCESSING;
// !!important, change vertex processing to mixed mode.
if(pDeviceSettings->BehaviorFlags & D3DCREATE_HARDWARE_VERTEXPROCESSING)
pDeviceSettings->BehaviorFlags = D3DCREATE_MIXED_VERTEXPROCESSING;

因為硬件可能不支持索引頂點混合,這時就需要使用軟件頂點處理,所以在使用cSkinMesh類渲染蒙皮骨骼動畫網格模型的程序中,如果Direct3D設備使用純硬件頂點處理模式,則需要改為混合頂點處理模式,否則在調用IDirect3DDevice9::SetSoftwareProcessing()函數將頂點處理模式改為軟件頂點處理模式時會出錯。

接下來在回調函數OnCreateDevice()中創建cSkinMesh類的實例:

g_skin_mesh = new cSkinMesh();
V_RETURN(g_skin_mesh->create(pd3dDevice, L"tiny.x"));

再接下來在回調函數OnFrameRender()中渲染網格模型:

V(g_skin_mesh->render(&g_mat_world, fElapsedTime));

最后在回調函數OnDestroyDevice()中釋放網格模型:

g_skin_mesh->destroy();

 

運行截圖:

 

主程序:

#include "dxstdafx.h"
#include 
"resource.h"
#include 
"SkinMesh.h"

#pragma warning(disable : 
4127 4995)

#define IDC_TOGGLE_FULLSCREEN    1
#define IDC_TOGGLE_REF            2
#define IDC_CHANGE_DEVICE        3

#define release_com(p)    do { if(p) { (p)->Release(); (p) = NULL; } } while(0)

ID3DXFont
*                    g_font;
ID3DXSprite
*                g_text_sprite;
bool                        g_show_help;

CDXUTDialogResourceManager    g_dlg_resource_manager;
CD3DSettingsDlg                g_settings_dlg;
CDXUTDialog                    g_button_dlg;

cSkinMesh
*                    g_skin_mesh;
D3DXMATRIX                    g_mat_world;

//--------------------------------------------------------------------------------------
// Rejects any devices that aren't acceptable by returning false
//--------------------------------------------------------------------------------------
bool CALLBACK IsDeviceAcceptable( D3DCAPS9* pCaps, D3DFORMAT AdapterFormat, 
                                  D3DFORMAT BackBufferFormat, 
bool bWindowed, void* pUserContext )
{
    
// Typically want to skip backbuffer formats that don't support alpha blending

    IDirect3D9
* pD3D = DXUTGetD3DObject(); 

    
if( FAILED( pD3D->CheckDeviceFormat( pCaps->AdapterOrdinal, pCaps->DeviceType, AdapterFormat, 
                    D3DUSAGE_QUERY_POSTPIXELSHADER_BLENDING, D3DRTYPE_TEXTURE, BackBufferFormat ) ) )
        
return false;

    
return true;
}


//--------------------------------------------------------------------------------------
// Before a device is created, modify the device settings as needed.
//--------------------------------------------------------------------------------------
bool CALLBACK ModifyDeviceSettings( DXUTDeviceSettings* pDeviceSettings, const D3DCAPS9* pCaps, void* pUserContext )
{
    
// If video card does not support hardware transform and light, then uses sofaware mode.
    if((pCaps->DevCaps & D3DDEVCAPS_HWTRANSFORMANDLIGHT) == 0)
        pDeviceSettings
->BehaviorFlags = D3DCREATE_SOFTWARE_VERTEXPROCESSING;

    
// !!important, change vertex processing to mixed mode.
    if(pDeviceSettings->BehaviorFlags & D3DCREATE_HARDWARE_VERTEXPROCESSING)
        pDeviceSettings
->BehaviorFlags = D3DCREATE_MIXED_VERTEXPROCESSING;

    
static bool is_first_time = true;

    
if(is_first_time)
    {
        is_first_time 
= false;

        
// if using reference device, then pop a warning message box.
        if(pDeviceSettings->DeviceType == D3DDEVTYPE_REF)
            DXUTDisplaySwitchingToREFWarning();
    }

    
return true;
}


//--------------------------------------------------------------------------------------
// Create any D3DPOOL_MANAGED resources here 
//--------------------------------------------------------------------------------------
HRESULT CALLBACK OnCreateDevice( IDirect3DDevice9* pd3dDevice, 
                                 
const D3DSURFACE_DESC* pBackBufferSurfaceDesc, 
                                 
void* pUserContext )
{
    HRESULT    hr;

    V_RETURN(g_dlg_resource_manager.OnCreateDevice(pd3dDevice));
    V_RETURN(g_settings_dlg.OnCreateDevice(pd3dDevice));

    D3DXCreateFont(pd3dDevice, 
180, FW_BOLD, 1, FALSE, DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, DEFAULT_QUALITY,
                   DEFAULT_PITCH 
| FF_DONTCARE, L"Arial"&g_font);
    
    g_skin_mesh 
= new cSkinMesh();
    V_RETURN(g_skin_mesh
->create(pd3dDevice, L"tiny.x"));

    
return S_OK;
}


//--------------------------------------------------------------------------------------
// Create any D3DPOOL_DEFAULT resources here 
//--------------------------------------------------------------------------------------
HRESULT CALLBACK OnResetDevice( IDirect3DDevice9* pd3dDevice, 
                                
const D3DSURFACE_DESC* pBackBufferSurfaceDesc, 
                                
void* pUserContext )
{
    HRESULT hr;

    V_RETURN(g_dlg_resource_manager.OnResetDevice());
    V_RETURN(g_settings_dlg.OnResetDevice());
    V_RETURN(g_font
->OnResetDevice());
    V_RETURN(D3DXCreateSprite(pd3dDevice, 
&g_text_sprite));

    
// set dialog position and size

    g_button_dlg.SetLocation(pBackBufferSurfaceDesc
->Width - 1700);
    g_button_dlg.SetSize(
170170);

    
// setup view matrix

    D3DXMATRIX mat_view;
    D3DXVECTOR3 eye(
0.0f0.0f-1000.0f);
    D3DXVECTOR3  at(
0.0f0.0f,  0.0f);
    D3DXVECTOR3  up(
0.0f1.0f,  0.0f);

    D3DXMatrixLookAtLH(
&mat_view, &eye, &at, &up);
    pd3dDevice
->SetTransform(D3DTS_VIEW, &mat_view);

    
// set projection matrix
    D3DXMATRIX mat_proj;    
    
float aspect = (float)pBackBufferSurfaceDesc->Width / pBackBufferSurfaceDesc->Height;
    D3DXMatrixPerspectiveFovLH(
&mat_proj, D3DX_PI/4, aspect, 1.0f2000.0f);
    pd3dDevice
->SetTransform(D3DTS_PROJECTION, &mat_proj);

    
// setup light
    
    D3DLIGHT9 light;
    ZeroMemory(
&light, sizeof(D3DLIGHT9));

    light.Type       
= D3DLIGHT_DIRECTIONAL;
    light.Diffuse.r  
= 1.0f;
    light.Diffuse.g  
= 1.0f;
    light.Diffuse.b  
= 1.0f;
    light.Range         
= 1000.0f;

    D3DXVECTOR3 light_dir(
0.0f-1.0f1.0f);    
    D3DXVec3Normalize((D3DXVECTOR3
*&light.Direction, &light_dir);
    pd3dDevice
->SetLight(0&light);
    pd3dDevice
->LightEnable(0, TRUE);
    pd3dDevice
->SetRenderState(D3DRS_LIGHTING, TRUE);

    pd3dDevice
->SetRenderState(D3DRS_AMBIENT, 0x00505050);

    
return S_OK;
}

//--------------------------------------------------------------------------------------
// Release resources created in the OnResetDevice callback here 
//--------------------------------------------------------------------------------------
void CALLBACK OnLostDevice( void* pUserContext )
{
    g_dlg_resource_manager.OnLostDevice();
    g_settings_dlg.OnLostDevice();
    g_font
->OnLostDevice();

    release_com(g_text_sprite);
}


//--------------------------------------------------------------------------------------
// Release resources created in the OnCreateDevice callback here
//--------------------------------------------------------------------------------------
void CALLBACK OnDestroyDevice( void* pUserContext )
{
    g_dlg_resource_manager.OnDestroyDevice();
    g_settings_dlg.OnDestroyDevice();    

    release_com(g_font);

    g_skin_mesh
->destroy();
}

//--------------------------------------------------------------------------------------
// Handle updates to the scene
//--------------------------------------------------------------------------------------
void CALLBACK OnFrameMove( IDirect3DDevice9* pd3dDevice, double fTime, float fElapsedTime, void* pUserContext )
{
    D3DXMATRIX mat_trans, mat_rot;    
    
    D3DXMatrixTranslation(
&mat_trans, 0.0f30.0f-100.0f);
    D3DXMatrixRotationY(
&mat_rot, timeGetTime() / 1000.0f);
        
    g_mat_world 
= mat_trans * mat_rot;
}

//--------------------------------------------------------------------------------------
// Render the helper information
//--------------------------------------------------------------------------------------
void RenderText()
{
    CDXUTTextHelper text_helper(g_font, g_text_sprite, 
20);
    
    text_helper.Begin();

    
// show frame and device states
    text_helper.SetInsertionPos(55);
    text_helper.SetForegroundColor( D3DXCOLOR(
1.0f0.475f0.0f1.0f) );
    text_helper.DrawTextLine( DXUTGetFrameStats(
true) );
    text_helper.DrawTextLine( DXUTGetDeviceStats() );

    
// show helper information
    
    
const D3DSURFACE_DESC* surface_desc = DXUTGetBackBufferSurfaceDesc();

    
if(g_show_help)
    {
        text_helper.SetInsertionPos(
10, surface_desc->Height - 15 * 6);
        text_helper.SetForegroundColor( D3DXCOLOR(
1.0f0.475f0.0f1.0f) );
        text_helper.DrawTextLine(L
"Controls (F1 to hide):");
        
        text_helper.SetInsertionPos(
40, surface_desc->Height - 15 * 4);
        text_helper.DrawTextLine(L
"Quit: ESC");
    }
    
else
    {
        text_helper.SetInsertionPos(
10, surface_desc->Height - 15 * 4);
        text_helper.SetForegroundColor( D3DXCOLOR(
1.0f1.0f1.0f1.0f) );
        text_helper.DrawTextLine(L
"Press F1 for help");
    }

    text_helper.End();
}

//--------------------------------------------------------------------------------------
// Render the scene 
//--------------------------------------------------------------------------------------
void CALLBACK OnFrameRender( IDirect3DDevice9* pd3dDevice, double fTime, float fElapsedTime, void* pUserContext )
{
    HRESULT hr;

    
if(g_settings_dlg.IsActive())
    {
        g_settings_dlg.OnRender(fElapsedTime);
        
return;
    }

    
// Clear the render target and the zbuffer 
    V( pd3dDevice->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, D3DCOLOR_ARGB(0000), 1.0f0) );

    
// Render the scene
    if( SUCCEEDED( pd3dDevice->BeginScene() ) )
    {                                    
        V(g_skin_mesh
->render(&g_mat_world, fElapsedTime));
        RenderText();
        V(g_button_dlg.OnRender(fElapsedTime));

        V( pd3dDevice
->EndScene() );
    }
}


//--------------------------------------------------------------------------------------
// Handle messages to the application 
//--------------------------------------------------------------------------------------
LRESULT CALLBACK MsgProc( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, 
                          
bool* pbNoFurtherProcessing, void* pUserContext )
{
    
*pbNoFurtherProcessing = g_dlg_resource_manager.MsgProc(hWnd, uMsg, wParam, lParam);
    
if(*pbNoFurtherProcessing)
        
return 0;

    
if(g_settings_dlg.IsActive())
    {
        g_settings_dlg.MsgProc(hWnd, uMsg, wParam, lParam);
        
return 0;
    }

    
*pbNoFurtherProcessing = g_button_dlg.MsgProc(hWnd, uMsg, wParam, lParam);
    
if(*pbNoFurtherProcessing)
        
return 0;

    
return 0;
}


//--------------------------------------------------------------------------------------
// Handle keybaord event
//--------------------------------------------------------------------------------------
void CALLBACK OnKeyboardProc(UINT charater, bool is_key_down, bool is_alt_down, void* user_context)
{
    
if(is_key_down)
    {
        
switch(charater)
        {
        
case VK_F1:
            g_show_help 
= !g_show_help;
            
break;
        }
    }
}

//--------------------------------------------------------------------------------------
// Handle events for controls
//--------------------------------------------------------------------------------------
void CALLBACK OnGUIEvent(UINT eventint control_id, CDXUTControl* control, void* user_context)
{
    
switch(control_id)
    {
    
case IDC_TOGGLE_FULLSCREEN:
        DXUTToggleFullScreen();
        
break;

    
case IDC_TOGGLE_REF:
        DXUTToggleREF();
        
break;

    
case IDC_CHANGE_DEVICE:
        g_settings_dlg.SetActive(
true);
        
break;
    }
}

//--------------------------------------------------------------------------------------
// Initialize dialogs
//--------------------------------------------------------------------------------------
void InitDialogs()
{
    g_settings_dlg.Init(
&g_dlg_resource_manager);
    g_button_dlg.Init(
&g_dlg_resource_manager);

    g_button_dlg.SetCallback(OnGUIEvent);

    
int x = 35, y = 10, width = 125, height = 22;

    g_button_dlg.AddButton(IDC_TOGGLE_FULLSCREEN, L
"Toggle full screen", x, y,         width, height);
    g_button_dlg.AddButton(IDC_TOGGLE_REF,          L
"Toggle REF (F3)",     x, y += 24, width, height);
    g_button_dlg.AddButton(IDC_CHANGE_DEVICE,      L
"Change device (F2)", x, y += 24, width, height, VK_F2);    
}

//--------------------------------------------------------------------------------------
// Initialize everything and go into a render loop
//--------------------------------------------------------------------------------------
INT WINAPI WinMain( HINSTANCE, HINSTANCE, LPSTR, int )
{
    
// Enable run-time memory check for debug builds.
#if defined(DEBUG) | defined(_DEBUG)
    _CrtSetDbgFlag( _CRTDBG_ALLOC_MEM_DF 
| _CRTDBG_LEAK_CHECK_DF );
#endif

    
// Set the callback functions
    DXUTSetCallbackDeviceCreated( OnCreateDevice );
    DXUTSetCallbackDeviceReset( OnResetDevice );
    DXUTSetCallbackDeviceLost( OnLostDevice );
    DXUTSetCallbackDeviceDestroyed( OnDestroyDevice );
    DXUTSetCallbackMsgProc( MsgProc );
    DXUTSetCallbackFrameRender( OnFrameRender );
    DXUTSetCallbackFrameMove( OnFrameMove );
    DXUTSetCallbackKeyboard(OnKeyboardProc);
   
    
// TODO: Perform any application-level initialization here
    InitDialogs();

    
// Initialize DXUT and create the desired Win32 window and Direct3D device for the application
    DXUTInit( truetruetrue ); // Parse the command line, handle the default hotkeys, and show msgboxes
    DXUTSetCursorSettings( truetrue ); // Show the cursor and clip it when in full screen
    DXUTCreateWindow( L"Use Skin Mesh" );
    DXUTCreateDevice( D3DADAPTER_DEFAULT, 
true640480, IsDeviceAcceptable, ModifyDeviceSettings );

    
// Start the render loop
    DXUTMainLoop();

    
// TODO: Perform any application-level cleanup here

    
return DXUTGetExitCode();
}

下載示例工程


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


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導航

統計

常用鏈接

隨筆分類(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>
            欧美黄色视屏| 日韩一级在线| 一区二区三区免费看| 亚洲网在线观看| 欧美日韩中文另类| 午夜综合激情| 午夜视频一区二区| 国产一区二区三区不卡在线观看| 中文av一区二区| 91久久夜色精品国产九色| 久久国产精品一区二区三区四区| 亚洲视屏在线播放| 亚洲一区二区3| 欧美日韩亚洲国产一区| 国产拍揄自揄精品视频麻豆| 一区在线视频观看| 亚洲国产中文字幕在线观看| 狠久久av成人天堂| 性欧美18~19sex高清播放| 在线观看亚洲视频啊啊啊啊| 99国产一区| 激情视频一区| 999亚洲国产精| 久久久久久综合网天天| 久久成人18免费观看| 久久网站免费| 欧美黄色小视频| 在线免费观看成人网| 欧美在线观看一区| 欧美成人午夜| 亚洲一区3d动漫同人无遮挡| 99亚洲一区二区| 亚洲午夜久久久久久久久电影网| 久久蜜桃精品| 亚洲一区国产视频| 国产精品久久久久久久9999 | 亚洲欧美日韩一区在线| 最新精品在线| 欧美日韩精品免费看| 亚洲国产婷婷香蕉久久久久久99| 久久久精彩视频| 国产综合欧美| 国产精品99久久久久久久vr| 欧美影院成人| 欧美一级在线播放| 国产精品日韩一区二区三区| 免费观看30秒视频久久| 国产亚洲精品久久久久久| 亚洲欧美在线看| 欧美va天堂在线| 亚洲午夜免费视频| 欧美精品在线播放| 久久久久九九九| 性亚洲最疯狂xxxx高清| 亚洲免费成人| 亚洲欧美视频在线观看视频| 尤物在线精品| 在线综合视频| 亚洲天堂久久| 毛片一区二区| 宅男精品导航| 麻豆成人av| 久久久美女艺术照精彩视频福利播放| 亚洲人成网站在线播| 91久久国产综合久久91精品网站| 亚洲欧美日韩天堂| 亚洲欧美bt| 久久精品亚洲一区二区三区浴池 | 亚洲欧洲日本国产| 亚洲国产91精品在线观看| 欧美aaa级| 欧美视频在线免费看| 欧美阿v一级看视频| 国产日韩1区| 久久精品国产在热久久| 久久婷婷综合激情| 在线国产欧美| 免费看的黄色欧美网站| 亚洲成人在线网| 夜夜嗨av一区二区三区四区| 欧美片在线观看| 在线视频中文亚洲| 国产精品99久久久久久久女警| 久久久久久自在自线| 国产精品二区三区四区| 欧美激情性爽国产精品17p| 欧美一区三区二区在线观看| 亚洲精品日韩久久| 欧美激情精品久久久久久黑人| 亚洲女同同性videoxma| 亚洲欧美日韩一区在线观看| 久久久久久**毛片大全| 麻豆免费精品视频| 久久天天躁狠狠躁夜夜av| 久久精品国产亚洲高清剧情介绍 | 欧美日本一区| 午夜亚洲性色福利视频| 午夜日韩激情| 尤物精品在线| 国产亚洲女人久久久久毛片| 免费视频久久| 西西人体一区二区| 亚洲国产精品欧美一二99| 在线亚洲欧美视频| 国产欧美一区二区三区国产幕精品| 欧美一级日韩一级| 99热在这里有精品免费| 性久久久久久久久| 国产一区二区三区精品欧美日韩一区二区三区 | 国产综合久久久久久| 久久大逼视频| 亚洲尤物精选| 国产精品嫩草99av在线| 久久蜜桃av一区精品变态类天堂| 久久久久久久国产| 久久激情视频免费观看| 黄色成人免费观看| 欧美国产视频一区二区| 欧美一级欧美一级在线播放| 亚洲日韩成人| 在线一区二区三区做爰视频网站 | 国产精品午夜在线| 国产精品一区二区在线观看不卡| 国产精品免费在线 | 欧美一区二区在线观看| 欧美电影免费观看| 亚洲激情视频在线| 香蕉久久夜色精品国产| 欧美视频在线一区| 最新日韩在线视频| 亚洲国产婷婷| 久久久久久久久综合| 国产精品一二| 欧美一区影院| 亚洲欧美精品一区| 一区二区三区视频观看| 欧美理论大片| 亚洲图片欧美一区| 久久一综合视频| 久久艳片www.17c.com| 亚洲久久一区| 校园激情久久| 欧美寡妇偷汉性猛交| 国产精品videosex极品| 久久视频在线视频| 欧美黄色一区| 国产精品综合久久久| 一区二区成人精品| 亚洲精品少妇30p| 久久免费99精品久久久久久| 欧美制服丝袜| 欧美高清日韩| 日韩写真视频在线观看| 免费日韩成人| 亚洲经典三级| 一区二区高清在线观看| 99国产精品国产精品毛片| 欧美一区在线视频| 在线观看日韩www视频免费| 一区免费观看视频| 国产精品扒开腿做爽爽爽软件| 欧美日韩播放| 欧美日韩一区在线观看视频| 亚洲高清免费视频| 久久免费偷拍视频| 老色鬼精品视频在线观看播放| 亚洲第一黄色网| 亚洲在线观看免费视频| 欧美中在线观看| 亚洲一区二区在线播放| 久久久久国产一区二区| 亚洲精品欧美日韩| 午夜免费在线观看精品视频| 亚洲精品美女在线| 久久嫩草精品久久久久| 亚洲视频在线二区| 久久综合一区| 久久精品夜色噜噜亚洲a∨| 欧美日韩大陆在线| 亚洲免费在线视频| 久久中文精品| 久久米奇亚洲| 在线日本高清免费不卡| 欧美xart系列在线观看| 99re热这里只有精品视频| 亚洲一区二区在线免费观看| 国产精品久久波多野结衣| 日韩视频中文字幕| 久久国产精品久久久久久久久久| 国产一区二区三区在线观看视频| 久久人人爽爽爽人久久久| 亚洲人成在线影院| 久久精品导航| 99国产精品视频免费观看| 久久av一区| 一区二区三区四区国产精品| 久久久免费av| 女生裸体视频一区二区三区| 国产在线精品二区| 91久久精品www人人做人人爽|