www84811.com-国产区一区二区三区,亚洲第一中文字幕在线观看,91精品久久香蕉国产线看观看,国产精品欧美久久

電子開發(fā)網(wǎng)

電子開發(fā)網(wǎng)電子設(shè)計 | 電子開發(fā)網(wǎng)Rss 2.0 會員中心 會員注冊
搜索: 您現(xiàn)在的位置: 電子開發(fā)網(wǎng) >> 編程學(xué)習(xí) >> C語言 >> 正文

C語言寫的俄羅斯方塊程序

作者:佚名    文章來源:本站原創(chuàng)    點(diǎn)擊數(shù):    更新時間:2017/6/16

大概在最近兩天之內(nèi)編碼完成,但此前一天開始構(gòu)思。第一天晚上主要完成了方塊旋轉(zhuǎn)算法,第二天也就是今天加了消方塊的處理算法。但是可能還有一些考慮不周的地方,比如,沒有采用定時中斷,而是圖方便采用了和cpu頻率有關(guān)的delay()函數(shù)來模擬時間間隔,這是需要改進(jìn)的地方。
其中的主要邏輯有:
(1)由于c的隨機(jī)性函數(shù)不好,所以每次游戲開始根據(jù)bios時間設(shè)置種子。
(2)得分越高,方塊下降速度越快(每200分為單位)。
(3)每下落一個方塊加1分,每消除一行加10分,兩行加30分,三行加70分,四行加150分。初試分?jǐn)?shù)為100分。
游戲控制:
   up-旋轉(zhuǎn);空格-下落到底; 左右下方向鍵-控制方向。P-開始或暫停游戲。 ESC-退出。
特點(diǎn):
(1)由于tc不支持中文,所以基本都是英文注釋。
(2)函數(shù)命名盡可能規(guī)范的表達(dá)其內(nèi)部處理目的和過程。
(3)代碼加上注釋僅有577行。(我下載過的兩個俄羅斯方塊代碼一個在1087行,一個在993行,我的比它們代碼少)。
(4)除了消除空格時算法比較復(fù)雜,其他算法都比較簡單易讀。
(5)繪圖效率和局部代碼效率扔有待提高。
(6)FrameTime參數(shù)可能依據(jù)不同硬件環(huán)境進(jìn)行具體設(shè)置,InitGame需要正確的TC路徑。

    俄羅斯方塊源于大約9年前上大一時的一個夢,我們在學(xué)習(xí)c語言時,我的同寢室友邀請我合作一起完成俄羅斯方塊(課外作業(yè)性質(zhì)),但是當(dāng)時限于我們的水平比較菜和學(xué)習(xí)狀態(tài)比較懶散,我們沒有完成。大一的時候我在機(jī)房里無意發(fā)現(xiàn)別人留下的俄羅斯方塊程序,運(yùn)行,老師發(fā)現(xiàn)后激動的問我是我寫的嗎,我慚愧的搖搖頭。那時看到別人做c的大程序深感羨慕(自己只是寫幾十行的程序)。數(shù)年后我仍然看到有不同樣式的實(shí)現(xiàn),但是我一直沒有實(shí)現(xiàn)它,知道今天忽然有這個想法去做,算是彌補(bǔ)多年前的遺憾和心愿吧。

