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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【OpenCV】Chapter10.色彩转换与图像绘制

發布時間:2024/3/7 编程问答 66 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【OpenCV】Chapter10.色彩转换与图像绘制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近想對OpenCV進行系統學習,看到網上這份教程寫得不錯,于是跟著來學習實踐一下。
【youcans@qq.com, youcans 的 OpenCV 例程, https://youcans.blog.csdn.net/article/details/125112487】
程序倉庫:https://github.com/zstar1003/OpenCV-Learning

色彩轉換

顏色空間轉換

常見的色彩空間包括:GRAY 色彩空間(灰度圖像)、XYZ 色彩空間、YCrCb 色彩空間、HSV 色彩空間、HLS 色彩空間、CIELab 色彩空間、CIELuv 色彩空間、Bayer 色彩空間等。

色彩空間名詞解釋:

  • RGB:紅色(Red)、綠色(Green)、藍色(Blue);
  • HSV/HSB:色調(Hue)、飽和度(Saturation)和明度(Value/Brightness);
  • HSl:色調(Hue)、飽和度(Saturation)和灰度(Intensity);
  • HSL:包括色調(Hue)、飽和度(Saturation)和亮度(Luminance/Lightness)

常見色彩空間轉換,這里只列舉兩個常見的。

  • RGB -> GRAY
    注意RGB可以轉灰度,灰度不能轉RGB
    轉換公式:gray = 0.299 x R + 0.587 x G + 0.114 x B

  • RGB -> HSV
    RGB轉HSV公式為

OpenCV提供了函數cv.cvtColor()可以將圖像從一個顏色空間轉換為另一個顏色空間。

cv.cvtColor(src, code [, dst, dstCn]]) → dst

參數說明:

  • src:輸入圖像,nparray 多維數組,8位無符號/ 16位無符號/單精度浮點數格式
  • code:顏色空間轉換代碼,詳見 ColorConversionCodes
  • dst:輸出圖像,大小和深度與 src 相同
  • dstCn:輸出圖像的通道數,0 表示由src和code自動計算

示例程序:

""" 顏色空間轉換 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimgBGR = cv.imread("../img/img.jpg", flags=1)imgRGB = cv.cvtColor(imgBGR, cv.COLOR_BGR2RGB) # BGR 轉換為 RGB, 用于 PyQt5, matplotlib imgGRAY = cv.cvtColor(imgBGR, cv.COLOR_BGR2GRAY) # BGR 轉換為灰度圖像 imgHSV = cv.cvtColor(imgBGR, cv.COLOR_BGR2HSV) # BGR 轉換為 HSV 圖像 imgYCrCb = cv.cvtColor(imgBGR, cv.COLOR_BGR2YCrCb) # BGR轉YCrCb imgHLS = cv.cvtColor(imgBGR, cv.COLOR_BGR2HLS) # BGR 轉 HLS 圖像 imgXYZ = cv.cvtColor(imgBGR, cv.COLOR_BGR2XYZ) # BGR 轉 XYZ 圖像 imgLAB = cv.cvtColor(imgBGR, cv.COLOR_BGR2LAB) # BGR 轉 LAB 圖像 imgYUV = cv.cvtColor(imgBGR, cv.COLOR_BGR2YUV) # BGR 轉 YUV 圖像# 調用matplotlib顯示處理結果 titles = ['BGR', 'RGB', 'GRAY', 'HSV', 'YCrCb', 'HLS', 'XYZ', 'LAB', 'YUV'] images = [imgBGR, imgRGB, imgGRAY, imgHSV, imgYCrCb,imgHLS, imgXYZ, imgLAB, imgYUV] plt.figure(figsize=(10, 8)) for i in range(9):plt.subplot(3, 3, i + 1), plt.imshow(images[i], 'gray')plt.title(titles[i])plt.xticks([]), plt.yticks([]) plt.tight_layout() plt.show()

顏色反轉

圖像顏色反轉也稱為反色變換,是像素顏色的逆轉,將黑色像素點變白色,白色像素點變黑色,像素位置不變。
RGB圖片實現顏色反轉非常容易,一種簡單的思路就是對每個像素點用255-顏色值。但是這樣處理的效率不高。

OpenCV提供了一個查表函數cv.LUT可以快速實現像素值的改變。其本質就是先對每個0-255的像素灰度值建立一個變換字典,這樣處理像素值就只需要從字典里去查找對應的數據進行替換,而無需再去運算。

下面的示例程序比較了兩種方法的執行效率。

""" 圖像顏色反轉 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/img.jpg", flags=1) h, w, ch = img.shape # 圖片的高度, 寬度 和通道數timeBegin = cv.getTickCount() imgInv = np.empty((w, h, ch), np.uint8) # 創建空白數組 for i in range(h):for j in range(w):for k in range(ch):imgInv[i][j][k] = 255 - img[i][j][k] timeEnd = cv.getTickCount() time = (timeEnd - timeBegin) / cv.getTickFrequency() print("圖像反轉(for 循環實現): {} s".format(round(time, 4)))timeBegin = cv.getTickCount() transTable = np.array([(255 - i) for i in range(256)]).astype("uint8") invLUT = cv.LUT(img, transTable) timeEnd = cv.getTickCount() time = (timeEnd - timeBegin) / cv.getTickFrequency() print("圖像反轉(LUT 查表實現): {} s".format(round(time, 4)))plt.figure(figsize=(9, 6)) plt.subplot(131), plt.title("img"), plt.axis('off') plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(132), plt.title("imgInv"), plt.axis('off') plt.imshow(cv.cvtColor(imgInv, cv.COLOR_BGR2RGB)) plt.subplot(133), plt.title("invLUT"), plt.axis('off') plt.imshow(cv.cvtColor(invLUT, cv.COLOR_BGR2RGB)) plt.tight_layout() plt.show()

輸出

圖像反轉(for 循環實現): 1.9181 s
圖像反轉(LUT 查表實現): 0.0326 s

由此可見兩者速度差異還是比較明顯的。

色彩風格濾鏡

色彩風格濾鏡就是OpenCV提供了一些色彩搭配方案,通過函數cv.applyColorMap可以進行調用。

OpenCV 提供了 22 種色彩風格類型:

ColorMaps[] = { "Autumn", "Bone", "Jet", "Winter", "Rainbow", "Ocean", "Summer", "Spring","Cool", "HSV", "Pink", "Hot", "Parula", "Magma", "Inferno", "Plasma", "Viridis","Cividis", "Twilight", "Twilight Shifted", "Turbo", "Deep Green"};

示例程序:

""" 色彩風格濾鏡 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/img.jpg", flags=1)# 偽彩色處理 pseudo1 = cv.applyColorMap(img, colormap=cv.COLORMAP_PINK) pseudo2 = cv.applyColorMap(img, colormap=cv.COLORMAP_JET) pseudo3 = cv.applyColorMap(img, colormap=cv.COLORMAP_WINTER) pseudo4 = cv.applyColorMap(img, colormap=cv.COLORMAP_RAINBOW) pseudo5 = cv.applyColorMap(img, colormap=cv.COLORMAP_HOT)plt.figure(figsize=(9, 6)) plt.subplot(231), plt.axis('off'), plt.title("Origin") plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(232), plt.axis('off'), plt.title("cv.COLORMAP_PINK") plt.imshow(cv.cvtColor(pseudo1, cv.COLOR_BGR2RGB)) plt.subplot(233), plt.axis('off'), plt.title("cv.COLORMAP_JET") plt.imshow(cv.cvtColor(pseudo2, cv.COLOR_BGR2RGB)) plt.subplot(234), plt.axis('off'), plt.title("cv.COLORMAP_WINTER") plt.imshow(cv.cvtColor(pseudo3, cv.COLOR_BGR2RGB)) plt.subplot(235), plt.axis('off'), plt.title("cv.COLORMAP_RAINBOW") plt.imshow(cv.cvtColor(pseudo4, cv.COLOR_BGR2RGB)) plt.subplot(236), plt.axis('off'), plt.title("cv.COLORMAP_HOT") plt.imshow(cv.cvtColor(pseudo5, cv.COLOR_BGR2RGB)) plt.tight_layout() plt.show()

調節色彩

通過cv.LUT可以在RGB色彩范圍內調節三通道的數值,從而調節色彩。
下面的示例程序將各通道的最大值設置為maxG,將某顏色通道的色階從 0-255 映射到 0-maxG,就可以使該顏色通道的色彩衰減。

示例程序:

""" 調節色彩 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/img.jpg", flags=1)maxG = 128 # 修改顏色通道最大值,0<=maxG<=255 lutHalf = np.array([int(i * maxG / 255) for i in range(256)]).astype("uint8") lutEqual = np.array([i for i in range(256)]).astype("uint8")lut3HalfB = np.dstack((lutHalf, lutEqual, lutEqual)) # (1,256,3), B_half/BGR lut3HalfG = np.dstack((lutEqual, lutHalf, lutEqual)) # (1,256,3), G_half/BGR lut3HalfR = np.dstack((lutEqual, lutEqual, lutHalf)) # (1,256,3), R_half/BGRblendHalfB = cv.LUT(img, lut3HalfB) # B 通道衰減 50% blendHalfG = cv.LUT(img, lut3HalfG) # G 通道衰減 50% blendHalfR = cv.LUT(img, lut3HalfR) # R 通道衰減 50%plt.figure(figsize=(9, 5)) plt.subplot(131), plt.axis('off'), plt.title("B half decayed") plt.imshow(cv.cvtColor(blendHalfB, cv.COLOR_BGR2RGB)) plt.subplot(132), plt.axis('off'), plt.title("G half decayed") plt.imshow(cv.cvtColor(blendHalfG, cv.COLOR_BGR2RGB)) plt.subplot(133), plt.axis('off'), plt.title("R half decayed") plt.imshow(cv.cvtColor(blendHalfR, cv.COLOR_BGR2RGB)) plt.tight_layout() plt.show()

