亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JS實現移動端在線簽協議功能

2024-05-06 16:54:28
字體:
來源:轉載
供稿:網友

在一個風和日麗的下午,剛準備下班,突然接到需求說要做一個在線簽協議功能,當時心里想著不就百度一頓拷貝就完事了嗎(因為我沒用過canvas,所謂初生牛犢不怕虎 ),誰知做起來如此吃力,下面就來記錄下歷程。

協議模板

JS,移動端,在線簽協議 

分析

如上圖,需要做的就是做一個簽字板可以在上面寫字,寫完后點擊完成可以生成如上圖的圖片所示,把簽好的字放到指定的位置。

做這個第一反應肯定就是使用canvas繪制路徑

我的思路是:

一個字一個字寫,每寫一個字點一下記錄,最后拼接,但想到用戶體驗問題就pass了這個思路。

最后的思路:一行可以寫很多個字,可以讓用戶滑動canvas,一直寫下去(因為協議模板最后還要抄寫一段話)

canvas繪制路徑--實現簽名功能

JS,移動端,在線簽協議

<canvas id="canvas" style="top:0">您的手機不支持在線簽署</canvas>const canvasPaint = {};//定義一個全局對象,把canvas的各種狀態存進去canvasPaint.canvas = document.getElementById("canvas");canvasPaint.ctx = document.getElementById("canvas").getContext("2d");canvasPaint.ctx.lineCap = 'round';//讓結束線帽呈現圓滑狀canvasPaint.ctx.lineJoin = 'round';//交匯時呈現圓滑狀canvasPaint.ctx.strokeWidth = 5;//描邊寬度canvasPaint.ctx.lineWidth = 5;//線條寬度

初始化好畫布后,我們需要監聽畫布上的滑動事件

