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

CSS、SVG、Canvas對(duì)特殊字體的繪制與導(dǎo)出

開(kāi)發(fā) 前端
簡(jiǎn)單解釋一下:所謂繪制,就是視覺(jué)上可以看到就行(預(yù)覽狀態(tài)),導(dǎo)出呢,就是將看到的轉(zhuǎn)換成圖片(或者Canvas),以便于后續(xù)處理。

最近在項(xiàng)目中需要對(duì)特殊字體進(jìn)行繪制與導(dǎo)出,如下:

圖片

簡(jiǎn)單解釋一下:所謂繪制,就是視覺(jué)上可以看到就行(預(yù)覽狀態(tài)),導(dǎo)出呢,就是將看到的轉(zhuǎn)換成圖片(或者Canvas),以便于后續(xù)處理。

這里總結(jié)了 3 種方式,分別是 CSS 、 SVG、Canvas,來(lái)看看各自有什么差異和優(yōu)缺點(diǎn)吧

一、CSS 的繪制與導(dǎo)出

首先來(lái)看 CSS ,這是最簡(jiǎn)單的繪制方式了。

假設(shè) HTML是這樣的。

<div class="text">前端偵探</div>

加點(diǎn)樣式。

.text{
display: flex;
width: 200px;
height: 200px;
justify-content: center;
align-items: center;
background-color: rebeccapurple;
color: #fff;
font-size: 36px;
font-family: MFMengYuan-Regular;
}

這里給了一個(gè)特殊的字體MFMengYuan-Regular(造字工坊夢(mèng)緣體),當(dāng)然現(xiàn)在肯定是沒(méi)有效果,因?yàn)橄到y(tǒng)并沒(méi)有這樣的字體。

圖片

為了使這個(gè)特殊字體生效,需要手動(dòng)通過(guò)@font-face去定義。

@font-face {
font-family: "MFMengYuan-Regular";
src: url("https://webfontsource.yuewen.com/api/v1/yfont/font.eot?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2"); /* IE9 */
src: local('?'),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.woff2?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2") format("woff2"),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.woff?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2") format("woff"),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.ttf?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2");
}

這里引用的是一個(gè)在線生成的字體,對(duì)于 CSS 來(lái)說(shuō)也是小菜一碟,效果如下:

圖片

是不是非常輕松?

CSS 繪制非常容易,但現(xiàn)在僅僅是視覺(jué)上的,那如何將這個(gè)樣式轉(zhuǎn)換成圖片導(dǎo)出呢?

在這里,需要借助 SVG? 中的foreignObject[1]元素,通過(guò)這個(gè)元素,可以將 HTML?嵌入到SVG中,例如:

<svg xmlns="http://www.w3.org/2000/svg">
<foreignObject width="200" height="200">
<body xmlns="http://www.w3.org/1999/xhtml">
<div>前端偵探</div>
</body>
</foreignObject>
</svg>

一些截圖工具庫(kù),比如 html2canvas都依賴 foreignObject 這個(gè)特性。

而SVG本質(zhì)上就是圖片,然后就可以將這個(gè)圖片繪制到 Canvas 上,進(jìn)一步進(jìn)行圖片合成和處理了,整體思路如下:

圖片

不過(guò)需要注意的是,SVG?是一個(gè)獨(dú)立的圖片,必須包含繪制內(nèi)容的全部信息,比如這里需要手動(dòng)將style?樣式內(nèi)嵌到div中,就像這樣(代碼結(jié)構(gòu)可能不是很好看)。

<div class="text">
<style>
@font-face {
font-family: "MFMengYuan-Regular";
src: url("https://webfontsource.yuewen.com/api/v1/yfont/font.eot?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2"); /* IE9 */
src: local('?'),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.woff2?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2") format("woff2"),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.woff?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2") format("woff"),
url("https://webfontsource.yuewen.com/api/v1/yfont/font.ttf?base64=0&fnotallow=MFMengYuan-Regular&text=%E5%89%8D%E7%AB%AF%E4%BE%A6%E6%8E%A2");
}
.text{
display: flex;
width: 200px;
height: 200px;
justify-content: center;
align-items: center;
background-color: rebeccapurple;
color: #fff;
font-size: 36px;
font-family: MFMengYuan-Regular;
}
</style>
前端偵探
</div>

接下來(lái)通過(guò)JS將其包裹上foreignObject元素,注意一下特殊字符的轉(zhuǎn)義。