調節飽和度和明度

將RGB顏色空間轉換到HSV空間,可以調整圖片的飽和度和明度。

示例程序:

""" 調節飽和度和明度 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/img.jpg", flags=1) hsv = cv.cvtColor(img, cv.COLOR_BGR2HSV) # 色彩空間轉換, BGR->HSV# 調節通道強度 lutWeaken = np.array([int(0.6 * i) for i in range(256)]).astype("uint8") lutEqual = np.array([i for i in range(256)]).astype("uint8") lutRaisen = np.array([int(102 + 0.6 * i) for i in range(256)]).astype("uint8") # 調節飽和度 lutSWeaken = np.dstack((lutEqual, lutWeaken, lutEqual)) # Saturation weaken lutSRaisen = np.dstack((lutEqual, lutRaisen, lutEqual)) # Saturation raisen # 調節明度 lutVWeaken = np.dstack((lutEqual, lutEqual, lutWeaken)) # Value weaken lutVRaisen = np.dstack((lutEqual, lutEqual, lutRaisen)) # Value raisenblendSWeaken = cv.LUT(hsv, lutSWeaken) # 飽和度降低 blendSRaisen = cv.LUT(hsv, lutSRaisen) # 飽和度增大 blendVWeaken = cv.LUT(hsv, lutVWeaken) # 明度降低 blendVRaisen = cv.LUT(hsv, lutVRaisen) # 明度升高plt.figure(figsize=(9, 6)) plt.subplot(231), plt.axis('off'), plt.title("Saturation weaken") plt.imshow(cv.cvtColor(blendSWeaken, cv.COLOR_HSV2RGB)) plt.subplot(232), plt.axis('off'), plt.title("Normal saturation") plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(233), plt.axis('off'), plt.title("Saturation raisen") plt.imshow(cv.cvtColor(blendSRaisen, cv.COLOR_HSV2RGB)) plt.subplot(234), plt.axis('off'), plt.title("Value weaken") plt.imshow(cv.cvtColor(blendVWeaken, cv.COLOR_HSV2RGB)) plt.subplot(235), plt.axis('off'), plt.title("Normal value") plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(236), plt.axis('off'), plt.title("Value raisen") plt.imshow(cv.cvtColor(blendVRaisen, cv.COLOR_HSV2RGB)) plt.tight_layout() plt.show()

圖像繪制

繪制直線

函數cv.line()繪制圖像中點pt1與點pt2之間的線段
函數cv.arrowedLine()繪制圖像中點pt1與點pt2之間的帶箭頭線段

cv.line(img, pt1, pt2, color[, thickness=1, lineType=LINE_8, shift=0]) → img
cv.arrowedLine(img, pt1, pt2, color[, thickness=1, line_type=8, shift=0, tipLength=0.1]) → img

參數說明:

  • img:輸入輸出圖像,允許單通道灰度圖像或多通道彩色圖像
  • pt1:線段第一個點的坐標,(x1, y1)
  • pt2:線段第二個點的坐標,(x2, y2)
  • tipLength:箭頭部分長度與線段長度的比例,默認為 0.1

示例程序:

""" 繪制直線 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npheight, width, channels = 200, 120, 3 img = np.ones((height, width, channels), np.uint8) * 160 # 創建黑色圖像 RGB=0# 注意 pt1, pt2 坐標的格式是 (x,y) 而不是 (y,x) img1 = img.copy() cv.line(img1, (0, 0), (200, 150), (0, 0, 255), 1) # 紅色 R=255 cv.line(img1, (0, 0), (150, 200), (0, 255, 0), 1) # 綠色 G=255 cv.line(img1, (0, 50), (200, 50), (128, 0, 0), 2) # 深藍色 B = 128 cv.line(img1, (0, 100), (200, 100), 128, 2) # color=128 等效于 (128,0,0) cv.line(img1, (0, 150), (200, 150), 255, 2) # color=255 等效于 (255,0,0)# img2 = img.copy() # tipLength 指箭頭部分長度與整個線段長度的比例 img2 = cv.arrowedLine(img.copy(), (10, 0), (100, 30), (0, 0, 255), tipLength=0.05) # 從 pt1 指向 pt2 img2 = cv.arrowedLine(img2, (10, 50), (100, 80), (0, 0, 255), tipLength=0.1) img2 = cv.arrowedLine(img2, (10, 100), (100, 130), (0, 0, 255), tipLength=0.2) # 雙向箭頭 img2 = cv.arrowedLine(img2, (100, 130), (10, 100), (0, 0, 255), tipLength=0.2) # 雙向箭頭 img2 = cv.arrowedLine(img2, (10, 150), (200, 200), (0, 0, 255), tipLength=0.1) # 終點越界,箭頭不顯示# 繪制直線可以用于灰度圖像,參數 color 只有第一通道值有效,并被設為灰度值 gray = np.zeros((height, width), np.uint8) # 創建灰度圖像 img3 = cv.line(gray, (0, 10), (200, 10), (0, 255, 255), 2) img3 = cv.line(gray, (0, 30), (200, 30), (64, 128, 255), 2) img3 = cv.line(gray, (0, 60), (200, 60), (128, 64, 255), 2) img3 = cv.line(gray, (0, 100), (200, 100), (255, 0, 255), 2) img3 = cv.line(gray, (20, 0), (20, 200), 128, 2) img3 = cv.line(gray, (60, 0), (60, 200), (255, 0, 0), 2) img3 = cv.line(gray, (100, 0), (100, 200), (255, 255, 255), 2)plt.figure(figsize=(9, 6)) plt.subplot(131), plt.title("img1"), plt.axis('off') plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB)) plt.subplot(132), plt.title("img2"), plt.axis('off') plt.imshow(cv.cvtColor(img2, cv.COLOR_BGR2RGB)) plt.subplot(133), plt.title("img3"), plt.axis('off') plt.imshow(img3, cmap="gray") plt.tight_layout() plt.show()

繪制矩形

函數cv.rectangle()用來在圖像上繪制垂直于圖像邊界的矩形

cv.rectangle(img, pt1, pt2, color[, thickness=1, lineType=LINE_8, shift=0]) → img
cv.rectangle(img, rec, color[, thickness=1, lineType=LINE_8, shift=0]) → img

參數說明:

  • img:輸入輸出圖像,允許單通道灰度圖像或多通道彩色圖像
  • pt1:矩陣第一個點的坐標,(x1, y1) 格式的元組
  • pt2:與 pt1 成對角的矩陣第二個點的坐標,(x2, y2) 格式的元組
  • color:繪圖線條的顏色,(b,g,r) 格式的元組,或者表示灰度值的標量
  • thickness:繪制矩形的線寬,默認值 1px,負數表示矩形內部填充
  • lineType:繪制線段的線性,默認為 LINE_8
  • shift:點坐標的小數位數,默認為 0
