亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gapisnake.cpp

?? 基于windows mobile的貪吃蛇游戲源碼
?? CPP
字號:
// gapi snake sample
// gapisnake.cpp


#include <windows.h>
#include <windowsx.h>
#include <aygshell.h>
#include "resource.h"
#include <gx.h>

//#include <vibrate.h> PPC Not Support



#define MENU_HEIGHT 20
#define MAX_LOADSTRING 100
#define SAKNE_SIZE 4
#define MOVE_UP 1
#define MOVE_DOWN 2
#define MOVE_LEFT 3
#define MOVE_RIGHT 4

// Global Variables:
HINSTANCE			hInst;					// The current instance
HWND				hwndCB;					// The command bar handle

// Global GAPI variables:
GXDisplayProperties gx_displayprop;
GXKeyList gx_keylist;
unsigned short *framebuf = NULL;  //screen buffer, same as OFF SCREEN


// Global variables for this program (line drawing stuff only)
 int x1=10,x2=100,y1=40,y2=80, dx1=4,dy1=-4, dx2=3,dy2=3;
 typedef struct tag_snakebody *LPSNAKEBODY;
 typedef struct tag_snakehead
 {
	int x;
	int y;
	int next_m;
	int pre_m;
	int eat;
	LPSNAKEBODY next;
	
 }SNAKEHEAD;


 typedef struct tag_snakebody
 {
	int x;
	int y;
	int next_m;
	int pre_m;
	LPSNAKEBODY next;
	LPSNAKEBODY pre;

 }SNAKEBODY;

 typedef struct tag_food
 {
	int x;
	int y;
 }FOODINFO,LPFOODINFO;


static SHACTIVATEINFO s_sai;
SNAKEHEAD snakehead;

// Forward declarations of functions included in this code module:
ATOM				MyRegisterClass	(HINSTANCE, LPTSTR);
BOOL				InitInstance	(HINSTANCE, int);
LRESULT CALLBACK	WndProc			(HWND, UINT, WPARAM, LPARAM);
void ClearScreen(unsigned short * buffer,int r, int g, int b);
void RunVibrate(int time);
void Run(HWND hwnd);

int WINAPI WinMain(	HINSTANCE hInstance,
					HINSTANCE hPrevInstance,
					LPTSTR    lpCmdLine,
					int       nCmdShow)
{
	MSG msg;
	HACCEL hAccelTable;

	// Perform application initialization:
	if (!InitInstance (hInstance, nCmdShow)) 
	{
		return FALSE;
	}

	// Main message loop:
	while (GetMessage(&msg, NULL, 0, 0)) 
	{
		if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) 
		{
			TranslateMessage(&msg);
			DispatchMessage(&msg);
		}
	}

	return msg.wParam;
}


ATOM MyRegisterClass(HINSTANCE hInstance, LPTSTR szWindowClass)
{
	WNDCLASS	wc;

    wc.style			= CS_HREDRAW | CS_VREDRAW;
    wc.lpfnWndProc		= (WNDPROC) WndProc;
    wc.cbClsExtra		= 0;
    wc.cbWndExtra		= 0;
    wc.hInstance		= hInstance;
    wc.hIcon			= NULL;
    wc.hCursor			= 0;
    wc.hbrBackground	= (HBRUSH) GetStockObject(WHITE_BRUSH);
    wc.lpszMenuName		= 0;
    wc.lpszClassName	= szWindowClass;

	return RegisterClass(&wc);
}


BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
{
	HWND	hWnd = NULL;
	TCHAR	szTitle[MAX_LOADSTRING];			// The title bar text
	TCHAR	szWindowClass[MAX_LOADSTRING];		// The window class name

	hInst = hInstance;		// Store instance handle in our global variable
	// Initialize global strings
	wcscpy(szWindowClass,_T("G_Snake"));
	wcscpy(szTitle,_T("GAPI_Snake"));

	//If it is already running, then focus on the window
	hWnd = FindWindow(szWindowClass, szTitle);	
	if (hWnd) 
	{
		SetForegroundWindow ((HWND) (((DWORD)hWnd) | 0x01));    
		return 0;
	} 

	MyRegisterClass(hInstance, szWindowClass);
	
	RECT	rect;
	GetClientRect(hWnd, &rect);
	
	hWnd = CreateWindow(szWindowClass, szTitle, WS_VISIBLE,
		0, 0, GetSystemMetrics(SM_CXSCREEN), GetSystemMetrics(SM_CYSCREEN), NULL, NULL, hInstance, NULL);
	if (!hWnd)
	{	
		return FALSE;
	}
	//When the main window is created using CW_USEDEFAULT the height of the menubar (if one
	// is created is not taken into account). So we resize the window after creating it
	// if a menubar is present
	{
		RECT rc;
		GetWindowRect(hWnd, &rc);
		rc.bottom -= MENU_HEIGHT;
		if (hwndCB)
			MoveWindow(hWnd, rc.left, rc.top, rc.right, rc.bottom, FALSE);
	}


	ShowWindow(hWnd, nCmdShow);
	UpdateWindow(hWnd);

	// GAPI Stuff

	// Attempt to take over the screen
	if (GXOpenDisplay( hWnd, GX_FULLSCREEN) == 0)
		return FALSE;

	// Get display properties
	gx_displayprop = GXGetDisplayProperties();

	// Check for 16 bit color display
	if (gx_displayprop.cBPP != 16)
	{
		// Only dealing with 16 bit color in this code
		GXCloseDisplay();
		MessageBox(hWnd,L"Sorry, only supporting 16bit color",L"Sorry!", MB_OK);
		return FALSE;
	}
	//alloc screen buf, use it to save all element of a full frame;
	framebuf = (unsigned short*)malloc(sizeof(short)*gx_displayprop.cxWidth*gx_displayprop.cyHeight);
	if(framebuf==NULL)
		return FALSE;
	//clear white screen 
	ClearScreen(framebuf,0x00,0xff,0xff);
	// Take over button handling
	GXOpenInput();

	// Get default buttons for up/down etc.
	gx_keylist = GXGetDefaultKeys(GX_NORMALKEYS);

	return TRUE;
}

//get 16bit color RGB at point(x,y)
void Get16Pixel(unsigned short *buffer,int x, int y,int *r, int *g, int *b)
{
	unsigned short *pixeladd;
	int address  = (x * gx_displayprop.cbxPitch>>1) + (y * gx_displayprop.cbyPitch>>1);
	pixeladd = (buffer+address);
	if (gx_displayprop.ffFormat & kfDirect565)//565 format
	{
		unsigned short PixelCol;
		PixelCol = (*pixeladd);
		*r = (PixelCol & 0xf800) >> 11;
		*g = (PixelCol & 0x07e0) >> 5;
		*b = (PixelCol & 0x001f);
	}
	else//555 format
	{
		unsigned short PixelCol;
		PixelCol = (*pixeladd);
		*r = (PixelCol & 0x7c00) >> 11;
		*g = (PixelCol & 0x03e0) >> 5;
		*b = (PixelCol & 0x001f);
	}
    


}

// Plot a pixel given video memory address, color, x and y co-ords
void PlotPixel(unsigned short *buffer, int x, int y, int r, int g, int b)
{

	int address  = (x * gx_displayprop.cbxPitch>>1) + (y * gx_displayprop.cbyPitch>>1);

	unsigned short PixelCol;

	if (gx_displayprop.ffFormat & kfDirect565)
	{
		PixelCol = (unsigned short) (r & 0xff) << 11 | (g & 0xff) << 5 | (b & 0xff);
	}
	else
	{
		PixelCol = (unsigned short) (r & 0xff) << 10 | (g & 0xff) << 5 | (b & 0xff);
	}

	*(unsigned short *)(buffer+address) = PixelCol;
}


// Simple midpoint line algorithm.
void DrawLine(unsigned short *buffer, int x0, int y0, int x1, int y1, int r, int g, int b)
{

	int x;

	if (x0>x1) {x=x1; x1=x0; x0=x;}
	if (y0>y1) {x=y1; y1=y0; y0=x;}
	
	float dx,dy,y,m;

	dy=y1-y0;
	dx=x1-x0;
	m=dy/dx;
	y=y0;
	for (x=x0; x<x1; x++)
	{
		PlotPixel(buffer,x,(int)y,r,g,b);
		y+=m;
	}
}