const htmlSvg = `data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="${width/pixelRatio}" height="${height/pixelRatio}">
<foreignObject x="0" y="0" width="100%" height="100%">
<body xmlns="http://www.w3.org/1999/xhtml" style="height:100%;margin:0">
${dom.outerHTML}
</body>
</foreignObject></svg>`.replace(/"/g,"'").replace(/%/g,"%25").replace(/#/g,"%23").replace(/{/g,"%7B").replace(/}/g,"%7D").replace(/</g,"%3C").replace(/>/g,"%3E");
img.src = htmlSvg

這樣得到的一個(gè)??SVG??字符串就是一個(gè)完整的圖片了。

圖片

等等...圖片是出來(lái)了,不過(guò)字體好像丟失了?

為什么會(huì)這樣呢?原因在于,上面字體使用的是在線字體,在線字體在轉(zhuǎn)成字符后就是普通的字符了,不會(huì)發(fā)出請(qǐng)求,自然也不會(huì)包含字體的真實(shí)信息了,所以要解決這個(gè)問(wèn)題就必須提前將字體轉(zhuǎn)成本地??base64??格式,如下

<div class="text">
<style>
@font-face {
font-family: "MFMengYuan-Regular";
src: local('?'),
url(data:font/woff;charset=utf-8;base64,d09GRgABAAAAAAwcAA0AAAAAEPgAAAAAAAAAAAAAAAAAA...==) format('woff');
}
.text{
display: flex;
width: 200px;
height: 200px;
justify-content: center;
align-items: center;
background-color: rebeccapurple;
color: #fff;
font-size: 36px;
font-family: MFMengYuan-Regular;
}
</style>
前端偵探
</div>

這樣就正常了(SVG字符可能會(huì)比較長(zhǎng))。

圖片

同樣也能將這個(gè)圖片繪制到Canvas上。

const context = canvas.getContext('2d');
context.drawImage(htmlSvg, 0, 0, width, height);

效果如下:

圖片

除此之外,通過(guò)Canvas還能將圖片轉(zhuǎn)成blob地址,相比完整 SVG地址而言,地址更加簡(jiǎn)潔,有時(shí)候圖片過(guò)大,在賦值給圖片src會(huì)造成瀏覽器卡頓,盡量用blob方式。

canvas.toBlob(function(blob){
img.src = URL.createObjectURL(blob)
})

效果如下:

圖片

完整轉(zhuǎn)換過(guò)程可以查看以下鏈接:

  • CSS font - 碼上掘金 (juejin.cn)[2]
  • CSS font (codepen.io)[3]
  • CSS font (runjs.work)[4]

二、SVG 的繪制與導(dǎo)出

下面來(lái)看SVG方式,相比CSS而言,可能稍微麻煩一點(diǎn),主要是文本排版方面,同樣需要注意字體base64處理。

<svg id="svg" class="text" xmlns='http://www.w3.org/2000/svg' viewBox="0 0 200 200" width="200" height="200">
<style>
@font-face {
font-family: "MFMengYuan-Regular";
src: local('?'),
url(data:font/woff;charset=utf-8;base64,d09GRgABAAAAAAwcAA0AAAAAEPgAAAAAAAAAAAAAAAAAAAAAAAAAAAA...==) format('woff');
}
.text{
background-color: rebeccapurple;
}
</style>
<text x="50%" y="50%" text-anchor="middle" dominant-baseline="middle" fill="#fff" font-size="36" font-family="MFMengYuan-Regular">前端偵探</text>
</svg>

這里需要注意一下 SVG 中的文本居中方式,用到了dominant-baseline(基線對(duì)齊)和text-anchor(錨點(diǎn)對(duì)齊),如下:

圖片

兩者結(jié)合,再配合x=50%和y=50%就實(shí)現(xiàn)了水平垂直居中效果了,如下:

圖片

由于已經(jīng)是SVG了,所以導(dǎo)出圖片或者繪制到Canvas畫布上就更方便,只需要將整個(gè) dom 結(jié)構(gòu)轉(zhuǎn)義一下就可以了,無(wú)需額外包裹。

const htmlSvg = `data:image/svg+xml,${dom.outerHTML}`.replace(/"/g,"'").replace(/%/g,"%25").replace(/#/g,"%23").replace(/{/g,"%7B").replace(/}/g,"%7D").replace(/</g,"%3C").replace(/>/g,"%3E");
img.src = htmlSvg

效果如下:

圖片

繪制到Canvas上也是同樣的方式。

const context = canvas.getContext('2d');
context.drawImage(htmlSvg, 0, 0, width, height);

效果如下:

圖片

完整轉(zhuǎn)換過(guò)程可以查看以下鏈接:

  • SVG font - 碼上掘金 (juejin.cn)[5]
  • SVG font (codepen.io)[6]
  • SVG font (runjs.work)[7]

三、Canvas 的繪制與導(dǎo)出

最后是 Canvas方式。

這里要繪制的很簡(jiǎn)單,就是一個(gè)矩形和一行文字,主要步驟如下:

const context = canvas.getContext('2d');
context.fillStyle = 'rebeccapurple'// 填充顏色
context.fillRect(0,0,width,height) // 繪制矩形
context.fillStyle = '#fff' // 填充顏色
context.font = `36px MFMengYuan-Regular`; // 設(shè)置字體屬性
context.textAlign = 'center'; // 設(shè)置文本對(duì)齊
context.textBaseline = 'middle' // 設(shè)置基線對(duì)齊
context.fillText('前端偵探', width/2, height/2); // 繪制文本

效果如下:

? 圖片 ?

不出意料,字體果然沒(méi)有繪制,因?yàn)橄到y(tǒng)并沒(méi)有這種字體,那如何主動(dòng)添加字體呢?

這里有一個(gè)策略,Canvas讀取的是頁(yè)面上已經(jīng)渲染過(guò)的字體,也就是說(shuō)頁(yè)面上如果提前渲染過(guò)該字體,那么在繪制的時(shí)候就可以直接繪制出來(lái),如果字體是動(dòng)態(tài)的,可以通過(guò)動(dòng)態(tài)創(chuàng)建。

const fontStyle = `
@font-face {
font-family: "MFMengYuan-Regular";
src: local('?'),
url(data:font/woff;charset=utf-8;base64,d09GRgABAAAAAAwcAA0AAAAAEPgAAAAAAAAAAA...==) format('woff');
}
`
const style = document.createElement('style')
style.textContent = fontStyle
document.head.appendChild(style)

現(xiàn)在重新繪制,如下:

圖片

可以看到,起初是沒(méi)有字體的,刷新后才繪制新的字體。

原因是,前面這段代碼僅僅是表示頁(yè)面有這個(gè)字體,但是并沒(méi)有渲染過(guò),通過(guò)Canvas繪制后,這個(gè)字體才真正被渲染,所以到了第二次字體才生效。

知道原因后,解決就很簡(jiǎn)單了。如果不是實(shí)時(shí)繪制,比如說(shuō)預(yù)覽狀態(tài)通過(guò) CSS 繪制,那么等到 Canvas 繪制的時(shí)候(比如通過(guò)按鈕點(diǎn)擊生成預(yù)覽圖),字體當(dāng)然已經(jīng)渲染過(guò),自然也不會(huì)有這個(gè)問(wèn)題。如果一定要實(shí)時(shí)繪制,可以采用逐幀比對(duì)的方式,一旦圖像發(fā)生變化,就表示字體渲染成功,實(shí)現(xiàn)如下

該方法參考自張?chǎng)涡窭蠋熯@篇文檔:canvas API中文網(wǎng) - 中文文檔 - CanvasRenderingContext2D.font[8]。

