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

一張漂亮的可視化圖表背后

開發 開發工具
這篇文章討論了可視化作品背后的一些視覺元素理論,以及人類的視覺識別機制。在這些機制的基礎上,介紹了如何運用常用的設計原則來進行視覺編碼。

一、可視化之根

多年前讀過一篇非常震撼的文章,叫《Lisp之根》(英文版:The roots of Lisp),大意是Lisp僅僅通過一種數據結構(列表)和有限的幾個函數,就構建出了一門極為簡潔,且極具擴展性的編程語言。當時就深深的被這種設計哲學所震撼:一方面它足夠簡單,每個單獨的函數都足夠簡單,另一方面它有非常復雜,像宏,高階函數,遞歸等機制可以構建出任意復雜的程序,而復雜的機制又是由簡單的組件組成的。

數據的可視化也是一樣,組成一幅內容清晰、表達力強、美觀的可視化信息圖的也僅僅是一些基本的元素,這些元素的不同組合卻可以產生出令人著迷的力量。

要列出“可視化元素之根”很容易:位置、長度、角度、形狀、紋理、面積(體積)、色相、飽和度等幾種有限的元素,邱南森在他的《數據之美》中提供了一張視覺元素的圖,其中包含了大部分常用的元素。

邱南森在他的《數據之美》中提供了一張視覺元素的圖

令人振奮的是,這些元素可以自由組合,而且組合旺旺會產生1+1>2的效果。

二、心理學與認知系統

數據可視化其實是基于人類的視覺認知系統的,因此對人類視覺系統的工作方式有一些了解可以幫助我們設計出更為高效(更快的傳遞我們想要表達的信息給讀者)的可視化作品。

1. 心理物理學

在生活中,我們會遇到這樣的場景:一件原價10元的商品,如果降價為5元,則消費者很容易購買;而一件原價100元的商品,降價為95元,則難以刺激消費者產生購買的沖動。這兩個打折的絕對數字都是5元,但是效果是不一樣的。

韋伯-費希納定理描述的正是這種_非理性_的場景。這個定理的一個比較裝逼的描述是:

【感覺量與物理量的對數值成正比,也就是說,感覺量的增加落后于物理量的增加,物理量成幾何級數增長,而心理量成算術級數增長,這個經驗公式被稱為費希納定律或韋伯-費希納定律。

—— 摘自百度百科】

這個現象由人類的大腦構造而固有,因此在設計可視化作品時也應該充分考慮,比如:

  • 避免使用面積圖作為對比
  • 在做對比類圖形時,當差異不明顯時需要考慮采用非線性的視覺元素
  • 選用多種顏色作為視覺編碼時,差異應該足夠大

比如:

設計可視化

如上圖中,當面積增大之后,肉眼越來越難從形狀的大小中解碼出實際的數據差異,上邊的三組矩形(每行的兩個為一組),背后對應的數據如下,可以看到每組中的兩個矩形的絕對差都是5:

  1. var data = [ 
  2.   {width: 5, height: 5}, 
  3.   {width: 10, height: 10}, 
  4.  
  5.   {width: 50, height: 50}, 
  6.   {width: 55, height: 55}, 
  7.  
  8.   {width: 100, height: 100}, 
  9.   {width: 105, height: 105} 
  10. ]; 

2. 格式塔學派

格式塔學派是心理學中的一個重要流派,她強調整體認識,而不是結構主義的組成說。格式塔認為,人類在看到畫面時,會優先將其簡化為一個整體,然后再細化到每個部分;而不是先識別出各個部分,再拼接為整體。

比如那條著名的斑點狗:

斑點狗

我們的眼睛-大腦可以很容易的看出陰影中的斑點狗,而不是先識別出狗的四條腿或者尾巴(事實上在這張圖中,人眼無法識別出各個獨立的部分)。

格式塔理論有幾個很重要的原理:

  • 接近性原理
  • 相似性原理
  • 封閉性原理
  • 連續性原理
  • 主體/背景原理

當然,格式塔學派后續還有一些發展,總結出了更多的原理。工程上,這些原理還在大量使用,指導設計師設計各式各樣的用戶界面。鑒于網上已經有眾多的格式塔理論及其應用的文章,這里就不在贅述。有興趣的同學可以參考這幾篇文章:

  • 優設上的一篇格式塔文章
  • 優設上的一篇關于格式塔與Web設計的文章
  • 騰訊CDC的一篇格式塔介紹