void DrawBlock(unsigned short *buffer, int x, int y, int w, int h, int r, int g, int b)
{
	int dx,dy;
	if(y<0 || w<0 ||h<0)
		return;
	
	for(dy = y; dy<y+h; dy++)
	{
		for(dx = x; dx<x+w; dx++)
		{
			PlotPixel(buffer,dx,dy,r,g,b);

		}
	}
	
}



// Clear the screen to a color desribed by the red, green, blue values
void ClearScreen(unsigned short * buffer,int r, int g, int b)
{


	unsigned short * line_buffer  = buffer;


	if (buffer == NULL) return;


	// Calculate the pixel color from the r,g,b components.
	unsigned short PixelCol;

	if (gx_displayprop.ffFormat & kfDirect565)
	{
		PixelCol = (unsigned short) (r & 0xff) << 11 | (g & 0xff) << 5 | (b & 0xff);
	}
	else
	{
		PixelCol = (unsigned short) (r & 0xff) << 10 | (g & 0xff) << 5 | (b & 0xff);
	}


	// Use two loops to fill the entire screen with the necessary color
	for (unsigned int y=0; y<gx_displayprop.cyHeight; y++)
	{
		unsigned short * pixel = buffer;

		for (unsigned int x=0; x<gx_displayprop.cxWidth; x++)
		{
			*pixel = PixelCol;
			pixel += gx_displayprop.cbxPitch >> 1;
		}

		buffer += gx_displayprop.cbyPitch >> 1;
	}

}

void InitSnake()
{

	LPSNAKEBODY snaketrack;
	snakehead.x=100;
	snakehead.y=100;
	snakehead.next_m=MOVE_UP;
	snakehead.pre_m=MOVE_UP;
	snakehead.next=NULL;

	snaketrack = (LPSNAKEBODY)malloc(sizeof(SNAKEBODY));
	snaketrack->next_m = MOVE_UP;
	snaketrack->pre_m = MOVE_UP;
	snaketrack->next = NULL;
	snaketrack->pre = NULL;
	snaketrack->x = snakehead.x;
	snaketrack->y = snakehead.y + SAKNE_SIZE;
	snakehead.next = snaketrack;
	
	//init snake's boby length is 30 body(block)
	for(int i = 0; i <30; i++)
	{
		snaketrack->next = (LPSNAKEBODY)malloc(sizeof(SNAKEBODY));
		snaketrack->next->next = NULL;
		snaketrack->next->pre = snaketrack;
		snaketrack = snaketrack->next;
		snaketrack->next_m = snaketrack->pre->next_m;
		snaketrack->pre_m = snaketrack->pre->next_m;
		snaketrack->x = snaketrack->pre->x;
		snaketrack->y = snaketrack->pre->y + SAKNE_SIZE;
		
	}

}

//destroy snake's resource alloc memory previously
void ReleaseSnake()
{
	LPSNAKEBODY snaketrack,last;
	snaketrack = snakehead.next;

	while(snaketrack)
		if(snaketrack->next != NULL)
			snaketrack = snaketrack->next;
		else
			break;
	while(snaketrack)
	{
		last = snaketrack->pre;
		free(snaketrack);
		snaketrack = last;
	}
}


LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{

	switch (message) 
	{
		
		case WM_CREATE:
			
			InitSnake();
			SetTimer(hWnd,1,100,NULL);
			break;

		case WM_TIMER:
			
			Run(hWnd);
		
			break;

		case WM_PAINT:
			{
				PAINTSTRUCT ps;
				RECT rect;
				HDC hdc = BeginPaint(hWnd,&ps);
				GetClientRect(hWnd,&rect);
				rect.top = 80;
				DrawText(hdc,_T("snake has died\nplease push left softkey EXIT"),-1,&rect,DT_CENTER );
				EndPaint(hWnd,&ps);
			}
			
			break;
		case WM_KEYDOWN:
			if (wParam == (unsigned) gx_keylist.vkUp)
			{
				snakehead.next_m = MOVE_UP;
				
			}
			if (wParam == (unsigned) gx_keylist.vkDown)
			{
				snakehead.next_m = MOVE_DOWN;
				
			}
			if (wParam == (unsigned) gx_keylist.vkLeft)
			{
				snakehead.next_m = MOVE_LEFT;
				
			}
			if (wParam == (unsigned) gx_keylist.vkRight)
			{
				snakehead.next_m = MOVE_RIGHT;
				
			}
			
			if(wParam == (unsigned) gx_keylist.vkA)
			{
				KillTimer(hWnd,1);
				SendMessage(hWnd,WM_CLOSE,0,0);
				ReleaseSnake();
			}

			break;


		
		case WM_DESTROY:
			if(framebuf!=NULL)
				free(framebuf);
			GXCloseInput();
			GXCloseDisplay();

			PostQuitMessage(0);
			break;

		case WM_KILLFOCUS:
			GXSuspend();
			break;

		case WM_SETFOCUS:
			GXResume();
			break;


		case WM_SETTINGCHANGE:
			SHHandleWMSettingChange(hWnd, wParam, lParam, &s_sai);
     		break;

		default:
			return DefWindowProc(hWnd, message, wParam, lParam);
   }
   return 0;
}

