日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JavaScript OpenGL接口再设计

發布時間:2025/3/15 javascript 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript OpenGL接口再设计 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Web OpenGL封裝

  • 簡介
  • 上下文GLContext
  • 基類GLObject
  • 著色器GLShader
  • 著色器程序GLProgram
  • 著色器程序屬性GLAttribute、GLUniform
  • 數據緩存GLBuffer
  • GLTexture和GLFrameBuffer
  • html標簽
    • Canvas
    • vertex shader
    • fragment shader
    • iChannels
  • 主程序ShaderToyGame
  • 主函數

簡介

將OpenGL提供的庫函數接口進行一層封裝。

上下文GLContext

OpenGL自身是一個巨大的狀態機(State Machine):一系列的變量描述OpenGL此刻應當如何運行。OpenGL的狀態通常被稱為OpenGL上下文(Context)。我們通常使用如下途徑去更改OpenGL狀態:設置選項,操作緩沖。最后,我們使用當前OpenGL上下文來渲染。

<!--GLContext單例GL上下文對象--> <script type="text/javascript">class GLContext {static width = 0static height = 0constructor() {this.gl = null}static getWebGL() {if (!this.gl) {// 獲取html中的glCanvaslet canvas = document.getElementById('glCanvas') //.transferControlToOffscreen()GLContext.width = canvas.widthGLContext.height = canvas.height// 獲取glCanvas中的gl上下文this.gl = canvas.getContext('webgl2')}return this.gl}} </script>

基類GLObject

由于大部分GL相關的封裝類,都有著共同的方法,因此寫一個基類。

<!--GLObjectGL對象的基類--> <script type="text/javascript">class GLObject {constructor() {this.gl = GLContext.getWebGL()}bind() {}unbind() {}} </script>

著色器GLShader

OpenGL在創建一個“筆刷”的時候需要先創建vertex shader和fragment shader。

<!--用于創建:頂點著色器 or 片元著色器GLShaderGL著色器--> <script type="text/javascript">class GLShader extends GLObject {/*** @param sourceCode 元素id、shaderCode字符串、元素對象* @param type shader的類型*/constructor(sourceCode, type) {super()if (sourceCode == undefined || type.constructor != Number) {// sourceCode為空 或者 type著色器類型不是數字throw "sourceCode is undefined or type not number. \n";} else if (sourceCode.constructor == String) {// sourceCode本身是一個字符串, 要么是shader源碼, 要么是標簽的idif (sourceCode[0] == '#') {// sourceCode是一個idsourceCode = $(sourceCode)[0].innerHTML}} else if (sourceCode.constructor == HTMLScriptElement) {// sourceCode是一個元素對象sourceCode = sourceCode.innerHTML} else {// 其他情況直接錯誤throw "Create Shader Error. \n";}// 創建對應type的著色器this.id = GLShader.createShader(this.gl, sourceCode, type)}/*** @param gl gl上下文* @param sourceCode shaderCode字符串* @param type shader的類型*/static createShader(gl, sourceCode, type) {// 創建對應type的shader句柄let shader = gl.createShader(type);// 綁定sourceCode和typegl.shaderSource(shader, sourceCode);// 編譯shadergl.compileShader(shader);// 檢查錯誤if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {// 獲取shader編譯信息let info = gl.getShaderInfoLog(shader);// 釋放shadergl.deleteShader(shader)// 拋出錯誤throw "Could not compile WebGL program. \n" + (type == gl.VERTEX_SHADER ? "vertex" : "fragment") + " shader error. \n" + info;}// 創建完成return shader;}delete() {// 釋放shaderthis.gl.deleteShader(this.id)}} </script>

著色器程序GLProgram

真正的“筆刷(Program)”,需要傳入vertex shader和fragment shader,才能成為一個program。

<!--用于創建:筆刷(著色器程序)GLProgram著色器程序--> <script type="text/javascript">class GLProgram extends GLObject {/*** @param vsCode vs元素id、vsCode字符串、元素對象(頂點著色器)* @param fsCode fs元素id、fsCode字符串、元素對象(片元著色器)*/constructor(vsCode, fsCode) {super()if (vsCode == undefined || fsCode == undefined) {// vsCode為空 或者 fsCode為空throw "vsCode is undefined or fsCode is undefined. \n";}// gl句柄let gl = this.gl// 創建vs和fslet vertexShader = new GLShader(vsCode, gl.VERTEX_SHADER)let fragmentShader = new GLShader(fsCode, gl.FRAGMENT_SHADER)// 創建shader programlet program = gl.createProgram()// 將vs、fs與program綁定gl.attachShader(program, vertexShader.id)gl.attachShader(program, fragmentShader.id)// 鏈接shader programgl.linkProgram(program)// 檢查錯誤if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {// 獲取program鏈接信息let info = gl.getProgramInfoLog(program)// 釋放programthis.delete()// 拋出錯誤throw 'WebGL program compile error. \n' + info}// 保存vs、fs、program的句柄this.vertexShader = vertexShaderthis.fragmentShader = fragmentShaderthis.id = program}/*** 使用program腳本*/use() {this.gl.useProgram(this.id)}/*** 刪除program腳本,釋放內存*/delete() {this.vertexShader.delete()this.fragmentShader.delete()this.gl.deleteProgram(this.id)}} </script>

著色器程序屬性GLAttribute、GLUniform

在use program后,program還可能需要顏料(attribute/uniform),為此包裝對應的attribute和uniform。

<!--GLAtributeGLUniform--> <script type="text/javascript">class GLAttribute extends GLObject {/*** @param program 著色器對象、著色器id* @param name 屬性名*/constructor(program, name) {super()if (program == undefined || name == undefined) {// program為空 或者 name為空throw "program is undefined or name is undefined. \n";} else if (program.constructor != GLProgram) {// program不是GLProgram類型的throw "typeof(" + program + ") != GLProgram. \n";}// program idprogram = program.id// gl句柄let gl = this.gl// 獲取program中name的idlet id = gl.getAttribLocation(program, name)if (id < 0) {// 在gl中, 獲取到的id不可能小于0 (小于0說明name錯誤)throw "attribute " + name + " id < 0. \n";}// 保存idthis.id = id}/*** 綁定Attribute*/bind() {this.gl.enableVertexAttribArray(this.id)}/*** 解綁定Attribute*/unbind() {this.gl.disableVertexAttribArray(this.id)}/*** 設置Attribute屬性*/vertexAttribPointer(size, type, normalized, stride, offset) {this.gl.vertexAttribPointer(this.id, size, type, normalized, stride, offset)}}class GLUniform extends GLObject {/*** @param program 著色器對象、著色器id* @param name 屬性名*/constructor(program, name) {super()if (program == undefined || name == undefined) {// program為空 或者 name為空throw "program is undefined or name is undefined \n";} else if (program.constructor != GLProgram) {// program不是GLProgram類型的throw "typeof(" + program + ") != GLProgram. \n";}// program idprogram = program.id// gl句柄let gl = this.gl// 獲取program中name的idlet id = gl.getUniformLocation(program, name)if (id < 0) {// 在gl中, 獲取到的id不可能小于0 (小于0說明name錯誤)throw "uniform " + name + " id < 0 \n";}// 保存idthis.id = id}uniform1f(v0) {this.gl.uniform1f(this.id, v0)}uniform1fv(value) {this.gl.uniform1fv(this.id, value)}uniform1i(v0) {this.gl.uniform1i(this.id, v0)}uniform1iv(value) {this.gl.uniform1iv(this.id, v0)}uniform2f(v0, v1) {this.gl.uniform2f(this.id, v0, v1)}uniform2fv(value) {this.gl.uniform2fv(this.id, value)}uniform2i(v0, v1) {this.gl.uniform2i(this.id, v0, v1)}uniform2iv(value) {this.gl.uniform2iv(this.id, value)}uniform3f(v0, v1, v2) {this.gl.uniform3f(this.id, v0, v1, v2)}uniform3fv(value) {this.gl.uniform3fv(this.id, value)}uniform3i(v0, v1, v2) {this.gl.uniform3i(this.id, v0, v1, v2)}uniform3iv(value) {this.gl.uniform3iv(this.id, value)}uniform4f(v0, v1, v2, v3) {this.gl.uniform4f(this.id, v0, v1, v2, v3)}uniform4fv(value) {this.gl.uniform4fv(this.id, value)}uniform4i(v0, v1, v2, v3) {this.gl.uniform4i(this.id, v0, v1, v2, v3)}uniform4iv(value) {this.gl.uniform4iv(this.id, value)}uniformMatrix2fv(location, transpose, value) {this.gl.uniformMatrix2fv(this.id, transpose, value)}uniformMatrix3fv(location, transpose, value) {this.gl.uniformMatrix2fv(this.id, transpose, value)}uniformMatrix4fv(location, transpose, value) {this.gl.uniformMatrix2fv(this.id, transpose, value)}} </script>

數據緩存GLBuffer

OpenGL在繪制時需要知道畫在**哪里(vertex/uv)**也就是buffer。

<!--GLBuffer--> <script type="text/javascript">class GLBuffer extends GLObject {/*** @param buffer 數據信息*/constructor(buffer) {super()if (buffer == undefined) {// buffer為空throw "buffer is undefined \n";}// gl句柄let gl = this.gl// vbolet vbo = gl.createBuffer()// 綁定vbogl.bindBuffer(gl.ARRAY_BUFFER, vbo)// vbo數據設置gl.bufferData(gl.ARRAY_BUFFER, buffer, gl.STATIC_DRAW)// 保存vbo idthis.id = vbo}/*** 綁定vbo*/bind() {this.gl.bindBuffer(this.gl.ARRAY_BUFFER, this.id)}/*** 釋放vbo*/delete() {this.gl.deleteBuffer(this.id)}} </script>

GLTexture和GLFrameBuffer

已經準備好筆刷、顏料、畫什么東西,最后還差畫在哪里(fbo)。當然我們還可以直接拿一張圖貼到fbo上,也就是直接拿一張**貼紙(texture)**畫在fbo上。

<!--GLTextureGLFramebuffer--> <script type="text/javascript">class GLTexture extends GLObject {/*** @param imageUrl 圖片*/constructor(imageUrl) {super()if (imageUrl == undefined) {// 路徑為空throw "imageUrl is undefined. \n";} else if (imageUrl.constructor == String) {// 路徑不為空if (imageUrl[0] == '#') {// 獲取srcimageUrl = $($(imageUrl)[0]).attr("src")}}// gl句柄let gl = this.gl// this句柄let that = this// 創建imagelet image = new Image()// 服務器不支持跨域訪問的話就會被攔截image.crossOrigin = "Anonymous"// image加載成功后的回調 (ps: 這里可能會出現加載的時序問題)image.onload = function() {// 創建texture idlet textureId = gl.createTexture()// 綁定texturegl.bindTexture(gl.TEXTURE_2D, textureId)// 設置texture屬性gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR)gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR)gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE)gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE)// 設置像素存儲模式gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, true)// 設置texture格式gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image)if (textureId <= 0) {// 創建成功的texture id必然大于0, 小于說明失敗, 因此釋放texturegl.deleteTexture(textureId)// 拋出錯誤throw "texture create error. \n";}// 保存idthat.id = textureId// 解綁定 (ps: 最好做, 為了保持一致, 這個原因是因為后面可能會有繪制也會用到gl.bindTexture(gl.TEXTURE_2D, textureId))gl.bindTexture(gl.TEXTURE_2D, null)}// image加載失敗后的回調image.onerror = function() {alert("get image error")}// 設置image的src, 設置后將加載image.src = imageUrl}/*** 綁定texture*/bind() {this.gl.bindTexture(this.gl.TEXTURE_2D, this.id)}/*** 釋放texture*/delete() {this.gl.deleteTexture(this.id)}}class GLFramebuffer extends GLObject {/*** 一般來說, FBO是framebuffer和texture綁定* @param texture 紋理*/constructor(texture) {// 創建fbolet framebuffer = gl.createFramebuffer()// 綁定fbogl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer)// 保存texture對象if (texture == undefined) {this.texture = undefined} else if (texture.constructor == GLTexture) {this.texture = texture} else if (texture.constructor == String) {this.texture = new GLTexture(texture)}// 將fbo和texture綁定if (texture != undefined) {gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this.texture.id, 0)}// 保存fbo idthis.id = framebuffer}/*** 綁定fbo*/bind() {this.gl.bindFramebuffer(this.FRAMEBUFFER, this.id)}/** * 釋放fbo*/delete() {this.texture.delete()this.deleteFramebuffer(this.id)}} </script>

html標簽

Canvas

畫布,WebGL需要先創建一個Canvas,通過Canvas拿到WebGLContext

<div style="display: flex;"><canvas id="glCanvas" width="680" height="640">你的瀏覽器似乎不支持或者禁用了HTML5 <code>&lt;canvas&gt;</code> 元素.</canvas> </div>

vertex shader

頂點著色器的代碼。

<!-- shader腳本 --> <script id="shader-vs" type="x-shader/x-vertex">attribute vec4 iPosition;attribute vec2 iTexcoord;uniform float iTime;varying highp vec2 vTexcoord;void main(void) {gl_Position = iPosition;vTexcoord = iTexcoord;} </script>

fragment shader

片段著色器的代碼。

<script id="shader-fs" type="x-shader/x-fragment">uniform sampler2D iChannel0;uniform highp float iTime;varying highp vec2 vTexcoord;void main(void) {gl_FragColor = texture2D(iChannel0, vTexcoord);} </script>

iChannels

紋理圖片。

<img id="iChannel0" src="images/src0.jpg" class="hidden"/> <img id="iChannel1" src="images/src1.jpg" class="hidden"/> <!-- ..................<img id="iChannel7" src="images/src7.jpg" class="hidden"/> -->

主程序ShaderToyGame

這只是一個調用以上封裝好GL接口的實例。

<script type="text/javascript">class ShaderToyGame {constructor() {let gl = GLContext.getWebGL()// 確認WebGL支持性if (!gl) {alert("無法初始化WebGL,你的瀏覽器、操作系統或硬件等可能不支持WebGL。")return}// 使用完全不透明的黑色清除所有圖像gl.clearColor(0.0, 1.0, 0.0, 1.0)// 用上面指定的顏色清除緩沖區gl.clear(gl.COLOR_BUFFER_BIT)// 設置視口gl.viewport(0, 0, GLContext.width, GLContext.height)}run(isRun) {if (this.isRun == isRun) {// 狀態一樣, 直接返回return;}// 是否運行, false會停止運行this.isRun = isRun;if (isRun) {// 開啟requestrequestAnimationFrame(renderGL)}}renderGL(now) {// gl上下文let gl = GLContext.getWebGL()// 使用programthis.program.use()// 綁定和輸入頂點數據this.verteBuffer.bind()this.vertexPosition.bind()this.vertexPosition.vertexAttribPointer(3, gl.FLOAT, false, 0, 0)// 綁定和輸入紋理數據this.texcoordBuffer.bind()this.texcoordPosition.bind()this.texcoordPosition.vertexAttribPointer(2, gl.FLOAT, false, 0, 0)// 輸入時間數據this.timeUniform.uniform1f(now * 0.001)// 輸入紋理數據for(let i = 0; i < this.maxSize; i++) {if(this.textures[i]) {gl.activeTexture(gl.TEXTURE0+i)this.textures[i].bind()this.iChannels[i].uniform1i(i)}}// 繪制gl.drawArrays(gl.TRIANGLE_STRIP, 0, 4)// 遞歸調用if(this.isRun)requestAnimationFrame(renderGL)}render() {let gl = GLContext.getWebGL()// 頂點坐標let vertices = [1.0, 1.0, 0.0, -1.0, 1.0, 0.0,1.0, -1.0, 0.0, -1.0, -1.0, 0.0]// 紋理坐標let texcoord = [1.0, 1.0,0.0, 1.0,1.0, 0.0,0.0, 0.0]// 頂點bufferthis.verteBuffer = new GLBuffer(new Float32Array(vertices))// 紋理bufferthis.texcoordBuffer = new GLBuffer(new Float32Array(texcoord))// 著色器programlet program = new GLProgram("#shader-vs", "#shader-fs")this.program = program// 頂點屬性let vertexPosition = new GLAttribute(program, "iPosition")// 紋理屬性let texcoordPosition = new GLAttribute(program, "iTexcoord")// 時間屬性let timeUniform = new GLUniform(program, "iTime")// 紋理數組let iChannels = []this.textures = []// texture最大數量this.maxSize = 8// 創建iChannels屬性數組和texture數組for(let i = 0; i < this.maxSize; i++) {let iChannel = new GLUniform(program, 'iChannel'+i)let texture = undefinedif(iChannel.id) { texture = new GLTexture('#iChannel'+i) }iChannels.push(iChannel)this.textures.push(texture)}// 開始渲染run(true);}destory() {this.isRun = falsethis.program.delete()this.verteBuffer.delete()this.texcoordBuffer.delete()for(let i = 0; i < this.maxSize; i++) {if(this.textures[i]) { this.textures[i].delete() }}}} </script>

主函數

<script type="text/javascript">// 主函數function main() {let stg = new ShaderToyGame()stg.render()}main() </script>

總結

以上是生活随笔為你收集整理的JavaScript OpenGL接口再设计的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久成人国产精品入口 | 亚洲综合激情网 | 国产在线免费 | 久热av在线 | 国产成人久久av | 区一区二在线 | 麻豆影视在线播放 | 亚洲成人网在线 | 国产高清99| 久久久国产精品一区二区中文 | 欧美一级片免费观看 | 日本久久不卡视频 | 99在线视频精品 | 国产精品系列在线观看 | 国产麻豆剧果冻传媒视频播放量 | 亚洲精品国产麻豆 | 欧美精品国产综合久久 | 成人a大片 | 久久er99热精品一区二区 | 久热这里有精品 | 五月开心色 | 国产亚洲精品久久网站 | 国产精品久久久久影院日本 | 精品九九久久 | 国产婷婷精品 | 在线黄av| www.五月天激情 | 中国精品少妇 | 五月天丁香亚洲 | 色婷婷激情五月 | 99久久精品免费看国产一区二区三区 | 天天射天天干天天操 | 手机av资源 | 国产无区一区二区三麻豆 | 激情综合一区 | 欧美日韩观看 | 欧美色图亚洲图片 | 中文字幕欧美日韩va免费视频 | 久久久91精品国产一区二区三区 | 中中文字幕av在线 | 在线观看完整版 | 在线看国产视频 | 中文国产字幕在线观看 | 精品免费一区二区三区 | 国产国语在线 | 成人免费一级 | 亚洲精品国精品久久99热一 | 丁香婷五月 | 天天弄天天操 | 欧美精品做受xxx性少妇 | 欧美日韩伦理一区 | 色综合夜色一区 | 久草网在线视频 | 久久精品超碰 | 日韩美av在线 | 免费网站看v片在线a | 97超在线视频 | 国产99久久九九精品 | 99这里精品 | 中文字幕免费一区 | 国产一区免费观看 | 国产精品久久久久免费观看 | 久久精品爱视频 | 久草资源在线观看 | 全黄网站| 久久综合色天天久久综合图片 | 欧美日韩裸体免费视频 | 啪啪免费视频网站 | 99精品久久只有精品 | 丁香六月天婷婷 | 日韩在线视频一区 | 国产国产人免费人成免费视频 | av高清一区 | 一区二区免费不卡在线 | 欧美精品一区在线 | 青草草在线视频 | 亚洲精品久久久久www | 天无日天天操天天干 | 婷婷精品视频 | 91精品久久久久久久久 | www国产亚洲精品久久麻豆 | 久草视频网| 欧美综合久久 | 97视频在线 | 最新av免费在线 | 亚洲综合在线一区二区三区 | 亚洲片在线资源 | 国产高清久久久 | 97成人资源| 精品免费久久久久 | 在线亚洲精品 | 国产精品久久久久久久久久久久久久 | 狠狠狠色丁香婷婷综合久久88 | 91亚洲精品久久久 | av大片免费| 麻豆视频国产在线观看 | 91大神精品视频 | 玖玖精品在线 | 97电院网手机版 | 日三级在线 | 色综合久久久久综合体桃花网 | 久久精品日产第一区二区三区乱码 | 中文字幕在线日亚洲9 | 69精品久久 | 久久久久久久久久久网 | 中文在线免费一区三区 | 日日夜夜网 | 亚洲精品在线一区二区 | 在线国产日韩 | 成 人 免费 黄 色 视频 | 欧美a级一区二区 | 中文字幕在线精品 | 国产精品久久久久久久7电影 | 免费网站在线观看成人 | 久久免费美女视频 | 久久大片| 国产精品成人免费 | 特级aaa毛片 | 国产91免费在线观看 | 精品国产乱码久久久久久1区二区 | 国产精品第10页 | 久久久视屏 | 99热这里是精品 | 五月天婷亚洲天综合网鲁鲁鲁 | 麻豆国产露脸在线观看 | 91视频 - 114av| 国产一区二区久久久久 | 国产一级黄色av | 国产一级久久 | 精品国产1区 | 91视频-88av | 久久免费视频在线观看 | 一区二区三区在线免费观看 | 久久精品三级 | 国产亚洲久一区二区 | 亚洲午夜久久久久 | 午夜视频不卡 | 精品麻豆入口免费 | 久久久久成人精品 | 午夜少妇一区二区三区 | 欧美不卡在线 | 人成在线免费视频 | 嫩草av影院 | 国产精品一区二区三区在线 | 久久精品最新 | 久久久久久久久艹 | 激情av网址| 久久久久久久影视 | 999成人国产 | 不卡的av中文字幕 | www国产亚洲精品久久麻豆 | 国产黄色片久久久 | 免费午夜网站 | 亚洲黄色免费网站 | 国产精品热 | 天天人人综合 | 亚洲午夜精品在线观看 | 午夜久久影视 | 九九九热精品免费视频观看 | 91插插影库| 热99久久精品 | free. 性欧美.com | 永久免费毛片 | 国产精品久久久久三级 | 国产成人在线综合 | 一区二区三区四区在线 | 欧美激情视频一区二区三区免费 | 夜夜操网 | 国产精品久久久久久久久蜜臀 | 激情久久久久久久久久久久久久久久 | 久草视频国产 | 日韩大片在线 | 不卡国产视频 | 一级特黄aaa大片在线观看 | 国产精品一区免费看8c0m | 精品三级av | 亚洲首页 | 国产精品久久久久久久久搜平片 | 欧美一区二区三区激情视频 | 国产韩国精品一区二区三区 | 亚洲欧洲日韩 | 免费69视频 | 成人网页在线免费观看 | 亚洲精品乱码久久久久久 | 色婷婷综合成人av | 开心丁香婷婷深爱五月 | 欧美极品在线播放 | 91精品一区国产高清在线gif | 丁香在线观看完整电影视频 | 中文字幕乱偷在线 | 黄色成人毛片 | 国产视频 亚洲视频 | 99热手机在线| 久久有精品 | 最近免费中文字幕大全高清10 | 韩国av电影网 | 国产午夜剧场 | 91精品国产电影 | 99色网站 | 欧美成人精品三级在线观看播放 | 国产一区二区在线播放 | 日韩欧美一区二区三区在线观看 | 国产主播大尺度精品福利免费 | 操综合 | 色综合色综合色综合 | 成人免费观看完整版电影 | 一本一本久久a久久精品综合妖精 | 人人擦| 日韩手机在线观看 | 久久色在线观看 | 久草在线免费看视频 | 91精品欧美一区二区三区 | 国产一区二区久久 | 精品极品在线 | 久久香蕉国产精品麻豆粉嫩av | 亚洲欧洲xxxx | 国产又黄又猛又粗 | 免费网址你懂的 | 99自拍视频在线观看 | 操操操综合 | 中文字幕在线看 | 久操视频在线观看 | 欧美污网站 | 午夜精品久久 | 99久久99久久 | 亚洲精品国产拍在线 | 午夜10000 | 91丨九色丨高潮 | 欧美一级片在线观看视频 | 伊人小视频 | 亚洲电影院| 精品国产欧美一区二区 | 黄色亚洲| 亚洲午夜大片 | 国产 欧美 日韩 | 日韩在线 | av福利电影 | 日韩理论 | 国产综合精品一区二区三区 | 天天干,夜夜爽 | 在线精品视频免费播放 | 超碰在97| 五月婷婷中文网 | 美女国产免费 | 国产精品18久久久久久久久 | 成人免费 在线播放 | 久久精品99国产国产 | 久久人人爽人人人人片 | 久久 国产一区 | 国产理论片在线观看 | 欧美在线a视频 | 久草网站在线观看 | 久久久久国产精品午夜一区 | 黄色午夜网站 | 九9热这里真品2 | 久久人人爽人人人人片 | 国产一卡二卡四卡国 | 久久99久| 久久99精品国产一区二区三区 | 亚洲精品激情 | 日日日日日 | 日韩精品黄 | 天天干天天操天天操 | 亚洲国产成人在线 | 99精品免费久久久久久久久 | 美女网站色免费 | 91av官网 | av女优中文字幕在线观看 | 人人插人人射 | 国产成人av综合色 | 91传媒视频在线观看 | 在线免费视 | 日日夜夜亚洲 | 激情网第四色 | 欧美日韩国内在线 | 97超碰人人| 特级毛片aaa | 国产无套精品久久久久久 | 亚洲日本va在线观看 | www黄色com| 超碰免费在线公开 | 国产亚洲日 | 午夜av片| 一区二区三区日韩精品 | 久草精品视频在线观看 | 国产无套精品久久久久久 | 国产日韩欧美视频在线观看 | 波多野结衣在线观看一区 | 中文字幕不卡在线88 | 成人午夜精品福利免费 | 久久草| 黄色一级动作片 | 久久久久久久久网站 | 天天操夜夜爱 | 天天操综 | 少妇性aaaaaaaaa视频 | 成人黄色在线 | 在线观看 国产 | 日本精品中文字幕 | 日韩在线视频网站 | 狠狠干夜夜爽 | 成人a视频在线观看 | 日本精品视频在线播放 | 日韩精品免费在线视频 | 视频二区| 国产97免费 | 五月天中文在线 | 国产精品乱码一区二区视频 | 婷五月天激情 | 国产精品视频免费观看 | 伊人色综合久久天天 | 中文字幕最新精品 | 欧美色综合天天久久综合精品 | 久国产在线播放 | 日韩高清无线码2023 | 国产亚洲精品bv在线观看 | 97电影网站| 91精品在线视频 | 日日色综合 | 日韩av网站在线播放 | www日韩精品| 99免在线观看免费视频高清 | 亚州国产精品久久久 | 成人黄色大片在线观看 | 中文字幕乱码一区二区 | 欧美人人 | 亚洲黄色av网址 | 国产精品成人aaaaa网站 | 韩国一区二区三区在线观看 | 国产黄色看片 | 一区二区三区电影在线播 | 91精品国自产在线 | 亚洲成年人免费网站 | 91中文在线视频 | 东方av在| 天天操夜操 | 久久综合久久综合久久综合 | 久久久久国产一区二区 | 亚洲第一中文网 | 久久久这里有精品 | 毛片视频电影 | 欧美成人精品欧美一级乱黄 | 三级视频片 | 成片视频免费观看 | 国产香蕉久久 | 日精品在线观看 | 国产一区二区在线免费观看 | 国产精品久久伊人 | 美女视频黄,久久 | 91午夜精品| 99精品免费久久久久久久久 | 天天干人人干 | 国产很黄很色的视频 | 韩国av永久免费 | 2023亚洲精品国偷拍自产在线 | 免费久久视频 | 亚洲成人免费在线 | 久久最新视频 | 欧美日韩国产一区二区三区 | 激情久久综合网 | 日韩电影在线看 | 精品免费久久久久 | 久久婷婷国产 | 久久久久久久久久影院 | 久久精品人人做人人综合老师 | av中文字幕av| 国产精品国产自产拍高清av | 精品国产一区二区三区av性色 | 国产日韩欧美在线一区 | 国产成人免费av电影 | 日韩高清三区 | 久久精品中文视频 | 这里有精品在线视频 | 久久久久中文 | 久久精品国产免费看久久精品 | 91精品国产高清自在线观看 | 精品国产一区二区三区男人吃奶 | 久久久久久久国产精品 | 久久99久久99精品免观看软件 | 亚洲精品男人的天堂 | 69视频网站 | 免费在线观看中文字幕 | 色网站在线观看 | av中文字幕在线观看网站 | 操综合 | 日本精品视频在线播放 | 精品电影一区 | 9在线观看免费 | 超碰公开在线 | 成人va视频 | 日日爽| 欧美资源| 亚洲一区欧美激情 | 天天操天天摸天天干 | 在线日韩中文字幕 | 4438全国亚洲精品观看视频 | 九九热国产| 国产1区2区3区精品美女 | 国产精品久久久久久久久毛片 | 91插插影库 | 久久黄色美女 | 免费看一级一片 | 国产一区二区三区午夜 | 在线观看视频在线观看 | 亚洲最新视频在线 | 欧美综合在线视频 | 亚洲专区路线二 | 91九色最新地址 | 91一区啪爱嗯打偷拍欧美 | 久久激情小说 | 日韩欧美一区视频 | 人操人| 亚洲精品一区二区三区高潮 | 日一日干一干 | 欧美日韩精品在线免费观看 | 丝袜美女视频网站 | 国产日韩欧美网站 | 99精品视频免费观看视频 | 日韩欧美在线不卡 | 久久成人黄色 | 国产精品白虎 | 久久久久电影 | 在线观看视频国产一区 | 欧美大jb| 日韩午夜在线播放 | 天天干天天操天天做 | 国产日本高清 | 日本黄色免费电影网站 | 日韩av一卡二卡三卡 | 久久视频国产 | 国产偷v国产偷∨精品视频 在线草 | 久久精品艹 | 人人超碰人人 | 亚洲精品高清一区二区三区四区 | 狠狠久久综合 | 久久99中文字幕 | 久草在线免费在线观看 | 欧美在线观看小视频 | 日韩毛片在线播放 | 久久久免费国产 | 五月天伊人网 | 成人黄色在线播放 | 亚洲国产精品500在线观看 | 人人看人人 | 欧美高清成人 | av在线免费播放 | 天天综合网天天综合色 | 久久国产精品99久久久久久老狼 | 99精品国产免费久久久久久下载 | 日韩激情在线视频 | 蜜臀精品久久久久久蜜臀 | 91精品久久久久 | 91九色在线视频 | 欧美污污网站 | 国产精品高潮久久av | 黄色免费网站 | 亚洲高清久久久 | 国产一级做a爱片久久毛片a | 日韩国产精品久久久久久亚洲 | 成人在线观看免费视频 | 国产精品久久久毛片 | 国产1区2| 夜夜操夜夜干 | 免费a视频 | 开心激情综合网 | 中文字幕国内精品 | 久草在线一免费新视频 | 中文字幕免费国产精品 | 成年人免费在线 | 国产v在线观看 | 91黄色免费看| 久热色超碰 | 亚洲国产精品视频在线观看 | 人人狠狠综合久久亚洲婷 | 久久,天天综合 | 久久91久久久久麻豆精品 | 亚洲小视频在线 | 天堂入口网站 | 欧美在线观看禁18 | www.亚洲精品在线 | 久久成人综合视频 | 国产原创在线 | 热久久国产精品 | 国产视频1区2区3区 久久夜视频 | 欧美一级久久久久 | 婷婷色吧 | 欧美性生活免费 | 成人免费观看视频网站 | 免费在线观看亚洲视频 | 91桃色在线播放 | 日韩精品免费在线视频 | 久热这里有精品 | 狠狠操狠狠插 | 国产精品美女久久久久久久 | 国产va饥渴难耐女保洁员在线观看 | 色偷偷网站视频 | www.色五月 | 欧美孕妇与黑人孕交 | a电影免费看 | 天天插天天干天天操 | 99免费在线观看视频 | 夜夜摸夜夜爽 | 一级成人免费视频 | 粉嫩一区二区三区粉嫩91 | 96国产精品 | 成人av免费网站 | 国产在线一卡 | 久久久久久久国产精品 | 欧美成人a在线 | 国产亚洲精品久久久久久网站 | 热99久久精品 | 欧美最新大片在线看 | 在线播放国产精品 | 中文字幕在线观看av | 久久久久久国产一区二区三区 | 日日夜夜精品免费观看 | 狠狠干婷婷色 | 国产麻豆视频在线观看 | 欧美三级高清 | 一级黄色大片在线观看 | 999久久a精品合区久久久 | 久久人人爽爽人人爽人人片av | 91精品久久久久久久久久久久久 | 免费看国产曰批40分钟 | 日韩av三区 | 中文在线字幕免费观 | 亚洲aⅴ免费在线观看 | 在线看黄色的网站 | 久久好看免费视频 | 三级黄色大片在线观看 | 中文字幕精品在线 | 亚洲美女视频在线 | 日韩精品在线观看视频 | av免费看看| 亚洲色图27p | 男女激情片在线观看 | 99久久精品国产亚洲 | 在线观看黄污 | 在线播放 日韩专区 | 日韩va在线观看 | 久草视频免费看 | 婷婷激情五月 | 欧美黄在线 | 黄色毛片观看 | 久久99这里只有精品 | 成年人视频在线观看免费 | 久久久免费毛片 | 国产手机在线观看 | 亚洲成av人电影 | 国产精品毛片久久 | 久久天| 草久在线| 一区二区三区在线观看 | 一级黄色片在线播放 | 成人黄色小视频 | 热九九精品| 成年人精品 | www色综合| 麻豆免费视频网站 | 日韩欧美一区二区在线观看 | 日韩在线中文字幕 | 亚洲精品88欧美一区二区 | 亚洲天堂网在线观看视频 | 免费91麻豆精品国产自产在线观看 | 超碰日韩在线 | 日韩欧美精品在线观看 | 黄免费在线观看 | 97人人网| 色wwww| 香蕉国产91 | 国产精品a成v人在线播放 | 日韩最新理论电影 | 成人片在线播放 | 国产精品一区二区在线 | 天天爽夜夜爽精品视频婷婷 | 日韩高清无线码2023 | 三三级黄色片之日韩 | 国产免费又粗又猛又爽 | 国产精品久久久一区二区 | 91久久久久久国产精品 | 欧美一级裸体视频 | 又爽又黄又无遮挡网站动态图 | 欧美一区二区在线刺激视频 | 亚洲伦理电影在线 | 人人干人人草 | 亚洲精品乱码久久久一二三 | 国产精品久久久久婷婷 | 亚州国产视频 | 久久精品日本啪啪涩涩 | 男女拍拍免费视频 | 国产精品美女久久久久久 | 成人av资源网站 | www.狠狠操 | 91片在线观看 | 男女激情片在线观看 | 国产片免费在线观看视频 | 国产精品久久久久久久免费观看 | 国产精品自产拍在线观看网站 | avv天堂| 不卡的av在线播放 | 91亚洲精品久久久蜜桃网站 | 国产va在线 | 亚洲va天堂va欧美ⅴa在线 | 91麻豆文化传媒在线观看 | 99视频这里有精品 | a级国产乱理论片在线观看 特级毛片在线观看 | 欧美另类交在线观看 | 黄色一级免费 | 国产视频2 | 一级一片免费观看 | 五月天色网站 | 免费看的黄色片 | 日韩免费在线视频观看 | 亚洲日日夜夜 | 亚洲精品视频在线观看免费视频 | 91精品久久久久久久99蜜桃 | 亚洲精品乱码久久久久久写真 | 亚洲小视频在线观看 | 亚洲更新最快 | 国产高清在线看 | 久久精品国产一区二区三区 | 国产精品免费在线播放 | 日韩中文字幕免费 | 国产中文字幕在线视频 | 一级特黄av | 欧美视频日韩视频 | 91精品视频播放 | 成人黄色av网站 | 久久久久久国产精品 | 久久女同性恋中文字幕 | 午夜精品久久久久久久久久 | 黄色三级免费 | 国产综合久久 | av五月婷婷| 国产第一页精品 | 国产超碰97 | 美女视频免费精品 | 香蕉视频在线网站 | 九九在线视频免费观看 | 久久不射电影院 | 狠狠的操你 | 成人免费91| 青草视频在线播放 | 欧美日韩国产精品一区二区三区 | 久久精品这里都是精品 | 特级黄色视频毛片 | 精品久久久国产 | 国产香蕉视频 | 欧美中文字幕第一页 | 午夜久久精品 | 久久男人中文字幕资源站 | 久久久污| av观看久久久 | 亚洲久草在线 | 婷婷av电影 | 久久久www成人免费毛片 | 国产视频精品久久 | 最近日韩中文字幕中文 | 久久久久久久久久久综合 | 亚洲欧美偷拍另类 | 欧美日韩高清国产 | 亚洲三级黄色 | 欧洲精品久久久久毛片完整版 | 天天色天天操综合 | 青青久视频| 成人一级片在线观看 | 国产精品一区二区三区久久 | 日韩av免费在线看 | 欧美一级片播放 | 久精品视频在线观看 | 福利一区二区 | 亚洲视频高清 | 亚洲精品日韩一区二区电影 | 狠狠色丁香婷婷综合久小说久 | 精品国产乱码 | 天天操天天是 | 麻豆高清免费国产一区 | 91视频在线免费看 | 精品国精品自拍自在线 | 欧洲亚洲女同hd | 久久综合狠狠综合久久狠狠色综合 | 五月天最新网址 | av三区在线 | 国产精品久久久久久久久久不蜜月 | 日韩电影在线视频 | 国产美女免费看 | 日韩一区二区三免费高清在线观看 | 婷婷av网站 | 成人av网站在线 | 成人小视频在线免费观看 | 有没有在线观看av | 日韩字幕在线观看 | www.夜夜爱| 午夜在线国产 | 国产亚洲成人网 | 狠狠色噜噜狠狠狠狠2021天天 | 国产黄色精品在线 | 久久欧美精品 | 久久99久久99精品免观看粉嫩 | 在线观看一级视频 | 国产精品综合久久久久久 | 99久久精品久久久久久动态片 | 91色网址 | 国产玖玖在线 | 日本免费久久高清视频 | 在线观看的a站 | 韩国av免费观看 | 久久99精品国产一区二区三区 | 在线黄色国产电影 | 91亚洲网站| 免费成人在线观看 | 国产伦理精品一区二区 | 狠狠色免费 | 亚洲自拍自偷 | 国产裸体永久免费视频网站 | 色婷婷亚洲婷婷 | 国产精品欧美日韩 | 久久激情婷婷 | 在线你懂 | 久草在线在线精品观看 | 国产黄色资源 | av中文字幕在线观看网站 | 国产精品免费成人 | 国产福利免费在线观看 | av高清一区二区三区 | 国产中年夫妇高潮精品视频 | 久久久96 | 免费成人av电影 | 国产综合香蕉五月婷在线 | 天天操天天摸天天爽 | 欧美一级久久久 | 91三级在线观看 | 91视频免费看片 | 久久激五月天综合精品 | 99久e精品热线免费 99国产精品久久久久久久久久 | 婷婷午夜天 | 天天天操操操 | av电影中文| 国产一区二区影院 | 久久一级片 | 一区二区 久久 | 中文字幕在线免费看 | 91成人精品视频 | 天天干天天色2020 | 日韩毛片久久久 | 成人av一区二区三区 | 久精品视频免费观看2 | 国产精品毛片一区视频播 | 亚洲综合网站在线观看 | av网站免费线看精品 | 国产色婷婷在线 | 国产一区二区三区免费观看视频 | 欧美在线视频不卡 | 亚洲国产电影在线观看 | 国外成人在线视频网站 | 精品久久精品久久 | 黄www在线观看 | 久久免费的精品国产v∧ | 国产一级免费电影 | 国内久久久久久 | 亚洲天天干 | 亚洲第一区精品 | 国产高清视频免费在线观看 | 国产亚洲在线视频 | 久久国产一区 | 亚洲丁香久久久 | 欧美在线aa| 黄污网| 亚洲色图27p| 日韩a级黄色 | 免费色视频网址 | 天天操天天摸天天干 | 丁香导航 | 99re久久资源最新地址 | 日韩大片在线观看 | 蜜臀aⅴ国产精品久久久国产 | 中文字幕影视 | 丝袜精品视频 | 欧美成a人片在线观看久 | 在线观看911视频 | 国产美女视频免费观看的网站 | 久久免费精品视频 | 久久午夜免费视频 | 热久精品| 免费成人在线电影 | 精品色综合 | 婷婷六月天丁香 | 91精品91| 国产一在线精品一区在线观看 | 色中文字幕在线观看 | 国产精品一级在线 | 99国产精品久久久久久久久久 | 国产区精品在线 | 免费视频一二三区 | 精品国产一区二区三区四 | 国产精品亚洲综合久久 | 精品国产精品久久一区免费式 | 亚洲区另类春色综合小说 | 亚洲免费公开视频 | 国产不卡在线看 | 日韩视频图片 | 色综合小说| 色综合中文综合网 | 91在线永久 | 97精品超碰一区二区三区 | 五月天婷亚洲天综合网鲁鲁鲁 | www日韩在线观看 | 蜜桃av观看 | 黄a在线| 在线免费观看的av网站 | 久久99久久99精品 | 国产r级在线观看 | 日韩av中文字幕在线免费观看 | 精品亚洲一区二区 | 国产中文字幕久久 | 国产亚洲精品成人av久久ww | 丰满少妇在线观看 | 日韩欧美有码在线 | 亚洲区精品视频 | 国产黄影院色大全免费 | 色偷偷中文字幕 | 日韩电影在线一区 | 99久久精品久久久久久清纯 | 91精品一区二区三区蜜臀 | 99在线观看精品 | 日本丰满少妇免费一区 | 国产精品一区二区视频 | 香蕉影视app | 水蜜桃亚洲一二三四在线 | 日韩理论片在线观看 | 国产在线观看91 | 久久久久久久久久久免费av | 欧美日韩综合在线观看 | 99免费观看视频 | www四虎影院| 波多野结衣一区三区 | 五月天综合网站 | 五月婷婷欧美视频 | 天天色天天干天天色 | 91麻豆精品国产91久久久无需广告 | 国产成人精品不卡 | 日韩午夜剧场 | 在线电影 一区 | 综合久久久久久久久 | 精品国产一区二区三区噜噜噜 | 中文字幕一区二区三区在线观看 | 成人三级黄色 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 在线 欧美 日韩 | 国产日韩视频在线观看 | 黄色三级在线观看 | 亚洲日本一区二区在线 | 久久久99久久 | 国产午夜三级一二三区 | 免费中文字幕在线观看 | 高清久久久久久 | 亚洲欧美怡红院 | 成年人视频在线免费观看 | 天天色播 | 国产一区二区三区在线免费观看 | 欧美久久久久久久久中文字幕 | 97在线免费观看视频 | 欧美日韩中文国产一区发布 | 性色视频在线 | 91在线视频观看 | 国产免费高清视频 | 激情图片区 | 碰超在线97人人 | 天天干天天做 | 欧美一区二区三区免费观看 | 免费网站黄| 国产亚洲精品久久久久久久久久久久 | 日韩美av在线 | 久热免费在线观看 | 婷婷伊人网 | 一区二区三区福利 | 色综合天天综合网国产成人网 | av网站在线观看免费 | 91.精品高清在线观看 | а天堂中文最新一区二区三区 | 亚洲春色综合另类校园电影 | 黄色大片免费网站 | 91福利国产在线观看 | 在线观看免费成人av | 中文字幕第一页在线视频 | 一色屋精品视频在线观看 | 久久久久这里只有精品 | 欧美少妇18p | 人成免费网站 | 999视频网站| 亚洲天堂在线观看完整版 | 久久久高清一区二区三区 | 黄色aaaaa| 五月婷婷综合在线观看 | 麻豆一区在线观看 | 999久久久免费视频 午夜国产在线观看 | 色婷婷激情四射 | 国内久久精品视频 | 亚洲japanese制服美女 | 91精品国产欧美一区二区 | 999久久国产 | 在线观看岛国片 | 在线免费观看欧美日韩 | 精品日韩在线一区 | 丁香花在线视频观看免费 | 在线播放91 | 天天干,天天操,天天射 | 日本在线精品视频 | 色婷五月天 | 免费男女羞羞的视频网站中文字幕 | 精品久久久久国产免费第一页 | 91人人爽人人爽人人精88v | 欧美色图30p | 狠狠色伊人亚洲综合成人 | 色网站在线免费观看 | 国产91在线 | 美洲 | 久久精品欧美一区二区三区麻豆 | 日韩一区二区三区在线观看 | 午夜私人影院久久久久 | 麻豆国产电影 | 欧美性生活免费看 | 国产99免费视频 | 中文字幕观看在线 | 成人毛片一区二区三区 | 成人av电影在线 | 综合网婷婷| 国产免费片 | 98超碰在线 | 国产免费xvideos视频入口 | 欧美日韩在线观看一区 | 九九日九九操 | 国产福利精品视频 | 国产精品成人一区二区三区吃奶 | 亚洲最新av在线网址 | 免费网站黄 | 国产一卡二卡四卡国 | 亚洲欧美在线观看视频 | 免费在线色视频 | 精品久久一区 | 久久人人爽人人爽 | 精品一区二区三区在线播放 | 免费在线黄网 | 中文字幕亚洲在线观看 | 婷婷综合成人 | 在线观看国产一区 | 国产欧美日韩视频 | 亚洲国产福利视频 | 欧美精品久久久久久久久久久 | 日本少妇视频 | 日日干网 | 成人黄色在线观看视频 | 丁香婷婷社区 | 99九九热只有国产精品 | 国模一二三区 | 天天色成人 | 国产高清在线 | 久久不见久久见免费影院 | 天天操天天色天天射 | 日韩精品电影在线播放 | 久人人 | 日韩av在线看 | 一 级 黄 色 片免费看的 | 国产精品美女久久久久久久 | 成人国产精品一区二区 | 国产亚洲精品久久 | 九九精品毛片 | 亚州精品国产 | 99久久超碰中文字幕伊人 | 日韩精品一区二区三区中文字幕 | 久久全国免费视频 | 国产在线观看,日本 | 国产精品久久久久久一区二区 | 超碰97免费在线 | 日日夜夜天天久久 | 日本精品久久久一区二区三区 | 97香蕉视频 | 一区二区视频在线观看免费 | 操操日日| 99在线视频精品 | 久久久黄色免费网站 | 国产成人综合在线观看 | 久久新 | 国产日产精品一区二区三区四区的观看方式 | 国产精品99久久久久 | 国产精品对白一区二区三区 | 麻豆视频免费入口 | 精品国产免费久久 | 日韩精品一区电影 | 精品国产一二三 | 日韩a免费 | 黄污视频网站 | 国产成人黄色av | 国产偷国产偷亚洲清高 | 国产精选在线 | 91精品国产网站 | av激情五月 | av色影院| 天天干天天操天天拍 |