三、視覺設計的基本原則

《寫給大家看的設計書》一書中,作者用通俗易懂的方式給出了幾條設計的基本原則,這些原則完全可以直接用在數據可視化中的設計中:

  • 親密性(將有關聯的信息物理上放在一起,而關聯不大的則通過留白等手段分開)
  • 對齊(將元素通過水平,垂直方向對齊,方便視覺識別)
  • 重復(重復使用某一模式,比如標題1的字體顏色,標題2的字體顏色等,保持重復且一致)
  • 對比(通過強烈的對比將不同的信息區分開)

視覺設計的基本原則

如果稍加留意,就會發現現實世界中在大量的使用這幾個原則。1,2,3三個標題的形式就是重復性的體現;每個標題的內容自成一體是因為組成它的元素(數字,兩行文字)的距離比較近,根據親密性原則,人眼會自動將其歸為一類;超大的數字字體和較小的文字形成了對比;大標題的顏色和其他內容形成了對比等等。

這些原則其實跟上面提到的格式塔學派,以及韋伯-費希納定理事實上是相關的,在理解了這些人類視覺識別的機制之后,使用這些原則就非常自然和得心應手了。

一些例子

  • 淡化圖表的網格(和數據圖形產生對比)
  • 通過深色來強調標尺(強烈的線條和其余部分產生對比)
  • 離群點的高亮(通過不同顏色產生對比)
  • 使用顏色(通過不同的顏色,利用親密性原則方便讀者對數據分組)
  • 元素顏色和legend(使用重復性原則)
  • 同一個頁面上有多個圖表,采取同樣的圖例,色彩選擇(強調重復性原則)

視覺設計的基本原則

四、實例

上篇文章提到我通過一個手機App收集到了女兒成長的一些記錄,包括哺乳信息,換尿布記錄,以及睡眠信息。這個例子中,我會一步步的介紹如何將這些信息可視化出來,并解釋其中使用的視覺原理。

可視化的第一步是要明確你想要從數據中獲取什么信息,我想要獲取的信息是孩子的睡眠總量以及睡眠時間分布情況。

1. 進階版的條形圖

確定了可視化的目的之后,第二步是選取合適的視覺編碼。上面提到過,對于人眼來說,最精確的視覺編碼方式是長度。我們可以將睡眠時間轉化為長度來展現,最簡單的方式是按天聚合,然后化成柱狀圖。比如:

  1. 2016/11/21,768 
  2. 2016/11/22,760 
  3. 2016/11/23,700 

不過這種圖無法看出時間的分布。我們可以考慮通過條形圖的變體來滿足前面提到的兩個核心訴求。先來在紙上畫一個簡單的草圖。縱軸是24小時,橫軸是日期。和普通的條形圖不一樣的是,每個條形的總長度是固定的,而且條形代表的不是簡單非數據類型,而是24小時。在草稿中,每個畫斜線的方塊表示孩子在睡眠狀態,而虛線部分表示她醒著。

進階版的條形圖

2. 原始數據

  1. name,date,length,note 
  2. 心心,2016/11/21 19:23,119, 
  3. 心心,2016/11/21 22:04,211, 
  4. 心心,2016/11/22 02:03,19, 
  5. 心心,2016/11/22 02:23,118, 
  6. 心心,2016/11/22 05:58,242, 
  7. 心心,2016/11/22 10:57,128, 
  8. 心心,2016/11/22 14:35,127, 
  9. 心心,2016/11/22 17:15,127, 
  10. 心心,2016/11/22 20:02,177, 
  11. 心心,2016/11/23 01:27,197, 