void ChangeDirection()
{
 LPSNAKEBODY traceon,temp1,temp2;
 traceon = snakehead.next;

 

 if(traceon != NULL)
 {

  traceon->next_m = snakehead.pre_m;
  snakehead.pre_m = snakehead.next_m;
  traceon = traceon->next;
  while(traceon)
  {
   traceon->next_m = traceon->pre->pre_m; 
   traceon->pre->pre_m = traceon->pre->next_m;
   traceon = traceon->next;
  }

  
 }


}

void SortAll()
{
 /* sort all food,include snake head,and virtual place */

 LPSNAKEBODY traceon;
 void *buf;
 int  size;

 switch(snakehead.next_m)
 {
 case MOVE_UP:
   snakehead.y -= SAKNE_SIZE;
   break;
 case MOVE_LEFT:
   snakehead.x -= SAKNE_SIZE;
   break;
  case MOVE_DOWN:
   snakehead.y += SAKNE_SIZE;
   break;
  case MOVE_RIGHT:
   snakehead.x += SAKNE_SIZE;
   break;
  default:
   break;
 }

 traceon = snakehead.next;
 while(traceon)
 {
  switch(traceon->next_m)
  {
   case MOVE_UP:
    traceon->y -= SAKNE_SIZE;
    break;
   case MOVE_LEFT:
    traceon->x -= SAKNE_SIZE;
    break;
   case MOVE_DOWN:
    traceon->y += SAKNE_SIZE;
    break;
   case MOVE_RIGHT:
    traceon->x += SAKNE_SIZE;
    break;
   default:
    break;
  }
  traceon = traceon->next;
 }

}


BOOL RedrawSnake()
{
	unsigned short * buffer  = (unsigned short *) GXBeginDraw();
	if(buffer == NULL)
	{
		return FALSE;
	}
	int i = 0;
	LPSNAKEBODY snaketrack;
	ClearScreen(framebuf,0xff,0x00,0xff);
	snaketrack = snakehead.next;
	DrawBlock(framebuf,snakehead.x,snakehead.y,SAKNE_SIZE,SAKNE_SIZE,0,0,0);
	while(snaketrack)
	{	i+=1;
		DrawBlock(framebuf,snaketrack->x,snaketrack->y,SAKNE_SIZE,SAKNE_SIZE,32,16,i);
		snaketrack = snaketrack->next;
	}
	memcpy(buffer,framebuf, sizeof(short)*gx_displayprop.cxWidth*gx_displayprop.cyHeight);
	// End the drawing code
	GXEndDraw();
	return TRUE;
}



