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

首頁(yè) > 編程 > HTML > 正文

基于Html5 canvas實(shí)現(xiàn)裁剪圖片和馬賽克功能及又拍云上傳圖片 功能

2024-08-26 00:21:32
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

1.核心功能

  此組件功能包含:

    圖片裁剪(裁剪框拖動(dòng),裁剪框改變大?。?;

    圖片馬賽克(繪制馬賽克,清除馬賽克);

    圖片預(yù)覽、圖片還原(返回原圖、返回處理圖);

    圖片上傳(獲取簽名、上傳圖片)。

2.核心邏輯

  2.1圖片裁剪

  獲取裁剪框(矩形)相對(duì)于畫布的位置(左上)和裁剪框的height、width。獲?。╣etImageData)canvas相應(yīng)位置的圖片對(duì)象(ImageData)。清空canvas畫布。在canvas畫布的相應(yīng)位置繪制(putImageData)獲取的圖片對(duì)象(ImageData)。生成預(yù)覽圖。

  2.2圖片馬賽克

  馬賽克的繪制,就是在以鼠標(biāo)劃過(guò)路徑(畫筆寬度)為中心的區(qū)域,重新繪制成其他的顏色。一般結(jié)果是,會(huì)取周圍的相近的顏色。

  取色方法:

  1)比如現(xiàn)有一鼠標(biāo)劃過(guò)的點(diǎn)的坐標(biāo)(x,y),定義一個(gè)矩形左上角坐標(biāo)?。▁,y),寬30px,高30px。我們把矩形寬高都除以5(分成5份,可以自定義為n份),所以現(xiàn)在是25個(gè)6px的小格子。每個(gè)小格子寬高都是6px。

  2)然后,我們隨機(jī)獲取一個(gè)小格子,獲?。╣etImageData)這個(gè)小格子的圖片對(duì)象(ImageData);再隨機(jī)獲取此圖片對(duì)象上某個(gè)像素點(diǎn)(寬1px,高1px)的顏色color(rgba:ImageData.data[0],ImageData.data[1],ImageData.data[2],ImageData.data[3]);最后我們把第一個(gè)6x6px的小格子的每個(gè)像素點(diǎn)的顏色都設(shè)置為color。

  3)其他24個(gè)小格子的顏色,遍歷2步驟即可。

  2.3清除馬賽克

  我們需要理解一個(gè)問(wèn)題,不管是繪制馬賽克,還是清除馬賽克,其本質(zhì)都是在繪制圖片。我們?cè)谀硞€(gè)位置繪制了馬賽克,清除的時(shí)候,就是把原圖在當(dāng)前位置的圖片對(duì)象再畫出來(lái)。就達(dá)到了清除的效果。所以,我們需要備份一個(gè)canvas,和原圖一模一樣,清除的時(shí)候,需要獲取備份畫布上對(duì)應(yīng)位置的圖像,繪制到馬賽克的位置。

  2.4圖片預(yù)覽

  圖片預(yù)覽就是獲取裁剪框的區(qū)域,獲取區(qū)域內(nèi)的圖片對(duì)象。再繪制到畫布上。

  2.5圖片還原至原圖

  清空畫布,再次繪制原圖

  2.6還原至已操作圖片

  預(yù)覽是保存畫布圖片對(duì)象(ImageData),清空畫布,繪制保存的圖片對(duì)象至畫布

  2.7圖片上傳

  獲取(toDataURL)canvas圖片路徑,將獲取到的base64圖片轉(zhuǎn)化為File對(duì)象。進(jìn)行上傳。

3.完整代碼如下:

