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

天行健 君子當(dāng)自強(qiáng)而不息

創(chuàng)建游戲內(nèi)核(8)【接口與實(shí)現(xiàn)分離版】

 
本篇是創(chuàng)建游戲內(nèi)核(7)【接口與實(shí)現(xiàn)分離版】的續(xù)篇,關(guān)于該內(nèi)核的細(xì)節(jié)說明請參考創(chuàng)建游戲內(nèi)核(8),這個(gè)版本主要是按照功能劃分模塊的思想,并嚴(yán)格按照接口與實(shí)現(xiàn)相分離的原則來寫的,沒有用面向?qū)ο蟮乃枷雭韺懀瑳]有繼承沒有多態(tài)。大家可以對比兩個(gè)版本,比較優(yōu)劣。


接口:

void set_light_type(D3DLIGHT9* light, D3DLIGHTTYPE type);

void move_light(D3DLIGHT9* light, 
                
float x_pos, float y_pos, float z_pos);

void move_light_rel(D3DLIGHT9* light, 
                    
float x_pos, float y_pos, float z_pos);

void get_light_pos(const D3DLIGHT9* light, 
                   
float* x_pos, float* y_pos, float* z_pos);

void point_light(D3DLIGHT9* light,
                 
float x_from, float y_from, float z_from,
                 
float x_at,   float y_at,   float z_at);

void get_light_direction(const D3DLIGHT9* light, 
                         
float* x_dir, float* y_dir, float* z_dir);

void set_light_diffuse(D3DLIGHT9* light, 
                       unsigned 
char red, unsigned char green, unsigned char blue);

void get_light_diffuse(const D3DLIGHT9* light, 
                       unsigned 
char* red, unsigned char* green, unsigned char* blue);

void set_light_specular(D3DLIGHT9* light,
                       unsigned 
char red, unsigned char green, unsigned char blue);

void get_light_specular(const D3DLIGHT9* light,
                        unsigned 
char* red, unsigned char* green, unsigned char* blue);

void set_light_ambient(D3DLIGHT9* light,
                       unsigned 
char red, unsigned char green, unsigned char blue);

void get_light_ambient(const D3DLIGHT9* light,
                       unsigned 
char* red, unsigned char* green, unsigned char* blue);

void set_light_range(D3DLIGHT9* light, float range);
float get_light_range(const D3DLIGHT9* light);

void set_light_falloff(D3DLIGHT9* light, float falloff);
float get_light_falloff(const D3DLIGHT9* light);

void set_light_attenuation_0(D3DLIGHT9* light, float attenuation);
float get_light_attenuation_0(const D3DLIGHT9* light);

void set_light_attenuation_1(D3DLIGHT9* light, float attenuation);
float get_light_attenuation_1(const D3DLIGHT9* light);

void set_light_attenuation_2(D3DLIGHT9* light, float attenuation);
float get_light_attenuation_2(const D3DLIGHT9* light);

void set_light_theta(D3DLIGHT9* light, float theta);
float get_light_theta(const D3DLIGHT9* light);

void set_light_phi(D3DLIGHT9* light, float phi);
float get_light_phi(const D3DLIGHT9* light);


實(shí)現(xiàn):

//---------------------------------------------------------------------------
// set light type (D3DLIGHT_POINT, D3DLIGHT_SPOT, D3DLIGHT_DIRECTIONAL).
//---------------------------------------------------------------------------
void set_light_type(D3DLIGHT9* light, D3DLIGHTTYPE type)
{
    light->Type = type;
}

//---------------------------------------------------------------------------
// move light source to specified position.
//---------------------------------------------------------------------------
void move_light(D3DLIGHT9* light, 
                
float x_pos, float y_pos, float z_pos)
{
    light->Position.x = x_pos;
    light->Position.y = y_pos;
    light->Position.z = z_pos;
}

//---------------------------------------------------------------------------
// move light source to specified position which is relative to current position.
//---------------------------------------------------------------------------
void move_light_rel(D3DLIGHT9* light, 
                    
float x_pos, float y_pos, float z_pos)
{
    light->Position.x += x_pos;
    light->Position.y += y_pos;
    light->Position.z += z_pos;
}

