精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

使用JavaScript和Canvas開發(fā)游戲之認識Canvas

開發(fā) 前端
Canvas元素以及JavaScript引擎中新增的一些特性,讓Web開發(fā)人員不必借助第三方插件,即可設計開發(fā)出精細且具有交互性的2D網(wǎng)頁。這篇文章就向大家介紹一下Canvas元素,以及它的一些可能的用途。

1、認識一下Canvas

http://www.brighthub.com/internet/web-development/articles/38364.aspx

Canvas元素以及JavaScript引擎中新增的一些特性,讓Web開發(fā)人員不必借助第三方插件,即可設計開發(fā)出精細且具有交互性的2D網(wǎng)頁。這篇文章就向大家介紹一下Canvas元素,以及它的一些可能的用途。

JavaScript與Canvas元素

HTML是為創(chuàng)建靜態(tài)頁面而生的。HTML所能實現(xiàn)的動態(tài)效果,也僅限于顯示GIF動畫和閃爍的文本。JavaScript改變了這一切,通過它能夠動態(tài)修改網(wǎng)頁。今天,很多Web服務都利用AJAX來創(chuàng)建網(wǎng)頁,為用戶提供更加流暢的體驗,也超越了標準HTML頁面中常見的“點擊-重新加載-點擊”式的交互模式。

然而,JavaScript的某些功能會受到其宿主瀏覽器的制約。盡管可以在網(wǎng)頁中創(chuàng)建和修改任何元素,但JavaScript不能(輕易地)讓瀏覽器顯示一種新對象。通過JavaScript修改文本、插入圖像或者縮放表格都很容易,因為這些對象本來就是HTML所支持的。如果你想再玩得刺激一點,比如寫一個網(wǎng)頁游戲,怎么辦?那恐怕就得苦心積慮地改變標準HTML元素的用途,克服種種不測才能達到目的。要么,你就得求助于Flash或Silverlight這樣的插件。

Canvas元素登場了。這個新HTML元素為JavaScript開發(fā)者提供了一種無需插件即可在網(wǎng)頁中直接繪圖的機制。Canvas元素最早是由蘋果公司在其WebKit框架中引入的,Safari瀏覽器和Dashboard微件都在使用。Canvas元素現(xiàn)在也被建議加入了HTML5規(guī)范,得到了***的Chrome、Firefox、Opera以及Konqueror等瀏覽器的支持。Internet Explorer(至少在IE8之前)還不支持Canvas,但ExplorerCanvas項目倒是為IE提供了與Canvas元素類似的功能。

Canvas元素對做過2D圖形編程的人是小菜一碟。可以在這個元素上畫線、畫各種形狀、畫漸變,甚至可以利用與其他2D API中類似的函數(shù)來修改其中的每一個像素。得益于Chrome的V8、Firefox的SpiderMonkey以及Safari的Nitro等***JavaScript引擎的性能,創(chuàng)建精細且具有交互性的Web應用已經(jīng)完全沒有問題。

我們這一系列文章將教會大家使用JavaScript和Canvas元素創(chuàng)建一個簡單的平臺游戲。將要涉及的內容包括動畫、加載資源、分層渲染、滾動和交互。通過一步一步地展示示例代碼和實際效果,你可以很快學會如何駕馭強大的Canvas元素。

2、在Canvas上繪圖

http://www.brighthub.com/internet/web-development/articles/38744.aspx

下面,我們就通過一個循序漸進的示例及實時演示,來介紹如何使用JavaScript在Canvas元素上繪圖及實現(xiàn)動畫。

準備工作