int JudgeDeath(unsigned short * buffer)
{
 /* return 1 means will die,and return 0 means will survive */
 int tempx,tempy,r,g,b;

 switch(snakehead.next_m)
 {
  case MOVE_UP:
   tempx = snakehead.x;
   tempy = snakehead.y - SAKNE_SIZE;
   break;
  case MOVE_LEFT:
   tempx = snakehead.x - SAKNE_SIZE;
   tempy = snakehead.y;
   break;
  case MOVE_DOWN:
   tempx = snakehead.x;
   tempy = snakehead.y + SAKNE_SIZE;
   break;
  case MOVE_RIGHT:
   tempx = snakehead.x + SAKNE_SIZE;
   tempy = snakehead.y;
   break;
  default:
   break;
 }

 if((tempx < 0) || (tempx > gx_displayprop.cxWidth) ||
    (tempy < 0) || (tempy > gx_displayprop.cyHeight))
    return 1;

 Get16Pixel(buffer,tempx,tempy,&r,&g,&b);
 // if point color is not same as backcolor, it thinks snake is dead.
 // it is simple to deal with color infomation.
 // because device is 16 color bit(565 format), 0x1f is equal to RGB's R value(0xff)
 // and g = 3f is equal to G max value, b = 1f is equal to B max value.
 if( r != 0x1f && g != 0x3f && b != 0x1f) 
 {
	MessageBeep(-1);
	return 1;
	
 }

 return 0; /* survive */

}



void Run(HWND hwnd)
{
	if(1 == JudgeDeath(framebuf))
	{
		KillTimer(hwnd,1);
//		RunVibrate(1000);
		SendMessage(hwnd,WM_PAINT,0,0);
		InvalidateRect(hwnd,NULL,TRUE);
	}
	
	ChangeDirection();
	SortAll();
	RedrawSnake();
	
}