//---------------------------------------------------------------------------
// Get current position.
//---------------------------------------------------------------------------
void get_light_pos(const D3DLIGHT9* light, 
                   
float* x_pos, float* y_pos, float* z_pos)
{
    
if(x_pos != NULL)
        *x_pos = light->Position.x;

    
if(y_pos != NULL)
        *y_pos = light->Position.y;

    
if(z_pos != NULL)
        *z_pos = light->Position.z;
}

//---------------------------------------------------------------------------
// move light source to specified position and pointer it to specified direction.
//---------------------------------------------------------------------------
void point_light(D3DLIGHT9* light,
                 
float x_from, float y_from, float z_from,
                 
float x_at,   float y_at,   float z_at)
{
    
// move the light
    move_light(light, x_from, y_from, z_from);

    
// calculate vector between angles
    light->Direction.x = x_at - x_from;
    light->Direction.y = y_at - y_from;
    light->Direction.z = z_at - z_from;
}

//---------------------------------------------------------------------------
// Get the direction of current light source.
//---------------------------------------------------------------------------
void get_light_direction(const D3DLIGHT9* light, 
                         
float* x_dir, float* y_dir, float* z_dir)
{
    
if(x_dir != NULL)
        *x_dir = light->Direction.x;

    
if(y_dir != NULL)
        *y_dir = light->Direction.y;

    
if(z_dir != NULL)
        *z_dir = light->Direction.z;        
}

//---------------------------------------------------------------------------
// set diffuse color of light source.
//---------------------------------------------------------------------------
void set_light_diffuse(D3DLIGHT9* light, 
                       unsigned 
char red, unsigned char green, unsigned char blue)
{
    light->Diffuse.r = red / 255.0f;
    light->Diffuse.g = green / 255.0f;
    light->Diffuse.b = blue / 255.0f;
}

//---------------------------------------------------------------------------
// Get diffuse color of light source.
//---------------------------------------------------------------------------
void get_light_diffuse(const D3DLIGHT9* light, 
                       unsigned 
char* red, unsigned char* green, unsigned char* blue)
{
    
if(red != NULL)
        *red = (unsigned 
char)(255.0f * light->Diffuse.r);

    
if(green != NULL)
        *green = (unsigned 
char)(255.0f * light->Diffuse.g);

    
if(blue != NULL)
        *blue = (unsigned 
char)(255.0f * light->Diffuse.b);
}

//---------------------------------------------------------------------------
// set specular color of light source.
//---------------------------------------------------------------------------
void set_light_specular(D3DLIGHT9* light,
                       unsigned 
char red, unsigned char green, unsigned char blue)
{
    light->Specular.r = red / 255.0f;
    light->Specular.g = green / 255.0f;
    light->Specular.b = blue / 255.0f;
}

//---------------------------------------------------------------------------
// Get specular color of light source.
//---------------------------------------------------------------------------
void get_light_specular(const D3DLIGHT9* light,
                        unsigned 
char* red, unsigned char* green, unsigned char* blue)
{
    
if(red != NULL)
        *red = (unsigned 
char)(255.0f * light->Specular.r);

    
if(green != NULL)
        *green = (unsigned 
char)(255.0f * light->Specular.g);

    
if(blue != NULL)
        *blue = (unsigned 
char)(255.0f * light->Specular.b);
}

//---------------------------------------------------------------------------
// set ambient color of light source.
//---------------------------------------------------------------------------
void set_light_ambient(D3DLIGHT9* light,
                       unsigned 
char red, unsigned char green, unsigned char blue)
{
    light->Ambient.r = red / 255.0f;
    light->Ambient.g = green / 255.0f;
    light->Ambient.b = blue / 255.0f;
}