""" 繪制矩形 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npheight, width, channels = 400, 300, 3 img = np.ones((height, width, channels), np.uint8) * 160 # 創建黑色圖像 RGB=0img1 = img.copy() cv.rectangle(img1, (0, 20), (100, 200), (255, 255, 255)) # 白色 cv.rectangle(img1, (20, 0), (300, 100), (255, 0, 0), 2) # 藍色 B=255 cv.rectangle(img1, (300, 400), (250, 300), (0, 255, 0), -1) # 綠色,填充 cv.rectangle(img1, (0, 400), (50, 300), 255, -1) # color=255 藍色 cv.rectangle(img1, (20, 220), (25, 225), (0, 0, 255), 4) # 線寬的影響 cv.rectangle(img1, (60, 220), (67, 227), (0, 0, 255), 4) cv.rectangle(img1, (100, 220), (109, 229), (0, 0, 255), 4)img2 = img.copy() x, y, w, h = (50, 50, 200, 100) # 左上角坐標 (x,y), 寬度 w,高度 h cv.rectangle(img2, (x, y), (x + w, y + h), (0, 0, 255), 2) text = "({},{}),{}*{}".format(x, y, w, h) cv.putText(img2, text, (x, y - 5), cv.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255))# 繪制直線可以用于灰度圖像,參數 color 只有第一通道值有效,并被設為灰度值 gray = np.zeros((height, width), np.uint8) # 創建灰度圖像 img3 = cv.line(gray, (0, 10), (300, 10), 64, 2) cv.line(img3, (0, 30), (300, 30), (128, 128, 255), 2) cv.line(img3, (0, 60), (300, 60), (192, 64, 255), 2) cv.rectangle(img3, (0, 200), (30, 150), 128, -1) # Gray=128 cv.rectangle(img3, (60, 200), (90, 150), (128, 0, 0), -1) # Gray=128 cv.rectangle(img3, (120, 200), (150, 150), (128, 255, 255), -1) # Gray=128 cv.rectangle(img3, (180, 200), (210, 150), 192, -1) # Gray=192 cv.rectangle(img3, (240, 200), (270, 150), 255, -1) # Gray=255plt.figure(figsize=(9, 6)) plt.subplot(131), plt.title("img1"), plt.axis('off') plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB)) plt.subplot(132), plt.title("img2"), plt.axis('off') plt.imshow(cv.cvtColor(img2, cv.COLOR_BGR2RGB)) plt.subplot(133), plt.title("img3"), plt.axis('off') plt.imshow(img3, cmap="gray") plt.tight_layout() plt.show()

繪制傾斜矩形

cv.rectangle()只能繪制垂直的矩形,如果需要繪制傾斜矩形,需要繪制多條直線。

示例程序:

""" 繪制傾斜矩形 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npheight, width, channels = 600, 400, 3 img = np.ones((height, width, channels), np.uint8) * 192 # 創建黑色圖像 RGB=0# 圍繞矩形中心旋轉 x, y, w, h = (100, 200, 200, 100) # 左上角坐標 (x,y), 寬度 w,高度 h cx, cy = x + w // 2, y + h // 2 # 矩形中心 img1 = img.copy() cv.circle(img1, (cx, cy), 4, (0, 0, 255), -1) # 旋轉中心 angle = [15, 30, 45, 60, 75, 90] # 旋轉角度,順時針方向 for i in range(len(angle)):ang = angle[i] * np.pi / 180x1 = int(cx + (w / 2) * np.cos(ang) - (h / 2) * np.sin(ang))y1 = int(cy + (w / 2) * np.sin(ang) + (h / 2) * np.cos(ang))x2 = int(cx + (w / 2) * np.cos(ang) + (h / 2) * np.sin(ang))y2 = int(cy + (w / 2) * np.sin(ang) - (h / 2) * np.cos(ang))x3 = int(cx - (w / 2) * np.cos(ang) + (h / 2) * np.sin(ang))y3 = int(cy - (w / 2) * np.sin(ang) - (h / 2) * np.cos(ang))x4 = int(cx - (w / 2) * np.cos(ang) - (h / 2) * np.sin(ang))y4 = int(cy - (w / 2) * np.sin(ang) + (h / 2) * np.cos(ang))color = (30 * i, 0, 255 - 30 * i)cv.line(img1, (x1, y1), (x2, y2), color)cv.line(img1, (x2, y2), (x3, y3), color)cv.line(img1, (x3, y3), (x4, y4), color)cv.line(img1, (x4, y4), (x1, y1), color)# 圍繞矩形左上頂點旋轉 x, y, w, h = (200, 200, 200, 100) # 左上角坐標 (x,y), 寬度 w,高度 h img2 = img.copy() cv.circle(img2, (x, y), 4, (0, 0, 255), -1) # 旋轉中心 angle = [15, 30, 45, 60, 75, 90, 120, 150, 180, 225] # 旋轉角度,順時針方向 for i in range(len(angle)):ang = angle[i] * np.pi / 180x1, y1 = x, yx2 = int(x + w * np.cos(ang))y2 = int(y + w * np.sin(ang))x3 = int(x + w * np.cos(ang) - h * np.sin(ang))y3 = int(y + w * np.sin(ang) + h * np.cos(ang))x4 = int(x - h * np.sin(ang))y4 = int(y + h * np.cos(ang))color = (30 * i, 0, 255 - 30 * i)cv.line(img2, (x1, y1), (x2, y2), color)cv.line(img2, (x2, y2), (x3, y3), color)cv.line(img2, (x3, y3), (x4, y4), color)cv.line(img2, (x4, y4), (x1, y1), color)plt.figure(figsize=(9, 6)) plt.subplot(121), plt.title("img1"), plt.axis('off') plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB)) plt.subplot(122), plt.title("img2"), plt.axis('off') plt.imshow(cv.cvtColor(img2, cv.COLOR_BGR2RGB)) plt.show()

繪制圓形

函數cv.circle()用來在圖像上繪制圓形

cv.circle(img, center, radius, color[, thickness=1, lineType=LINE_8, shift=0]) → img

參數說明:

  • img:輸入輸出圖像,允許單通道灰度圖像或多通道彩色圖像
  • center:圓心點的坐標,(x, y) 格式的元組
  • radius:圓的半徑,整數
  • color:繪圖線條的顏色,(b,g,r) 格式的元組,或者表示灰度值的標量
  • thickness:繪制矩形的線寬,默認值 1px,負數表示矩形內部填充
  • lineType:繪制線段的線性,默認為 LINE_8
    • cv.LINE_4:4 鄰接線型
    • cv.LINE_8:8 鄰接線型
    • cv.LINE_AA:抗鋸齒線型,圖像更平滑
  • shift:點坐標的小數位數,默認為 0

示例程序:

""" 繪制圓形 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = np.ones((400, 600, 3), np.uint8) * 192center = (0, 0) # 圓心坐標 cx, cy = 300, 200 # 圓心坐標 for r in range(200, 0, -20):color = (r, r, 255 - r)cv.circle(img, (cx, cy), r, color, -1)cv.circle(img, center, r, 255)cv.circle(img, (600, 400), r, color, 5)plt.figure(figsize=(6, 4)) plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.axis('off') plt.show()

繪制橢圓

函數cv.ellipse()用來在圖像上繪制橢圓輪廓、填充橢圓、橢圓弧或填充橢圓扇區

cv.ellipse(img, center, axes, angle, startAngle, endAngle, color[, thickness=1, lineType=LINE_8, shift=0]) → img
cv.ellipse(img, box, color[, thickness=1, lineType=LINE_8]) → img

參數說明:

  • img:輸入輸出圖像,允許單通道灰度圖像或多通道彩色圖像
  • center:橢圓中心點的坐標,(x, y) 格式的元組
  • axes:橢圓半軸長度,(hfirst, hsecond) 格式的元組
  • angle: 橢圓沿 x軸方向的旋轉角度(角度制,順時針方向)
  • startAngle:繪制的起始角度
  • endAngle:繪制的終止角度
  • color:繪圖線條的顏色,(b,g,r) 格式的元組,或者表示灰度值的標量
  • thickness:繪制矩形的線寬,默認值 1px,負數表示矩形內部填充
  • lineType:繪制線段的線性,默認為 LINE_8
  • shift:點坐標的小數位數,默認為 0

示例程序:

""" 繪制橢圓 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = np.ones((600, 400, 3), np.uint8) * 224 img1 = img.copy() img2 = img.copy()# (1) 半軸長度 (haf) 的影響 cx, cy = 200, 150 # 圓心坐標 angle = 30 # 旋轉角度 startAng, endAng = 0, 360 # 開始角度,結束角度 haf = [50, 100, 150, 180] # 第一軸的半軸長度 has = 100 # 第二軸的半軸長度 for i in range(len(haf)):color = (i * 50, i * 50, 255 - i * 50)cv.ellipse(img1, (cx, cy), (haf[i], has), angle, startAng, endAng, color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cx + haf[i] * np.cos(angPi))ye = int(cy + haf[i] * np.sin(angPi))cv.circle(img1, (xe, ye), 2, color, -1)cv.arrowedLine(img1, (cx, cy), (xe, ye), color) # 從圓心指向第一軸端點text = "haF={}".format(haf[i])cv.putText(img1, text, (xe + 5, ye), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) # 繪制第二軸 xe = int(cx + has * np.sin(angPi)) # 計算第二軸端點坐標 ye = int(cy - has * np.cos(angPi)) cv.arrowedLine(img1, (cx, cy), (xe, ye), color) # 從圓心指向第二軸端點 text = "haS={}".format(has) cv.putText(img1, text, (xe + 5, ye), cv.FONT_HERSHEY_SIMPLEX, 0.5, color)# (2) 旋轉角度 (angle) 的影響 cx, cy = 200, 450 # 圓心坐標 haf, has = 120, 50 # 半軸長度 startAng, endAng = 0, 360 # 開始角度,結束角度 angle = [0, 30, 60, 135] # 旋轉角度 for i in range(len(angle)):color = (i * 50, i * 50, 255 - i * 50)cv.ellipse(img1, (cx, cy), (haf, has), angle[i], startAng, endAng, color, 2)angPi = angle[i] * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cx + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.circle(img1, (xe, ye), 2, color, -1)cv.arrowedLine(img1, (cx, cy), (xe, ye), color) # 從圓心指向第一軸端點text = "rotate {}".format(angle[i])cv.putText(img1, text, (xe + 5, ye), cv.FONT_HERSHEY_SIMPLEX, 0.5, color)# (3) 起始角度 (startAngle) 的影響 I cx, cy = 50, 80 # 圓心坐標 haf, has = 40, 30 # 半軸長度 angle = 0 # 旋轉角度 endAng = 360 # 結束角度 startAng = [0, 45, 90, 180] # 開始角度 for i in range(len(startAng)):color = (i * 20, i * 20, 255 - i * 20)cxi = cx + i * 100cv.ellipse(img2, (cxi, cy), (haf, has), angle, startAng[i], endAng, color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cxi + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.arrowedLine(img2, (cxi, cy), (xe, ye), 255) # 從圓心指向第一軸端點text = "start {}".format(startAng[i])cv.putText(img2, text, (cxi - 40, cy), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) text = "end={}".format(endAng) cv.putText(img2, text, (10, cy - 40), cv.FONT_HERSHEY_SIMPLEX, 0.5, 255)# (4) 起始角度 (startAngle) 的影響 II cx, cy = 50, 200 # 圓心坐標 haf, has = 40, 30 # 半軸長度 angle = 30 # 旋轉角度 endAng = 360 # 結束角度 startAng = [0, 45, 90, 180] # 開始角度 for i in range(len(startAng)):color = (i * 20, i * 20, 255 - i * 20)cxi = cx + i * 100cv.ellipse(img2, (cxi, cy), (haf, has), angle, startAng[i], endAng, color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cxi + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.arrowedLine(img2, (cxi, cy), (xe, ye), 255) # 從圓心指向第一軸端點text = "start {}".format(startAng[i])cv.putText(img2, text, (cxi - 40, cy), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) text = "end={}".format(endAng) cv.putText(img2, text, (10, cy - 40), cv.FONT_HERSHEY_SIMPLEX, 0.5, 255)# (5) 結束角度 (endAngle) 的影響 I cx, cy = 50, 320 # 圓心坐標 haf, has = 40, 30 # 半軸長度 angle = 0 # 旋轉角度 startAng = 0 # 開始角度 endAng = [45, 90, 180, 360] # 結束角度 for i in range(len(endAng)):color = (i * 20, i * 20, 255 - i * 20)cxi = cx + i * 100cv.ellipse(img2, (cxi, cy), (haf, has), angle, startAng, endAng[i], color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cxi + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.arrowedLine(img2, (cxi, cy), (xe, ye), 255) # 從圓心指向第一軸端點text = "end {}".format(endAng[i])cv.putText(img2, text, (cxi - 40, cy), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) text = "start={}".format(startAng) cv.putText(img2, text, (10, cy - 40), cv.FONT_HERSHEY_SIMPLEX, 0.5, 255)# (6) 結束角度 (endAngle) 的影響 II cx, cy = 50, 420 # 圓心坐標 haf, has = 40, 30 # 半軸長度 angle = 30 # 旋轉角度 startAng = 45 # 開始角度 endAng = [30, 90, 180, 360] # 結束角度 for i in range(len(endAng)):color = (i * 20, i * 20, 255 - i * 20)cxi = cx + i * 100cv.ellipse(img2, (cxi, cy), (haf, has), angle, startAng, endAng[i], color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cxi + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.arrowedLine(img2, (cxi, cy), (xe, ye), 255) # 從圓心指向第一軸端點text = "end {}".format(endAng[i])cv.putText(img2, text, (cxi - 40, cy), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) text = "start={}".format(startAng) cv.putText(img2, text, (10, cy - 40), cv.FONT_HERSHEY_SIMPLEX, 0.5, 255)# (7) 結束角度 (endAngle) 的影響 II cx, cy = 50, 550 # 圓心坐標 haf, has = 40, 30 # 半軸長度 angle = 30 # 旋轉角度 startAng = [0, 0, 180, 180] # 開始角度 endAng = [90, 180, 270, 360] # 結束角度 for i in range(len(endAng)):color = (i * 20, i * 20, 255 - i * 20)cxi = cx + i * 100cv.ellipse(img2, (cxi, cy), (haf, has), angle, startAng[i], endAng[i], color, 2)angPi = angle * np.pi / 180 # 轉換為弧度制,便于計算坐標xe = int(cxi + haf * np.cos(angPi))ye = int(cy + haf * np.sin(angPi))cv.arrowedLine(img2, (cxi, cy), (xe, ye), 255) # 從圓心指向第一軸端點text = "start {}".format(startAng[i])cv.putText(img2, text, (cxi - 40, cy - 20), cv.FONT_HERSHEY_SIMPLEX, 0.5, color)text = "end {}".format(endAng[i])cv.putText(img2, text, (cxi - 40, cy), cv.FONT_HERSHEY_SIMPLEX, 0.5, color) text = "rotate={}".format(angle) cv.putText(img2, text, (10, cy - 50), cv.FONT_HERSHEY_SIMPLEX, 0.5, 255)plt.figure(figsize=(9, 6)) plt.subplot(121), plt.title("Ellipse1"), plt.axis('off') plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB)) plt.subplot(122), plt.title("Ellipse2"), plt.axis('off') plt.imshow(cv.cvtColor(img2, cv.COLOR_BGR2RGB)) plt.show()

繪制多段線和多邊形

函數cv.polylines()用來繪制多邊形曲線或多段線
函數cv.fillPoly()用來繪制一個或多個填充的多邊形區域
函數cv.fillConvexPoly()用來繪制一個填充的凸多邊形

cv.polylines(img, pts, isClosed, color[, thickness=1, lineType=LINE_8, shift=0]) → img
cv.fillPoly(img, pts, color[, lineType=LINE_8, shift=0, offset=Point()]) → img
cv.fillConvexPoly(img, points, color[, lineType=LINE_8, shift=0]) → img

參數說明:

  • img:輸入輸出圖像,允許單通道灰度圖像或多通道彩色圖像
  • pts:多邊形頂點坐標, 二維 Numpy 數組的列表
  • points:多邊形頂點坐標,二維 Numpy 數組
  • isClosed: 閉合標志,True 表示閉合多邊形,False 表示多邊形不閉合

示例程序:

""" 繪制多段線和多邊形 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = np.ones((980, 400, 3), np.uint8) * 224 img1 = img.copy() img2 = img.copy() img3 = img.copy() img4 = img.copy()# 多邊形頂點 points1 = np.array([[200, 100], [295, 169], [259, 281], [141, 281], [105, 169]], np.int) points2 = np.array([[200, 400], [259, 581], [105, 469], [295, 469], [141, 581]]) # (5,2) points3 = np.array([[200, 700], [222, 769], [295, 769], [236, 812], [259, 881],[200, 838], [141, 881], [164, 812], [105, 769], [178, 769]])# 繪制多邊形,閉合曲線 pts1 = [points1] # pts1 是列表,列表元素是形狀為 (m,2) 的 numpy 二維數組 cv.polylines(img1, pts1, True, (0, 0, 255)) # pts1 是列表 cv.polylines(img1, [points2, points3], 1, 255, 2) # 可以繪制多個多邊形# 繪制多段線,曲線不閉合 cv.polylines(img2, [points1], False, (0, 0, 255)) cv.polylines(img2, [points2, points3], 0, 255, 2) # 可以繪制多個多段線# 繪制填充多邊形,注意交叉重疊部分處理 cv.fillPoly(img3, [points1], (0, 0, 255)) cv.fillPoly(img3, [points2, points3], 255) # 可以繪制多個填充多邊形# 繪制一個填充多邊形,注意交叉重疊部分 cv.fillConvexPoly(img4, points1, (0, 0, 255)) cv.fillConvexPoly(img4, points2, 255) # 不能繪制存在自相交的多邊形 cv.fillConvexPoly(img4, points3, 255) # 可以繪制凹多邊形,但要慎用plt.figure(figsize=(9, 6)) plt.subplot(141), plt.title("closed polygon"), plt.axis('off') plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB)) plt.subplot(142), plt.title("unclosed polygo"), plt.axis('off') plt.imshow(cv.cvtColor(img2, cv.COLOR_BGR2RGB)) plt.subplot(143), plt.title("fillPoly"), plt.axis('off') plt.imshow(cv.cvtColor(img3, cv.COLOR_BGR2RGB)) plt.subplot(144), plt.title("fillConvexPoly"), plt.axis('off') plt.imshow(cv.cvtColor(img4, cv.COLOR_BGR2RGB)) plt.tight_layout() plt.show()

添加水印

添加水印的思路是先在黑色背景上添加圖像或文字制作水印,再使用cv.addWeight函數,通過重疊混合把水印添加到原始圖像上。

示例程序:

""" 添加水印 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/lena.jpg", 1) # 加載原始圖片 h, w = img.shape[0], img.shape[1]# 生成水印圖案 logo = cv.imread("../img/img.jpg", 0) # 加載 Logo logoResize = cv.resize(logo, (200, 200)) # 調整圖片尺寸 grayMark = np.zeros(img.shape[:2], np.uint8) # 水印黑色背景 grayMark[10:210, 10:210] = logoResize # 生成水印圖案# 生成文字水印 mark = np.zeros(img.shape[:2], np.uint8) # 黑色背景 for i in range(h // 100):cv.putText(mark, "zstar", (50, 70 + 100 * i), cv.FONT_HERSHEY_SIMPLEX, 1.5, 255, 2) MAR = cv.getRotationMatrix2D((w // 2, h // 2), 45, 1.0) # 旋轉 45 度 grayMark2 = cv.warpAffine(mark, MAR, (w, h)) # 旋轉變換,默認為黑色填充# 添加圖片水印 markC3 = cv.merge([grayMark, grayMark, grayMark]) imgMark1 = cv.addWeighted(img, 1, markC3, 0.25, 0) # 加權加法圖像融合# 添加文字水印 markC32 = cv.merge([grayMark2, grayMark2, grayMark2]) imgMark2 = cv.addWeighted(img, 1, markC32, 0.25, 0) # 加權加法圖像融合plt.figure(figsize=(9, 6)) plt.subplot(221), plt.title("original"), plt.axis('off') plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(222), plt.title("watermark"), plt.axis('off') plt.imshow(cv.cvtColor(markC3, cv.COLOR_BGR2RGB)) plt.subplot(223), plt.title("watermark embedded"), plt.axis('off') plt.imshow(cv.cvtColor(imgMark1, cv.COLOR_BGR2RGB)) plt.subplot(224), plt.title("watermark embedded"), plt.axis('off') plt.imshow(cv.cvtColor(imgMark2, cv.COLOR_BGR2RGB)) plt.tight_layout() plt.show()