// 先隨便繪制一個(gè)字體
context.font = `36px UNKNOW`;
context.fillText('前端偵探', width/2, height/2);
const dataDefault = context.getImageData(0, 0, width/4, height/2).data;
const detect = function () {
// 然后繪制實(shí)際字體
context.font = `36px MFMengYuan-Regular`;
context.fillText('前端偵探', width/2, height/2);
// 如果前后數(shù)據(jù)一致,說(shuō)明字體還沒(méi)加載成功,繼續(xù)檢測(cè)
var dataNow = context.getImageData(0, 0, width/4, height/2).data;
if ([].slice.call(dataNow).join('') == [].slice.call(dataDefault).join('')) {
console.log('沒(méi)有變化,重新渲染')
requestAnimationFrame(detect);
}
};

這樣就可以實(shí)時(shí)繪制特殊字體了。

圖片

Canvas本身就是圖片了,直接可以轉(zhuǎn)換成圖片或者導(dǎo)出,這里就不多介紹了。

完整實(shí)現(xiàn)過(guò)程可以查看以下鏈接:

  • Canvas font - 碼上掘金 (juejin.cn)[9]
  • Canvas font (codepen.io)[10]
  • Canvas font (runjs.work)[11]

四、總結(jié)一下各自優(yōu)缺點(diǎn)