知道了什么是Canvas元素之后,該學習在屏幕上繪圖了。首先,需要一個HTML頁面來放置和顯示Canvas元素。

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">  
  2. <html lang="en">  
  3.    <head>  
  4.       <title>JavaScript Platformer 1</title>  
  5.       <script type="text/javascript" src="jsplatformer1.js"></script>  
  6.       <style type="text/css">  
  7.          body { font-family: Arial,Helvetica,sans-serif;}  
  8.       </style>  
  9.    </head>  
  10.   <body>  
  11.      <p>  
  12.         <a href="http://www.brighthub.com/internet/web-development/articles/38364.aspx">  
  13.            Game Development with Javascript and the canvas element  
  14.         </a>  
  15.      </p>  
  16.      <canvas id="canvas" width="600" height="400">  
  17.         <p>Your browser does not support the canvas element.</p>  
  18.      </canvas>  
  19.   </body>  
  20. /html> 

這些HTML代碼很直觀。其中有兩個重要的元素。

  1. <script type="text/javascript" src="jsplatformer1.js"></script> 

這里包含的是將會修改Canvas元素的JavaScript代碼,對應的Canvas元素的標記如下:

  1. <canvas id="canvas" width="600" height="400">  
  2.     <p>Your browser does not support the canvas element.</p>  
  3. </canvas>  

以上代碼創(chuàng)建了一個Canvas元素。不支持Canvas的瀏覽器,比如Internet Explorer(IE8之前的版本),會忽略這個元素,而只顯示其子元素。在這個簡單的例子中,這個子元素就是一個段落,其中的文本告訴用戶他們的瀏覽器不支持Canvas元素。而對于那些支持Canvas元素的瀏覽器,如Chrome、Opera和Firefox,則會忽略Canvas元素的子元素。

這個Canvas元素的ID屬性很重要,因為后面的JavaScript將通過它來取得對該元素的引用。而width和height屬性指定了畫布的寬度和高度,這兩個屬性跟table或img等其他HTML元素中的同名屬性作用一樣。

以下是 jsplatformer1.js的代碼:

  1.  
  2. //每秒鐘target幀  
  3. const FPS = 30;  
  4. var x = 0;  
  5. var y = 0;  
  6. var xDirection = 1;  
  7. var yDirection = 1;  
  8. var image = new Image();  
  9. image.src = "jsplatformer1-smiley.jpg";  
  10. var canvas = null;  
  11. var context2D = null;  
  12.  
  13. window.onload = init;  
  14. function init(){  
  15.     canvas = document.getElementById('canvas');  
  16.     context2D = canvas.getContext('2d');  
  17.     setInterval(draw, 1000/FPS);  
  18. }  
  19. function draw(){  
  20.     context2D.clearRect(0, 0, canvas.width, canvas.height);  
  21.     context2D.drawImage(image, x, y);  
  22.     x += 1* xDirection;  
  23.     y += 1* yDirection;  
  24.  
  25.     if (x >= 450) {  
  26.         x = 450;  
  27.         xDirection = -1;  
  28.     }else if(x <= 0){  
  29.         x = 0;  
  30.         xDirection = 1;  
  31.     }  
  32.     if (y >= 250) {  
  33.         y = 250;  
  34.         yDirection = -1;  
  35.     }else if(y <= 0){  
  36.         y = 0;  
  37.         yDirection = 1;  
  38.     }  
  39. }  

如果只是一個Canvas元素,也沒有什么用。JavaScript必須要在這塊畫布上面畫點什么,相應的代碼保存在 jsplatformer1.js中。簡單來說,JavaScript在這里先加載了一幅圖像,然后將其畫在畫布上面,***讓它在畫布上移動。

首先,定義一些全局變量。

  1. const FPS = 30;  

FPS定義的是畫布重繪的頻率。

  1. var x = 0;  
  2. var y = 0;  
  3. var xDirection = 1;  
  4. var yDirection = 1; 

變量x、y、xDirection和yDirection用于定義圖像(相對于畫布左上角)的位置,以及它在任意一時刻移動的方向。

  1. var image = new Image();  
  2. image.src = "http://javascript-tutorials.googlecode.com/files/jsplatformer1-smiley.jpg"