//-----------------------【以下是我的代碼文件:】---------------------
/********************************/
/* Desc:    俄羅斯方塊游戲                */
/* By:        hoodlum1980                */
/* Email:    jinfd@126.com            */
/* Date:    2008.03.12 22:30            */
/********************************/
#include 
#include 
#include 
#include 
#include 
#include 
#define true         1
#define false         0
#define BoardWidth    12
#define BoardHeight     23
#define _INNER_HELPER 
/*inner helper method */
/*Scan Codes Define*/
enum KEYCODES
{
    K_ESC                =0x011b,
    K_UP                =0x4800,        /* upward arrow */
    K_LEFT            =0x4b00,
    K_DOWN            =0x5000,
    K_RIGHT            =0x4d00,
    K_SPACE            =0x3920,
    K_P                =0x1970
};
/* the data structure of the block */
typedef struct tagBlock
{
    char c[4][4];    /* cell fill info array, 0-empty, 1-filled */
    int x;                /* block position cx [ 0,BoardWidht -1] */
    int y;                /* block position cy [-4,BoardHeight-1] */
    char color;        /* block color */
    char size;        /* block max size in width or height */
    char name;        /* block name (the block's shape) */
} Block;
/* game's global info */
int FrameTime= 1300;
int CellSize= 18;
int BoardLeft= 30;
int BoardTop=    30;
/* next block grid */
int NBBoardLeft= 300;
int NBBoardTop=    30;
int NBCellSize=  10;
/* score board position */
int ScoreBoardLeft= 300;
int ScoreBoardTop=100;
int ScoreBoardWidth=200;
int ScoreBoardHeight=35;
int ScoreColor=LIGHTCYAN;
/* infor text postion */
int InfoLeft=300;
int InfoTop=200;
int InfoColor=YELLOW;
int BorderColor=DARKGRAY;
int BkGndColor=BLACK;
int GameRunning=true;
int TopLine=BoardHeight-1;    /* top empty line */
int TotalScore=100;
char info_score[20];
char info_help[255];
char info_common[255];
/* our board, Board[x][y][0]-isFilled, Board[x][y][1]-fillColor */
unsigned char Board[BoardWidth][BoardHeight][2];
char BufferCells[4][4];    /* used to judge if can rotate block */
Block curBlock;        /* current moving block */
Block nextBlock;    /* next Block to appear */
/* function list */
int GetKeyCode();
int CanMove(int dx,int dy);
int CanRotate();
int RotateBlock(Block *block);
int MoveBlock(Block *block,int dx,int dy);
void DrawBlock(Block *block,int,int,int);
void EraseBlock(Block *block,int,int,int);
void DisplayScore();
void DisplayInfo(char* text);
void GenerateBlock(Block *block);
void NextBlock();
void InitGame();
int PauseGame();
void QuitGame();
/*Get Key Code */
int GetKeyCode()
{
    int key=0;
    if(bioskey(1))
    {
        key=bioskey(0);
    }
    return key;
}
/* display text! */
void DisplayInfo(char *text)
{
    setcolor(BkGndColor);
    outtextxy(InfoLeft,InfoTop,info_common);
    strcpy(info_common,text);
    setcolor(InfoColor);
    outtextxy(InfoLeft,InfoTop,info_common);
}
/* create a new block by key number,
* the block anchor to the top-left corner of 4*4 cells
*/
void _INNER_HELPER GenerateBlock(Block *block)
{
    int key=(random(13)*random(17)+random(1000)+random(3000))%7;
    block->size=3;/* because most blocks' size=3 */
    memset(block->c,0,16);
    switch(key)
    {
        case 0:
            block->name='T';
            block->color=RED;
            block->c[1][0]=1;
            block->c[1][1]=1, block->c[2][1]=1;
            block->c[1][2]=1;
            break;
        case 1:
            block->name='L';
            block->color=YELLOW;
            block->c[1][0]=1;
            block->c[1][1]=1;
            block->c[1][2]=1, block->c[2][2]=1;
            break;
        case 2:
            block->name='J';
            block->color=LIGHTGRAY;
            block->c[1][0]=1;
            block->c[1][1]=1;
            block->c[1][2]=1, block->c[0][2]=1;
            break;
        case 3:
            block->name='z';
            block->color=CYAN;
            block->c[0][0]=1, block->c[1][0]=1;
            block->c[1][1]=1, block->c[2][1]=1;
            break;
        case 4:
            block->name='5';
            block->color=LIGHTBLUE;
            block->c[1][0]=1, block->c[2][0]=1;
            block->c[0][1]=1, block->c[1][1]=1;
            break;
        case 5:
            block->name='o';
            block->color=BLUE;
            block->size=2;
            block->c[0][0]=1, block->c[1][0]=1;
            block->c[0][1]=1, block->c[1][1]=1;
            break;
        case 6:
            block->name='I';
            block->color=GREEN;
            block->size=4;
            block->c[1][0]=1;
            block->c[1][1]=1;
            block->c[1][2]=1;
            block->c[1][3]=1;
            break;
    }
}
/* get next block! */
void NextBlock()
{
    /* copy the nextBlock to curBlock */
    curBlock.size=nextBlock.size;
    curBlock.color=nextBlock.color;
    curBlock.x=(BoardWidth-4)/2;
    curBlock.y=-curBlock.size;
    memcpy(curBlock.c,nextBlock.c,16);
    /* generate nextBlock and show it */
    EraseBlock(&nextBlock,NBBoardLeft,NBBoardTop,NBCellSize);
    GenerateBlock(&nextBlock);
    nextBlock.x=1,nextBlock.y=0;
    DrawBlock(&nextBlock,NBBoardLeft,NBBoardTop,NBCellSize);
}
/* rotate the block, update the block struct data */
int _INNER_HELPER RotateCells(char c[4][4],char blockSize)
{
    char temp,i,j;
    switch(blockSize)
    {
        case 3:
            temp=c[0][0];
            c[0][0]=c[2][0], c[2][0]=c[2][2],    c[2][2]=c[0][2], c[0][2]=temp;
            temp=c[0][1];
            c[0][1]=c[1][0], c[1][0]=c[2][1],    c[2][1]=c[1][2], c[1][2]=temp;
            break;
        case 4:    /* only 'I' block arived here! */
            c[1][0]=1-c[1][0], c[1][2]=1-c[1][2], c[1][3]=1-c[1][3];
            c[0][1]=1-c[0][1], c[2][1]=1-c[2][1],    c[3][1]=1-c[3][1];
            break;
    }
}
/* judge if the block can move toward the direction */
int CanMove(int dx,int dy)
{
    int i,j,tempX,tempY;
    for(i=0;i(BoardWidth-1))    return false; /* make sure x is valid! */
                /* cannot move downward */
                tempY = curBlock.y + j + dy;
                if(tempY>(BoardHeight-1))    return false; /* y is only checked lower bound, maybe negative!!!! */
                /* the cell already filled, we must check Y's upper bound before check cell ! */
                if(tempY>=0 && Board[tempX][tempY][0]) return false;
            }
        }
    }
    return true;
}
/* judge if the block can rotate */
int CanRotate()
{
    int i,j,tempX,tempY;
    /* update buffer */
    memcpy(BufferCells, curBlock.c, 16);
    RotateCells(BufferCells,curBlock.size);
    for(i=0;i(BoardWidth-1))
                    return false;
                if(tempY>(BoardHeight-1))
                    return false;
                if(tempY>=0 && Board[tempX][tempY][0])
                    return false;
            }
        }
    }
    return true;
}
/* draw the block */
void _INNER_HELPER DrawBlock(Block *block,int bdLeft,int bdTop,int cellSize)
{
    int i,j;
    setfillstyle(SOLID_FILL,block->color);
    for(i=0;isize;i++)
    {
        for(j=0;jsize;j++)
        {
            if(block->c[i][j] && (block->y+j)>=0)
            {
                floodfill(
                    bdLeft+cellSize*(i+block->x)+cellSize/2,
                    bdTop+cellSize*(j+block->y)+cellSize/2,
                    BorderColor);
            }
        }
    }
}
/* Rotate the block, if success, return true */
int RotateBlock(Block *block)
{
    char temp,i,j;
    int b_success;
    if(curBlock.size==2)
        return;
    if(( b_success=CanRotate()))
    {
        EraseBlock(block,BoardLeft,BoardTop,CellSize);
        memcpy(curBlock.c,BufferCells,16);
        DrawBlock(block,BoardLeft,BoardTop,CellSize);
    }
    return b_success;
}
/* erase a block, only fill the filled cell with background color */
void _INNER_HELPER EraseBlock(Block *block,int bdLeft,int bdTop,int cellSize)
{
    int i,j;
    setfillstyle(SOLID_FILL,BkGndColor);
    for(i=0;isize;i++)
    {
        for(j=0;jsize;j++)
        {
            if(block->c[i][j] && (block->y+j>=0))
            {
                floodfill(
                    bdLeft+cellSize*(i+block->x)+cellSize/2,
                    bdTop+cellSize*(j+block->y)+cellSize/2,
                    BorderColor);
            }
        }
    }
}
/* move by the direction if can, donothing if cannot
* return value: true - success, false - cannot move toward this direction
*/
int MoveBlock(Block *block,int dx,int dy)
{
    int b_canmove=CanMove(dx,dy);
    if(b_canmove)
    {
        EraseBlock(block,BoardLeft,BoardTop,CellSize);
        curBlock.x+=dx;
        curBlock.y+=dy;
        DrawBlock(block,BoardLeft,BoardTop,CellSize);
    }
    return b_canmove;
}
/* drop the block to the bottom! */
int DropBlock(Block *block)
{
    EraseBlock(block,BoardLeft,BoardTop,CellSize);
    while(CanMove(0,1))
    {
        curBlock.y++;
    }
    DrawBlock(block,BoardLeft,BoardTop,CellSize);
    return 0;/* return value is assign to the block's alive */
}
/* init the graphics mode, draw the board grid */
void InitGame()
{
    int i,j,gdriver=DETECT,gmode;
    struct time sysTime;
    /* draw board cells */
    memset(Board,0,BoardWidth*BoardHeight*2);
    memset(nextBlock.c,0,16);
    strcpy(info_help,"P: Pause Game. --by hoodlum1980");
    initgraph(&gdriver,&gmode,"c:\\tc\\");
    setcolor(BorderColor);
    for(i=0;i<=BoardWidth;i++)
    {
        line(BoardLeft+i*CellSize, BoardTop, BoardLeft+i*CellSize, BoardTop+ BoardHeight*CellSize);
    }
    for(i=0;i<=BoardHeight;i++)
    {
        line(BoardLeft, BoardTop+i*CellSize, BoardLeft+BoardWidth*CellSize, BoardTop+ i*CellSize);
    }
    /* draw board outer border rect */
    rectangle(BoardLeft-CellSize/4, BoardTop-CellSize/4,
        BoardLeft+BoardWidth*CellSize+CellSize/4,
        BoardTop+BoardHeight*CellSize+CellSize/4);
    /* draw next block grids */
    for(i=0;i<=4;i++)
    {
        line(NBBoardLeft+i*NBCellSize, NBBoardTop, NBBoardLeft+i*NBCellSize, NBBoardTop+4*NBCellSize);
        line(NBBoardLeft, NBBoardTop+i*NBCellSize, NBBoardLeft+4*NBCellSize, NBBoardTop+ i*NBCellSize);
    }
    /* draw score rect */
    rectangle(ScoreBoardLeft,ScoreBoardTop,ScoreBoardLeft+ScoreBoardWidth,ScoreBoardTop+ScoreBoardHeight);
    DisplayScore();
    /* set new seed! */
    gettime(&sysTime);
    srand(sysTime.ti_hour*3600+sysTime.ti_min*60+sysTime.ti_sec);
    GenerateBlock(&nextBlock);
    NextBlock();    /* create first block */
    setcolor(DARKGRAY);
    outtextxy(InfoLeft,InfoTop+20,"Up  -rotate  Space-drop");
    outtextxy(InfoLeft,InfoTop+35,"Left-left    Right-right");
    outtextxy(InfoLeft,InfoTop+50,"Esc -exit");
    DisplayInfo(info_help);
}
/* set the isFilled and fillcolor data to the board */
void _INNER_HELPER FillBoardData()
{
    int i,j;
    for(i=0;i=0)
            {
                Board[curBlock.x+i][curBlock.y+j][0]=1;
                Board[curBlock.x+i][curBlock.y+j][1]=curBlock.color;
            }
        }
    }
}
/* draw one line of the board */
void _INNER_HELPER PaintBoard()
{
    int i,j,fillcolor;
    for(j=max((TopLine-4),0);j0 && topy>0);
    /* remove the full filled line (max remove lines count = 4) */
    do
    {
        sum=0;
        for(i=0;i< BoardWidth; i++)
            sum+=Board[i][j][0];
        if(sum==BoardWidth)/* we find this line is full filled, remove it! */
        {
            /* move the cells data down one line */
            for(k=j; k > topy;k--)
            {
                for(i=0;i0 && j>topy && lines<4);
    /* speed up the game when score is high, minimum is 400 */
    FrameTime=max(1200-100*(TotalScore/200), 400);
    TopLine=topy;/* update the top line */
    /* if no lines remove, only add 1: */
    if(lines==0)
        TotalScore++;
}
/* display the score */
void _INNER_HELPER DisplayScore()
{
    setcolor(BkGndColor);
    outtextxy(ScoreBoardLeft+5,ScoreBoardTop+5,info_score);
    setcolor(ScoreColor);
    sprintf(info_score,"Score: %d",TotalScore);
    outtextxy(ScoreBoardLeft+5,ScoreBoardTop+5,info_score);
}
/* we call this function when a block is inactive. */
void UpdateBoard()
{
    FillBoardData();
    CheckBoard();
    PaintBoard();
    DisplayScore();
}
/* pause the game, and timer handler stop move down the block! */
int PauseGame()
{
    int key=0;
    DisplayInfo("Press P to Start or Resume!");
    while(key!=K_P && key!=K_ESC)
    {
        while(!(key=GetKeyCode())){}
    }
    DisplayInfo(info_help);
    return key;
}
/* quit the game and do cleaning work. */
void QuitGame()
{
    closegraph();
}
/* the entry point function. */
void main()
{
    int i,flag=1,j,key=0,tick=0;
    InitGame();
    if(PauseGame()==K_ESC)
        goto GameOver;
    /* wait until a key pressed */
    while(key!=K_ESC)
    {
        /* wait until a key pressed */
        while(!(key=GetKeyCode()))
        {
            tick++;
            if(tick>=FrameTime)
            {
                /* our block has dead! (can't move down), we get next block */
                if(!MoveBlock(&curBlock,0,1))
                {
                    UpdateBoard();
                    NextBlock();
                    if(!CanMove(0,1))
                        goto GameOver;
                }
                tick=0;
            }
            delay(100);
        }
        switch(key)
        {
            case K_LEFT:
                MoveBlock(&curBlock,-1,0);
                break;
            case K_RIGHT:
                MoveBlock(&curBlock,1,0);
                break;
            case K_DOWN:
                MoveBlock(&curBlock,0,1);
                break;
            case K_UP:
                RotateBlock(&curBlock);
                break;
            case K_SPACE:
                DropBlock(&curBlock);
                break;
            case K_P:
                PauseGame();
                break;
        }
    }
GameOver:
    DisplayInfo("GAME OVER!  Press any key to exit!");
    getch(); /* wait the user Press any key. */
    QuitGame();
}
//----------------------------------【代碼文件結(jié)尾】--------------------------------------
Tags:C語言,俄羅斯方塊程序  
責(zé)任編輯:admin
  • 上一篇文章: 沒有了
  • 下一篇文章:
  • 請文明參與討論,禁止漫罵攻擊。 昵稱:注冊  登錄
    [ 查看全部 ] 網(wǎng)友評論
    關(guān)于我們 - 聯(lián)系我們 - 廣告服務(wù) - 友情鏈接 - 網(wǎng)站地圖 - 版權(quán)聲明 - 在線幫助 - 文章列表
    返回頂部
    刷新頁面
    下到頁底
    晶體管查詢
    www84811.com-国产区一区二区三区,亚洲第一中文字幕在线观看,91精品久久香蕉国产线看观看,国产精品欧美久久
    欧美在线综合视频| 中文字幕免费在线观看视频一区| 奇米综合一区二区三区精品视频| 日韩一区二区精品在线观看| 国产一区二区在线观看视频| 亚洲欧洲一区二区三区| 欧美日韩亚洲综合| 久久超碰97人人做人人爱| 欧美激情在线看| 色妞www精品视频| 日本视频中文字幕一区二区三区| 久久精品人人做人人爽人人| 91在线播放网址| 日韩精品一二三四| 国产日韩视频一区二区三区| 欧洲人成人精品| 国产一区视频在线看| 亚洲视频在线观看一区| 日韩一区二区电影在线| 成人av免费在线播放| 石原莉奈一区二区三区在线观看| 国产亚洲精品aa午夜观看| 在线看一区二区| 国模套图日韩精品一区二区| 国产精品久久久久久久久搜平片| 国产美女主播视频一区| 国产精品免费久久| 欧美久久一二三四区| 国产成人在线影院| 婷婷开心激情综合| 中国色在线观看另类| 欧美日韩mp4| 波波电影院一区二区三区| 丝袜美腿亚洲色图| 国产精品麻豆欧美日韩ww| 欧美一二三四区在线| 色呦呦国产精品| 国产精品香蕉一区二区三区| 午夜欧美电影在线观看| 中文字幕欧美区| 日韩女优毛片在线| 色婷婷av一区| 懂色av中文一区二区三区| 日韩精品一级中文字幕精品视频免费观看 | 亚洲伦理在线精品| 欧美va日韩va| 欧美日韩三级一区| 91在线观看视频| 国产精品综合视频| 男男gaygay亚洲| 樱花草国产18久久久久| 国产午夜精品久久| 日韩欧美国产三级电影视频| 在线观看亚洲a| 成人免费高清视频| 黄一区二区三区| 青娱乐精品在线视频| 亚洲精品国久久99热| 中文一区在线播放| 精品国产欧美一区二区| 欧美日韩精品系列| 91久久奴性调教| 不卡视频一二三四| 国产高清精品网站| 久久国产欧美日韩精品| 日韩电影一二三区| 亚洲h精品动漫在线观看| 亚洲日本va午夜在线影院| 国产亚洲欧洲一区高清在线观看| 欧美成人综合网站| 欧美丰满一区二区免费视频| 在线观看欧美精品| 色综合欧美在线| 91视视频在线直接观看在线看网页在线看 | 国产欧美日韩综合| 久久色.com| 精品精品国产高清一毛片一天堂| 欧美精品1区2区3区| 精品视频1区2区3区| 在线视频一区二区三区| 在线日韩一区二区| 日本韩国精品在线| 91欧美一区二区| 色综合网色综合| 91无套直看片红桃| 91在线一区二区| 91在线观看美女| 91小视频免费看| 91免费版pro下载短视频| 91在线一区二区| 色欧美乱欧美15图片| 91官网在线免费观看| 在线免费观看一区| 欧美三级午夜理伦三级中视频| 欧美午夜电影网| 7799精品视频| 精品日韩在线观看| www激情久久| 国产日韩精品一区二区浪潮av| 国产拍欧美日韩视频二区| 欧美激情一区二区三区四区| 国产日韩精品视频一区| 国产精品传媒在线| 亚洲伦理在线精品| 香蕉成人啪国产精品视频综合网| 午夜久久电影网| 秋霞午夜鲁丝一区二区老狼| 久久国产综合精品| 国产精品亚洲人在线观看| 成人综合在线观看| 91论坛在线播放| 欧美日韩国产天堂| 日韩三级电影网址| 国产清纯白嫩初高生在线观看91| 国产精品久久久久婷婷| 亚洲精品国产a久久久久久| 亚洲国产色一区| 另类综合日韩欧美亚洲| 国产精品亚洲专一区二区三区 | 一区二区免费在线播放| 五月天丁香久久| 国内不卡的二区三区中文字幕| 国产91清纯白嫩初高中在线观看| 99re成人在线| 7777精品伊人久久久大香线蕉| 欧美v国产在线一区二区三区| 亚洲国产精品成人久久综合一区| 亚洲女人****多毛耸耸8| 五月综合激情婷婷六月色窝| 久久9热精品视频| 高清日韩电视剧大全免费| 色哟哟国产精品| 欧美一个色资源| 国产精品久久久久影院老司| 亚洲线精品一区二区三区八戒| 男女视频一区二区| 成人美女在线观看| 欧美嫩在线观看| 久久综合成人精品亚洲另类欧美| 自拍偷自拍亚洲精品播放| 日韩av在线播放中文字幕| 国产99久久久国产精品潘金网站| 91蝌蚪porny| 日韩亚洲国产中文字幕欧美| 国产精品免费久久| 日韩激情一区二区| 丁香婷婷深情五月亚洲| 欧美三区免费完整视频在线观看| 精品国产污网站| 亚洲日本成人在线观看| 美女视频黄免费的久久| 99久久99久久精品免费看蜜桃| 91精品综合久久久久久| 国产精品伦一区| 免费观看一级特黄欧美大片| 99这里只有精品| 日韩精品综合一本久道在线视频| 中文字幕一区二区三区蜜月 | 欧美一级片在线看| 国产日韩欧美高清在线| 亚洲国产成人av好男人在线观看| 国产精品一区二区男女羞羞无遮挡| 一本大道久久a久久精品综合| 日韩亚洲欧美在线观看| 亚洲精品视频观看| 国产原创一区二区| 欧美日韩国产综合视频在线观看 | 一区在线中文字幕| 蜜桃一区二区三区在线| 色婷婷av一区二区三区软件 | 亚洲免费资源在线播放| 国产在线观看一区二区| 欧美日韩一区二区不卡| 国产精品青草久久| 精品一区二区免费| 欧美日韩一区二区三区四区| 中文av一区二区| 精品无人码麻豆乱码1区2区| 欧美日韩一级黄| 一区免费观看视频| 国产麻豆成人传媒免费观看| 欧美日韩久久不卡| 亚洲视频电影在线| 国产91精品一区二区麻豆网站| 日韩一区二区三区免费看| 亚洲综合视频在线| 99久久免费国产| 国产人伦精品一区二区| 久久99精品视频| 欧美老女人第四色| 亚洲精品ww久久久久久p站| 懂色av一区二区三区蜜臀| 精品国产区一区| 男女男精品网站| 欧美电影影音先锋| 亚洲成人综合在线| 色综合久久88色综合天天免费| 国产精品日产欧美久久久久| 国产精品自产自拍| 26uuu色噜噜精品一区|