下面簡(jiǎn)單整理了一下各自實(shí)現(xiàn)的難易程度。

CSS繪制最簡(jiǎn)單,尤其是在文本排版方面,要遠(yuǎn)遠(yuǎn)領(lǐng)先其他兩種方式。

SVG繪制相對(duì)比較簡(jiǎn)單,在矢量圖形處理,比如描邊特效要比 CSS 更有優(yōu)勢(shì),這兩種方式導(dǎo)出的難點(diǎn)在于一些外鏈資源的額外處理。

而Canvas繪制稍微復(fù)雜一些,在特殊字體需要逐幀去檢測(cè)是否渲染,優(yōu)點(diǎn)是繪制出來(lái)就是圖片,無(wú)需額外導(dǎo)出。


繪制

導(dǎo)出

CSS

??????(簡(jiǎn)單)

????(一般)

SVG

????(一般)

????(一般)

Canvas

??(復(fù)雜)

????????(超級(jí)簡(jiǎn)單)

關(guān)于 CSS 和 SVG 的選擇可以看實(shí)際文本排版需求,比如文本需要換行,字號(hào)大小也不一致,像這種情況 CSS 就比較有優(yōu)勢(shì)了,無(wú)需去精確計(jì)算文本坐標(biāo)。

另外,在實(shí)際工作中,根據(jù)需求可能需要多種方式結(jié)合使用,也就是預(yù)覽狀態(tài)和導(dǎo)出狀態(tài)分別用不同的方式實(shí)現(xiàn),比如圖片混合,在預(yù)覽狀態(tài)完全可以通過(guò) CSS 實(shí)現(xiàn),在導(dǎo)出時(shí)才通過(guò) Canvas 去繪制合成。

參考資料

[1]foreignObject: https://developer.mozilla.org/en-US/docs/Web/SVG/Element/foreignObject?。

[2]CSS font - 碼上掘金 (juejin.cn): https://code.juejin.cn/pen/7170205919391776801?。

[3]CSS font (codepen.io): https://codepen.io/xboxyan/pen/oNydKrv?。

[4]CSS font (runjs.work): https://runjs.work/projects/62abc5942d9042b5?。

[5]SVG font - 碼上掘金 (juejin.cn): https://code.juejin.cn/pen/7170214063337635853?。

[6]SVG font (codepen.io): https://codepen.io/xboxyan/pen/zYaaOvb?。

[7]SVG font (runjs.work): https://runjs.work/projects/e2ff8774f0d0463b?。

[8]canvas API中文網(wǎng) - 中文文檔 - CanvasRenderingContext2D.font: https://www.canvasapi.cn/CanvasRenderingContext2D/font#&others?。

[9]Canvas font - 碼上掘金 (juejin.cn): https://code.juejin.cn/pen/7170227469218218014?。

[10]Canvas font (codepen.io): https://codepen.io/xboxyan/pen/ExRRYMV?。

[11]Canvas font (runjs.work): https://runjs.work/projects/fc8d17a0c2494531?。

責(zé)任編輯:姜華 來(lái)源: 前端偵探
相關(guān)推薦

2023-01-09 11:33:25

CSS寫作網(wǎng)格線

2024-04-08 09:11:13

SVG前端CSS

2021-12-13 20:08:28

理論渲染技術(shù)

2010-08-20 14:47:02

IEFirefoxCSS

2010-09-02 13:53:58

CSS Sprites

2024-05-16 10:35:09

SVGCSS背景平鋪

2022-11-14 11:41:13

SVG開(kāi)發(fā)組件

2017-04-05 16:30:09

Node.jsFFmpeg Canvas

2010-09-06 10:16:21

CSS字體

2022-02-28 15:52:07

canvasHarmonyOS鴻蒙

2012-02-22 15:41:50

HTML 5

2012-05-07 14:25:16

HTML5

2024-01-29 09:33:48

CSS前端SVG

2012-02-24 15:28:36

ibmdw

2022-07-05 16:21:44

繪制表盤鴻蒙