添加馬賽克

實現馬賽克的原理就是將處理區域劃分為一個個小方塊,每個小方塊內所有像素置為相同的或相似的像素值。

示例程序:

""" 添加馬賽克 """ import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread("../img/lena.jpg", 1) # 加載原始圖片 roi = cv.selectROI(img, showCrosshair=True, fromCenter=False) x, y, wRoi, hRoi = roi # 矩形裁剪區域的位置參數 # x, y, wRoi, hRoi = 208, 176, 155, 215 # 矩形裁剪區域 imgROI = img[y:y + hRoi, x:x + wRoi].copy() # 切片獲得矩形裁剪區域plt.figure(figsize=(9, 6)) plt.subplot(231), plt.title("Original image"), plt.axis('off') plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB)) plt.subplot(232), plt.title("Region of interest"), plt.axis('off') plt.imshow(cv.cvtColor(imgROI, cv.COLOR_BGR2RGB))mosaic = np.zeros(imgROI.shape, np.uint8) # ROI 區域 ksize = [5, 10, 20] # 馬賽克塊的寬度 for i in range(3):k = ksize[i]for h in range(0, hRoi, k):for w in range(0, wRoi, k):color = imgROI[h, w]mosaic[h:h + k, w:w + k, :] = color # 用頂點顏色覆蓋馬賽克塊imgMosaic = img.copy()imgMosaic[y:y + hRoi, x:x + wRoi] = mosaicplt.subplot(2, 3, i + 4), plt.title("Coding image (size={})".format(k)), plt.axis('off')plt.imshow(cv.cvtColor(imgMosaic, cv.COLOR_BGR2RGB))plt.subplot(233), plt.title("Mosaic"), plt.axis('off') plt.imshow(cv.cvtColor(mosaic, cv.COLOR_BGR2RGB)) plt.show()

趣味應用

下面這個是迷途小書童的Note編寫的,通過調整色調和色相,可以將圖片變成賽博朋克風格。

完整代碼:

""" Title:賽博朋克特效實現 Author:迷途小書童的Note Link:https://mp.weixin.qq.com/s/brZSanGvqqi6AHT3wg54Lg """import cv2 import numpy as npdef modify_color_temperature(img):# ---------------- 冷色調 ---------------- ## 1.計算三個通道的平均值,并依據平均值調整色調imgB = img[:, :, 0]imgG = img[:, :, 1]imgR = img[:, :, 2]# 調整色調 # 白平衡 -> 三個值變化相同# 冷色調(增加b分量) -> 除了b之外都增加# 暖色調(增加r分量) -> 除了r之外都增加bAve = cv2.mean(imgB)[0]gAve = cv2.mean(imgG)[0] + 10rAve = cv2.mean(imgR)[0] + 10aveGray = (int)(bAve + gAve + rAve) / 3# 2. 計算各通道增益系數,并使用此系數計算結果bCoef = aveGray / bAvegCoef = aveGray / gAverCoef = aveGray / rAveimgB = np.floor((imgB * bCoef)) # 向下取整imgG = np.floor((imgG * gCoef))imgR = np.floor((imgR * rCoef))# 3. 變換后處理imgb = imgBimgb[imgb > 255] = 255imgg = imgGimgg[imgg > 255] = 255imgr = imgRimgr[imgr > 255] = 255cold_rgb = np.dstack((imgb, imgg, imgr)).astype(np.uint8)return cold_rgbdef reverse_hue(image):# 反轉色相image_hls = cv2.cvtColor(image, cv2.COLOR_BGR2HLS)image_hls = np.asarray(image_hls, np.float32)hue = image_hls[:, :, 0]hue[hue < 90] = 180 - hue[hue < 90] - 10image_hls[:, :, 0] = hueimage_hls = np.asarray(image_hls, np.uint8)image = cv2.cvtColor(image_hls, cv2.COLOR_HLS2BGR)return imagedef cyberpunk(image):image_lab = cv2.cvtColor(image, cv2.COLOR_BGR2Lab)image_lab = np.asarray(image_lab, np.float32)image_lab[:,:,0] = np.clip(image_lab[:,:,0] * 1.2,0,255)# 提高像素亮度,讓亮的地方更亮light_gamma_high = np.power(image_lab[:, :, 0], 0.9)light_gamma_high = np.asarray(light_gamma_high / np.max(light_gamma_high) * 255, np.uint)# 降低像素亮度,讓暗的地方更暗light_gamma_low = np.power(image_lab[:, :, 0], 1.1)light_gamma_low = np.asarray(light_gamma_low / np.max(light_gamma_low) * 255, np.uint8)# 調色至偏紫dark_b = image_lab[:, :, 2] * (light_gamma_low / 255) * 0.4dark_a = image_lab[:, :, 2] * (1 - light_gamma_high / 255) * 0.1image_lab[:, :, 2] = np.clip(image_lab[:, :, 2] - dark_b, 0, 255)image_lab[:, :, 1] = np.clip(image_lab[:, :, 1] - dark_a, 0, 255)image_lab = np.asarray(image_lab, np.uint8)return cv2.cvtColor(image_lab, cv2.COLOR_Lab2BGR)if __name__ == "__main__":# 設置窗口可縮放cv2.namedWindow('origin', cv2.WINDOW_NORMAL | cv2.WINDOW_KEEPRATIO)cv2.namedWindow('cold_style', cv2.WINDOW_NORMAL | cv2.WINDOW_KEEPRATIO)cv2.namedWindow('reverser_hue', cv2.WINDOW_NORMAL | cv2.WINDOW_KEEPRATIO)cv2.namedWindow('cyberpunk', cv2.WINDOW_NORMAL | cv2.WINDOW_KEEPRATIO)image = cv2.imread("../img/img.jpg")cv2.imshow("origin", image)image = modify_color_temperature(image)cv2.imshow("cold_style", image)image = reverse_hue(image)cv2.imshow("reverser_hue", image)# cv2.waitKey()image = cyberpunk(image)cv2.imshow("cyberpunk", image)cv2.imwrite("result2.jpg", image)cv2.waitKey()

總結

以上是生活随笔為你收集整理的【OpenCV】Chapter10.色彩转换与图像绘制的全部內容,希望文章能夠幫你解決所遇到的問題。

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