//---------------------------------------------------------------------------
// Get ambient color of light source.
//---------------------------------------------------------------------------
void get_light_ambient(const D3DLIGHT9* light,
                       unsigned 
char* red, unsigned char* green, unsigned char* blue)
{
    
if(red != NULL)
        *red = (unsigned 
char)(255.0f * light->Ambient.r);

    
if(green != NULL)
        *green = (unsigned 
char)(255.0f * light->Ambient.g);

    
if(blue != NULL)
        *blue = (unsigned 
char)(255.0f * light->Ambient.b);
}

//---------------------------------------------------------------------------
// set the range of light source.
//---------------------------------------------------------------------------
void set_light_range(D3DLIGHT9* light, float range)
{
    light->Range = range;
}

//---------------------------------------------------------------------------
// Get the range of light source.
//---------------------------------------------------------------------------
float get_light_range(const D3DLIGHT9* light)
{
    
return light->Range;
}

//---------------------------------------------------------------------------
// set the fallof of light source.
//---------------------------------------------------------------------------
void set_light_falloff(D3DLIGHT9* light, float falloff)
{
    light->Falloff = falloff;
}

//---------------------------------------------------------------------------
// Get the fallof of light source.
//---------------------------------------------------------------------------
float get_light_falloff(const D3DLIGHT9* light)
{
    
return light->Falloff;
}

//---------------------------------------------------------------------------
// set attenuation 0 of light source.
//---------------------------------------------------------------------------
void set_light_attenuation_0(D3DLIGHT9* light, float attenuation)
{
    light->Attenuation0 = attenuation;
}

//---------------------------------------------------------------------------
// Get attenuation 0 of light source.
//---------------------------------------------------------------------------
float get_light_attenuation_0(const D3DLIGHT9* light)
{
    
return light->Attenuation0;
}

//---------------------------------------------------------------------------
// set attenuation 1 of light source.
//---------------------------------------------------------------------------
void set_light_attenuation_1(D3DLIGHT9* light, float attenuation)
{
    light->Attenuation1 = attenuation;
}

//---------------------------------------------------------------------------
// Get attenuation 1 of light source.
//---------------------------------------------------------------------------
float get_light_attenuation_1(const D3DLIGHT9* light)
{
    
return light->Attenuation1;
}

//---------------------------------------------------------------------------
// set attenuation 2 of light source.
//---------------------------------------------------------------------------
void set_light_attenuation_2(D3DLIGHT9* light, float attenuation)
{
    light->Attenuation2 = attenuation;
}

//---------------------------------------------------------------------------
// Get attenuation 2 of light source.
//---------------------------------------------------------------------------
float get_light_attenuation_2(const D3DLIGHT9* light)
{
    
return light->Attenuation2;
}

//---------------------------------------------------------------------------
// set angle thera of light source.
//---------------------------------------------------------------------------
void set_light_theta(D3DLIGHT9* light, float theta)
{
    light->Theta = theta;
}

//---------------------------------------------------------------------------
// Get angle thera of light source.
//---------------------------------------------------------------------------
float get_light_theta(const D3DLIGHT9* light)
{
    
return light->Theta;
}

//---------------------------------------------------------------------------
// set angle phi of light source.
//---------------------------------------------------------------------------
void set_light_phi(D3DLIGHT9* light, float phi)
{
    light->Phi = phi;
}

//---------------------------------------------------------------------------
// Get angle phi of light source.
//---------------------------------------------------------------------------
float get_light_phi(const D3DLIGHT9* light)
{
    
return light->Phi;
}

測試代碼:

/***********************************************************************************
PURPOSE:
    Test D3D light function.
***********************************************************************************/


#include <windows.h>
#include "core_framework.h"
#include "core_graphics.h"
#include "core_tool.h"

// The 3D vertex format and descriptor
typedef struct
{
    
float x, y, z;      // 3D coordinates    
    float nx, ny, nz;   // normals
    D3DCOLOR diffuse;   // color
} VERTEX;

#define VERTEX_FVF   (D3DFVF_XYZ | D3DFVF_NORMAL | D3DFVF_DIFFUSE)

IDirect3DVertexBuffer9* g_vertex_buffer;