這里有個問題,我們的縱軸是24小時,如果她晚上23點開始睡覺,睡了3個小時,那么這個條形就回超出24格的軸。我寫了一個函數來做數據轉換:

  1. require 'csv' 
  2. require 'active_support/all' 
  3. require 'json' 
  4.  
  5. csv = CSV.read('./visualization/data/sleeping_data_refined.csv', :headers => :first_row) 
  6.  
  7. data = [] 
  8. csv.each do |row| 
  9.   date = DateTime.parse(row['date'], "%Y/%m/%d %H:%M") 
  10.  
  11.   mins_until_end_of_day = date.seconds_until_end_of_day / 60 
  12.   diff = mins_until_end_of_day - row['length'].to_i 
  13.  
  14.   if (diff >= 0) then 
  15.     data << { 
  16.       :name => row['name'], 
  17.       :date => row['date'], 
  18.       :length => row['length'], 
  19.       :note => row['note'] 
  20.     } 
  21.   else 
  22.     data << { 
  23.       :name => row['name'], 
  24.       :date => date.strftime("%Y/%m/%d %H:%M"), 
  25.       :length => mins_until_end_of_day, 
  26.       :note => row['note'] 
  27.     } 
  28.  
  29.     data << { 
  30.       :name => row['name'], 
  31.       :date => (date.beginning_of_day + 1.day).strftime("%Y/%m/%d %H:%M"), 
  32.       :length => diff.abs, 
  33.       :note => row['note'] 
  34.     } 
  35.   end 
  36. end 

有了干凈的數據之后,我們可以編寫一些前端的代碼來繪制條形圖了。畫圖的時候有幾個要注意的點:

  • 每天內的時間段對應的矩形需要有相同的X坐標
  • 不同的睡眠長度要有顏色區分(睡眠時間越長,顏色越深)
  1. require 'csv' 
  2. require 'active_support/all' 
  3. require 'json' 
  4.  
  5. csv = CSV.read('./visualization/data/sleeping_data_refined.csv', :headers => :first_row) 
  6.  
  7. data = [] 
  8. csv.each do |row| 
  9.   date = DateTime.parse(row['date'], "%Y/%m/%d %H:%M") 
  10.  
  11.   mins_until_end_of_day = date.seconds_until_end_of_day / 60 
  12.   diff = mins_until_end_of_day - row['length'].to_i 
  13.  
  14.   if (diff >= 0) then 
  15.     data << { 
  16.       :name => row['name'], 
  17.       :date => row['date'], 
  18.       :length => row['length'], 
  19.       :note => row['note'] 
  20.     } 
  21.   else 
  22.     data << { 
  23.       :name => row['name'], 
  24.       :date => date.strftime("%Y/%m/%d %H:%M"), 
  25.       :length => mins_until_end_of_day, 
  26.       :note => row['note'] 
  27.     } 
  28.  
  29.     data << { 
  30.       :name => row['name'], 
  31.       :date => (date.beginning_of_day + 1.day).strftime("%Y/%m/%d %H:%M"), 
  32.       :length => diff.abs, 
  33.       :note => row['note'] 
  34.     } 
  35.   end 
  36. end 

函數getFirstInDomain可以根據一個日期值返回一個X坐標,這樣2016/11/21 19:23和2016/11/21 22:04都會返回一個整數值(借助d3提供的標尺函數)。

另外,我們根據每次睡覺的分鐘數將睡眠質量劃分為5個等級:

  1. var level = d3.scale.threshold() 
  2.   .domain([60, 120, 180, 240, 300]) 
  3.   .range(["low", "fine", "medium", "good", "great", "prefect"]); 

然后在繪制過程中,根據實際數據值來確定不同的CSS Class:

  1. svg.selectAll(".bar") 
  2.   .data(data) 
  3.   .enter() 
  4.   .append("rect") 
  5.   .attr("class", function(d) { 
  6.     return level(d.length)+" bar"; 
  7.   }) 
  8. //... 

實現之后,看起來是這個樣子的。事實上這個圖標可以比較清楚的看出大部分睡眠集中在0-6點,而中午的10-13點以及黃昏18-20點基本上只有一些零星的睡眠。

原始數據

3. 星空圖

上面的圖有一個缺點,是當日期很多的時候(上圖差不多有100天的數據),X軸會比較難畫,如果縮減成按周,或者按月,又會增加很多額外的復雜度。

另外一個嘗試是變形:既然這個統計是和時間相關的,那么圓形的鐘表形象是一個很好的隱喻,每天24小時自然的可以映射為一個圓。而睡眠時間可以通過弧長來表示,睡眠時間越長,弧長越大:

星空圖

4. 角度轉弧度

我們首先將整個圓(360度)按照分鐘劃分,則每分鐘對應的角度數為:360/(24*60),再將角度轉化為弧度:degree * π/180:

  1. var perAngle = (360 / (24 * 60)) * (Math.PI/180); 