<template>  <div class="canvas-clip" :loading="loading">    <div      v-show="isDrop"      class="canvas-mainBox"      ref="canvas-mainBox"      id="canvas-mainBox"      @mousedown.stop="startMove($event)"    >      <div class="canvas-minBox left-up" @mousedown.stop="startResize($event,0)"></div>      <div class="canvas-minBox up" @mousedown.stop="startResize($event,1)"></div>      <div class="canvas-minBox right-up" @mousedown.stop="startResize($event,2)"></div>      <div class="canvas-minBox right" @mousedown.stop="startResize($event,3)"></div>      <div class="canvas-minBox right-down" @mousedown.stop="startResize($event,4)"></div>      <div class="canvas-minBox down" @mousedown.stop="startResize($event,5)"></div>      <div class="canvas-minBox left-down" @mousedown.stop="startResize($event,6)"></div>      <div class="canvas-minBox left" @mousedown.stop="startResize($event,7)"></div>    </div>    <!-- 畫布 -->    <canvas      class="canvas-area"      ref="canvas"      id="canvas"      :width="canvasWidth"      :height="canvasHeight"      @mousedown.stop="startMove($event)"      :class="{hoverPaint:isMa,hoverClear:isMaClear}"    ></canvas>    <!-- 備份畫布 -->    <canvas class="canvas-copy" ref="canvasCopy" :width="canvasWidth" :height="canvasHeight"></canvas>    <div class="canvas-btns">      <button v-if="backBtn" @click="clipBack">返回</button>      <button :class="{active:btnIndex==0}" @click="sourceImg">原圖</button>      <button :class="{active:btnIndex==1}" @click="paintRectReady" :disabled="isDisabled">馬賽克</button>      <button :class="{active:btnIndex==2}" @click="paintRectClearReady" :disabled="isDisabled">橡皮擦</button>      <button :class="{active:btnIndex==3}" @click="clipReady" :disabled="isDisabled">裁剪</button>      <button :class="{active:btnIndex==4}" @click="clipPosition">預(yù)覽</button>      <button @click="getSignature">上傳</button>      <button class="close" @click="canvasClose()">x</button>      <!-- <div class="paint-size" v-if="isMaClear || isMa">        <span>畫筆大小</span>        <input :defaultValue="maSize" v-model="maSize" max="100" min="1" type="range">        <span class="size-num">{{maSize}}</span>      </div> -->    </div>  </div></template><script>import axios from "axios";import md5 from "js-md5";import req from "../../axios/config";export default {  props: ["imgUrl"],  data() {    return {      resizeFX: "",      movePrev: "",      canvasWidth: 800, // 畫布寬      canvasHeight: 600, // 畫布高      loading: false,      isDrop: false, // 裁剪      isMa: false, // 馬賽克      maSize: 30, // 馬賽克大小      isMaClear: false, // 清除馬賽克      backBtn: false, // 返回按鈕      isDisabled: false,//禁用按鈕      btnIndex: 0,//當(dāng)前按鈕      mouseX:'',// 鼠標(biāo)位置      mouseY:'',      clipEle: "", // 裁剪框元素      canvasDataSession: "", // 預(yù)覽前的畫布信息      canvas: "", // 畫布      ctx: "", // 畫布上下文      canvasCopy: "", // copy畫布      ctxCopy: "", // copy畫布上下文      uploadOption: { // 圖片上傳參數(shù)        path: "",        policy: "",        signature: "",        username: ""      }    };  },  mounted() {    this.clipEle = this.$refs["canvas-mainBox"];    this.canvas = this.$refs["canvas"];    this.ctx = this.canvas.getContext("2d");    this.canvasCopy = this.$refs["canvasCopy"];    this.ctxCopy = this.canvasCopy.getContext("2d");    this.draw();  },  methods: {    // 創(chuàng)建圖片    draw() {      var img = new Image();      img.setAttribute('crossOrigin', 'anonymous');      img.onload = () => {        this.ctx.drawImage(img, 0, 0, 800, 600);        this.ctxCopy.drawImage(img, 0, 0, 800, 600);      };      img.src = this.imgUrl + '?time=' + new Date().valueOf();    },    //預(yù)覽 計(jì)算裁剪框的位置(左上坐標(biāo))    clipPosition() {      this.isDisabled = true;      this.backBtn = true;      this.isMa = false;      this.isMaClear = false;      this.btnIndex = 4;      //畫布位置      var canvasPx = this.canvas.offsetLeft,        canvasPy = this.canvas.offsetTop;      if (this.isDrop) {        // 裁剪框位置        var clipPx = this.clipEle.offsetLeft,          clipPy = this.clipEle.offsetTop,          x = clipPx - canvasPx,          y = clipPy - canvasPy,          w = this.clipEle.offsetWidth,          h = this.clipEle.offsetHeight,          // 預(yù)覽圖居中          positionX = 400 - this.clipEle.offsetWidth / 2,          positionY = 300 - this.clipEle.offsetHeight / 2;      } else {        // 沒(méi)有裁剪框,保存完整圖片        var x = 0,          y = 0,          w = this.canvas.offsetWidth,          h = this.canvas.offsetHeight,          // 預(yù)覽圖居中          positionX = 0,          positionY = 0;      }      var imageData = this.ctx.getImageData(x, y, w, h);      this.canvasDataSession = this.ctx.getImageData(        0,        0,        this.canvasWidth,        this.canvasHeight      );      this.ctx.clearRect(0, 0, this.canvasWidth, this.canvasHeight);      this.ctx.putImageData(imageData, positionX, positionY);      this.clipEle.style.display = "none";      this.canvasCopy.style.display = "none";    },    // 返回預(yù)覽前狀態(tài)    clipBack() {      this.btnIndex = -1;      this.backBtn = false;      this.isDisabled = false;      this.isDrop = false;      this.ctx.putImageData(this.canvasDataSession, 0, 0);      this.canvasCopy.style.display = "block";    },    // 原圖    sourceImg() {      this.isDisabled = false;      this.btnIndex = 0;      this.backBtn = false;      this.isMa = false;      this.isDrop = false;      this.isMaClear = false;      var img = new Image();      this.ctx.clearRect(0, 0, this.canvasWidth, this.canvasHeight);      img.setAttribute('crossOrigin', 'anonymous');      img.onload = () => {        this.ctx.drawImage(img, 0, 0, this.canvasWidth, this.canvasHeight);      };      img.src = this.imgUrl + '?time=' + new Date().valueOf();      this.canvasCopy.style.display = "block";    },    // 獲取簽名    getSignature() {      // canvas圖片base64 轉(zhuǎn) File 對(duì)象      var dataURL = this.canvas.toDataURL("image/jpg"),        arr = dataURL.split(","),        mime = arr[0].match(/:(.*?);/)[1],        bstr = atob(arr[1]),        n = bstr.length,        u8arr = new Uint8Array(n);      while (n--) {        u8arr[n] = bstr.charCodeAt(n);      }      var obj = new Blob([u8arr], { type: mime }),        time = new Date().toGMTString(),        formData = new FormData();      formData.append("file", obj);      // 獲取文件后綴      var suffix = formData.get("file").type.split("/")[1];      req        .get("/carsource-api/upyun/sign", { suffix: suffix })        .then(response => {          if (response.data.code === 0) {            this.uploadOption.path = response.data.data.path;            formData.append("policy", response.data.data.policy);            formData.append("authorization", response.data.data.signature);            this.updateImg(formData);          }        })        .catch(function(error) {});    },    // 上傳    updateImg(formData) {      axios({        url: "http://v0.api.upyun.com/tmp-img",        method: "POST",        data: formData      }).then(response => {        if (response.data.code == 200) {          this.$message.success("圖片修改成功");          this.canvasClose("upload", response.data.url.slice(4));        }      });    },    // 裁剪框縮放 移動(dòng)    startResize(e, n) {      this.resizeFX = n;      $(document).mousemove(this.resizeDiv);      document.addEventListener("mouseup", this.stopResize);    },    stopResize(e) {      $(document).off("mousemove", this.resizeDiv);      document.removeEventListener("mouseup", this.stopResize);    },    startMove(e) {      this.movePrev = [e.pageX, e.pageY];      $(document).mousemove(this.moveDiv);      document.addEventListener("mouseup", this.stopMove);    },    stopMove(e) {      $(document).off("mousemove", this.moveDiv);      document.removeEventListener("mouseup", this.stopMove);    },    moveDiv(e) {      // 馬賽克      if (this.isMa) {        this.paintRect(e);      }      // 清除馬賽克      if (this.isMaClear) {        this.paintRectClear(e);      }      // 裁剪      if (this.isDrop) {        var targetDiv = $("#canvas-mainBox"),          offsetArr = targetDiv.offset();        var chaX = e.pageX - this.movePrev[0],          chaY = e.pageY - this.movePrev[1],          ox = parseFloat(targetDiv.css("left")),          oy = parseFloat(targetDiv.css("top"));        targetDiv.css({          left: ox + chaX + "px",          top: oy + chaY + "px"        });        this.movePrev = [e.pageX, e.pageY];      }    },    resizeDiv(e) {      e.preventDefault();      e.stopPropagation();      // 獲取需要改變尺寸元素到頁(yè)面的距離      var targetDiv = $("#canvas-mainBox"),        offsetArr = targetDiv.offset();      var eleSWidth = targetDiv.width(),        eleSHeight = targetDiv.height(),        ox = parseFloat(targetDiv.css("left")),        oy = parseFloat(targetDiv.css("top"));      // 獲取鼠標(biāo)位置,和元素初始o(jì)ffset進(jìn)行對(duì)比,      var chaX = e.pageX - offsetArr.left,        chaY = e.pageY - offsetArr.top;      switch (this.resizeFX) {        case 0:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX >= eleSWidth - 10 || chaY >= eleSHeight - 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            width: eleSWidth + chaX * -1 + "px",            height: eleSHeight + chaY * -1 + "px",            left: ox + chaX + "px",            top: oy + chaY + "px"          });          break;        case 1:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaY >= eleSHeight - 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            height: eleSHeight + chaY * -1 + "px",            top: oy + chaY + "px"          });          break;        case 2:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX <= 10 || chaY >= eleSHeight - 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,設(shè)置位置          // 原始高+((m-e)*-1),原始寬+((m-e)),原始位置+(m-e)          targetDiv.css({            width: chaX + "px",            height: eleSHeight + chaY * -1 + "px",            top: oy + chaY + "px"          });          break;        case 3:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX <= 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            width: chaX + "px"          });          break;        case 4:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX <= 10 || chaY <= 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            width: chaX + "px",            height: chaY + "px"          });          break;        case 5:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaY <= 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            height: chaY + "px"          });          break;        case 6:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX >= eleSWidth - 10 || chaY <= 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            width: eleSWidth + chaX * -1 + "px",            height: chaY + "px",            left: ox + chaX + "px"          });          break;        case 7:          //如果移動(dòng)距離接近寬度或高度,則不進(jìn)行改變          if (chaX >= eleSWidth - 10) {            return;          }          // 獲得位置差(m-e),先設(shè)置寬度和高度,再設(shè)置位置          // 原始寬高+((m-e)*-1),原始位置+(m-e)          targetDiv.css({            width: eleSWidth + chaX * -1 + "px",            left: ox + chaX + "px"          });          break;        default:          break;      }    },    // 裁剪    clipReady() {      this.btnIndex = 3;      this.isMa = false;      this.isDrop = true;      this.isMaClear = false;    },    // 馬賽克    paintRectReady() {      this.btnIndex = 1;      this.isMa = true;      this.isDrop = false;      this.isMaClear = false;    },    // 橡皮擦    paintRectClearReady() {      this.btnIndex = 2;      this.isMa = false;      this.isDrop = false;      this.isMaClear = true;    },    // 繪制馬賽克    paintRect(e) {      var offT = this.canvas.offsetTop, // 距離上邊距離        offL = this.canvas.offsetLeft, // 距離左邊距離        x = e.clientX,        y = e.clientY;      if(this.mouseX - x > this.maSize/2 || x - this.mouseX > this.maSize/2 || this.mouseY - y > this.maSize/2 || y - this.mouseY > this.maSize/2){        var oImg = this.ctx.getImageData(x - offL ,y - offT,this.maSize,this.maSize);        var w = oImg.width;        var h = oImg.height;        //馬賽克的程度,數(shù)字越大越模糊        var num = 6;        //等分畫布        var stepW = w/num;        var stepH = h/num;        //這里是循環(huán)畫布的像素點(diǎn)        for(var i=0;i<stepH;i++){          for(var j=0;j<stepW;j++){            //獲取一個(gè)小方格的隨機(jī)顏色,這是小方格的隨機(jī)位置獲取的            var color = this.getXY(oImg,j*num+Math.floor(Math.random()*num),i*num+Math.floor(Math.random()*num));            //這里是循環(huán)小方格的像素點(diǎn),            for(var k=0;k<num;k++){                for(var l=0;l<num;l++){                    //設(shè)置小方格的顏色                    this.setXY(oImg,j*num+l,i*num+k,color);                }                }          }            }        this.ctx.putImageData(oImg,x - offL ,y - offT);        this.mouseX = e.clientX        this.mouseY = e.clientY      }    },    getXY(obj,x,y){      var w = obj.width;      var h = obj.height;      var d = obj.data;      var color = [];      color[0] = d[4*(y*w+x)];      color[1] = d[4*(y*w+x)+1];      color[2] = d[4*(y*w+x)+2];      color[3] = d[4*(y*w+x)+3];      return color;    },    setXY(obj,x,y,color){      var w = obj.width;      var h = obj.height;      var d = obj.data;      d[4*(y*w+x)] = color[0];      d[4*(y*w+x)+1] = color[1];      d[4*(y*w+x)+2] = color[2];      d[4*(y*w+x)+3] = color[3];    },    // 清除馬賽克    paintRectClear(e) {      var offT = this.canvasCopy.offsetTop, // 距離上邊距離        offL = this.canvasCopy.offsetLeft, // 距離左邊距離        x = e.clientX,        y = e.clientY,        // 獲取原圖此位置圖像數(shù)據(jù)        imageData = this.ctxCopy.getImageData(          x - offL,          y - offT,          this.maSize,          this.maSize        );      this.ctx.putImageData(imageData, x - offL, y - offT);    },    // 關(guān)閉畫布    canvasClose(type, url) {      this.$emit("isShowImgChange", type, url);    }  }};</script><style scoped>.canvas-clip {  position: fixed;  top: 0;  bottom: 0;  left: 0;  right: 0;  z-index: 9010;  background: #000;}.canvas-mainBox {  position: absolute;  width: 400px;  height: 300px;  left: 50%;  top: 50%;  margin-left: -200px;  margin-top: -150px;  border: 1px solid #FFF;  cursor: move;  z-index: 9009;}.canvas-minBox {  position: absolute;  width: 8px;  height: 8px;  background: #FFF;}.left-up {  top: -4px;  left: -4px;  cursor: nw-resize;}.up {  top: -4px;  left: 50%;  margin-left: -4px;  cursor: n-resize;}.right-up {  top: -4px;  right: -4px;  cursor: ne-resize;}.right {  top: 50%;  margin-top: -4px;  right: -4px;  cursor: e-resize;}.right-down {  bottom: -4px;  right: -4px;  cursor: se-resize;}.down {  bottom: -4px;  left: 50%;  margin-left: -4px;  cursor: s-resize;}.left-down {  bottom: -4px;  left: -4px;  cursor: sw-resize;}.left {  top: 50%;  margin-top: -4px;  left: -4px;  cursor: w-resize;}.canvas-btns {  position: fixed;  right: 50px;  top: 30px;  z-index: 9003;}.canvas-btns button {  display: inline-blovk;  background: green;  cursor: pointer;  border: none;  width: 60px;  height: 30px;  line-height: 30px;  color: #fff;  font-size: 15px;}.canvas-btns button.active {  background: rgb(32, 230, 32);}.canvas-btns button.close {  background: rgb(230, 72, 32);}.canvas-copy {  position: absolute;  top: 50%;  left: 50%;  margin-top: -300px;  margin-left: -400px;  z-index: 9007;}.canvas-mosatic {  position: absolute;  top: 50%;  left: 50%;  margin-top: -300px;  margin-left: -400px;  z-index: 9009;}.canvas-area {  position: absolute;  top: 50%;  left: 50%;  margin-top: -300px;  margin-left: -400px;  z-index: 9008;}.paint-size{  margin-top: 20px;  font-size: 13px;  color: #FFF;  height: 30px;  line-height: 30px;  text-align: right;}.paint-size input{  vertical-align: middle;  background: green;}.paint-size .size-num{  display: inline-block;  width: 15px;}.hoverClear{  cursor: url('./paint.png'),auto;}.hoverPaint{  cursor: url('./paint.png'),auto;}</style> 

4.效果圖如下:

Html5,canvas,裁剪圖片,馬賽克,又拍云

總結(jié)

以上所述是小編給大家介紹的基于Html5 canvas實(shí)現(xiàn)裁剪圖片和馬賽克功能及又拍云上傳圖片 功能 ,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到HTML教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
午夜在线激情影院| 色视频欧美一区二区三区| 色网在线播放| bdsm在线观看播放视频| 国产午夜精品理论片| 日本一卡二卡在线| 亚洲一区二区三区四区中文字幕| 这里有精品可以观看| 国产精品欧美色图| 影音先锋在线中文字幕| 久操视频免费在线观看| 成人午夜激情av| 狠狠色香婷婷久久亚洲精品| 97久久精品人人爽人人爽蜜臀| 亚洲成人动漫在线| 国产精品美女久久久久av爽| 亚洲欧美日韩国产成人精品影院| 欧美日韩日本国产| 黄色大片免费观看| 日韩欧美国产中文字幕| 国产又黄又粗的视频| 黄色毛片在线看| 欧美极品少妇xxxxⅹ免费视频| 手机在线免费毛片| 激情校园亚洲图片| 一本色道**综合亚洲精品蜜桃冫| 天堂国产一区二区三区| 天堂网中文在线观看| 极品粉嫩国产18尤物| 国产三级做爰高清在线| 精品一区二区三区国产| 嫩草影院永久一二三入口| 日本精品久久久久中文字幕| 人人玩人人添人人澡免费| 九九在线视频| 国产精品福利观看| 久久精品国产亚洲5555| 天天射天天拍| 57pao国产精品一区| 黄色成人在线网站| 久久久久久综合| 欧美精品乱码视频一二专区| 国内自拍中文字幕| 丰满大乳少妇在线观看网站| 在线精品自拍| 久久伦理在线| 国产成人a人亚洲精品无码| 国产精品乱码一区二三区小蝌蚪| 亚洲AV无码久久精品国产一区| 日韩免费三级| 日本在线成人一区二区| 美女mm1313爽爽久久久蜜臀| 精品国产乱码久久久久久影片| 亚洲在线播放| 中文字幕精品久久久| 精品一区二区三区影院在线午夜| 在线不卡中文字幕播放| 精品一区二区免费在线观看| 精品一区二区三区在线观看国产| 丝袜人妻一区二区三区| 国产亚洲综合在线| 亚洲欧美日韩国产成人| 黄色在线论坛| 嫩草影院永久入口| 97国产在线观看| 亚洲精品自拍视频| 日韩欧美123| 高清中文字幕一区二区三区| 欧美日韩一区二区三区四区不卡| 亚洲一区二区四区蜜桃| 热久久久久久| 欧美一区二区三区影视| 国产精品va在线观看视色| 91精品网站在线观看| 中文字幕第八页| 能免费看av的网站| 欧美裸体在线版观看完整版| 一区二区三区日本视频| 欧美成人免费在线观看视频| 99精品视频一区二区| 电影一区中文字幕| 国产欧美日韩综合一区在线播放| 外国电影一区二区| 亚洲av无码一区二区三区观看| 久久婷婷国产麻豆91天堂| av污在线观看| 国产一区二区精品| 黄色片免费大全| 国产美女www爽爽爽视频| 一区二区三区亚洲变态调教大结局| 特级全黄一级毛片| 欧美久久久久中文字幕| 国产激情99| 免费亚洲精品视频| 亚洲性生活视频在线观看| 朝桐光av在线| 色女人在线视频| 性人久久久久| 精品视频中文字幕| 翔田千里一区二在线观看| 国产原创精品在线| 国产在线视频欧美一区二区三区| 亚洲在线免费播放| 午夜性爽视频男人的天堂| 国产精品扒开做爽爽爽的视频| 国产一区日韩| 91国偷自产一区二区三区的观看方式| 亚洲精品不卡在线观看| 国产精品麻豆入口| 亚洲毛片欧洲毛片国产一品色| 国产 日韩 亚洲 欧美| 亚洲九九九在线观看| 国产欧美一区二区三区另类精品| 日韩一级毛片| 日韩理论片一区二区| 西西午夜视频| 亚洲精品国产精品国自产网站按摩| 亚洲乱码国产一区三区| av在线首页| 国产精品伦一区二区三区级视频频| 成人av影院在线| 国产女主播一区二区三区| 免费中文字幕日韩欧美| 97久久人人超碰| 亚洲人成啪啪网站| 亚洲精品免费电影| 国产精品久久二区| 特大巨黑人吊性xxxxn38| 国产中文在线| 欧美国产一区二区三区激情无套| 97人澡人人添人人爽欧美| 色婷婷综合久久久久久| 欧美日韩在线视频免费观看| 国产日韩欧美一区二区三区视频| 成人黄色片免费| 久久久另类综合| 亚欧精品在线视频| 国产精品国产一区二区三区四区| 欧美日韩国产综合网| 天天色影综合网| 精品一区二区三区高清免费不卡| 国产超碰在线一区| 欧美日韩中文一区二区| 日韩精品影片| 可以在线观看的av| 日韩美女主播在线视频一区二区三区| 欧美亚洲国产成人| 欧美一二三区在线观看| 国产成人在线观看网站| 波多野结衣中文字幕一区二区三区| 色视频在线看| 亚洲精品高清无码视频| 日韩国产精品毛片| 蜜臀久久精品久久久久| 精品一区二区三区影院在线午夜| 日韩女优在线播放| 国产麻豆天美果冻无码视频| 91啪亚洲精品| 国产精品欧美韩国日本久久| 超薄肉色丝袜足j调教99| 电影午夜精品一区二区三区| 亚洲精选久久| 欧美12一14sex性hd| av成人老司机| 日韩久久中文字幕| 欧美成人自拍视频| av男人的天堂网| 啪啪av大全导航福利综合导航| 日本黄色小说视频| 成人妖精视频yjsp地址| 亚洲视频小说| 在线免费观看黄色av| 又黄又爽无遮挡| 中文字幕一区二区三区四区视频| 国产不卡高清在线观看视频| 国产精品扒开腿做爽爽爽男男| 国产精品欧美激情在线观看| 最近最新中文字幕在线| 国产精品亚洲第一区在线暖暖韩国| 成人区人妻精品一区二| 色在线视频播放| 人妻精油按摩bd高清中文字幕| 一本大道av伊人久久综合| 精品网站999www| 高清无码一区二区在线观看吞精| 婷婷综合另类小说色区| 粉嫩av一区二区三区免费野| 性生交大片免费全黄| 精品国产一区二区三区av性色| 色老综合老女人久久久| 国产自产一区二区| 国内一区二区三区精品视频| 全网国产福利在线播放| 欧美日韩一区成人| 黄色av免费在线播放| 91在线国内视频| 7777奇米亚洲综合久久| 国产精品精品软件视频| 欧美大胆性生话| 91久久国语露脸精品国产高跟| 精品成人免费一区二区在线播放| 韩国在线视频一区| 欧美在线电影| 无码国产精品一区二区高潮| 亚洲精品一区二区三区蜜桃下载| 精品国产乱码久久久久久天美| 欧美亚洲成人免费| 久久一区二区三区电影| 欧洲激情一区二区| 五月天婷婷在线观看| 欧美亚洲一级| www成人在线视频| 美女在线视频一区二区| 国产精品88久久久久久妇女| 亚洲欧美色图小说| 国产剧情日韩欧美| 国产视频一区三区| 在线观看视频一区二区三区| 99视频在线精品国自产拍免费观看| 又黄又爽在线观看| 日本一区二区三区视频在线播放| 欧美大交乱xxxxxbbb| 欧美1区2区3区4区| 久久久久久av| 精品无人区乱码1区2区3区在线| 欧美疯狂做受xxxx富婆| 久久久久国产精品免费网站| 91探花福利精品国产自产在线| 51久久夜色精品国产麻豆| 亚洲欧美日韩国产精品| 97人摸人人澡人人人超一碰| 777久久久精品一区二区三区| 国产成人高潮免费观看精品| 久草成色在线| 久久夜色精品| 91精品国自产在线偷拍蜜桃| 亚洲精品男人的天堂| 国产99在线观看| 看一级黄色录像| 成人黄色中文字幕| 国产精品视频观看| 国产美女主播视频一区| 国产九九九九九| 国产成人亚洲精品狼色在线| 中文字字幕在线中文乱码电影| 国产精品私拍pans大尺度在线| www.4438全国最大| 蜜臀av在线播放一区二区三区| 91精品久久久久久久久久另类| 一区二区视频欧美| 最新的欧美黄色| 九九精品久久久| va婷婷在线免费观看| 色综合老司机第九色激情| 亚洲久草在线视频| 麻豆福利在线观看| 国产精品免费看久久久香蕉| 国产欧洲精品视频| 美女诱惑一区| 国产一区二区三区av电影| 黄色国产网站| 性猛交╳xxx乱大交| 91丨九色丨国产在线| 久久久精品999| 亚洲福利一区| 欧美午夜女人视频在线| av中文在线播放| 欧美激情乱人伦一区| 国产精品zjzjzj在线观看| 美女91在线| 成人网欧美在线视频| h在线免费观看| 日韩av毛片在线观看| 不卡在线一区| 成人在线视频你懂的| 久久久噜噜噜久久中文字免| 男人天堂av网| 黑人性受xxxx黑人xyx性爽| 国产成人精品无码播放| 日韩新的三级电影| 秋霞欧美一区二区三区视频免费| 欧美日本不卡高清| 欧美色精品天天在线观看视频| 天堂资源在线观看| 91精品国产乱码久久久久久久久| 欧美日韩国产一区在线| 国产精品国产高清国产| 免费污视频在线| 久久国产精品高清一区二区三区| 国产精品视频一区二区免费不卡| 第一站视频久草网| 欧美私人网站| 久久精品夜色噜噜亚洲aⅴ| 性欧美xxxx大乳国产app| 成人动漫一区二区在线| 3p视频在线观看| 亚洲一| 激情综合网五月激情| 亚洲国产一区二区a毛片| 风间由美性色一区二区三区| 精品视频一区二区三区四区五区| 国产免费一区二区三区| 欧美唯美清纯偷拍| 亚洲综合专区| 日韩二区三区在线| 麻豆免费版在线观看| 天天爽夜夜爽一区二区三区| 欧洲午夜精品| www.xxx.国产| 操操操综合网| 波多野一区二区| 国产亚洲欧美日韩高清| 91精品啪aⅴ在线观看国产| 成人h小游戏| 成人6969www免费视频| 精品一区二区三区在线观看视频| av观看成片免费网站| 最近中文字幕在线观看| 国产情侣免费视频| wwwav网站| 户外露出精品视频国产| 四虎永久免费网站| 9191国语精品高清在线| 日韩理论片在线| 毛片在线网站| 亚洲18在线看污www麻豆| 国精产品一区一区三区免费视频| 国产在视频线精品视频|