//--------------------------------------------------------------------------------
// Initialize data for game.
//--------------------------------------------------------------------------------
BOOL game_init()
{
    
// initialize vertex data
    VERTEX _verts[] = {
        { -100.0f,  100.0f, -100.0f, 0.0f,0.0f,-1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f,  100.0f, -100.0f, 0.0f,0.0f,-1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f, -100.0f, -100.0f, 0.0f,0.0f,-1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f, -100.0f, -100.0f, 0.0f,0.0f,-1.0f, D3DCOLOR_RGBA(255,255,255,255) },

        {  100.0f,  100.0f, -100.0f, 1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f,  100.0f,  100.0f, 1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f, -100.0f, -100.0f, 1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f, -100.0f,  100.0f, 1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },

        {  100.0f,  100.0f,  100.0f, 0.0f,0.0f,1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f,  100.0f,  100.0f, 0.0f,0.0f,1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        {  100.0f, -100.0f,  100.0f, 0.0f,0.0f,1.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f, -100.0f,  100.0f, 0.0f,0.0f,1.0f, D3DCOLOR_RGBA(255,255,255,255) },

        { -100.0f,  100.0f,  100.0f, -1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f,  100.0f, -100.0f, -1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f, -100.0f,  100.0f, -1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) },
        { -100.0f, -100.0f, -100.0f, -1.0f,0.0f,0.0f, D3DCOLOR_RGBA(255,255,255,255) }
    }; 

    
// Create Direct3D and Direct3DDevice object
    if(! create_display(g_hwnd, get_window_width(g_hwnd), get_window_height(g_hwnd), 16, TRUE, FALSE))
        
return FALSE;

    
// builds a left-handed perspective projection matrix based on a field of view
    set_perspective(D3DX_PI/4.0, 1.33333f, 1.0f, 1000.0f);

    D3DXMATRIX _mat_view;

    
// create and set the view matrix
    D3DXMatrixLookAtLH(&_mat_view, 
                       &D3DXVECTOR3(0.0f, 0.0f, -500.0f),
                       &D3DXVECTOR3(0.0f, 0.0f, 0.0f), 
                       &D3DXVECTOR3(0.0f, 1.0f, 0.0f));

    g_d3d_device->SetTransform(D3DTS_VIEW, &_mat_view);

    BYTE* _vertex_ptr;

    
// create the vertex buffer and set data
    g_d3d_device->CreateVertexBuffer(sizeof(_verts), 0, VERTEX_FVF, D3DPOOL_DEFAULT, &g_vertex_buffer, NULL);     

    
// locks a range of vertex data and obtains a pointer to the vertex buffer memory
    g_vertex_buffer->Lock(0, 0, (void**)&_vertex_ptr, 0);

    memcpy(_vertex_ptr, _verts, 
sizeof(_verts));

    
// unlocks vertex data
    g_vertex_buffer->Unlock();

    
// enable d3d lighting
    g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE); 

    D3DLIGHT9 _light;    

    memset(&_light, 0, 
sizeof(_light));

    
// set light
    set_light_type(&_light, D3DLIGHT_POINT);
    set_light_diffuse(&_light, 128, 128, 0);
    set_light_range(&_light, 1000.0);
    set_light_attenuation_0(&_light, 0.5);
    move_light(&_light, 300.0, 0.0, -600.0);

    
// attach light to d3d device and enable _light
    g_d3d_device->SetLight(0, &_light);    

    