那么對于指定的時間,比如10:20,先計算出其分鐘數:10*60+20,再乘以preAngle,就可以得出起始弧度;起始時間的分鐘數加上睡眠時長,再乘以preAngle,就是結束弧度。

  1. function startAngle(date) { 
  2.   var start = (date.getHours() * 60 + date.getMinutes()) * perAngle; 
  3.   return Math.floor(start*1000)/1000; 
  4.  
  5. function endAngle(date, length) { 
  6.   var end = (date.getHours() * 60 + date.getMinutes() + length) * perAngle; 
  7.   return Math.floor(end*1000)/1000; 

實現的結果是這樣的:

星空圖

初看起來,它像是星空圖,但是圖中的不同顏色含義沒有那么直觀,我們需要在圖上補充一個圖例。通過使用d3的線性標尺和定義svg的漸變來實現,定義好漸變和漸變的顏色取值范圍之后,就可以來繪制圖例了。

星空圖

圖上的每段弧都會有鼠標移動上去的tooltip,這樣可以很好的和讀者大腦中的鐘表隱喻對照起來,使得圖表更容易理解。

星空圖

由于我將整個圓分成了24份,這點和普通的鐘表事實上有差異,那么如果加上鐘表的刻度,會不會更好一些呢?從結果來看,這樣的標線反而有點畫蛇添足,所以我在最后的版本中去掉了鐘表的標線。

可以看到,我們通過圓形的鐘表隱喻來體現每一天的睡眠分布,然后用顏色的深淺來表示每次睡眠的時長。由于鐘表的形象已經深入人心,因此讀者很容易發現0點在圓環群的正上方。中心的黃色實心圓幫助讀者視線先聚焦在最內側的圓上,然后逐漸向外,這和日期的分布方向正好一致。

最終的結果在這里:心心的睡眠記錄,完整的代碼在這里。

5. 更進一步

一個完整的可視化作品,不但要運用各種視覺編碼來將數據轉換為視覺元素,背景信息也同樣重要。既然這個星空圖是關于睡眠主題的,那么一個包含她在睡覺的圖片集合則會加強這種視覺暗示,幫助讀者快速理解。

6. 制作背景圖

我從相冊中選取了很多女兒睡覺時拍的照片,現在需要有個工具將這些照片縮小成合適大小,然后拼接成一個大的圖片。這其中有很多有趣的地方,比如圖片有橫屏、豎屏之分,有的還是正方形的,我需要讓縮放的結果是正方形的,這樣容易拼接一些。

好在有imagemagick這種神器,只需要一條命令就可以做到:

  1. $ montage *.jpg -geometry +0+0 -resize 128x128^ \ 
  2. -gravity center -crop 128x128+0+0 xinxin-sleeping.jpg 

這條命令將當前目錄下的所有的jpg文件縮放成128x128像素,并從中間開始裁剪-gravity center,+0+0表示圖片之間的縫隙,最后將結果寫入到xinxin-sleeping.jpg中。

拼接好圖片之后,就可以通過CSS或者圖片編輯器為其添加模糊效果,并設置深灰色半透明遮罩。

  1. body { 
  2.   background-image:url('/xinxin-sleeping.png'); 
  3.   background-size:cover; 
  4.   background-position:center; 

當然,背景信息只是補充作用,需要避免喧賓奪主。因此圖片做了模糊處理,且加上了深灰色的半透明Mask(此處應用了格式塔理論中的主體/背景原理)。

五、小結

這篇文章討論了可視化作品背后的一些視覺元素理論,以及人類的視覺識別機制。在這些機制的基礎上,介紹了如何運用常用的設計原則來進行視覺編碼。最后,通過一個實例來介紹如何運用這些元素 – 以及更重要的,這些元素的組合 – 來制作一個漂亮的、有意義的可視化圖表。

【本文是51CTO專欄作者“ThoughtWorks”的原創稿件,微信公眾號:思特沃克,轉載請聯系原作者】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2017-03-03 09:31:06

可視化圖表

2015-08-03 11:07:36

數據可視化

2015-08-20 10:04:40

可視化

2020-03-01 14:01:22

Echarts數據可視化圖表

2023-06-11 16:12:14

數據可視化圖表類型

2023-08-01 16:01:59

可視化Seaborn

2021-04-09 10:42:03

數據可視化框架大數據

2022-05-30 08:37:34

可視化圖表項目開源

2022-08-23 12:32:37

Python可視化圖表

2021-10-11 08:04:22

Python數據行程

2019-05-28 11:52:43

可視化圖表數據

2022-07-13 15:54:14

Matplotlib圖表

2020-03-11 14:39:26

數據可視化地圖可視化地理信息

2022-11-28 15:04:42

數據可視化工具

2024-05-22 16:03:49

2016-09-09 13:48:54

API可視化華為開發者社區

2022-05-16 09:34:17

Python可視化圖表

2018-12-26 15:55:50

數據分析數據可視化圖表

2025-03-04 00:22:31

2015-04-01 10:26:55

移動應用聊天投資
點贊
收藏

51CTO技術棧公眾號

精品视频在线观看免费观看| 99re热久久这里只有精品34| 国产视频一区三区| 国产性色av一区二区| 精品日韩久久久| 美女黄视频在线观看| 成人一级黄色片| 国产成人拍精品视频午夜网站| 中文乱码字幕高清一区二区| 99久久免费精品国产72精品九九| 日韩人在线观看| 手机成人av在线| 熟妇人妻av无码一区二区三区| 久久一区二区三区超碰国产精品| 久久精品国产综合| 日韩aaaaa| 祥仔av免费一区二区三区四区| 亚洲成人综合网站| 亚洲欧洲免费无码| 亚州av在线播放| 国产真实乱偷精品视频免| 91大神在线播放精品| 精品亚洲乱码一区二区| 亚州综合一区| 精品国产一区二区国模嫣然| 亚洲免费一级视频| 波多视频一区| 亚洲成人久久影院| 成人污网站在线观看| 懂色av中文在线| 26uuu色噜噜精品一区| 亚洲sss综合天堂久久| 免费无码国产精品| 国产亚洲欧洲| 久久久女女女女999久久| 国内毛片毛片毛片毛片毛片| 国产影视一区| 日韩毛片在线观看| 99久久人妻精品免费二区| 亚洲伊人影院| 日韩精品最新网址| 欧美一级免费在线| 伊人久久一区| 欧美精品色一区二区三区| 91av俱乐部| 日韩欧美2区| 91久久精品网| 91精品国产高清自在线看超| 色老板免费视频| 日韩精品欧美| 日韩中文字幕在线| 亚洲aaa视频| 成人婷婷网色偷偷亚洲男人的天堂| 亚洲精品国产精品自产a区红杏吧| 亚洲丝袜在线观看| 警花av一区二区三区| 在线电影欧美成精品| 九九热99视频| 91丨精品丨国产| 91麻豆精品国产91久久久使用方法| www.se五月| 国产免费区一区二区三视频免费 | 国产精品九色蝌蚪自拍| 日韩免费三级| 欧美96在线| 亚洲免费av在线| 国产a级黄色大片| 国产白丝在线观看| 精品美女永久免费视频| 日韩a在线播放| 电影亚洲精品噜噜在线观看| 欧美午夜精品久久久久久超碰| 色婷婷狠狠18| 亚洲一区二区三区中文字幕在线观看| 亚洲精品一区二区三区影院 | 国模叶桐国产精品一区| 99热在线观看免费精品| 久久久噜噜噜| 成人a在线观看| 亚洲国产一二三区| 99v久久综合狠狠综合久久| 日本成人黄色免费看| 日本高清视频在线播放| 亚洲一级不卡视频| 日韩一级在线免费观看| 欧美美女被草| 精品国产1区二区| 精品成人av一区二区三区| 日韩精品欧美| 国内精品一区二区三区| 亚洲精品一区二三区| 韩国精品久久久| 精品一区日韩成人| 午夜毛片在线| 天天综合色天天| jizz欧美性11| 狠狠一区二区三区| 日韩天堂在线视频| 五月婷婷激情网| 麻豆高清免费国产一区| 国产欧美一区二区视频| 午夜看片在线免费| 欧美日韩亚洲激情| www.成人黄色| 国产欧美日韩精品一区二区免费| 久久精品国产一区| 国产熟妇一区二区三区四区| 国产麻豆精品久久一二三| 免费国产一区二区| 在线电影福利片| 精品视频在线免费| 天天插天天射天天干| 亚洲女同另类| 国产精品aaa| 污视频软件在线观看| 中文字幕一区二区三区四区不卡| 男人添女荫道口喷水视频| www.成人在线视频| 国产视频精品在线| 精品在线视频免费观看| 欧美高清视频在线观看mv| 久久久久日韩精品久久久男男| 欧美日韩在线视频播放| 99视频一区二区三区| 精品91一区二区三区| 成人网ww555视频免费看| 日韩电视剧在线观看免费网站| 欧美精品入口蜜桃| 另类专区欧美蜜桃臀第一页| 欧美日韩亚洲免费| 国产传媒在线观看| 午夜精品久久久久久久久久久| 91极品视频在线观看| 亚洲精品aaaaa| 性色av一区二区三区| 国产高清视频免费观看| 国产精品白丝在线| 韩国中文字幕av| 综合国产视频| 欧美中文字幕视频| 视频一区二区免费| 午夜激情综合网| 91九色蝌蚪porny| 欧美性久久久| 高清视频一区| 爱情岛亚洲播放路线| 日韩精品一区国产麻豆| 黄色一级视频免费观看| 国产精品正在播放| 国产精品igao激情视频| 日韩激情欧美| 欧美寡妇偷汉性猛交| 亚洲精品视频网| 亚洲国产精品综合小说图片区| 337p日本欧洲亚洲大胆张筱雨| 亚洲色图欧美| 粉嫩av一区二区三区免费观看| 麻豆福利在线观看| 精品国精品国产尤物美女| 国产一级特黄毛片| eeuss影院一区二区三区| 超碰成人免费在线| 欧美一区自拍| 日本在线精品视频| 69xxxx欧美| 日韩视频永久免费| 日韩欧美国产亚洲| 久久久久久97三级| the porn av| 66久久国产| 成人久久18免费网站漫画| 国产在线精彩视频| 亚洲视频在线观看免费| 中文字幕一区二区三区人妻四季| 国产精品久久久久久久裸模| 国产精品久久久久久久99| 欧美日本三区| 欧美不卡1区2区3区| 国产69精品久久久久按摩| 播播国产欧美激情| 搡老岳熟女国产熟妇| 日本二三区不卡| 顶臀精品视频www| 97久久超碰国产精品| 污片在线免费看| 国产精品theporn| 欧美日韩在线一区二区三区| 日韩精品一级毛片在线播放| 欧美极品xxxx| 九色在线视频蝌蚪| 在线电影院国产精品| 色播视频在线播放| 国产精品久久久久久久浪潮网站| 18禁一区二区三区| 美女尤物国产一区| 久久99久久久久久| 成人三级视频| 国产一区高清视频| 91精品福利观看| 清纯唯美日韩制服另类| 国产人成网在线播放va免费| 日韩电视剧在线观看免费网站| 91精品在线视频观看| 精品久久久久久中文字幕大豆网| 正在播放国产对白害羞| 成人av在线看| 亚洲色图欧美自拍| 久久男女视频| 欧洲精品一区二区三区久久| 日韩在线二区| 日本一区视频在线| 国产成人一二| 999热视频在线观看| 欧美日韩亚洲国产| 青青a在线精品免费观看| 羞羞的视频在线观看| 日韩在线中文视频| 国产小视频免费在线网址| 精品日韩在线一区| 91片黄在线观看喷潮| 日韩欧美在线视频观看| 久久婷婷一区二区| ...中文天堂在线一区| 老熟妇一区二区| 久久综合狠狠综合| 亚洲精品乱码久久久久久久| 国产一区二区精品在线观看| 亚洲综合欧美激情| 三级在线观看一区二区| 欧美色图色综合| 精品成人一区| 少妇大叫太大太粗太爽了a片小说| 天堂网在线观看国产精品| 视频在线观看成人| 免费欧美视频| 欧美在线日韩精品| 亚洲区小说区图片区qvod按摩 | 日韩大胆成人| 国产一区喷水| 欧美绝顶高潮抽搐喷水合集| 国产精华一区| 国产精品xxx在线观看| 国产传媒一区| 一区二区三区四区视频免费观看 | 国产熟女一区二区三区五月婷| 欧美日韩一区二区电影| 天天爱天天做天天爽| 日本国产一区二区| 日韩久久久久久久久久| 欧美性感一类影片在线播放| 波多野结衣激情视频| 在线视频亚洲一区| 在线视频 91| 欧美福利电影网| 国产欧美久久久| 日韩一区二区在线观看视频播放| 精品人妻aV中文字幕乱码色欲| 日韩一区二区三区免费看| 午夜精品久久久久久久96蜜桃| 日韩精品综合一本久道在线视频| 刘玥91精选国产在线观看| 亚洲黄色在线看| 蜜桃视频在线免费| 在线电影av不卡网址| 欧美videos极品另类| 欧美成人精品在线| 女人高潮被爽到呻吟在线观看| 456国产精品| 久久69成人| 91在线看网站| 老司机成人在线| 欧美韩国日本精品一区二区三区| 欧洲三级视频| 国产女人18毛片| 午夜一区不卡| 色戒在线免费观看| 国产成人在线观看免费网站| 色天使在线视频| 国产精品久久久久久福利一牛影视| 久久久久亚洲AV成人| 精品久久久久久| 伊人亚洲综合网| 亚洲成成品网站| 韩国精品视频| 欧美成在线视频| 欧美动物xxx| 亚洲一区中文字幕在线观看| 久久草在线视频| 亚洲欧美日产图| 尤物在线精品| 性欧美videossex精品| 处破女av一区二区| 精品熟妇无码av免费久久| 色综合99久久久无码国产精品| 一区二区欧美在线观看| 国产精品露脸视频| 亚洲成人av片| 国产二区三区在线| 欧洲永久精品大片ww免费漫画| 久久一级大片| 亚洲v国产v| 99精品国产在热久久| 国产欧美精品一二三| 91色视频在线| 日本高清不卡免费| 欧美性猛xxx| 黄色aaa毛片| 精品国产一区久久久| 毛片免费看不卡网站| 鬼打鬼之黄金道士1992林正英| 日韩av自拍| 免费日韩视频在线观看| 成人天堂资源www在线| 四虎影视一区二区| 在线视频你懂得一区二区三区| 人妻少妇一区二区三区| 久久精品视频播放| 日本国产欧美| 欧美久久在线| 国产日韩亚洲欧美精品| 亚洲午夜久久久久久久久| 中文字幕一区二区三区在线播放 | 日韩在线观看视频一区二区| 欧美私模裸体表演在线观看| 日本免费一区二区三区最新| 欧美福利视频网站| 精品国产乱码一区二区三区| 亚洲国产激情一区二区三区| 美女91精品| 亚洲第九十七页| 婷婷久久综合九色国产成人| 成人毛片在线免费观看| 久久国产精品久久久| 精品国产亚洲一区二区三区在线| 先锋在线资源一区二区三区| 久久一日本道色综合久久| 亚洲av成人无码一二三在线观看| 亚洲一区二区三区四区在线观看 | 国产精品成人3p一区二区三区| 日韩电影免费观看在| 性高湖久久久久久久久| 青青草成人免费视频| 疯狂做受xxxx欧美肥白少妇| 人妻少妇精品无码专区| 98视频在线噜噜噜国产| 国产美女撒尿一区二区| 男的插女的下面视频| 成人av第一页| 日韩三级小视频| 日韩黄在线观看| 中文在线中文资源| 日韩国产一区久久| 日本va欧美va瓶| 免费成人深夜夜行网站| 制服丝袜日韩国产| 成人在线观看免费网站| 粉嫩高清一区二区三区精品视频| 伊人久久综合| 人妻无码中文久久久久专区| 午夜精品久久久久久久99水蜜桃| 亚洲 小说区 图片区 都市| 欧美在线视频在线播放完整版免费观看 | 第四色在线视频| 91精品91久久久中77777| 自拍视频在线| 亚洲最大福利视频| av不卡免费看| 公肉吊粗大爽色翁浪妇视频| 欧美日韩免费不卡视频一区二区三区 | 91影院在线观看| 波多野结衣大片| 久久精品国亚洲| 任你弄精品视频免费观看| 国产精品69页| 亚洲青青青在线视频| 成人免费一级视频| 国产精品第1页| 亚洲成人三区| 久久亚洲AV成人无码国产野外 | 97超级碰在线看视频免费在线看| 香蕉久久99| 精品综合久久久久| 亚洲国产毛片aaaaa无费看| 飘雪影院手机免费高清版在线观看 | 国产91av视频| 国产视频久久网| 成人污污视频| 欧美成人一区二区在线观看| 国产精品无人区| www黄色在线观看| 国产不卡av在线免费观看| 亚洲国产精品综合久久久 | 网友自拍区视频精品| 一本色道久久亚洲综合精品蜜桃 | 91视频www| 99久久夜色精品国产亚洲| 青草热久免费精品视频| 综合久久一区| 日本二区在线观看| 亚洲精品一区二区三区精华液|