//use vibrate character, PPC 2003 SDK not support
/*
void RunVibrate(int time)
{
	TCHAR buf[20];
	int caps =  -1;
	caps = VibrateGetDeviceCaps(VDC_AMPLITUDE);
	if(caps<=0)
		return;
	HRESULT hr = Vibrate(0, NULL, TRUE, INFINITE);
	if(hr == E_FAIL)
	{
		MessageBox(NULL,L"E_FAIL",L"",MB_OK);
	}
	else if(hr == E_NOTIMPL)
	{
		MessageBox(NULL,L"E_NOTIMPL",L"",MB_OK);
	}
	Sleep(1000);
	VibrateStop();
	
}
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久这里都是精品| 久久不见久久见中文字幕免费| 亚洲高清在线精品| 狠狠色伊人亚洲综合成人| 色综合咪咪久久| 久久久精品综合| 免费看黄色91| 欧美在线免费视屏| 中文一区一区三区高中清不卡| 首页国产欧美久久| 日本久久一区二区| 国产欧美综合在线观看第十页| 青青草伊人久久| 欧美色男人天堂| 亚洲乱码中文字幕| 国产91高潮流白浆在线麻豆| 日韩欧美一二三区| 亚洲成人在线免费| 色94色欧美sute亚洲线路二| 国产精品电影一区二区| 国产中文字幕精品| 欧美哺乳videos| 免费精品视频最新在线| 欧美人伦禁忌dvd放荡欲情| 亚洲欧美区自拍先锋| 波多野结衣91| 中文字幕一区二区5566日韩| 国产精品88av| 国产色综合久久| 国产精品888| 国产亚洲精品超碰| 欧美少妇一区二区| 亚洲一区av在线| 欧美色网站导航| 亚洲电影在线播放| 欧美人妖巨大在线| 视频一区视频二区在线观看| 欧美丰满少妇xxxxx高潮对白| 亚洲精品国产精品乱码不99| 色婷婷av一区二区三区之一色屋| 亚洲天堂免费看| 91福利国产成人精品照片| 亚洲精品写真福利| 欧美蜜桃一区二区三区| 日韩精品福利网| 欧美大片在线观看| 懂色av一区二区三区蜜臀| 国产精品美女一区二区三区| 成人免费福利片| 一区二区三区精品在线观看| 欧美日韩中文国产| 久久激五月天综合精品| 久久久精品人体av艺术| av高清久久久| 亚洲国产欧美在线| 精品乱人伦一区二区三区| 国产美女娇喘av呻吟久久| 国产精品久久久久久久久动漫| 色综合视频在线观看| 亚洲成av人片在线观看| 精品久久久久久综合日本欧美| 国产成人av福利| 一区二区三区波多野结衣在线观看| 欧美日本精品一区二区三区| 国产曰批免费观看久久久| 亚洲色图视频网站| 日韩欧美国产一二三区| 丰满放荡岳乱妇91ww| 亚洲一区二区三区在线播放| 日韩精品一区二区三区视频在线观看| 国产精品一区二区91| 尤物在线观看一区| 欧美不卡在线视频| 欧美综合色免费| 国产伦精品一区二区三区视频青涩 | 色av综合在线| 久久国产生活片100| 亚洲品质自拍视频| 日韩一卡二卡三卡| 色综合久久久久网| 国产综合久久久久久久久久久久| 夜夜嗨av一区二区三区| 久久先锋资源网| 欧美日高清视频| 成人午夜av在线| 老司机精品视频一区二区三区| 亚洲欧美偷拍另类a∨色屁股| 日韩欧美亚洲国产精品字幕久久久| 91在线无精精品入口| 激情都市一区二区| 婷婷久久综合九色综合伊人色| 一色桃子久久精品亚洲| 精品国产乱子伦一区| 欧美精品vⅰdeose4hd| av电影在线观看完整版一区二区| 美脚の诱脚舐め脚责91| 亚洲精品高清在线观看| 国产拍欧美日韩视频二区| 日韩一区二区三区视频在线 | 国产麻豆精品在线| 天天亚洲美女在线视频| 亚洲狠狠丁香婷婷综合久久久| 久久先锋影音av鲁色资源网| 欧美一级日韩免费不卡| 欧美伦理视频网站| 在线观看91精品国产入口| 91原创在线视频| heyzo一本久久综合| 国产 欧美在线| 国产精品一区二区三区四区| 狠狠色狠狠色综合系列| 久久99最新地址| 久久se这里有精品| 蜜臀99久久精品久久久久久软件 | 亚洲欧洲日韩综合一区二区| 国产亚洲精品福利| 国产无一区二区| 国产三级欧美三级| 国产欧美日韩视频一区二区| 久久久久久久久久美女| 久久久国产精品不卡| 久久久美女毛片| 欧美国产日本视频| 中文字幕在线观看一区二区| 中文字幕一区二区三区乱码在线| 国产精品久久福利| 亚洲精品一二三四区| 亚洲成精国产精品女| 日韩精品91亚洲二区在线观看| 日本欧美一区二区三区| 韩日精品视频一区| 成人午夜碰碰视频| 色诱视频网站一区| 欧美伊人久久久久久久久影院| 欧美日韩成人一区| 精品日产卡一卡二卡麻豆| 国产欧美日韩三区| 亚洲免费视频中文字幕| 日韩国产精品91| 国产成人av电影在线观看| 91小视频免费观看| 欧美顶级少妇做爰| 久久久国际精品| 亚洲卡通欧美制服中文| 五月婷婷综合网| 国产美女在线观看一区| 91婷婷韩国欧美一区二区| 欧美情侣在线播放| 久久久精品影视| 亚洲不卡av一区二区三区| 国产资源精品在线观看| 91麻豆精品秘密| 日韩无一区二区| 中文字幕一区二区在线观看| 天堂va蜜桃一区二区三区| 国产精品一二三四五| 欧美无人高清视频在线观看| 欧美精品一区二区不卡| 一区二区三区日韩在线观看| 精久久久久久久久久久| 欧美性极品少妇| 久久久久久久久久久久久久久99 | 色一情一伦一子一伦一区| 欧美一区二区三区四区在线观看| 国产女人18毛片水真多成人如厕| 亚洲第一福利视频在线| 国产a级毛片一区| 欧美一卡二卡在线| 一区2区3区在线看| 国产成人亚洲综合a∨猫咪| 欧美卡1卡2卡| 亚洲狠狠丁香婷婷综合久久久| 韩日精品视频一区| 51精品秘密在线观看| 亚洲色图20p| 成人免费视频app| 精品国产免费视频| 图片区小说区国产精品视频 | 国产一区二区在线观看免费| 精品视频全国免费看| 国产精品国产三级国产a| 国产在线观看免费一区| 正在播放亚洲一区| 一区二区在线免费| 99精品视频在线免费观看| 久久青草国产手机看片福利盒子 | 亚洲国产成人高清精品| av高清久久久| 国产精品欧美久久久久一区二区 | 青青草91视频| 欧美影片第一页| 亚洲一二三四区| 在线精品视频小说1| 亚洲免费伊人电影| 色哟哟精品一区| 亚洲一区二区三区四区在线观看 | 亚洲高清久久久| 精品视频1区2区| 午夜电影一区二区三区| 欧美一级在线免费|