// enale this light
    g_d3d_device->LightEnable(0, TRUE);

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Render every game frame.
//--------------------------------------------------------------------------------
BOOL game_frame()
{
    clear_display_buffer(D3DCOLOR_RGBA(0, 0, 0, 0));

    
if(SUCCEEDED(g_d3d_device->BeginScene()))
    {
        D3DXMATRIX _mat_world;

        
// create and set the world transformation matrix
        // rotate object along y-axis
        D3DXMatrixRotationY(&_mat_world, (float) (timeGetTime() / 1000.0));

        g_d3d_device->SetTransform(D3DTS_WORLD, &_mat_world);

        
// set the vertex stream, shader, and texture.

        // binds a vertex buffer to a device data stream
        g_d3d_device->SetStreamSource(0, g_vertex_buffer, 0, sizeof(VERTEX));

        
// set the current vertex stream declation
        g_d3d_device->SetFVF(VERTEX_FVF);

        
// renders a sequence of noindexed, geometric primitives of the specified type from the current set
        // of data input stream.
        for(short i = 0; i < 4; i++)
            g_d3d_device->DrawPrimitive(D3DPT_TRIANGLESTRIP, i * 4, 2);
        
        g_d3d_device->EndScene();
    }

    present_display();

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Release all game resources.
//--------------------------------------------------------------------------------
BOOL game_shutdown()
{
    release_com(g_vertex_buffer);
    release_com(g_d3d_device);
    release_com(g_d3d);

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Main function, routine entry.
//--------------------------------------------------------------------------------
int WINAPI WinMain(HINSTANCE inst, HINSTANCE pre_inst, LPSTR cmd_line, int cmd_show)
{    
    
if(! build_window(inst, "MainClass", "MainWindow", WS_OVERLAPPEDWINDOW, 0, 0, 800, 600))
        
return FALSE;

    run_game(game_init, game_frame, game_shutdown);
    
    
return 0;
}

點(diǎn)擊下載源碼和工程

程序截圖:


posted on 2007-10-03 17:11 lovedday 閱讀(377) 評(píng)論(2)  編輯 收藏 引用

評(píng)論

# re: 創(chuàng)建游戲內(nèi)核(8)【接口與實(shí)現(xiàn)分離版】 2007-10-04 16:58 AMXTSHMF

不懂哦!向你學(xué)習(xí)  回復(fù)  更多評(píng)論   

# re: 創(chuàng)建游戲內(nèi)核(8)【接口與實(shí)現(xiàn)分離版】 2007-10-04 17:14 lovedday

你的博客上寫的那么東西我也看不懂 ^:^  回復(fù)  更多評(píng)論   


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


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

3D游戲編程相關(guān)鏈接

搜索

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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网站| 国产精品日本精品| 亚洲精品国产精品乱码不99按摩| 久久国产色av| 麻豆精品网站| 亚洲福利国产精品| 欧美日韩久久精品| 亚洲一品av免费观看| 久久久久久久久综合| 亚洲精品美女久久久久| 国产精品qvod| 久久一本综合频道| 一本大道久久a久久综合婷婷| 一区二区亚洲精品| 欧美精品色网| 欧美亚洲视频在线观看| 久久影音先锋| av成人免费在线观看| 国产一区二区三区高清| 欧美黄在线观看| 亚洲免费在线精品一区| 亚洲高清毛片| 久久爱另类一区二区小说| 91久久久久久久久| 国产一区二区三区在线观看免费视频| 亚洲视频网在线直播| 欧美.日韩.国产.一区.二区| 亚洲一二区在线| 亚洲韩日在线| 国产欧美午夜| 欧美视频二区| 欧美二区在线看| 久久精品卡一| 在线亚洲美日韩| 亚洲国产精品久久91精品| 久久国产精品一区二区| 亚洲一区免费| 一二三四社区欧美黄| 伊人一区二区三区久久精品| 国产精品久久久久久久电影 | 久久久99国产精品免费| 91久久国产自产拍夜夜嗨| 久久久夜精品| 午夜老司机精品| 91久久精品日日躁夜夜躁国产| 久久婷婷国产麻豆91天堂| 亚洲——在线| 99国产一区| 亚洲精品美女91| 麻豆精品在线播放| 久久免费观看视频| 久久国产精品久久久久久久久久| 黄色亚洲大片免费在线观看| 国产精品高潮视频| 欧美日韩国产精品自在自线| 欧美国产亚洲另类动漫| 老司机精品福利视频| 久久久久久久999精品视频| 性欧美videos另类喷潮| 一区二区三区成人| 亚洲精品视频二区| 亚洲精品国久久99热| 亚洲国产日韩在线一区模特| 欧美成人国产| 欧美激情第五页| 亚洲国产第一页| 最新亚洲一区| 99综合精品| 亚洲色在线视频| 亚洲在线观看视频| 先锋亚洲精品| 欧美一区中文字幕| 久久精品国产一区二区电影| 久久精品国产99| 久久亚裔精品欧美| 欧美成人影音| 欧美手机在线视频| 国产精品一区二区在线观看不卡| 久久免费一区| 美女主播一区| 欧美日韩喷水| 国产人妖伪娘一区91| 好吊一区二区三区| 亚洲片区在线| 亚洲综合精品| 久久久久久亚洲精品中文字幕 | 国产精品一区毛片| 国产精品视频观看| 国产一区二区成人| 亚洲国产精品福利| 亚洲婷婷在线| 欧美亚洲视频| 欧美91福利在线观看| 亚洲精品女av网站| 亚洲精品久久久一区二区三区| 久久久夜精品| 91久久久亚洲精品| 99视频精品全部免费在线| 亚洲综合色在线| 久久青青草综合| 欧美人与性禽动交情品 | 国产一区二区久久精品| 亚洲国产毛片完整版| 亚洲午夜国产一区99re久久 | 久久久亚洲欧洲日产国码αv | 亚洲综合视频一区| 久久久久久一区| 91久久精品一区二区别| 亚洲无人区一区| 另类图片国产| 国产精品视频免费观看| 樱桃国产成人精品视频| 亚洲一区二区黄| 女女同性女同一区二区三区91| 久久免费视频在线观看| 91久久久久久国产精品| 欧美一级在线视频| 欧美国产日韩亚洲一区| 国产精品男人爽免费视频1| 亚洲国产高清视频| 欧美一区三区三区高中清蜜桃| 欧美一区二区日韩| 欧美黄色免费| 午夜久久资源| 欧美日韩精品系列| 91久久精品国产91久久性色tv| 亚洲高清资源综合久久精品| 校园春色国产精品| 亚洲日本激情| 免费成人在线观看视频| 国产亚洲激情视频在线| 亚洲——在线| 亚洲美女中文字幕| 裸体素人女欧美日韩| 国产日韩精品一区二区三区在线 | 亚洲丰满少妇videoshd| 午夜精品视频网站| 欧美日韩在线精品| 亚洲国产专区| 欧美成人四级电影| 久久精品国产久精国产爱| 国产精品极品美女粉嫩高清在线| 国产精品久久久99| 99在线视频精品| 亚洲国产你懂的| 久热国产精品| ●精品国产综合乱码久久久久| 亚洲精品小视频在线观看| 另类综合日韩欧美亚洲| 亚洲欧美日本伦理| 国产精品视频免费在线观看| 亚洲午夜精品在线| 日韩一区二区精品视频| 欧美日韩你懂的| 亚洲狼人精品一区二区三区| 欧美黄色片免费观看| 欧美aaa级| 日韩视频免费看| 99re这里只有精品6| 欧美日韩直播| 亚洲欧美999| 亚洲影视综合| 国产一区二区精品| 美国成人直播| 欧美成人午夜影院| 99精品久久| 中国成人黄色视屏| 国产欧美日韩综合一区在线观看 | 亚洲一区二区三区四区视频| 最新国产の精品合集bt伙计| 欧美日韩aaaaa| 亚洲免费人成在线视频观看| 亚洲欧美精品在线| 国产在线不卡视频| 欧美大片第1页| 欧美久久视频| 亚洲欧美在线一区| 久久精品一区四区| 亚洲精品1区2区| 一区二区三区国产盗摄| 国产精品自在线| 免费亚洲电影在线观看| 欧美大片在线观看一区| 亚洲免费网址| 久久久无码精品亚洲日韩按摩| 国产精品美女一区二区在线观看| 亚洲国产高清一区二区三区| 亚洲欧洲三级| 国产欧美日韩视频| 欧美国产日韩a欧美在线观看| 性感少妇一区| 亚洲国产成人91精品| 日韩视频在线观看免费| 国产欧美亚洲视频| 亚洲第一主播视频| 国产精品盗摄一区二区三区| 理论片一区二区在线| 欧美日韩福利在线观看| 久久精品视频播放| 欧美激情在线|