要把圖像畫到畫布上,必須先加載一幅圖像。為此,我們創(chuàng)建一個Image對象,將其src屬性設置為一幅圖像文件的URL(建議把圖片下載到本地。——譯者注)。

  1. var canvas = null;  
  2. var context2D = null

我們還需要取得對Canvas元素以及繪圖上下文(稍后再詳細介紹繪圖上下文)的引用。稍后我們會把正確的值賦給這兩個變量,現(xiàn)在先把它們設置為null。

  1. window.onload = init; 

***,當頁面加載完成后,我們必須知道立即運行繪制畫布的代碼;因此,在window對象的onload事件發(fā)生時,立即調用init函數(shù)。

init函數(shù)

  1. function init(){  
  2.     canvas = document.getElementById('canvas');  
  3.     context2D = canvas.getContext('2d');  
  4.     setInterval(draw, 1000/FPS);  
  5. }  

頁面加載完畢后就會調用上面這個init函數(shù)。在這個函數(shù)中,我們先通過在HTML文件中指定的ID屬性取得畫布元素(毫無疑問,除了把它叫做畫布,還能叫個啥?),然后再取得這個畫布的2D繪圖上下文對象。

上下文對象用于定義如何在畫布上繪圖。顧名思義,2D上下文嘛,支持在畫布上繪制2D圖形、圖像和文本。支持畫布元素的瀏覽器都支持2D上下文,除了2D上下文,還有其他試驗性的上下文對象。Opera有一個專門為游戲設計的2D上下文,而Mozilla則有一個能夠顯示3D場景的上下文。可惜呀,目前這些上下文對象只有特定的瀏覽器才支持。如果你想用畫布來創(chuàng)建Web應用,***還是只使用常見的2D上下文。

因為我們在這里是想繪制一幅能移動的圖像,所以必須建立渲染循環(huán)(render loop)。所謂渲染循環(huán),實際上就是一個被重復調用的函數(shù),渲染循環(huán)的每一次迭代,(在這個例子中)都可以讓圖像在屏幕上產(chǎn)生一點位移,如此循環(huán)往復就能給人圖像在移動的感覺。為此,我們調用了setInterval函數(shù),它的***個參數(shù)是應該被重復調用的函數(shù),這里的函數(shù)名是draw。setInterval函數(shù)的第二個參數(shù)指定調用函數(shù)的頻率。這個參數(shù)值的單位是毫秒,而用1000除以早先定義的FPS得到的就是每次調用之間相隔的毫秒數(shù)。

這里需要注意一下,雖然我們指定每秒鐘調用30次draw函數(shù),但實際上不會調用30次。多長時間調用一次draw函數(shù),取決于底層JavaScript引擎的速度和要執(zhí)行的draw函數(shù)代碼的復雜程度。如果系統(tǒng)很慢的話,很可能每秒鐘只能調用一次draw函數(shù)。所以說,這里指定給setInterval的頻率只是一種最理想的情況。

draw函數(shù)

在畫布上繪圖的操作實際上都是由draw函數(shù)來完成的。下面我們就一步一步地說明其中的繪圖操作。

  1. context2D.clearRect(0, 0, canvas.width, canvas.height); 

所有繪圖操作都是在上下文對象上發(fā)生的,并不是在畫布元素上發(fā)生的。這里首先清空上下文,以便為繪制每一幀畫面準備一個干凈的版面。

  1. context2D.drawImage(image, x, y); 

緊接著,就把圖像繪制到上下文對象中,參數(shù)x和y指定了繪制圖像的左上角坐標。

  1. x += 1 * xDirection;  
  2. y += 1 * yDirection; 