canvasPaint.canvas.addEventListener('touchstart', startEventHandler, {passive: false});function startEventHandler(event) { event.preventDefault(); canvasPaint.ctx.beginPath();//每次都是一個新路徑,不寫會和上個字的最后一筆連起來 canvasPaint.canvas.addEventListener('touchmove', moveEventHandler, {passive: false}); canvasPaint.canvas.addEventListener('touchend', endEventHandler, {passive: false});}

passive: false 和 event.preventDefault() 這兩個是絕配哦, event.preventDefault() 阻止默認行為,防止在畫布上寫字時觸發了瀏覽器自帶的下拉動作之類的。那 passive: false 是谷歌56版本后提出的新屬性,設置為 false 就是告訴瀏覽器我有阻止默認行為的代碼,剛開始不要給我滑動,你需要執行我的 event.preventDefault() 這句代碼,如果設置為了 true ,瀏覽器會自動忽略這句代碼,從而不能阻止成功,默認是 true ,所以這里就是坑之一了。

我們繼續編寫移動劃線邏輯

function moveEventHandler(event) { event.preventDefault(); var coverPos = canvasPaint.canvas.getBoundingClientRect(); canvasPaint.mouseX = event.clientX - coverPos.left; canvasPaint.mouseY = event.clientY - coverPos.top; if (canvasPaint.canPaint) {//后續為拖動畫布功能設置的狀態 canvasPaint.ctx.lineTo(//使用lineTo將移動過的坐標繪制成線 canvasPaint.mouseX, canvasPaint.mouseY ); canvasPaint.ctx.stroke();//繪制 }}function endEventHandler(event) { event.preventDefault(); //抬起手指時取消move和end事件的監聽 canvasPaint.canvas.removeEventListener('touchmove', moveEventHandler, false); canvasPaint.canvas.removeEventListener('touchend', endEventHandler, false);}

canvas--清除屏幕功能

這個功能比較簡單就一句話

function clearCanvas() { canvasPaint.ctx.clearRect(0, 0, canvasPaint.canvas.width, canvasPaint.canvas.height);}

提交簽名功能

首先需要將畫布上的文字轉換為img對象,然后使用drawImage繪制到協議上去

preLoadImg(['/assets/index/images/agree.jpg', canvasPaint.canvas.toDataURL()], result);//agree.jpg為協議名,canvasPaint.canvas.toDataURL()就是簽好的字轉換為base64的結果function preLoadImg(source, callBack, args) { var pr = []; source.forEach(url => { var p = loadImage(url) .then(function (img) { return img; }) .catch(function (err) { console.log(err); }); pr.push(p); }); Promise.all(pr) .then(function (imgArray) { callBack(imgArray, args); });}function loadImage(url) { return new Promise((resolve, reject) => { var img = new Image(); img.onload = function () { resolve(img); }; img.onerror = reject; img.src = url; });}

由于img賦值src是異步的,我們必須要一個完整的image對象,所以我們使用promise包裝,使得我們所有圖片都轉換完之后再將結果傳入回調函數(result)中

 

function result(imgArr) { drawName(imgArr);}function drawName(imgArr) { //繪制名字和底部的名字和日期 canvasPaint.canvas2 = document.getElementById('canvas2'); canvasPaint.context2 = canvasPaint.canvas2.getContext('2d'); canvasPaint.ratio = canvasPaint.canvas.height / canvasPaint.canvas.width; //計算畫布比例 canvasPaint.context2.drawImage(imgArr[0], 0, 0, 500, 707);//img0是底圖原協議 canvasPaint.context2.save(); canvasPaint.context2.translate(50, 190); canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[1], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); canvasPaint.context2.save(); canvasPaint.context2.translate(67, 723);//下方的字 canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[1], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); canvasPaint.context2.save(); canvasPaint.context2.translate(400, 625);//下方的字 canvasPaint.context2.font = "11px 微軟雅黑"; canvasPaint.context2.fillStyle = "#000"; canvasPaint.context2.textAlign = "center"; canvasPaint.context2.textBaseline = "middle"; var time = new Date().toLocaleString().split(' ')[0]; canvasPaint.context2.fillText(time, 0, 0); canvasPaint.context2.restore(); prevDrawStatement();}

這里最主要的還是要理解下畫布的rotate和translate方法,就可以把文字旋轉任意角度和放到任意位置了

長字手寫--畫布拖動

JS,移動端,在線簽協議 

上面簽字完成后,我們其實已經用了另一個canvas合成了文字和原協議,現在我們要做無限拖動功能,其實也很簡單。

在此之前我們需要清空之前的畫布

function prevDrawStatement() { clearCanvas();//清除畫布 canvasPaint.finish.innerHTML = "提交抄寫"; canvasPaint.pencilBtn.style.display = 'block'; canvasPaint.secondState.style.display = 'block'; canvasPaint.tips.innerHTML = "(最后一步)請抄寫屏幕上方引號內的確認語句"; canvasPaint.tips.style.color = 'red'; setTimeout(function () { canvasPaint.tips.style.color = '#666'; }, 2000); state = STATEMENT;//開始寫句子}

右上角有個移動簽字板功能,這里實現的是左右移動,相關代碼如下

 

function togglePencil() { if (canvasPaint.canPaint) { canvasPaint.canPaint = false; canvasPaint.pencilBtn.innerText = "使用簽字筆"; //不能簽字時應該把開始寫字事件去掉,同時加上document事件 canvasPaint.canvas.removeEventListener('touchstart', startEventHandler, false); document.addEventListener('touchstart', documentStartEventHandler, {passive: false}); } else { canvasPaint.canPaint = true; canvasPaint.pencilBtn.innerText = "移動簽字板"; //能簽字時應該把開始寫字事件綁定上去,同時去掉document事件 canvasPaint.canvas.addEventListener('touchstart', startEventHandler, {passive: false}); document.removeEventListener('touchstart', documentStartEventHandler, false); }}function documentStartEventHandler(event) { event.preventDefault(); canvasPaint.y = event.clientY; canvasPaint.top = parseFloat(canvasPaint.canvas.style.top);//畫板距離頂部的值 document.addEventListener('touchmove', documentMoveEventHandler, {passive: false}); document.addEventListener('touchend', documentEndEventHandler, {passive: false});}function documentMoveEventHandler(event) { event.preventDefault(); canvasPaint.newY = event.clientY - canvasPaint.y; if (!canvasPaint.canPaint) { canvasPaint.canvas.style.top = canvasPaint.newY + canvasPaint.top + 'px'; if (parseFloat(canvasPaint.canvas.style.top) > 0) {//限制邊界  canvasPaint.canvas.style.top = 0 + 'px'; } }}function documentEndEventHandler(event) { event.preventDefault();}

 

合成長句到協議中并顯示最終圖片

提交抄寫按鈕點擊后執行下面的函數

function statementDraw(imgArr) { canvasPaint.context2.save(); canvasPaint.context2.translate(52, 690); canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[0], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); console.log(canvasPaint.canvas2.toDataURL()); document.getElementById('resultImg').setAttribute('src', canvasPaint.canvas2.toDataURL()); document.getElementById('resultImg').style.position = 'absolute'; document.getElementById('resultImg').style.left = 0; document.getElementById('resultImg').style.top = 0; document.getElementById('resultImg').style.zIndex = 50;}

 

在一個風和日麗的下午,剛準備下班,突然接到需求說要做一個在線簽協議功能,當時心里想著不就百度一頓拷貝就完事了嗎(因為我沒用過canvas,所謂初生牛犢不怕虎 ),誰知做起來如此吃力,下面就來記錄下歷程。

協議模板

分析

如上圖,需要做的就是做一個簽字板可以在上面寫字,寫完后點擊完成可以生成如上圖的圖片所示,把簽好的字放到指定的位置。

做這個第一反應肯定就是使用canvas繪制路徑

我的思路是:

一個字一個字寫,每寫一個字點一下記錄,最后拼接,但想到用戶體驗問題就pass了這個思路。

最后的思路:一行可以寫很多個字,可以讓用戶滑動canvas,一直寫下去(因為協議模板最后還要抄寫一段話)

canvas繪制路徑--實現簽名功能

 

<canvas id="canvas" style="top:0">您的手機不支持在線簽署</canvas>const canvasPaint = {};//定義一個全局對象,把canvas的各種狀態存進去canvasPaint.canvas = document.getElementById("canvas");canvasPaint.ctx = document.getElementById("canvas").getContext("2d");canvasPaint.ctx.lineCap = 'round';//讓結束線帽呈現圓滑狀canvasPaint.ctx.lineJoin = 'round';//交匯時呈現圓滑狀canvasPaint.ctx.strokeWidth = 5;//描邊寬度canvasPaint.ctx.lineWidth = 5;//線條寬度

 

初始化好畫布后,我們需要監聽畫布上的滑動事件

canvasPaint.canvas.addEventListener('touchstart', startEventHandler, {passive: false});function startEventHandler(event) { event.preventDefault(); canvasPaint.ctx.beginPath();//每次都是一個新路徑,不寫會和上個字的最后一筆連起來 canvasPaint.canvas.addEventListener('touchmove', moveEventHandler, {passive: false}); canvasPaint.canvas.addEventListener('touchend', endEventHandler, {passive: false});}

 

passive: false 和 event.preventDefault() 這兩個是絕配哦, event.preventDefault() 阻止默認行為,防止在畫布上寫字時觸發了瀏覽器自帶的下拉動作之類的。那 passive: false 是谷歌56版本后提出的新屬性,設置為 false 就是告訴瀏覽器我有阻止默認行為的代碼,剛開始不要給我滑動,你需要執行我的 event.preventDefault() 這句代碼,如果設置為了 true ,瀏覽器會自動忽略這句代碼,從而不能阻止成功,默認是 true ,所以這里就是坑之一了。

我們繼續編寫移動劃線邏輯

 

function moveEventHandler(event) { event.preventDefault(); var coverPos = canvasPaint.canvas.getBoundingClientRect(); canvasPaint.mouseX = event.clientX - coverPos.left; canvasPaint.mouseY = event.clientY - coverPos.top; if (canvasPaint.canPaint) {//后續為拖動畫布功能設置的狀態 canvasPaint.ctx.lineTo(//使用lineTo將移動過的坐標繪制成線  canvasPaint.mouseX,  canvasPaint.mouseY ); canvasPaint.ctx.stroke();//繪制 }}function endEventHandler(event) { event.preventDefault(); //抬起手指時取消move和end事件的監聽 canvasPaint.canvas.removeEventListener('touchmove', moveEventHandler, false); canvasPaint.canvas.removeEventListener('touchend', endEventHandler, false);}

canvas--清除屏幕功能

這個功能比較簡單就一句話

function clearCanvas() { canvasPaint.ctx.clearRect(0, 0, canvasPaint.canvas.width, canvasPaint.canvas.height);}

 

提交簽名功能

首先需要將畫布上的文字轉換為img對象,然后使用drawImage繪制到協議上去

 

preLoadImg(['/assets/index/images/agree.jpg', canvasPaint.canvas.toDataURL()], result);//agree.jpg為協議名,canvasPaint.canvas.toDataURL()就是簽好的字轉換為base64的結果function preLoadImg(source, callBack, args) { var pr = []; source.forEach(url => { var p = loadImage(url)  .then(function (img) {  return img;  })  .catch(function (err) {  console.log(err);  }); pr.push(p); }); Promise.all(pr) .then(function (imgArray) {  callBack(imgArray, args); });}function loadImage(url) { return new Promise((resolve, reject) => { var img = new Image(); img.onload = function () {  resolve(img); }; img.onerror = reject; img.src = url; });}

 

由于img賦值src是異步的,我們必須要一個完整的image對象,所以我們使用promise包裝,使得我們所有圖片都轉換完之后再將結果傳入回調函數(result)中

function result(imgArr) { drawName(imgArr);}function drawName(imgArr) { //繪制名字和底部的名字和日期 canvasPaint.canvas2 = document.getElementById('canvas2'); canvasPaint.context2 = canvasPaint.canvas2.getContext('2d'); canvasPaint.ratio = canvasPaint.canvas.height / canvasPaint.canvas.width; //計算畫布比例 canvasPaint.context2.drawImage(imgArr[0], 0, 0, 500, 707);//img0是底圖原協議 canvasPaint.context2.save(); canvasPaint.context2.translate(50, 190); canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[1], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); canvasPaint.context2.save(); canvasPaint.context2.translate(67, 723);//下方的字 canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[1], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); canvasPaint.context2.save(); canvasPaint.context2.translate(400, 625);//下方的字 canvasPaint.context2.font = "11px 微軟雅黑"; canvasPaint.context2.fillStyle = "#000"; canvasPaint.context2.textAlign = "center"; canvasPaint.context2.textBaseline = "middle"; var time = new Date().toLocaleString().split(' ')[0]; canvasPaint.context2.fillText(time, 0, 0); canvasPaint.context2.restore(); prevDrawStatement();}

 


這里最主要的還是要理解下畫布的rotate和translate方法,就可以把文字旋轉任意角度和放到任意位置了

長字手寫--畫布拖動

上面簽字完成后,我們其實已經用了另一個canvas合成了文字和原協議,現在我們要做無限拖動功能,其實也很簡單。

在此之前我們需要清空之前的畫布

function prevDrawStatement() { clearCanvas();//清除畫布 canvasPaint.finish.innerHTML = "提交抄寫"; canvasPaint.pencilBtn.style.display = 'block'; canvasPaint.secondState.style.display = 'block'; canvasPaint.tips.innerHTML = "(最后一步)請抄寫屏幕上方引號內的確認語句"; canvasPaint.tips.style.color = 'red'; setTimeout(function () { canvasPaint.tips.style.color = '#666'; }, 2000); state = STATEMENT;//開始寫句子}

 

右上角有個移動簽字板功能,這里實現的是左右移動,相關代碼如下

function togglePencil() { if (canvasPaint.canPaint) { canvasPaint.canPaint = false; canvasPaint.pencilBtn.innerText = "使用簽字筆"; //不能簽字時應該把開始寫字事件去掉,同時加上document事件 canvasPaint.canvas.removeEventListener('touchstart', startEventHandler, false); document.addEventListener('touchstart', documentStartEventHandler, {passive: false}); } else { canvasPaint.canPaint = true; canvasPaint.pencilBtn.innerText = "移動簽字板"; //能簽字時應該把開始寫字事件綁定上去,同時去掉document事件 canvasPaint.canvas.addEventListener('touchstart', startEventHandler, {passive: false}); document.removeEventListener('touchstart', documentStartEventHandler, false); }}function documentStartEventHandler(event) { event.preventDefault(); canvasPaint.y = event.clientY; canvasPaint.top = parseFloat(canvasPaint.canvas.style.top);//畫板距離頂部的值 document.addEventListener('touchmove', documentMoveEventHandler, {passive: false}); document.addEventListener('touchend', documentEndEventHandler, {passive: false});}function documentMoveEventHandler(event) { event.preventDefault(); canvasPaint.newY = event.clientY - canvasPaint.y; if (!canvasPaint.canPaint) { canvasPaint.canvas.style.top = canvasPaint.newY + canvasPaint.top + 'px'; if (parseFloat(canvasPaint.canvas.style.top) > 0) {//限制邊界  canvasPaint.canvas.style.top = 0 + 'px'; } }}function documentEndEventHandler(event) { event.preventDefault();}

 

合成長句到協議中并顯示最終圖片

提交抄寫按鈕點擊后執行下面的函數

function statementDraw(imgArr) { canvasPaint.context2.save(); canvasPaint.context2.translate(52, 690); canvasPaint.context2.rotate(270 * Math.PI / 180); canvasPaint.context2.drawImage(imgArr[0], 80, 50, 33, 33 * canvasPaint.ratio);//畫反轉后的名字 canvasPaint.context2.restore(); console.log(canvasPaint.canvas2.toDataURL()); document.getElementById('resultImg').setAttribute('src', canvasPaint.canvas2.toDataURL()); document.getElementById('resultImg').style.position = 'absolute'; document.getElementById('resultImg').style.left = 0; document.getElementById('resultImg').style.top = 0; document.getElementById('resultImg').style.zIndex = 50;}

總結

以上所述是小編給大家介紹的JS實現移動端在線簽協議功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产ts人妖一区二区三区| 人人澡人人澡人人看欧美| 国产欧美日韩专区发布| 国产成人一区二区三区| 国产欧美一区二区三区视频| 国产精品草莓在线免费观看| 亚洲毛片在线观看| 在线日韩日本国产亚洲| 久热精品视频在线免费观看| 欧美在线视频一二三| 午夜精品视频在线| 97在线免费观看| 亚洲乱码国产乱码精品精| 日韩一区二区在线视频| 日韩一区二区三区xxxx| 欧美日韩国产综合新一区| 亚洲免费精彩视频| 亚洲乱码一区二区| 精品视频—区二区三区免费| 欧美激情免费看| 欧美重口另类videos人妖| 日本最新高清不卡中文字幕| 91亚洲午夜在线| 成人福利免费观看| 日韩极品精品视频免费观看| 狠狠色香婷婷久久亚洲精品| 国产成人在线视频| 欧美电影免费观看高清完整| 亚洲欧美日韩网| 欧美一区二粉嫩精品国产一线天| 91精品久久久久久久久青青| 久久777国产线看观看精品| 一本一本久久a久久精品牛牛影视| 亚洲福利小视频| 欧美野外wwwxxx| 日产日韩在线亚洲欧美| 精品福利樱桃av导航| 久久免费福利视频| 国产精品日韩一区| 国产精品视频专区| 欧美精品在线网站| 欧美精品xxx| 日韩h在线观看| 日韩中文字幕在线精品| 欧美肥老太性生活视频| 亚洲国产成人91精品| 国产伊人精品在线| 亚洲色图综合久久| 日韩电影免费在线观看中文字幕| 日韩www在线| 国产精品嫩草视频| 国产精品视频免费在线观看| 日韩网站在线观看| 日韩亚洲精品视频| 国产精品99久久久久久久久久久久| 欧美亚洲日本网站| 欧美日韩一区二区三区| 欧美一乱一性一交一视频| 欧美日韩亚洲精品一区二区三区| 国产精品九九久久久久久久| 久久99精品国产99久久6尤物| 中文字幕一精品亚洲无线一区| 欧美性高潮床叫视频| 色偷偷9999www| 欧美午夜女人视频在线| 国产日产久久高清欧美一区| 日韩成人在线视频| 日韩中文字幕精品视频| 一道本无吗dⅴd在线播放一区| 色综合久久久888| 日韩精品在线免费播放| 国产视频综合在线| 国产亚洲精品综合一区91| 欧美精品久久久久a| 欧美在线一区二区视频| 日韩中文字幕免费| 亚洲天堂av在线免费观看| 国产视频亚洲精品| 最近2019中文字幕在线高清| 91影院在线免费观看视频| 亚洲精品黄网在线观看| 日韩精品高清在线观看| 日韩精品免费在线播放| 欧美肥臀大乳一区二区免费视频| 欧美乱人伦中文字幕在线| 国产精品久久久久一区二区| 黄网动漫久久久| 91网站在线看| 精品视频久久久久久久| 亚洲新声在线观看| 国产精品中文字幕久久久| 精品久久香蕉国产线看观看亚洲| 亚洲精品之草原avav久久| 久久久www成人免费精品张筱雨| 97精品视频在线观看| 亚洲成色777777在线观看影院| 伊人伊成久久人综合网站| 亚洲丁香婷深爱综合| 亚洲综合色激情五月| 日韩av在线影视| 日韩美女视频免费在线观看| 欧美亚洲伦理www| 在线视频欧美日韩| 一区二区欧美日韩视频| 中文字幕av日韩| 欧美亚洲另类视频| 国产成人精品av在线| 欧美最猛性xxxxx亚洲精品| x99av成人免费| 欧美在线观看网址综合| 日韩在线不卡视频| 在线精品播放av| 午夜精品一区二区三区视频免费看| 精品国产美女在线| 91免费看视频.| 亚洲欧美成人一区二区在线电影| 国产成人福利夜色影视| 91大神福利视频在线| 日韩精品小视频| 国产日产亚洲精品| 久久精品视频播放| 国产美女主播一区| 精品国产福利在线| 欧美日韩激情小视频| 97av在线影院| 国产精品扒开腿爽爽爽视频| 色哟哟亚洲精品一区二区| 亚洲精品国产美女| 欧美国产精品人人做人人爱| 亚洲精品国产精品国自产观看浪潮| 欧美放荡办公室videos4k| 日本成人精品在线| 亚洲aⅴ男人的天堂在线观看| 日韩在线资源网| 成人黄色av免费在线观看| 国产欧美精品xxxx另类| 亚洲www永久成人夜色| 国产精品激情av在线播放| 久久综合久中文字幕青草| 欧美午夜久久久| 啊v视频在线一区二区三区| 久久伊人免费视频| 亚洲天堂成人在线视频| 亚洲人成啪啪网站| 国产在线拍偷自揄拍精品| 欧美日韩亚洲一区二区| 色狠狠久久aa北条麻妃| 国产视频精品自拍| 欧美另类老肥妇| 久久资源免费视频| 亚洲人成网站色ww在线| 亚洲精品福利视频| 国产人妖伪娘一区91| 精品久久久999| 国产精自产拍久久久久久蜜| 亚洲免费伊人电影在线观看av| 欧美成人免费网| 国产精品视频自在线| 久久亚洲精品毛片| 色综合天天狠天天透天天伊人| 国产一区二区日韩| 亚洲美女久久久| 欧美性猛交xxxx乱大交| 91最新在线免费观看|