最新日韩在线观看 | 国产免费又爽又刺激在线观看 | 成 人 黄 色 免费播放 | 中文字幕区 | 欧美一级黄色视屏 | 日韩大陆欧美高清视频区 | 91麻豆精品91久久久久同性 | 欧美地下肉体性派对 | 日韩在线观看视频一区二区三区 | 99久久久久国产精品免费 | 日韩国产精品毛片 | 国产精品久久久久影院 | 亚洲国产影院av久久久久 | 在线国产一区 | 久久精品人| 欧美性高跟鞋xxxxhd | 久久久精品免费观看 | 蜜桃视频在线视频 | 国产在线播放不卡 | 成人黄色av网站 | 黄色福利网 | 在线视频一区二区 | 欧美色图另类 | 国产精选视频 | 在线观看911视频 | 婷婷看片| 日韩视频在线不卡 | 中文字幕网址 | 国产a国产a国产a | 国产视频久久 | 欧美一区二区三区激情视频 | 91av视频| 亚洲精品小视频在线观看 | www.夜夜操.com| 久久久久成人精品免费播放动漫 | 亚洲黄色在线 | 天堂黄色片 | 久久婷婷精品视频 | 久久久久久久久久久久亚洲 | 久久国产精品一区二区三区 | 亚洲国产精品人久久电影 | 黄色毛片视频免费观看中文 | av丝袜制服| 久热久草在线 | 91在线小视频 | 最新精品视频在线 | 色综合激情网 | 人人插人人舔 | 国产伦理一区二区 | 在线观看成年人 | 伊人天天干 | 欧美日本在线观看视频 | 国产精品视频久久久 | 中文字幕 欧美性 | 日韩欧美视频免费看 | 91在线看免费 | 国产精品一区二区在线 | 婷婷六月中文字幕 | 一区二精品 | 午夜精品一区二区三区四区 | 黄色在线观看网站 | 国产高清在线视频 | 欧美日韩视频免费 | 日韩丝袜在线观看 | 亚洲精品在线看 | 国产成人精品亚洲日本在线观看 | 国产美女免费观看 | 久久福利在线 | 97超在线视频 | 亚洲久草在线视频 | 在线电影日韩 | 国产精品久久久久久av | 91精品国产成人www | 国偷自产中文字幕亚洲手机在线 | 亚洲精品综合一二三区在线观看 | 日韩mv欧美mv国产精品 | 99免费在线观看 | 免费在线观看亚洲视频 | 在线观看黄色的网站 | 在线观看中文字幕亚洲 | 国产1区2 | 久久色网站 | 中文字幕成人在线观看 | 99色在线视频 | 欧美怡红院视频 | 精品99久久久久久 | 久久综合九色综合欧美就去吻 | 亚洲另类视频在线观看 | 99精品在线看 | 亚州国产视频 | 久草在线在线精品观看 | 成人小视频在线观看免费 | 久精品视频在线 | 欧美性生交大片免网 | 视频一区二区免费 | 国产做a爱一级久久 | 色香网| 99精品久久只有精品 | 91亚洲综合 | 久久久久久美女 | 久久理论影院 | 国产精品久久精品 | 色婷婷亚洲婷婷 | 日韩国产高清在线 | 欧美日韩1区| 成人在线一区二区 | 高清有码中文字幕 | 免费福利片2019潦草影视午夜 | 国产香蕉97碰碰碰视频在线观看 | 久久久久久久久国产 | 江苏妇搡bbbb搡bbbb | 色国产在线 | 亚州欧美精品 | 精品产品国产在线不卡 | 久草色在线观看 | 一级片视频在线 | 国产成人久久 | 最新中文在线视频 | 黄色综合| 国产首页 | www91在线观看| 色综合色综合久久综合频道88 | 欧洲精品二区 | 国产精品福利午夜在线观看 | www国产亚洲精品久久网站 | 最近中文字幕免费视频 | 一级理论片在线观看 | 亚洲日b视频 | 久久手机在线视频 | 91九色视频在线播放 | 成人免费在线观看av | 婷婷在线免费 | 伊人婷婷在线 | 国产精品一区久久久久 | 91亚洲精品久久久蜜桃 | 亚洲成年人免费网站 | 午夜久久| 欧美日韩免费观看一区=区三区 | 激情av在线播放 | 国产精品免费看久久久8精臀av | 丁香5月婷婷久久 | 91色影院 | 91看片淫黄大片91 | 日本激情视频中文字幕 | 免费碰碰| 欧美日韩aa | 亚洲一级黄色片 | 免费a级毛片在线看 | 国产精品一区二区久久 | 久久久在线视频 | 国产日产亚洲精华av | 99成人在线视频 | 欧美日韩性 | 日韩经典一区二区三区 | 国产在线国偷精品产拍免费yy | 高清av免费一区中文字幕 | 精品国产免费久久 | 人人插人人玩 | 免费福利在线播放 | 午夜精品99久久免费 | 免费a现在观看 | 国产精品久久久久久久久久久久冷 | 久久中文网 | 色全色在线资源网 | 久久日韩精品 | 国产精品6 | 亚洲精品资源在线观看 | 久 久久影院 | 成人久久精品 | 国产一级二级三级在线观看 | 成人久久电影 | 久久69av| 色综合久久天天 | 成年人免费看av | 中文字幕视频网站 | 天堂中文在线视频 | 国产伦精品一区二区三区在线 | 午夜黄色一级片 | 欧美色就是色 | 西西4444www大胆视频 | 91av在线播放视频 | 午夜av免费 | av一级免费 | 国产在线观看av | 成人国产电影在线观看 | 久久情网 | 最近免费中文字幕 | 在线免费高清视频 | av黄色影院 | 性色在线视频 | av中文天堂| 天天操综合网站 | 毛片在线播放网址 | 精品国产一区二区三区四区在线观看 | 探花视频在线观看免费版 | 人人舔人人干 | 成人夜晚看av | 国产一级性生活 | 手机看片| 欧美最猛性xxxxx亚洲精品 | 中文字幕在线观看三区 | 99久久精品国产一区二区成人 | 日本一区二区免费在线观看 | 久草在线视频网站 | 三级黄色大片在线观看 | 精品久久久久久久久久岛国gif | 在线国产日本 | 国产高清一级 | 亚洲黄色免费 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 免费观看的黄色片 | av中文字幕在线观看网站 | 午夜国产福利在线 | 制服丝袜在线 | 在线成人免费 | 美女中文字幕 | 国产福利中文字幕 | 亚洲va在线va天堂va偷拍 | 一区三区在线欧 | 午夜精品久久一牛影视 | 天天草天天干天天 | 99久久精品久久久久久清纯 | 国产美女黄网站免费 | 日日综合 | 欧美 另类 交| 女人18片毛片90分钟 | 成人资源网| 欧美日韩国内在线 | 国产精品久久久久久久久久免费看 | 国产黄色资源 | 久久久久久免费视频 | 精品久久久久久一区二区里番 | 日韩和的一区二在线 | 国产原创91 | 黄色成人av | 天天天操操操 | 久久人人爽人人片av | 韩国av免费看| 国内一区二区视频 | 婷婷综合伊人 | 久草热视频 | 久久中文欧美 | 91福利视频免费 | 久久久网址 | 丰满少妇高潮在线观看 | 国产清纯在线 | 国产精品久久久久久久久岛 | 免费视频久久久久久久 | av成人黄色 | 欧美日韩一区二区在线观看 | 日韩中文字幕亚洲一区二区va在线 | 91亚洲在线 | 日本久久免费电影 | 亚洲成人av在线电影 | 黄色国产在线观看 | 91精品国 | 99九九热只有国产精品 | 在线а√天堂中文官网 | 国产精品久久久久免费观看 | 91.dizhi永久地址最新 | 午夜三级福利 | 日韩网站在线免费观看 | 亚洲婷久久 | 亚洲三级精品 | 日韩一级电影在线 | 精品久久久久久综合日本 | 偷拍视频一区 | 久久伦理影院 | 日韩av免费一区 | 成人毛片一区二区三区 | 在线观看国产日韩欧美 | 激情五月综合网 | 91在线看黄 | 久久精品国产免费看久久精品 | 中文字幕 二区 | 美女久久久 | 久久尤物电影视频在线观看 | 亚洲精品乱码久久久久久久久久 | 黄色特级片 | 国产视频 亚洲视频 | 手机av网站 | 天天做日日爱夜夜爽 | 国产成人91 | 99久久久免费视频 | 国产色网 | 日韩免费电影 | 国产精品久久久久一区二区三区共 | 亚洲精品综合久久 | 国产精品久久久久久一区二区三区 | 色综合久久精品 | 在线视频欧美精品 | 91麻豆精品久久久久久 | 在线成人免费电影 | 欧美一区二视频在线免费观看 | 日韩精品免费一区 | 成人午夜黄色影院 | av大全免费在线观看 | 久久天天综合网 | av在线播放快速免费阴 | 欧美日韩国产高清视频 | 五月婷网站 | 国产理论一区二区三区 | 国产精品久久久免费 | 国产破处视频在线播放 | 国产黄色精品在线观看 | 黄色一级免费电影 | 伊人久在线 | 国内小视频 | 国产精品免费观看视频 | 欧美91精品久久久久国产性生爱 | av电影中文字幕在线观看 | 日韩精品欧美一区 | 97品白浆高清久久久久久 | 四虎伊人 | 最近免费在线观看 | 久久免费视频这里只有精品 | 亚洲va综合va国产va中文 | 国内揄拍国内精品 | 欧美日韩高清免费 | 亚洲欧美一区二区三区孕妇写真 | 国产一级片观看 | 草莓视频在线观看免费观看 | 欧美性爽爽| 国产精品高清一区二区三区 | 97视频免费观看 | 热久久免费视频 | 国产一级淫片免费看 | 久久精品五月 | 久久久毛片 | 久久夜色电影 | 国产69精品久久久久99尤 | 成人av电影免费观看 | 99久高清在线观看视频99精品热在线观看视频 | 国产精品国内免费一区二区三区 | 日韩在线免费不卡 | aⅴ视频在线| 久久只精品99品免费久23小说 | 日韩电影中文字幕在线 | 99热只有精品在线观看 | 蜜桃视频精品 | 久久综合综合久久综合 | 国产在线精品二区 | 黄色资源网站 | 久草在线观看视频免费 | 一级免费看| 日韩电影久久久 | 久久视频网 | 国产小视频免费在线网址 | www毛片com| 91麻豆精品国产91久久久久久 | 色片网站在线观看 | 右手影院亚洲欧美 | 欧美a级成人淫片免费看 | wwwwww国产 | 亚洲伦理一区二区 | 青青河边草观看完整版高清 | 色婷婷伊人 | 91在线超碰 | 欧美aaaxxxx做受视频 | 精品国产乱码久久久久久天美 | 国产精品久久久久久婷婷天堂 | 国产成人精品999在线观看 | 色是在线视频 | 久久视频精品在线 | 91色亚洲 | 在线观看黄色av | 国产精品免费一区二区三区在线观看 | 欧美亚洲一区二区在线 | 91在线区 | 久久不卡av | 欧美亚洲久久 | 久久国产一区二区三区 | 国产精品乱码久久久久久1区2区 | 久久99热久久99精品 | 在线看毛片网站 | 国产精品免费麻豆入口 | 黄色综合 | 国产精品午夜免费福利视频 | 狠狠操夜夜 | 色狠狠综合 | 国产精品va最新国产精品视频 | 人人精品 | 99热在线观看| 国产精品久久久久久吹潮天美传媒 | 中文字幕在线免费观看视频 | 欧美国产日韩在线视频 | 一级c片| 中文一区在线观看 | 国内外成人免费在线视频 | 精品久久在线 | 亚洲综合少妇 | av日韩不卡 | 国产精品一区二区三区视频免费 | 探花视频免费观看 | 在线视频观看国产 | 久99热| 91亚色在线观看 | www.com.黄| 国产亚洲成人网 | 国产精品私拍 | 在线观看久| 欧美日韩精品影院 | 天天干夜夜操视频 | 伊人官网 | 中文字幕在线看人 | 狠狠88综合久久久久综合网 | 国内视频1区 | h视频日本 | 久久综合综合久久综合 | 国产精品2区 | 免费看片黄色 | 亚洲国产精品推荐 | 亚洲国产午夜 | 亚洲一级片免费观看 | 97在线视频网站 | 最新日韩精品 | 亚洲激精日韩激精欧美精品 | 91精品小视频 | 亚洲一区二区91 | 天天操比| 国产玖玖在线 | 欧美电影黄色 | 一区二区精品 | 果冻av在线 | 久久久久久久久网站 | 97超碰人人| 99福利片 | 日韩久久一区 | 国产一级性生活 | 午夜精品一二三区 | 久久伊人操| 国产精品成人一区二区三区吃奶 | 久久综合狠狠综合久久激情 | 在线免费观看涩涩 | 欧美日韩国产高清视频 | 国产亚洲精品久久久久久移动网络 | 免费av大片 | 99产精品成人啪免费网站 | 免费又黄又爽视频 | 国产精品永久在线 | 玖玖视频在线 | 一本一道波多野毛片中文在线 | 色91av| 国产亚洲欧美在线视频 | 亚洲成人动漫在线观看 | 成年人三级网站 | 日韩欧美一二三 | 久久97久久97精品免视看 | 国产区高清在线 | 久久激情视频 久久 | 91福利在线观看 | 97色涩 | 亚洲欧洲在线视频 | 又黄又爽的免费高潮视频 | 成人国产精品入口 | 欧美极品一区二区三区 | 免费视频97 | 五月婷久 | 欧美韩日视频 | 国产精品麻 | 成年人在线免费看视频 | 992tv在线成人免费观看 | 九九久久国产 | 天天射天天操天天干 | 在线v片| 国产亚洲久久 | 免费能看的av | 国产成人亚洲在线观看 | 亚洲国产wwwccc36天堂 | 亚洲无吗视频在线 | 最新在线你懂的 | 欧美日韩中| 九九九热精品免费视频观看网站 | 有码视频在线观看 | 国产高清视频网 | 欧美精品中文在线免费观看 | 国产精品人人做人人爽人人添 | 国产精品观看在线亚洲人成网 | 国产美女免费视频 | 免费在线观看日韩视频 | 黄色网址中文字幕 | 在线视频手机国产 | www.久久久.cum| 久久免费精品一区二区三区 | 伊人丁香 | 欧美国产日韩中文 | 欧美一区在线观看视频 | 2020天天干天天操 | 国产毛片久久 | 久久久久观看 | 人人爽人人澡人人添人人人人 | 国产亚洲精品久久久久久 | 日韩高清www | 91亚洲免费| 国产精品99久久久久久武松影视 | 久草免费在线观看视频 | 久久久久久免费 | 久久免费视频8 | 婷婷久久一区 | 久久久久久影视 | 日本精品视频在线播放 | 天天摸日日摸人人看 | a亚洲视频| 中文av在线免费观看 | 在线激情影院一区 | 天天艹天天干天天 | 97国产精品亚洲精品 | 国产黄色看片 | 看片的网址 | 国产精久久久久久妇女av | 成人影视片 | 国产精品美女视频 | 麻豆手机在线 | 一区三区在线欧 | 2019天天干天天色 | 最新色站| 人人插人人插 | 久碰视频在线观看 | 91九色porny蝌蚪视频 | 亚洲天堂网视频在线观看 | 日韩电影在线观看一区二区三区 | 91在线观看欧美日韩 | 黄色av电影一级片 | 人人爽人人爽人人爽人人爽 | 久久精品香蕉 | 黄色不卡av| 精品视频久久 | www99久久| 欧美午夜理伦三级在线观看 | 亚洲综合成人在线 | 免费网站v | 国产成人黄色网址 | 天天拍天天干 | 黄色a视频 | 激情久久久 | 久久激情五月婷婷 | 特及黄色片 | 日韩在线观看网址 | 国产成人精品一区二区三区 | 国产高清在线免费视频 | 中文字幕av有码 | 福利视频第一页 | 在线视频观看亚洲 | 丁香婷婷成人 | 99热国产在线 | 91亚洲精品久久久蜜桃网站 | av黄色免费在线观看 | 在线a视频免费观看 | 国产精品av久久久久久无 | 欧亚日韩精品一区二区在线 | 97超碰成人在线 | 999久久 | 国产精品女主播一区二区三区 | 久久久久成 | 精品久久久久久久久久久久 | 久久综合偷偷噜噜噜色 | 中文一区在线 | 日日夜夜免费精品视频 | 国产成人av福利 | 网站你懂的| 超碰在线人人爱 | 九九一级片 | 999国内精品永久免费视频 | 综合久久五月天 | 久久免费看a级毛毛片 | 日本护士三级少妇三级999 | 亚洲成人999| 丁香婷婷在线 | 男女拍拍免费视频 | 六月丁香在线视频 | 国产精品久久久久久久久久久免费 | 美国三级黄色大片 | 69国产盗摄一区二区三区五区 | 欧美午夜理伦三级在线观看 | 欧美精品三级在线观看 | 日韩黄色一区 | 五月天激情在线 | 中文字幕亚洲字幕 | 91视频高清完整版 | 国产精品高 | 尤物九九久久国产精品的分类 | 在线免费观看国产黄色 | 国产涩涩网站 | 色综合亚洲精品激情狠狠 | 9草在线 | 亚州av网站 | 精品久久久久久电影 | 久久最新网址 | 欧美精品在线观看一区 | av软件在线观看 | 日本中文字幕在线免费观看 | 97韩国电影| 奇米网在线观看 | 黄色一集片 | 国产精品久一 | 欧美美女一级片 | 亚洲在线高清 | 美女国产免费 | 久久国产一区二区 | 在线中文字母电影观看 | 国产成人久久精品亚洲 | 久久艹99| 黄色a视频 | www.夜夜| 欧美日韩一区二区视频在线观看 | 久久激情小视频 | 国产尤物在线视频 | 免费精品在线 | 久久九九国产视频 | 成人动漫一区二区三区 | 精品久久久久久一区二区里番 | 久草免费手机视频 | 伊人婷婷网 | 狠狠伊人 | 天天色视频 | 国产91丝袜在线播放动漫 | 国产精品久久久久久av | 综合久久网 | 中文字幕欧美激情 | 成年人在线观看免费视频 | 中文字幕国产一区二区 | 日韩视频图片 | 亚洲国产三级在线 | 手机看片久久 | 色网站视频 | 亚洲欧美激情精品一区二区 | 九七人人干| 成年人免费在线观看网站 | 黄色国产高清 | 在线看福利av | 九九精品久久 | 成人动漫视频在线 | 丁香激情综合久久伊人久久 | 免费日韩 精品中文字幕视频在线 | 亚洲午夜av久久乱码 | 久久丁香网 | 国产精品一区在线观看你懂的 | 黄色99视频 | 久草精品在线观看 | 国产一区欧美在线 | 国产精品女视频 | 99在线免费视频 | 日韩激情综合 | 国产亚洲精品久久久久久移动网络 | 又黄又爽的免费高潮视频 | 亚洲黄色激情小说 | 久久国产区 | 日韩中文字幕免费电影 | 欧美激情亚洲综合 | 91麻豆精品国产91久久久使用方法 | 亚洲精品在线观看视频 | 国产精品一区二区在线观看免费 | 中文字幕乱码视频 | 国产手机在线观看视频 | 波多野结衣亚洲一区二区 | 在线观看免费观看在线91 | 午夜久久久久久久久久久 | 91探花在线视频 | 福利视频导航网址 | 日韩福利在线观看 | 国产精品一区二区美女视频免费看 | 国产99亚洲 | 久久综合精品国产一区二区三区 | 永久黄网站色视频免费观看w | 国产视频网站在线观看 | 波多野结衣在线视频免费观看 | 天天性天天草 | av永久网址 | 日本久久久久久久久 | 精品免费一区二区三区 | 国产区免费在线 | 日韩欧美黄色网址 | 中文在线免费观看 | 色婷婷av国产精品 | av色一区| 五月天免费网站 | 日本中文字幕在线一区 | 色姑娘综合网 | 中文字幕av在线播放 | 国产在线91在线电影 | 亚洲成a人片77777kkkk1在线观看 | 一级免费看视频 | 99视频国产精品免费观看 | 伊人婷婷久久 | 日日躁夜夜躁xxxxaaaa | 18岁免费看片 | 国产精品永久在线观看 | 精品国产乱码一区二 | 91超在线 | 狠狠干天天 | 久久尤物电影视频在线观看 | 99看视频在线观看 | 久久精品79国产精品 | 午夜精品久久久久 | 免费亚洲黄色 | 日韩精品一区二区三区丰满 | 久久久www免费电影网 | 亚洲综合五月天 | 伊人影院av | 久草久热| 欧美高清视频不卡网 | 欧美日韩不卡在线视频 | 国产亚洲精品电影 | 黄色网在线免费观看 | 182午夜在线观看 | 国产91区| 国产精品99久久久久久宅男 | 中文在线天堂资源 | 亚洲精品久久激情国产片 | 日本视频网| 人操人 | 国产精品美女999 | 日本中文乱码卡一卡二新区 | 天天色官网| 久久日韩精品 | 婷久久| 久久在线免费观看视频 | 手机看片国产日韩 | 亚洲国产小视频在线观看 | 久久激五月天综合精品 | 久久综合给合久久狠狠色 | 三级免费黄 | 亚洲蜜桃在线 | 特级黄色片免费看 | 91欧美精品 | 天天草天天 | 色99之美女主播在线视频 | 999在线视频| 天天拍天天色 | 一本—道久久a久久精品蜜桃 | 亚洲精品国产精品乱码不99热 | 国产精品 日韩 欧美 | 免费看的毛片 | 日韩久久久久久久 | 一区二区三区四区在线 | 91亚洲狠狠婷婷综合久久久 | 91人人视频在线观看 | 日韩欧美在线免费观看 | a视频免费看 | 99在线免费视频 | av解说在线观看 | 欧美日韩xxxxx | 国产69精品久久久久久 | av免费在线网 | 久久精品一二三区 | 天天av综合网 | 久久福利 | 日韩黄色一区 | 国产精品久久久久一区二区国产 | 一区二区三区手机在线观看 | 久久午夜精品视频 | 5月丁香婷婷综合 | 一级理论片在线观看 | 日本在线观看中文字幕无线观看 | 婷婷综合五月天 | 久久国产手机看片 | 久久91久久久久麻豆精品 | 国产婷婷精品 | 在线观看视频精品 | 日韩电影在线观看一区二区 | www五月婷婷| 国产女人18毛片水真多18精品 | www久久九 | 国产精品久久一区二区三区不卡 | 欧美在线视频精品 | 色综合中文综合网 | 免费av观看 | 国产视频1| 国产在线观看91 | 91九色蝌蚪国产 | 天天插狠狠干 | 91一区啪爱嗯打偷拍欧美 | 特级毛片网站 | 免费看黄在线看 | 国精产品999国精产品视频 | 久草精品视频在线看网站免费 | 中文字幕乱码亚洲精品一区 | 日韩精品视频在线免费观看 | 午夜在线免费观看 | 天天做日日做天天爽视频免费 | 国产精品免费一区二区三区 | 69精品久久 | 国产一区国产精品 | 国产色拍拍拍拍在线精品 | 亚洲女人天堂成人av在线 | 国产精品毛片久久 | 日本最大色倩网站www | 日韩免费 | 国产精品一二 | 日韩三级视频在线观看 | 粉嫩av一区二区三区四区五区 | 欧美黄色特级片 | 色综合久久中文综合久久牛 | 国产精品不卡在线观看 | 综合婷婷丁香 | 在线视频 一区二区 | 日本久久久久久久久久久 | 日韩免费一二三区 | 超碰在线观看av.com | 天堂在线一区二区 | 成人黄色av免费在线观看 | 91精品入口 | 日韩影片在线观看 | 青青河边草观看完整版高清 | 青草草在线视频 | 一区二区 久久 | 亚洲欧洲美洲av | 夜夜视频 | 99综合影院在线 | 一级黄色免费 | 日韩一区二区三区免费视频 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 久久激情小说 | 欧美色图视频一区 | 精品美女国产在线 | 69国产成人综合久久精品欧美 | 日韩毛片在线一区二区毛片 | 国产精品嫩草69影院 | 亚洲激情婷婷 | 成人三级网站在线观看 | 国产成人久久精品 | 日韩欧美在线一区二区 | 香蕉视频在线看 | 在线看小早川怜子av | 在线黄色av | 久久免费的视频 | 一区二区亚洲精品 | 激情婷婷在线观看 | 免费男女羞羞的视频网站中文字幕 | www.久久色 | 欧美精品少妇xxxxx喷水 | 欧美少妇bbwhd | 亚洲日本va午夜在线影院 | 国产精品视频免费观看 | 97超碰人人澡人人爱学生 | 日韩精品免费在线观看 | 在线免费观看黄色 | 国产亚洲一级高清 | 免费看三级网站 | 日韩国产精品久久久久久亚洲 | 国产三级精品在线 | 日韩在线第一 | 亚洲精品av在线 | 色.com| 日韩电影在线观看一区二区 | 欧美在线不卡一区 | 国产在线观看xxx | 天天爽天天搞 | 日本99精品 | 一区二区三区动漫 | 国产精品99在线观看 | 黄在线免费观看 | 欧美日韩国产网站 | 最新久久免费视频 | 中文字幕五区 | 最新av在线网站 | 久久精品一区八戒影视 | 免费a v视频 | 日韩成人看片 | av福利在线免费观看 | 国产视频资源在线观看 | 成人资源在线 | 欧美一区二区日韩一区二区 | 日韩欧美不卡 | 欧美日韩视频在线 | 中文字幕在线观看日本 | 亚洲精品综合一区二区 | 91久久久久久久一区二区 | 国产精品美女久久久久久免费 | 亚洲精选在线 | 久久国产一区二区 | 国产成人av | 激情导航| 狠狠色噜噜狠狠狠 | av先锋中文字幕 | 欧美巨乳波霸 | 91九色最新 | 亚洲另类在线视频 | 亚洲精品国产精品久久99热 | 久久av一区二区三区亚洲 | 亚洲欧美日韩国产 | 五月婷婷六月丁香激情 | 午夜少妇av | 日韩色在线观看 | 免费日韩 精品中文字幕视频在线 | 伊人五月天.com | 91亚洲网 | 91麻豆网 | 久久优| av中文字幕在线电影 | 色福利网| 国产成人资源 | 久久精品99 | 射射色 | 爱爱一区| 天天干人人干 | 日韩av偷拍 | 久久久久久久综合色一本 | 国产成人精品一区二区在线 | 精品主播网红福利资源观看 | 福利网址在线观看 | 九九九九免费视频 | 色婷婷综合成人av | 99久热在线精品 | av在线进入 | 狠狠干天天操 | 一区二区三区在线视频观看58 | 日本精品一区二区三区在线播放视频 | 亚洲成av人片在线观看 | 精品一区三区 | 91九色国产在线 | 欧美少妇xx | 免费一级特黄录像 | 国产精品成人自产拍在线观看 | 久久艹欧美 | 美女免费黄视频网站 | 成人国产精品久久久久久亚洲 | 91精品少妇偷拍99 | 91在线操 | 一级黄色片在线免费观看 | 久草在线这里只有精品 | 天海冀一区二区三区 | 91看毛片 | 欧美成人a在线 | 午夜电影久久 | 日韩精品一区二区三区免费观看视频 | 国产精品国产三级国产不产一地 | 午夜精品一二区 | 亚洲天堂网在线视频观看 | 国产成人av免费在线观看 | 国产精品专区在线观看 | 精品一区二区精品 | 色五月激情五月 | 婷婷六月天天 | 色综合久久久久久久久五月 | 天堂黄色片 | 爱爱av网 | 国产一级高清视频 | 久久综合狠狠 | 精品国产一区二区三区四 | 久久精品99视频 | 丁香婷婷综合激情五月色 | 久久综合五月天 | 欧美色婷婷 | 久草视频在线免费 | 91福利区一区二区三区 | 香蕉影视在线观看 | 亚洲成人精品av | 国产精品国产三级国产不产一地 | 日韩专区 在线 | 在线免费色| 亚洲欧洲xxxx | 五月天色婷婷丁香 | 涩涩爱夜夜爱 | 少妇av网| 四虎www| 深爱激情五月网 | 手机看片国产 | 在线播放第一页 | a极黄色片 | 麻豆91在线观看 | 欧美极品少妇xbxb性爽爽视频 | 午夜精品久久久久久 | 久久91久久久久麻豆精品 | 黄污视频大全 | 久久国产成人午夜av影院宅 | 特级毛片在线免费观看 | 精品毛片一区二区免费看 | av免费观看高清 | 成人黄在线观看 | 国产一级不卡视频 | 成人一区影院 | 成年人黄色大片在线 | 91污在线观看 | 91精品国产99久久久久久红楼 | 欧美激情精品一区 | 伊人五月天婷婷 | 人人插人人 | 欧美日韩免费在线观看视频 | 亚洲国产精品va在线看黑人 | 狠狠狠狠狠狠操 | 日韩欧美综合在线视频 | 久久视频这里有久久精品视频11 | 激情综合五月 | 91综合色| 91亚瑟视频 | 91精品国产乱码久久 | 免费碰碰 | 精品资源在线 | 久操视频在线免费看 | 九九久| 精品久久久久免费极品大片 | 91久久久久久久一区二区 | 中文字幕永久免费 | www.久久爱.cn | 亚洲精品视频在线观看网站 | 黄色av一区二区三区 | 国产色视频网站 |