為了讓圖像在畫布上移動,需要根據(jù)xDirection和yDirection是等于1(向右或向下)還是等于-1(向左或向上),來遞增或遞減x與y的值。

  1. if (x >= 450){  
  2.     x = 450;  
  3.     xDirection = -1;  
  4. else if (x <= 0) {  
  5.     x = 0;  
  6.     xDirection = 1;  
  7. }  
  8. if (y >= 250) {  
  9.     y = 250;  
  10.     yDirection = -1;  
  11. else if (y <= 0) {  
  12.     y = 0;  
  13.     yDirection = 1;  

如果圖像移動到了畫布外面,則反轉圖像的移動方向。我們知道圖像的大小是150×150像素,而畫布的大小的是600×400像素,因而就有了450(600 – 150)和250(400 – 150)這兩個值。

***的效果就是笑臉圖像會在畫布的范圍內反彈往復。此時此刻,有讀者可能會想:同樣的效果如果通過修改DIV元素的位置來實現(xiàn)可能更容易一些。這一點我不否認。但這個例子只演示了畫布元素所能實現(xiàn)的簡單效果。下一篇文章我們就會介紹使用畫布元素能夠實現(xiàn)的高級效果,同樣的效果若采用其他方式,恐怕就要困難多了。

原文作者:Matthew Casperson 原文鏈接: Game Development with JavaScript and the Canvas element

譯文作者:李松峰 譯文鏈接:http://www.cn-cuckoo.com/2011/08/10/game-development-with-javascript-and-the-canvas-element-2554.html

【編輯推薦】

  1. JavaScript入門之語言基礎
  2. 云端JavaScript漫游指南(視頻)
  3. 使用node.js進行服務器端JavaScript編程
  4. JavaScript實現(xiàn)頁面滾動圖片加載
  5. JavaScript入門之基本函數(shù)
責任編輯:陳貽新 來源: 李松峰的博客
相關推薦

2011-08-12 08:56:31

JavaScript

2012-01-04 13:55:23

Canvas

2012-05-09 09:41:58

HTML5

2013-05-20 17:13:17

Android游戲開發(fā)CanvasPaint

2022-03-09 09:00:41

SwiftUI視圖生成器Swift

2022-05-27 11:22:40

Canvas超級瑪麗游戲

2010-09-30 13:11:59

J2MECanvas

2022-02-23 15:17:04

鴻蒙OpenHarmonJacascript

2012-05-09 12:18:14

HTML5Canvas

2012-06-04 10:16:18

HTML5

2009-12-29 10:06:09

WPF Canvas

2022-06-29 14:06:54

canvas鴻蒙

2021-09-01 22:59:31

Canvas標簽語法

2023-02-28 11:43:35

2012-02-24 15:28:36

ibmdw

2012-09-24 13:49:13

HTML5CanvasJS

2022-12-12 09:01:13

2012-06-12 09:53:14

HTML5

2021-02-21 22:53:01

CanvasHTML5JavaScript

2021-09-01 22:58:22

Canvas標簽
點贊
收藏

51CTO技術棧公眾號

少妇人妻偷人精品一区二区| 欧美亚洲动漫精品| 欧美激情性做爰免费视频| 性折磨bdsm欧美激情另类| 美女尤物在线视频| 337p粉嫩大胆噜噜噜噜噜91av | 亚洲看片一区| 国产亚洲精品一区二555| 不卡中文字幕在线观看| 男女免费观看在线爽爽爽视频| 久久久久久久久久久99999| 国产一区二区在线免费视频| 久久久久久久国产精品毛片| 午夜精品影视国产一区在线麻豆| 欧美日韩精品一区视频| 日韩精品一区在线视频| 超碰在线国产| 99精品国产一区二区三区不卡| 国产精品无码专区在线观看| 久久精品国产亚洲AV无码麻豆| 国产精品一线天粉嫩av| 日韩精品一区二区三区中文精品| 日韩欧美xxxx| av伦理在线| 成人福利网站| 老司机精品视频在线| 91国自产精品中文字幕亚洲| 肉色超薄丝袜脚交69xx图片| 亚洲v天堂v手机在线| 欧美一区在线视频| 热久久精品免费视频| 成av人片在线观看www| **网站欧美大片在线观看| 欧美激情第一页在线观看| 国产福利视频导航| 免费成人av资源网| 人妖精品videosex性欧美| 精品无码黑人又粗又大又长| 欧美va久久久噜噜噜久久| 国产视频精品xxxx| 又黄又爽的网站| 天堂精品在线视频| 91.麻豆视频| 在线观看免费视频高清游戏推荐| 亚洲伊人av| 精品久久香蕉国产线看观看亚洲 | 蜜桃视频在线免费| 成人三级伦理片| 亚洲最大av网站| 国产露脸91国语对白| 男女视频一区二区| 国产精品久久久久秋霞鲁丝| 无码人妻精品一区二区| 久久这里有精品15一区二区三区| 91精品国产色综合久久不卡98| 久久久久久国产精品免费播放| 91精品秘密在线观看| 日韩亚洲综合在线| 国产黄色录像片| 久久精品高清| 久久精品99国产精品酒店日本| 美女100%露胸无遮挡| 成人一区而且| 啊v视频在线一区二区三区 | 久久精品国产精品| av磁力番号网| 黄色在线视频网站| 亚洲美女精品一区| 日本一本中文字幕| 校园春色亚洲| 在线视频亚洲一区| 日本高清久久久| 国产乱码精品一区二区三区亚洲人| 欧美群妇大交群中文字幕| 亚洲欧美日本一区二区三区| 91麻豆精品国产91久久久更新资源速度超快| 欧美日韩一区二区三区不卡| 天堂av2020| 亚洲一区二区电影| 国产午夜精品久久久| 精品人妻无码一区二区三区换脸| 欧美一区二区三区高清视频| 久久天天躁夜夜躁狠狠躁2022| 五月天丁香激情| 亚洲日韩成人| 国产精品精品视频| 99热这里只有精品在线| 波多野洁衣一区| 四虎一区二区| 欧美理论片在线播放| 欧美性猛交xxxx富婆| 三上悠亚av一区二区三区| 秋霞一区二区| 亚洲夜晚福利在线观看| 紧身裙女教师波多野结衣| 99香蕉国产精品偷在线观看| 国产精品美女www| 亚洲第一免费视频| 国产欧美日韩精品在线| 在线丝袜欧美日韩制服| 成年人在线网站| 欧美二区乱c少妇| 国产福利在线观看视频| 国产大片一区| 欧美亚洲国产视频小说| 99草在线视频| 国产日韩欧美不卡| 野外做受又硬又粗又大视频√| 电影一区电影二区| 中文字幕在线一区| 精品国产一区二区三区在线观看| 亚洲精品国产精品国自| 国内久久视频| 国产色视频一区| 欧洲一级在线观看| 一区二区三区日韩精品| 在线视频日韩一区| 国产日韩三级| 久久精品视频在线观看| 成人一二三四区| jvid福利写真一区二区三区| 在线观看日本一区| 国模视频一区| 亚洲男人7777| 日本三级网站在线观看| 国产曰批免费观看久久久| 欧美一区二区福利| av资源新版天堂在线| 欧美一级一区二区| 欧美性x x x| 日韩av在线播放中文字幕| 精品视频在线观看| 黄色的视频在线观看| 欧美福利视频一区| 香蕉久久久久久久| 久久中文在线| 秋霞毛片久久久久久久久| free性m.freesex欧美| 欧美一区二区精品| 在线观看黄网址| 美国十次了思思久久精品导航| 欧美一卡2卡3卡4卡无卡免费观看水多多| а√天堂资源官网在线资源| 欧美久久一二区| 日韩欧美黄色网址| 日本亚洲最大的色成网站www| 欧美一区二区高清在线观看| 午夜欧美巨大性欧美巨大| 亚洲成人中文字幕| 日韩欧美不卡视频| 99精品视频一区| 1024精品视频| 国产一区二区在线| 国产精品福利在线观看| 国产香蕉在线| 欧美日韩一区久久| 午夜激情福利电影| 激情伊人五月天久久综合| 精品亚洲男同gayvideo网站| 午夜久久久久久久久久久| 超级碰碰久久| 亚洲深夜福利网站| 国产精品欧美综合| 国产精品九色蝌蚪自拍| 国产三级生活片| 欧美福利网址| 精品日本一区二区三区在线观看 | 久久久久久免费视频| 91久久久国产精品| 中文字幕免费高清电视剧网站在线观看 | 妺妺窝人体色www看人体| 精品91福利视频| 欧美精品videosex性欧美| 色综合久久久久久| 日本道精品一区二区三区| 国产欧美小视频| 国产麻豆9l精品三级站| 国产欧美日韩网站| 久久99视频| 成人观看高清在线观看免费| av小次郎在线| 日韩精品中文字幕在线观看 | 可以免费看不卡的av网站| 色视频一区二区三区| 9.1麻豆精品| 久久久久久久久久av| 欧美新色视频| 欧美日韩一区二区在线观看| 午夜免费激情视频| 97成人超碰视| 中文字幕12页| 一区二区三区四区五区精品视频| 四虎一区二区| 国产精品流白浆在线观看| 国产精品高清免费在线观看| h片在线播放| 亚洲视频综合网| 精品久久久久中文慕人妻| 欧美性猛交xxxxx免费看| 精品人妻伦九区久久aaa片| 91亚洲精华国产精华精华液| 手机看片一级片| 亚洲福利免费| 日本特级黄色大片| 亚洲天堂日韩在线| av一区二区三区四区电影| 另类图片综合电影| 欧美激情综合色综合啪啪五月| 国产黄在线看| 亚洲精品www久久久| 一区二区三区播放| 色伊人久久综合中文字幕| 久草视频免费播放| 国产精品国产三级国产专播品爱网 | 欧美成人免费小视频| 国产一区二区三区在线观看 | 日韩视频精品在线| 久久久久久久久亚洲精品| 日韩免费福利电影在线观看| 亚洲av无码乱码国产精品fc2| 一区二区三区日韩精品| 国产一区在线观看免费| 久久蜜桃香蕉精品一区二区三区| 中文字幕永久免费| 狠狠狠色丁香婷婷综合久久五月| 日韩av资源在线| 欧美日韩国产在线一区| 一本色道久久99精品综合| 伊人精品一区| 久久99影院| 老司机aⅴ在线精品导航| 97超碰人人看人人| 精品成人18| 成人字幕网zmw| 欧美黑粗硬大| 国产精品久久婷婷六月丁香| 成人教育av| 欧美亚洲伦理www| 国产精品电影| 91精品国产99| 蜜桃视频m3u8在线观看| 高清欧美性猛交xxxx黑人猛交| 成人福利在线观看视频| 久久成年人视频| 老司机在线视频二区| 日韩中文字幕在线看| 亚洲xxxxxx| 久久精品国产欧美激情| 国产原厂视频在线观看| 不卡av在线网站| 亚洲精品白浆| 性色av一区二区三区红粉影视| 日本孕妇大胆孕交无码| 欧美大片在线看免费观看| 日本一级理论片在线大全| 久久久免费电影| 丝袜老师在线| 国产成人一区二区三区| 成人在线爆射| 国产精品日韩在线播放| 日韩黄色三级| 91国产在线免费观看| 1769国产精品视频| 九九九久久久| 国产91久久精品一区二区| 日本三级中国三级99人妇网站 | 在线观看av的网址| 欧美人成在线| 国产乱子伦农村叉叉叉| 午夜综合激情| 男女视频在线看| 久久99精品网久久| 精品人妻一区二区乱码| 99久久久无码国产精品| 精品无人区无码乱码毛片国产| 亚洲国产高清不卡| 91成人福利视频| 精品美女国产在线| 美女黄页在线观看| 欧美一级精品大片| 亚洲欧洲成人在线| 中文字幕少妇一区二区三区| 国产日产一区二区三区| 亚洲91精品在线| 国产私拍福利精品视频二区| 91网站免费观看| 青草久久视频| 一区二区国产日产| 欧美午夜不卡影院在线观看完整版免费| 国产成人黄色片| 国产精品系列在线观看| 国产精品边吃奶边做爽| 中文字幕一区在线观看| 日韩少妇裸体做爰视频| 欧美日韩国产美女| 蜜臀av中文字幕| 中文字幕日韩在线视频| 2021中文字幕在线| 国产日本欧美一区| 日韩欧美ww| 国产对白在线播放| 久久婷婷丁香| 国产欧美视频一区| 国产精品麻豆视频| 国产成人免费看| 欧美一区二区福利视频| 国产三级在线看| 午夜免费久久久久| 日韩高清在线观看一区二区| 欧美久久久久久一卡四| 欧美日韩精选| 色乱码一区二区三区在线| 久久综合色综合88| 国产在线免费视频| 欧美一区二区三区公司| 超碰在线国产| 国产成人亚洲综合91| 精品综合久久88少妇激情| 久久免费视频2| 日本亚洲天堂网| 久久精品视频18| 欧美日韩免费区域视频在线观看| 国产sm主人调教女m视频| 中文字幕亚洲欧美日韩2019| 亚洲综合电影| 久久久久久久久久久久久久久久av| 午夜精品久久99蜜桃的功能介绍| 亚洲一区在线不卡| 久久精品欧美日韩精品| 久久久精品福利| 亚洲精品久久久久久下一站| 性网站在线观看| 91老司机精品视频| 久久精品久久久| 久久国产激情视频| 中文字幕二三区不卡| 久久久久精彩视频| 亚洲视频国产视频| av高清一区| 亚洲免费久久| 捆绑调教一区二区三区| 99久久99久久精品免费看小说.| 在线观看www91| aaa日本高清在线播放免费观看| 国产精品99久久久久久www| 日韩欧美影院| 日本久久久精品视频| 91美女片黄在线观看| 国产精品自拍99| 国产视频精品久久久| 欧美电影h版| 亚欧洲精品在线视频免费观看| 免费成人在线观看| 日韩精品123区| 欧美一区二区观看视频| 国产网红在线观看| 国产在线资源一区| 男人的天堂成人在线| 国产熟女一区二区| 欧美日韩卡一卡二| 中文字幕免费高清电视剧网站在线观看| 91久久精品一区二区别| 合欧美一区二区三区| 800av在线播放| 在线视频国内一区二区| 午夜在线视频| 99re在线视频观看| 亚洲三级网站| 亚洲精品91在线| 91精品国产全国免费观看| 欧美xxxx免费虐| 免费在线国产精品| 美国十次了思思久久精品导航| 婷婷久久综合网| 精品性高朝久久久久久久| 国产91亚洲精品久久久| 四虎精品欧美一区二区免费| 不卡在线观看av| 国产成人精品亚洲| 中文字幕亚洲二区| 久草手机视频在线观看| 精品少妇一区| av一区二区三区免费| 极品av少妇一区二区| 亚洲一级中文字幕| 欧美日韩国产一区二区三区地区| 最爽无遮挡行房视频在线| 欧美日韩亚洲一区二区三区在线观看| 日本一区中文字幕| 国产精品99无码一区二区| 亚洲一区av在线播放| 精品视频在线观看免费观看| 日日碰狠狠添天天爽超碰97| 国产精品蜜臀av| 香蕉视频免费看| 成人综合网网址| 老牛国产精品一区的观看方式| 国产精品成人免费观看| 亚洲日本aⅴ片在线观看香蕉| 日韩成人在线看|