2022-12-18 22:11:46

2010-09-30 14:55:23

Javascriptfloat

2023-05-08 09:08:33

CSS前端

2010-09-02 09:59:52

CSS SpritesCSS

2022-05-18 20:02:47

SVGcanvasChrome 插件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美激情综合五月色丁香| 懂色av粉嫩av蜜臀av一区二区三区| av丝袜天堂网| 国产精品天天操| 日韩最新在线| 亚洲成人一区二区在线观看| 日韩亚洲欧美成人| 久久婷婷五月综合色国产香蕉| 国产网址在线观看| 成人在线日韩| 国产精品伦一区二区三级视频| 在线播放日韩av| 久久久亚洲精品无码| 99视频在线观看免费| 久久影视一区| 欧美在线视频日韩| 美乳视频一区二区| 中文字幕亚洲高清| 国产成人aa在线观看网站站| 一区二区视频在线| 91欧美激情另类亚洲| 五月天色婷婷丁香| 99tv成人影院| 成人欧美一区二区三区视频网页| 久久国产精品久久久久久| 久久婷婷综合色| 国产精品一区在线看| 136福利精品导航| 亚洲欧美视频一区| 91亚洲精品在线观看| 日韩精品1区2区| 中文视频一区| 日韩免费高清av| 亚洲中文字幕无码一区二区三区| 国产专区第一页| 天堂成人娱乐在线视频免费播放网站 | 国内国产精品久久| 一区二区福利视频| 在线免费看黄色片| 久久综合五月天| gogo亚洲国模私拍人体| 日本在线视频网址| 国产69精品久久99不卡| 午夜免费在线观看精品视频| 国产制服丝袜在线| 姬川优奈av一区二区在线电影| 国产毛片精品一区| 欧美精品videosex极品1| 99热超碰在线| 秋霞午夜一区二区三区视频| 亚洲成人福利片| 午夜久久久久久久久久久| 精品国产乱码久久久久久蜜臀网站| 欧美做受69| 日本福利一区二区| 中文字幕制服丝袜在线| 国产精品视频一区二区三区,| 欧美激情偷拍| 欧美人与禽zozo性伦| 国产奶头好大揉着好爽视频| 在线中文资源天堂| 国产经典欧美精品| 欧美一级黑人aaaaaaa做受| 丰满的亚洲女人毛茸茸| 国产麻豆精品| 777色狠狠一区二区三区| 福利视频免费在线观看| 福利视频在线看| 国产亚洲欧美日韩日本| ts人妖另类在线| 中文字幕手机在线视频| 欧美日韩国产精品一区二区亚洲| 亚洲国产成人精品久久久国产成人一区 | 国产午夜精品麻豆| 久久久久国产一区| 男女在线观看视频| 国产女人水真多18毛片18精品视频| 成人午夜在线视频一区| 国产精品成人久久| 在线亚洲精品| 久久黄色av网站| 国产精品jizz| 清纯唯美激情亚洲| 精品国产乱码久久久久久图片| 天天综合五月天| 综合久久2019| 中文字幕第一区| 精品免费一区二区三区蜜桃| 国产精品视频在线观看免费| 国产精品综合一区二区三区| 99在线国产| 手机看片福利在线观看| 国产精品亚洲一区二区三区妖精| 国产精品电影在线观看| 亚洲欧美一区二区三区四区五区| 在线播放一区二区精品视频| 亚洲第一网站免费视频| 国产福利在线观看视频| 澳门精品久久国产| 91麻豆精品国产91久久久使用方法| 欧美日本视频在线观看| 五月天激情在线| 欧美性videos高清精品| 日韩亚洲欧美视频| 日韩经典一区| 欧美午夜xxx| 57pao国产成永久免费视频| 日本成人片在线| 欧美一区二区三区免费观看视频 | 91久久精品国产91性色69| 一区二区激情| 成人福利视频在线观看| 午夜视频在线免费播放| 岛国精品在线播放| 国产aⅴ精品一区二区三区黄| 日韩av一二三区| 欧美午夜一区| 欧洲日韩成人av| 在线观看亚洲欧美| 精品一区二区三区av| 国产精品永久在线| 中文字幕在线观看你懂的| 日韩制服丝袜av| 国产精品视频久久久| 中文人妻熟女乱又乱精品| 成人爽a毛片一区二区免费| 亚洲乱码一区二区三区三上悠亚| 日本一区二区不卡在线| 日本欧美一区二区三区| 国产日韩换脸av一区在线观看| 亚洲一区二区观看| 伊人久久大香线蕉综合四虎小说| 久久成年人免费电影| 欧美一区二区三区久久久| 日韩国产在线观看一区| 国产精品毛片va一区二区三区| 老熟妇一区二区三区啪啪| 青青草精品视频| 国产一区二区三区高清| 青青草免费观看免费视频在线| 国产伦精品一区二区三区在线观看| 亚洲一区久久久| 免费观看黄色av| 成人黄色网址在线观看| 久久一区免费| 岛国片av在线| 91福利精品第一导航| aaaa黄色片| 亚洲激情专区| 国产精品日韩专区| 国产一二在线观看| 国产精品高潮久久久久无| 4444在线观看| 性国裸体高清亚洲| 欧美丰满少妇xxxbbb| youjizz.com日本| 久久不见久久见免费视频7| 久久精品国产精品| 一级黄色片在线| 国产精品嫩草久久久久| 在线免费观看视频黄| 不卡一区2区| 高清欧美性猛交xxxx| 亚洲午夜在线播放| 欧美国产精品一区二区三区| 狠狠躁狠狠躁视频专区| 99九九热只有国产精品| 97视频在线观看亚洲| 人妻精品一区一区三区蜜桃91| 欧美国产禁国产网站cc| 久久久久久蜜桃一区二区| 91久久夜色精品国产按摩| 91久久久久久久久久| 在线视频国产区| 精品成人一区二区三区四区| 日本少妇吞精囗交| 26uuu国产日韩综合| 成年人三级视频| 91综合久久爱com| 91av国产在线| 国产高中女学生第一次| 亚洲成人7777| 久久美女免费视频| 亚洲欧洲日本mm| 免费看成人午夜电影| 69堂免费精品视频在线播放| 日韩欧美一级二级三级| 久久久久性色av无码一区二区| 国产综合自拍| 国产精品一区二区久久精品 | 久久精品国产精品亚洲红杏| 国产一级精品aaaaa看| 黄色成人免费网| 亚洲第一免费播放区| 怡红院av久久久久久久| 亚洲人精品午夜| 国产高清自拍视频| 久久精品国产77777蜜臀| 麻豆md0077饥渴少妇| 欧美性生活一级片| 国产在线不卡精品| 久草在线资源站手机版| 欧美成va人片在线观看| 天海翼在线视频| 99久久99久久精品国产片果冻 | 日韩一级在线播放| 在线观看91视频| 久久综合久久鬼| 中文字幕欧美日韩一区| 中文字幕乱妇无码av在线| 噜噜噜91成人网| 精品国产综合久久| 91成人精品观看| 日韩免费不卡av| 韩国中文免费在线视频| 日韩午夜av一区| 91视频免费在线看| 久久精品人人做| 丰满少妇xbxb毛片日本| 精品一区二区在线观看| 国产l精品国产亚洲区久久| 丝袜连裤袜欧美激情日韩| 成人在线一区二区| 欧美三级精品| 久久免费国产精品1| 韩国中文字幕在线| 欧美不卡一区二区三区| 中文字幕永久在线视频| 色综合一个色综合| 国产探花视频在线播放| 91亚洲精品乱码久久久久久蜜桃| 日韩在线综合网| 欧美96在线丨欧| 在线电影看在线一区二区三区| 国模精品视频| 亚洲欧美日韩国产中文专区| 探花国产精品一区二区| 午夜影视日本亚洲欧洲精品| 无码一区二区三区在线| 99久久国产免费看| 日韩av无码一区二区三区不卡| 一区二区免费不卡在线| 欧美视频观看一区| 亚洲伦理久久| 国产精品丝袜白浆摸在线 | 欧美精品九九久久| 国产在线激情视频| 久久婷婷国产麻豆91天堂| 欧美激情二区| 日韩欧美专区在线| 国产精品一区二区av白丝下载| 亚洲福利视频三区| 国产在线视频在线观看| 亚洲一区二区三区精品在线| 短视频在线观看| 99国产精品久| 日本免费福利视频| 91麻豆国产自产在线观看| 丰满少妇一区二区三区| 久久先锋影音av| 天天操天天干天天做| 另类小说综合欧美亚洲| 亚洲黄色片免费| 久久欧美肥婆一二区| 亚洲一区二区免费视频软件合集 | 香蕉久久一区二区不卡无毒影院| 色欲AV无码精品一区二区久久| 亚洲神马久久| 亚洲三级一区| 先锋资源久久| 欧美日韩一区二区视频在线观看| 亚洲人体在线| 亚洲a区在线视频| 粉嫩的18在线观看极品精品| 精品欧美一区二区久久久伦 | 国产在线不卡| r级无码视频在线观看| 欧美日韩一区二区三区视频播放| 国产成人激情小视频| 免费影视亚洲| 清纯唯美亚洲激情| 高清电影一区| 亚洲va国产va天堂va久久| 岛国av一区| 日韩亚洲欧美精品| 香蕉久久夜色精品国产更新时间| 91九色国产视频| 在线日韩成人| 午夜视频久久久| 九九视频免费观看视频精品| 亚洲国产精品毛片| 欧美日韩国产综合网| 精品少妇人欧美激情在线观看| 91精品推荐| 国产高清av在线播放| 男人的j进女人的j一区| 国产精品丝袜久久久久久消防器材| 午夜电影亚洲| 成人久久久久久久久| 国产一区二区三区四区在线观看| 日本福利视频在线观看| 一本色道久久综合亚洲精品高清| 秋霞无码一区二区| 麻豆一区二区在线| 日韩av无码一区二区三区不卡| 懂色av中文字幕一区二区三区| 中文字幕第22页| 久久黄色级2电影| 国产69视频在线观看| 欧美激情一区三区| 国产污视频在线看| 欧美日韩久久不卡| 亚洲欧洲精品视频| 欧美大片va欧美在线播放| 欧美一区 二区 三区| 日韩美女主播视频| 大奶一区二区三区| 制服诱惑一区| 日韩激情在线观看| 国产精品久久无码| 一区二区欧美国产| 日本一二三区不卡| 日韩一区二区在线播放| 超碰免费在线| 久久激情五月丁香伊人| 日韩性xxx| 国产日韩精品推荐| 午夜日韩在线| 欧美一级免费在线| 国产精品久久久久毛片软件| 自拍偷拍18p| 国产视频久久网| 久草免费在线视频| 国产精品一区二区不卡视频| 亚洲欧洲美洲一区二区三区| 成人性生交免费看| 中文字幕第一页久久| 超碰在线97观看| 国产性色av一区二区| 国产激情视频在线| 欧美国产亚洲精品久久久8v| 特黄毛片在线观看| 国产在线欧美日韩| 国产在线成人| 黄色性视频网站| 亚洲第一搞黄网站| 色欲av伊人久久大香线蕉影院| 日韩精品一区二区三区在线播放 | 欧美成人精品三级网站| 蜜桃精品久久久久久久免费影院| 久久要要av| 五月婷婷六月丁香激情| 国产精品日韩成人| 国产精品露脸视频| 精品国产拍在线观看| 成人免费91| 久久观看最新视频| 高清视频一区二区| 激情综合网五月婷婷| 亚洲精品国精品久久99热| 18视频免费网址在线观看| 国产精品免费久久久久久| 成人激情电影在线| 色戒在线免费观看| 亚洲欧美aⅴ...| 无码人妻丰满熟妇区bbbbxxxx| 777久久久精品| av在线导航| 国产激情美女久久久久久吹潮| 欧洲杯半决赛直播| mm131亚洲精品| 亚洲女同一区二区| 国产富婆一级全黄大片| 91国内揄拍国内精品对白| 亚洲黄页网站| 亚洲国产精品成人天堂| 91蜜桃传媒精品久久久一区二区| 欧美精品色哟哟| 欧美三级三级三级| 日本人妖在线| 国产精品爽爽ⅴa在线观看| 欧美在线影院| 久久国产精品无码一级毛片| 欧美日韩一区中文字幕| 在线中文字幕视频观看| 久久久久久国产精品免费免费| 亚洲宅男一区| 人妻丰满熟妇av无码区app| 中文字幕av免费专区久久| 国产成人三级一区二区在线观看一| 色老头一区二区三区在线观看| 成人影院免费观看| 91久久精品国产91久久| 99国产精品视频免费观看一公开 | 亚洲男人av在线| 久久国内精品| 欧美一区二区三区四区夜夜大片| 成人在线免费观看91| 欧美一级小视频| 亚洲高清免费视频|