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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

OpenCV修养(三)——图像处理(上)

發布時間:2023/12/9 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 OpenCV修养(三)——图像处理(上) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

    • 致謝
  • 3 圖像處理(上)
    • 3.1 幾何變換
      • 3.1.1 圖像縮放
      • 3.1.2 圖像平移
      • 3.1.3 圖像旋轉
      • 3.1.4 仿射變換
    • 3.2 圖像閾值
    • 3.3 圖像平滑
      • 3.3.1 圖像噪聲
        • 3.3.1.1 椒鹽噪聲
        • 3.3.1.2 高斯噪聲
      • 3.3.2 均值濾波
      • 3.3.3 方框濾波
      • 3.3.4 高斯濾波
      • 3.3.5 中值濾波
      • 3.3.6 小結
    • 3.4 形態學操作
      • 3.4.1 連通性
        • 3.4.1.1 鄰接
        • 3.4.1.2 連通
      • 3.4.2 腐蝕和膨脹
        • 3.4.2.1 腐蝕
        • 3.4.2.2 膨脹
      • 3.4.3 開閉運算
      • 3.4.4 黑帽和禮帽
      • 3.4.5 梯度
    • 3.5 圖像梯度處理
      • 3.5.1 Sobel算子
      • 3.5.2 Scharr算子
      • 3.5.3 laplacian算子

致謝

OpenCV高斯濾波GaussianBlur_godadream的博客-CSDN博客_gaussianblur

opencv 圖像平移、縮放、旋轉、翻轉 圖像仿射變換_Ibelievesunshine的博客-CSDN博客_opencv 圖像仿射變換

opencv 圖像變換原理詳解 圖像平移 圖像旋轉 圖像縮放 - 我堅信陽光燦爛 - 博客園 (cnblogs.com)

3 圖像處理(上)

3.1 幾何變換

3.1.1 圖像縮放

cv2.resize(src,dsize,fx=0,fy=0,interpolation = cv2.INTER_LINEAR)

參數:

  • src:輸入圖像
  • dsize:按固定比例縮小
  • fx、fy:自定義比例縮小
  • interpolation:插值方法
插值含義
cv2.INTER_LINEAR雙線性插值法
cv2.INTER_NEAREST最近鄰插值
cv2.INTER_AREA像素區域重采樣
cv2.INTER_CUBIC雙三次插值
import cv2 as cv# 讀取圖片 img = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg") # 縮放 row, col = img.shape[0:2] resize_img = cv.resize(img, (2*col, 2*row), cv2.INTER_NEAREST) cv.imshow("image", resize_img) cv.waitKey(0)

3.1.2 圖像平移

cv.warpAffine(src,M,dsize)

  • src:輸入的圖像
  • M:2×3的移動矩陣
  • 移動矩陣通常為2*3,對于處于(x,y)的像素點,要把他們移動到(x+tx,y+tyx+t_x,y+t_yx+tx?,y+ty?),則只需構建M = [10tx01ty]\left [\begin{array}{ccc}1&0&t_x \\0&1&t_y \end{array}\right][10?01?tx?ty??],并且該矩陣必須是np.fload32類型的矩陣
  • dsize:輸出圖像的大小
import cv2 as cv import numpy as np import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family']='SimHei'# 讀取圖像 img = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg")# 設置平移矩陣 rows, cols = img.shape[:2] M = np.float32([[1, 0, 100], [0, 1, 50]]) dst = cv.warpAffine(img, M, (cols, rows))# 圖像顯示 fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(10, 8), dpi=100) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(dst[:, :, ::-1]) axes[1].set_title("平移后結果") plt.show()

out:

3.1.3 圖像旋轉

圖像旋轉是指圖像按照某個位置轉動一定角度的過程,旋轉中圖像仍然保持原始尺寸。

同樣地,圖像的選擇也需要提供一個矩陣,我們在此稱其為旋轉矩陣,在openCV中,通過cv2.getRotationMatrix2D可以返回一個矩陣。

cv.warpAffine(src,M,dsize)

  • src:輸入的圖像
  • M:旋轉矩陣
  • dsize:輸出圖像的大小

cv.getRotationMatrix2D(center,anger,scale)

  • center:旋轉中心
  • angle:旋轉角度
  • scale:縮放比例
  • return:旋轉矩陣
import cv2 as cv import numpy as np import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family'] = 'SimHei'# 讀取圖像 img = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg")# 設置平移矩陣 rows, cols = img.shape[:2] M = cv.getRotationMatrix2D((100, 100), 30, 1) dst = cv.warpAffine(img, M, (cols, rows))# 圖像顯示 fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(10, 8), dpi=100) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(dst[:, :, ::-1]) axes[1].set_title("平移后結果") plt.show()

out:

3.1.4 仿射變換

圖像的仿射變換設計到圖像的形狀位置角度的變化,是深度學習預處理中常用到的一個功能。仿射變換的主要工作是對圖像進行縮放、旋轉、翻轉、平移的一系列組合操作。

仿射變換的內核是兩個點:

  • 變換前是直線的,變換后依然是直線
  • 直線比例保持不變

在OpenCV中,仿射變換的矩陣是一個2×3的矩陣。如下所示:
M=[A,B]=[a00a01b0a10a11b1]M = [A,B] = \left[ \begin{array}{ccc} a_{00} & a_{01} & b_0\\ a_{10} & a_{11} & b_1\\ \end{array} \right ] M=[A,B]=[a00?a10??a01?a11??b0?b1??]
其中該矩陣的2×2子矩陣是線性變換矩陣,右邊2×1矩陣是平移項。

對于圖像中任一位置(x,y),仿射變換執行的是如下的操作:

Taffine=A[xy]+B=M[xy1]T_{affine} = A\left[\begin{array}{ccc}x\\y\end{array}\right]+B = M\left[\begin{array}{ccc}x\\y\\1\end{array}\right]Taffine?=A[xy?]+B=M???xy1????

需要注意的是,對于圖像而言,寬度方向是x,高度方向是y,坐標的順序和圖像像素對應下標一致。所以原點的位置不是左下角而是右上角,y的方向也不是向上,而是向下。

在仿射變換中,原圖中所有的平行線在結果圖像中同樣平行。為了創建這個矩陣我們需要從原圖像中找到三個點以及它們在輸出圖像中的位置,然后通過OpenCV提供的cv2.getAffineTransform來創建仿射變換的2*3矩陣。

import cv2 as cv import numpy as np import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family'] = 'SimHei'# 讀取圖像 img = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg")# 設置平移矩陣 rows, cols = img.shape[:2] pts1 = np.float32([[50, 50], [200, 50], [50, 200]]) pts2 = np.float32([[100, 100], [200, 50], [100, 250]]) M = cv.getAffineTransform(pts1, pts2) dst = cv.warpAffine(img, M, (cols, rows))# 圖像顯示 fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(10, 8), dpi=100) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(dst[:, :, ::-1]) axes[1].set_title("平移后結果") plt.show()

out:

3.2 圖像閾值

ret,dst = cv2.threshold(src,thresh,maxval,type)

  • src:輸入圖,只能輸入單通道圖像,通常來說為灰度圖
  • dst:輸出圖
  • thresh:閾值
  • maxval:當像素值超過了閾值,所賦予的值
  • type:二值化操作的類型
    • cv2.THRESH_BINARY:超過閾值部分取maxval,否則取0
    • cv2.THRESH_BINARY_INV:THRESH_BINARY的反轉
    • cv2.THRESH_TRUNC:大于閾值部分設為閾值,否則不變
    • cv2.THRESH_TOZERO:大于閾值部分不改變,否則設為0
    • cv2.THRESH_TOZERO_INV:cv2.THRESH_TOZERO的反轉
import cv2 import cv2 as cv import numpy as np import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg") ret, thresh1 = cv2.threshold(img, 127, 255, cv.THRESH_BINARY) ret, thresh2 = cv2.threshold(img, 127, 255, cv.THRESH_BINARY_INV) ret, thresh3 = cv2.threshold(img, 127, 255, cv.THRESH_TRUNC) ret, thresh4 = cv2.threshold(img, 127, 255, cv.THRESH_TOZERO) ret, thresh5 = cv2.threshold(img, 127, 255, cv.THRESH_TOZERO_INV)title = ['img', 'THRESH_BINARY', 'THRESH_BINARY_INV', 'THRESH_TRUNC','THRESH_TOZERO', 'THRESH_TOZERO_INV']fig, axes = plt.subplots(nrows=2, ncols=3, figsize=(20, 8), dpi=80) axes[0][0].imshow(img[:, :, ::-1]) axes[0][0].set_title(title[0]) axes[0][1].imshow(thresh1[:, :, ::-1]) axes[0][1].set_title(title[1]) axes[0][2].imshow(thresh2[:, :, ::-1]) axes[0][2].set_title(title[2]) axes[1][0].imshow(thresh3[:, :, ::-1]) axes[1][0].set_title(title[3]) axes[1][1].imshow(thresh4[:, :, ::-1]) axes[1][1].set_title(title[4]) axes[1][2].imshow(thresh5[:, :, ::-1]) axes[1][2].set_title(title[5]) plt.show()

out:

3.3 圖像平滑

3.3.1 圖像噪聲

由于圖像采集、處理、傳輸等過程不可避免的會受到噪聲的污染,妨礙人們對圖像理解及分析處理,常見的噪聲有高斯噪聲、椒鹽噪聲等。

3.3.1.1 椒鹽噪聲

椒鹽噪聲也稱為脈沖噪聲,是圖像中經常見到的一種噪聲,它是一種隨機出現的白點或者黑點,其出現的原因可能是因為影像訊號受到突如其來的強烈干擾而產生。如下圖所示:

3.3.1.2 高斯噪聲

高斯噪聲滿足高斯分布。

3.3.2 均值濾波

均值濾波實際上就是深度學習里面的平均池化。

讓我們先給出一張帶有噪點的圖片,以便下面做處理。

我們來解釋一下池化的含義。

池化是卷積神經網絡CNN的術語。認識什么是池化之前,我們要先了解什么是卷積,卷積就是通過一個小型矩陣(卷積核)對原圖片矩陣做掃描來輸入另外一個矩陣,這個另外的矩陣我們叫做卷積層。

小型矩陣和原圖片矩陣的映射關系是通過互相關運算來實現的,即對應的元素相乘在相加。如下圖所示:

理解了原理就好說了。池化層也是通過某種關系來輸出新矩陣的,根據這種關系我們將池化層分為平均池化層和最大池化層,其本質是用一個n×n的卷積核去掃描,而這個卷積核是沒有數字的,且他也不和原圖片做互相關運算。如果是平均池化層,那么是輸出卷積核覆蓋區域的平均數;而如果是最大池化層,則輸出卷積核覆蓋區域的最大數。

舉個例子,用2×2的池化窗口去掃描,如果窗口內的值是

  • max(0,1,3,4)=4,

  • max(1,2,4,5)=5,

  • max(3,4,6,7)=7,

  • max(4,5,7,8)=8。

說完了池化,讓我們回到濾波器。實際上,均值濾波的本質實際上就是平均池化窗口。

讓我們試著對上面的圖片做一下均值濾波處理。

import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") blur_img = cv.blur(img, (3, 3)) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(blur_img[:, :, ::-1]) axes[1].set_title("blur_img") plt.show()

out:

3.3.3 方框濾波

cv2.boxFilter( src, ddepth, ksize, anchor, normalize, borderType)

  • src指的是處理的圖像
  • ddepth:處理結果圖像的圖像深度,一般使用1 表示與原始圖像使用相同的圖像深度
  • normalize:是否進行歸一化

方框濾波使用歸一化時效果和均值濾波完全一樣,而不使用歸一化時,超過255的像素點默認會變成255,,如下所示。

import cv2 as cv import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") blur_img = cv.boxFilter(img, -1, (3, 3), normalize=False) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(blur_img[:, :, ::-1]) axes[1].set_title("blur_img") plt.show()

out:

3.3.4 高斯濾波

cv2.GaussianBlur(src, ksize, sigmaX, sigmaY=0, borderType=BORDER_DEFAULT);

  • src:輸入圖像

  • ksize:高斯卷積核的大小

  • sigmaX:表示水平方向的標準差

sigmaY:表示垂直方向的標準差,默認為0,表示于sigmaX相同

  • borderType:邊緣填充類型,默認無填充

高斯濾波器(卷積核)里的數值滿足高斯分布。

高斯濾波是一種線性平滑濾波,適用于消除高斯噪聲,廣泛應用于圖像處理的減噪過程。通俗的講,高斯濾波就是對整幅圖像進行加權平均的過程,每一個像素點的值,都由其本身和領域內的其他像素值經過加權平均后得到。

import cv2 as cv import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") blur_img = cv.GaussianBlur(img, (3, 3), 1) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(blur_img[:, :, ::-1]) axes[1].set_title("blur_img") plt.show()

out:

3.3.5 中值濾波

中值濾波是效果最好的濾波器,它是這么做的。用一個n×n(n一般為奇數)的卷積核去掃描一副圖像,在卷積核每一次覆蓋到的位置中,將里面所有的數字從小到大排列后取中位數,用中位數替換卷積核所在位置的中間值。如下圖所示:

import cv2 as cv import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") blur_img = cv.medianBlur(img, 5) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(blur_img[:, :, ::-1]) axes[1].set_title("blur_img") plt.show()

out:

3.3.6 小結

圖像處理中,常用的濾波算法有均值濾波、中值濾波以及高斯濾波等。

兩種噪聲:

噪聲說明
椒鹽噪聲圖像中隨機出現的白點或者黑點
高斯噪聲噪聲的概率分布是正態分布

三種濾波器的對比:

濾波器種類基本原理特點
均值濾波使用模板內所有像素的平均值代替模板中心像素灰度值算法簡單計算速度快,易收到噪聲的干擾,不能完全消除噪聲,只能相對減弱噪聲
中值濾波計算模板內所有像素中的中值,并用所計算出來的中值體改模板中心像素的灰度值對噪聲不是那么敏感,能夠較好的消除椒鹽噪聲,但是容易導致圖像的不連續性
高斯濾波對圖像鄰域內像素進行平滑時,鄰域內不同位置的像素被賦予不同的權值對圖像進行平滑的同時,同時能夠更多的保留圖像的總體灰度分布特征,對于高斯噪聲處理效果很好

我不是很建議你在初次學習的時候深究這些濾波器背后的數學原理,因為對于數學基礎不好的人來說一旦陷進去對自己的打擊很大。

3.4 形態學操作

形態學轉換是基于圖像形狀的一些簡單操作,它通常在二進制圖像上執行。腐蝕和膨脹是兩個基本的形態學運算符,他也有一些變體形式,如開運算、閉運算、禮帽黑帽等。

3.4.1 連通性

3.4.1.1 鄰接

在圖像中,最小的單位是像素,每個像素周圍有8個鄰接像素。常見的鄰接關系有3種:4鄰接、8鄰接和D鄰接。

其中我們用N4(p)N_4(p)N4?(p)表示像素p的4鄰接,同理ND(p)N_D(p)ND?(p),N8(p)N_8(p)N8?(p)。

3.4.1.2 連通

連通性是描述區域和邊界的重要概念,兩個像素連通的兩個必要條件是:

  • 兩個像素的位置是否相鄰
  • 兩個像素的灰度值是否滿足特定的相似性準則

連通也分三種,即4連通、8連通和m連通。

  • 4連通:對于具有值V的像素p和q,如果q在集合N4(p)N_4(p)N4?(p)中,則稱這兩個像素是4連通。
  • 8連通:對于具有值V的像素p和q,如果q在集合N8(p)N_8(p)N8?(p)中,則稱這兩個像素是8連通。

  • m連通:m連通就是同時滿足4連通和D連通即為m連通。

3.4.2 腐蝕和膨脹

腐蝕和膨脹是最基本的形態學操作,其都是針對白色部分而言。換而言之就是對高亮區域的擴大與縮小。

3.4.2.1 腐蝕

腐蝕的具體操作是用一個結構元素掃描圖像中的每一個元素,用結構元素中的每一個元素與其覆蓋的像素做“與”操作,如果都為1,則該像素為1,否則為0。如下圖所示,結構A被結構B(我們暫且看做是卷積核)腐蝕后:

腐蝕的作用就是消除物體邊界點,使目標縮小,其可以消除小于結構元素的噪聲點。通俗來說就是讓白色部分變小。

cv.erode(src,kernel,iterations,borderType,bordervalue)

  • src:要處理的圖像
  • kernel:核結構
  • iterations:腐蝕次數,默認為1
  • borderType:填充類型
  • bordervalue:填充值
import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") kernel = np.ones((5, 5)) new_img = cv.erode(img, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

3.4.2.2 膨脹

膨脹的具體操作是用一個結構元素掃描圖像中的每一個元素,用結構元素中的每一個元素與其覆蓋的像素做“與”操作,如果都為0,則該像素為0,否則為1。其原理和腐蝕很像的,我就不畫圖了,太累了。通俗來講,膨脹實際上就是擴大白色部分。

cv.dilate(src,kernel,iterations,borderType,bordervalue)

  • src:要處理的圖像
  • kernel:核結構
  • iterations:腐蝕次數,默認為1
  • borderType:填充類型
  • bordervalue:填充值
import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test03.jpg") kernel = np.ones((5, 5)) new_img = cv.dilate(img, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

3.4.3 開閉運算

開運算和閉運算和按照一定的次序去進行腐蝕和膨脹,但將原圖開運算后是無法通過閉運算返回原圖的。

開運算是先腐蝕后膨脹,其作用是分離物體,消除小區域。說成人話就是,如果你的圖像是全是黑的,但是其中有一些白色的噪聲點,那么開運算可以使你的圖片先去除白色噪聲,然后又恢復原來的圖片,這實際上是一個去除毛刺的操作;閉運算是先膨脹后腐蝕,其作用是消除/閉合物體里面的孔洞,可以填充閉合區域。說成人話就是,先膨脹讓白色噪聲變大,后腐蝕白色噪聲就無法消除了,所以所得圖片應該是和原圖差不多的白色噪聲或比原圖還大的白色噪聲。說了我們也聽不太懂,我們試著來處理一下。

cv.morphologyEx(src,op,kernel)

  • src:要處理的圖像
  • op:處理的方式,進行開運算則cv.MORPH_OPEN,若進行閉運算,則設為cv.MORPH_CLOSE
  • Kernel:核結構
import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg") kernel = np.ones((3, 3)) new_img = cv.morphologyEx(img, cv.MORPH_OPEN, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

有沒有感覺,這車子有點快跑出來的感覺。

import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg") kernel = np.ones((3, 3)) new_img = cv.morphologyEx(img, cv.MORPH_CLOSE, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

3.4.4 黑帽和禮帽

禮帽運算實際上是原圖像和開運算結果之差。

試想,開運算實際上就是消除白色毛刺,而原圖像又帶有刺,你用帶有刺的減去沒帶刺的,得到的結果(禮帽)不就是只有刺的圖了嗎。

開運算雖然優化了圖片,但是放大了裂縫或者局部低亮度的區域,因此,從原圖中減去開運算后的圖,得到的效果圖突出了比原圖輪廓周圍的區域更明亮的區域,且這一操作和選擇的核的大小有關。

而黑帽運算實際上是閉運算和原圖像之差。簡單來說,閉運算使得噪聲變大或不變,減去原圖像,得到的就是噪聲的輪廓。

黑帽運算后的效果圖突出了比原圖輪廓周圍的區域更暗的區域,且這一操作和選擇的核的大小有關。

黑帽運算用來分離比鄰近點暗一些的斑塊。

同樣的,黑帽運算和禮帽運算使用的是與開閉運算一樣的API。

cv.morphologyEx(src,op,kernel)

  • op部分選擇MORPH_TOPHAT則為禮帽,選擇MORPH_BLACKHAT則為黑帽
import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test01.jpg") kernel = np.ones((3, 3)) #new_img = cv.morphologyEx(img, cv.MORPH_TOPHAT, kernel) new_img = cv.morphologyEx(img, cv.MORPH_BLACKHAT, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

3.4.5 梯度

做一個梯度運算實際上就是先膨脹,再拿原圖膨脹的結果減去原圖腐蝕的結果。膨脹擴大白色區域,腐蝕縮小白色區域,兩個一做差,那么得到的肯定是白色區域的輪廓。如下圖所示:

import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test04.jpg") kernel = np.ones((3, 3)) new_img = cv.morphologyEx(img, cv.MORPH_GRADIENT, kernel) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

3.5 圖像梯度處理

3.5.1 Sobel算子

如上圖,我們如果在圖中畫一根紅線,紅線的左右有梯度嗎?明顯地,這里我們講的梯度可以用一個更簡單的詞來代替,即色差。可以看出,這條紅線左右是不存在梯度的。

那我們不禁想問,哪里有梯度呢?當然是這個白圈的邊緣了。

在形態學操作中,我們似乎都是用一個核去掃描圖像,在這里我們同樣這么做。我們可以用以下的卷積核去檢測區域的左右邊緣。
Gx=[?10+1?20+2?10+1]?AG_x = \left[\begin{array}{cc}-1&0&+1\\ -2&0&+2\\ -1&0&+1\end{array}\right]*A Gx?=????1?2?1?000?+1+2+1?????A
我們可以用以下的卷積核去檢測區域的上下邊緣。
Gy=[?1?2?1000+1+2+1]?AG_y = \left[\begin{array}{cc}-1&-2&-1\\ 0&0&0\\ +1&+2&+1\end{array}\right]*A Gy?=????10+1??20+2??10+1?????A
我們把以上兩個卷積核叫做Sobel算子矩陣,其用于增強邊緣的差異。當檢測目標區域邊緣時,我們可以用對應的核與目標區域做互相關運算。拿GxG_xGx?來說,其計算的結果我們可以看成是0列左右的差異值,即看成是梯度。

說完原理,讓我們看一下在OpenCV中如何使用Sobel算子。

dst = cv2.Sobel(src,ddepth,dx,dy,ksize)

  • ddeph:圖像深度
  • dx和dy分別表示水平和豎直方向
  • ksize是Sobel算子的大小
import cv2 import cv2 as cv import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test04.jpg") new_img = cv.Sobel(img, cv2.CV_64F, 1, 0, ksize=3) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

從指定參數和輸出結果來看,由于在sobel中我們指定參數dy = 0,dx = 1,說明使用上述Sobel算子矩陣GxG_xGx?。此矩陣右邊為正左邊為負。在圖像中,看往左半邊圓圈為白(255)方框為黑(0),則結果Sobel運算后得出結果為正數,所以得出的圖像左半圈留白明顯。其他情況也可按照上述推導過程推出結果,這里不過多贅述。

在Sobel運算中,白到黑是正數,黑到白是負數,而負數會被截斷成0,所以通常我們要取絕對值。

import cv2 import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test04.jpg") # kernel = np.ones((3, 3)) new_img = cv.Sobel(img, cv2.CV_64F, 1, 0, ksize=3) new_img = cv2.convertScaleAbs(new_img) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

當你想要同時檢測左右邊緣和上下邊緣時,同時對參數dx和dy設為1未嘗不可,但是由于dx設為1時上下會黑,dy設為1時左右會黑,當同時開啟時,可以會導致上下左右都會黑,而不會出現完美檢測輪廓的效果。如下圖所示:

import cv2 import cv2 as cv import matplotlib.pyplot as pltimg = cv.imread(r"C:\Users\13966\Desktop\Test04.jpg") new_img = cv.Sobel(img, cv2.CV_64F, 1, 1, ksize=3) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

為此,我們可以分別求解GxG_xGx?GyG_yGy?,然后將兩者用圖像混合操作按比例混合即可。如下所示:

import cv2 import cv2 as cv import matplotlib.pyplot as plt import numpy as npimg = cv.imread(r"C:\Users\13966\Desktop\Test04.jpg") new_img_x = cv.Sobel(img, cv2.CV_64F, 1, 0, ksize=3) new_img_y = cv.Sobel(img, cv2.CV_64F, 0, 1, ksize=3) new_img = cv.addWeighted(new_img_x, 0.5, new_img_y, 0.5, 0) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("image") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("new_img") plt.show()

out:

上面的圖片似乎不是很能看出效果,我們用另外一張圖片來看看效果:

import cv2 import cv2 as cv import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family']='SimHei'img = cv.imread(r"C:\Users\13966\Desktop\Test02.jpg") new_img = cv.Sobel(img, cv2.CV_64F, 1, 1, ksize=3) new_img_x = cv.Sobel(img, cv2.CV_64F, 1, 0, ksize=3) new_img_y = cv.Sobel(img, cv2.CV_64F, 0, 1, ksize=3) new_img1 = cv.addWeighted(new_img_x, 0.5, new_img_y, 0.5, 0) fig, axes = plt.subplots(nrows=1, ncols=3) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("指定參數效果") axes[2].imshow(new_img1[:, :, ::-1]) axes[2].set_title("混合效果") plt.show()

out:

3.5.2 Scharr算子

Scharr算子與Sobel算子類似,只不過它對于邊緣的檢測效果會放大。
Gx=[?303?10010?303]?AG_x = \left[\begin{array}{cc}-3&0&3\\ -10&0&10\\ -3&0&3\end{array}\right]*A Gx?=????3?10?3?000?3103?????A

Gy=[?3?10?3000?3?10?3]?AG_y = \left[\begin{array}{cc}-3&-10&-3\\ 0&0&0\\ -3&-10&-3\end{array}\right]*A Gy?=????30?3??100?10??30?3?????A

我們來看看它對于圖片的處理效果:

import cv2 import cv2 as cv import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family'] = 'SimHei'img = cv.imread(r"C:\Users\13966\Desktop\Test02.jpg") new_img_x = cv.Scharr(img, cv2.CV_64F, 1, 0) new_img_y = cv.Scharr(img, cv2.CV_64F, 0, 1) new_img = cv.addWeighted(new_img_x, 0.5, new_img_y, 0.5, 0) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("Scharr算子效果") plt.show()

out:

3.5.3 laplacian算子

laplacian算子和上述兩個算子不同,其由二階導組成,對于一些邊緣十分敏感,這雖然能夠提高精度,但是卻易受噪點影響。
G=[0131?41010]G = \left[\begin{array}{cc}0&1&3\\ 1&-4&1\\ 0&1&0\end{array}\right] G=???010?1?41?310????
對于拉普拉斯算子,其由于是二階導,所以不必在添加dx和dy參數。如下所示:

import cv2 import cv2 as cv import matplotlib.pyplot as plt import matplotlibmatplotlib.rcParams['font.family'] = 'SimHei'img = cv.imread(r"C:\Users\13966\Desktop\Test02.jpg") new_img = cv.Laplacian(img, cv2.CV_64F) fig, axes = plt.subplots(nrows=1, ncols=2) axes[0].imshow(img[:, :, ::-1]) axes[0].set_title("原圖") axes[1].imshow(new_img[:, :, ::-1]) axes[1].set_title("拉普拉斯算子效果") plt.show()

out:

總結

以上是生活随笔為你收集整理的OpenCV修养(三)——图像处理(上)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

视频在线观看一区 | 精品伊人久久久 | 国产色网| 久草免费色站 | 射射色 | 综合久久一本 | 久久激情日本aⅴ | 国产无套一区二区三区久久 | 国内精品久久久久久久久久清纯 | 91av视频导航| 中文字幕亚洲欧美日韩2019 | 亚洲三级精品 | 欧美精品久久久久久久亚洲调教 | 色播五月婷婷 | 深夜福利视频一区二区 | 亚洲在线黄色 | 91丨九色丨蝌蚪丨老版 | 欧美另类巨大 | 亚洲毛片一区二区三区 | 伊人电影在线观看 | a黄色 | 色视频网页 | 97在线看 | 国产一级一级国产 | x99av成人免费 | 91精品成人久久 | 欧美另类z0zx | 天天综合天天做天天综合 | 四虎永久网站 | 久久精品国产亚洲 | 日韩一区精品 | 久碰视频在线观看 | 免费看av在线 | 国产亚洲人 | 国产黄色av网站 | 黄色免费在线看 | 亚州av网站| 色大片免费看 | 国外调教视频网站 | 婷婷av网站 | 久久国内精品视频 | 成年人在线观看网站 | 精品久久视频 | 亚洲国产免费av | 99色在线视频 | 97视频在线免费播放 | 日本性动态图 | 成人免费影院 | 超碰在线日韩 | 好看av在线| 国产一区福利在线 | 天天操夜| a视频在线观看 | 久久国产精品99精国产 | 婷婷在线网站 | 在线亚洲高清视频 | 黄色成人在线观看 | 久久九九精品 | 亚洲日本激情 | 中文字幕资源网 | 免费日韩一区二区 | 久久久九色精品国产一区二区三区 | 91福利视频在线 | 亚洲欧美日韩精品一区二区 | 黄色av电影一级片 | 日韩av在线资源 | 成人亚洲免费 | 日韩av在线看 | 国产亚洲精品久久久久动 | 天天操夜夜拍 | 国产韩国精品一区二区三区 | 国产高清av免费在线观看 | 久久久精品网站 | 免费国产在线视频 | 大荫蒂欧美视频另类xxxx | 在线免费黄色av | 亚洲成人黄色 | 日日碰狠狠添天天爽超碰97久久 | 国产中的精品av小宝探花 | 久久艹精品 | 欧美精品一区二区免费 | 少妇bbb搡bbbb搡bbbb | 在线观看日本高清mv视频 | 久久国产精品成人免费浪潮 | 男女免费视频观看 | 狠狠gao| 亚洲一级在线观看 | 亚洲电影一区二区 | 黄色电影小说 | 911精品美国片911久久久 | 中文字幕日韩av | 日韩精品中文字幕在线不卡尤物 | 国产美女精品视频 | 九九久久久久久久久激情 | 欧美激情视频在线观看免费 | 久久精品国产精品亚洲 | 99 色| 99久久99久久免费精品蜜臀 | 中文字幕影片免费在线观看 | 免费亚洲婷婷 | 国产中文在线播放 | 久久综合色8888 | 在线91视频 | 天天操天天操天天操天天操天天操 | 一区二区毛片 | 日日摸日日添日日躁av | 狠狠干天天操 | 色丁香久久 | 毛片激情永久免费 | 亚洲一级特黄 | 久久国产精品免费 | 欧美孕交vivoestv另类 | 在线一区观看 | 五月天婷亚洲天综合网鲁鲁鲁 | 欧美少妇的秘密 | 色网站在线观看 | 草久在线观看 | 日日激情 | 久久天天躁夜夜躁狠狠85麻豆 | 国产亚洲永久域名 | 国产精品久久在线 | 日韩中文久久 | 91av在线视频免费观看 | 久久精品男人的天堂 | 日本精a在线观看 | av千婊在线免费观看 | 91香蕉视频污在线 | 日韩xxxxxxxxx | 免费a v网站 | 日本黄色一级电影 | 日韩色视频在线观看 | 亚洲视频2 | 91最新视频 | 啪啪凸凸 | 在线观看黄 | 在线视频观看成人 | 日韩精品一区二区在线观看 | 精品高清视频 | 怡红院av久久久久久久 | 在线观看黄色免费视频 | 国产在线美女 | 一级成人网 | mm1313亚洲精品国产 | 91精品爽啪蜜夜国产在线播放 | 久久人人爽爽 | 五月导航| 亚洲人片在线观看 | 黄色软件视频大全免费下载 | 久久久久区 | 国内精品久久影院 | 黄色1级大片 | 丁香久久婷婷 | 97在线免费 | 麻豆91精品91久久久 | 免费一级片久久 | 99精品视频精品精品视频 | 麻花传媒mv免费观看 | 中文字幕色播 | 日日夜夜免费精品视频 | 亚洲精品视频在线免费播放 | 香蕉影院在线播放 | 成人免费在线观看电影 | 国产成人久久 | 日日夜夜网 | 日韩一区在线免费观看 | 亚洲精品国久久99热 | 亚洲免费av一区二区 | 丁香婷婷色 | 久久av伊人 | 99日韩精品| 99免费看片| 日韩av影视在线 | 欧美日韩中文视频 | 午夜色性片| 欧美黑人巨大xxxxx | 青青草华人在线视频 | 亚洲狠狠婷婷 | 黄色aaa毛片| 国产黄a三级三级三级三级三级 | 国产无遮挡猛进猛出免费软件 | 色福利网 | 久久久久久久99精品免费观看 | 日韩欧美视频一区二区 | www.天天综合 | 三级动图 | 国产精品 国产精品 | 人人爽人人澡人人添人人人人 | 999成人网 | 久久99国产精品视频 | 国产 字幕 制服 中文 在线 | 综合色站导航 | 国产手机在线视频 | 精品视频国产一区 | 中文国产在线观看 | 国产精品乱码一区二区视频 | 天天碰天天操 | 国产视频一区在线播放 | 国产小视频免费观看 | 国产精品v欧美精品v日韩 | 日韩精品不卡在线 | 日韩中字在线观看 | 国产视频69 | 一个色综合网站 | 国内丰满少妇猛烈精品播放 | 欧美激情xxxx性bbbb | 欧美国产亚洲精品久久久8v | 国产成人免费高清 | 丝袜av网站 | 日本在线观看中文字幕无线观看 | 免费看污在线观看 | 97在线免费视频观看 | 欧美精品久久久久性色 | 麻豆影音先锋 | 久久久综合九色合综国产精品 | 99精品免费久久久久久日本 | 精品一区二区在线观看 | 成年人视频在线免费播放 | 欧美另类重口 | 日韩黄视频 | 麻豆免费看片 | 国产综合精品一区二区三区 | 一区二区三区四区五区在线视频 | 精品久久久久久综合 | 人人干人人草 | 91人人射 | 午夜av一区二区三区 | 91成人小视频 | 国产精品久久精品国产 | 欧美成年人在线观看 | www.狠狠插.com | 99精品视频播放 | 国产精品99久久免费观看 | 免费福利在线 | 国产精品久久99综合免费观看尤物 | 在线中文字幕视频 | 男女精品久久 | 久久久久久综合网天天 | 网站免费黄色 | 久久69av | 欧美精品被 | 久久久久看片 | 午夜精品久久久99热福利 | 久久精品福利视频 | 99这里都是精品 | 麻豆播放| 婷婷六月天在线 | 国产在线无 | 久久久精品国产一区二区三区 | 色婷在线 | 天天天射 | 黄色一级在线免费观看 | 久久99免费观看 | 国产中文在线视频 | 丰满少妇在线观看资源站 | 四虎影视成人精品 | 99视频在线精品国自产拍免费观看 | 日韩在线免费高清视频 | 亚洲高清资源 | 亚洲aⅴ免费在线观看 | 97福利在线观看 | 日日夜夜干| 久久久精品福利视频 | av电影 一区二区 | 欧美analxxxx | 久久久久激情视频 | 黄色精品一区二区 | 久久黄色美女 | 久久国产91 | 91精品国产91久久久久 | 久久久久国产精品视频 | 日韩免费视频线观看 | 久草在线播放视频 | 国产精品一区二区免费视频 | 免费av小说 | 中文字幕中文 | 国产高清免费视频 | 视频国产精品 | 国产护士hd高朝护士1 | 日本成人中文字幕在线观看 | 国内外激情视频 | 99国产一区二区三精品乱码 | 狠狠干五月天 | 黄色成人av | 九九热只有精品 | 操操操操网 | 99热国产在线 | 国产男女无遮挡猛进猛出在线观看 | 91网免费观看 | 国产69精品久久app免费版 | 日韩电影在线观看中文字幕 | 日韩欧美精品在线 | 五月天中文在线 | 午夜久久电影网 | 久久a免费视频 | a成人v| 日韩色高清 | 国产在线a免费观看 | 成年人黄色免费视频 | 亚洲区精品视频 | 免费看的黄色录像 | 九九日九九操 | 国产精品一区二区62 | 久久综合婷婷国产二区高清 | 亚洲黄色av网址 | 欧美一性一交一乱 | 国产经典 欧美精品 | 99久久精品免费看国产 | 成人毛片a | 国产精品黄网站在线观看 | 国产一区二区免费 | 一级黄色片毛片 | 三级在线视频观看 | 久久综合狠狠狠色97 | 日韩av成人免费看 | 91成品人影院 | 色婷婷成人网 | 久久久久久久久久毛片 | 97精品国产 | 欧美va日韩va | 国产成人久久精品一区二区三区 | 九九久久在线看 | 国产精品永久免费在线 | 精品99久久 | 久久99网站 | 日本久久久久久久久久久 | 国产亚洲精品久久久久久久久久 | 国产一区二区三区久久久 | 丁香激情综合久久伊人久久 | 久久精品免费电影 | 五月婷婷在线综合 | 黄色视屏在线免费观看 | 免费观看视频黄 | 91丨九色丨蝌蚪丨对白 | 久久无码av一区二区三区电影网 | 免费看的国产视频网站 | 精品国产一区二区三区不卡 | 人人爱人人射 | 天天碰天天操视频 | 日本电影久久 | 日韩综合色 | 91最新地址永久入口 | 欧美亚洲一区二区在线 | 美女视频a美女大全免费下载蜜臀 | 九九热久久久 | 久久国产欧美日韩精品 | 久久精品久久久久电影 | www.超碰 | 色综合久久中文字幕综合网 | 在线免费高清 | 91成人免费观看视频 | 国产高清视频在线观看 | 成av在线 | 日韩在线观看一区 | 97品白浆高清久久久久久 | 国产第一二区 | 中文字幕中文字幕在线一区 | 欧美久久久久久久久久久久久 | 一区二区三区高清在线观看 | 色999精品| 久久久精品 一区二区三区 国产99视频在线观看 | 99精品在线 | 精品字幕 | 精品视频资源站 | 久久av电影 | 久久久精品免费看 | 久久99久久99精品免视看婷婷 | 香蕉在线影院 | 亚洲欧美日韩国产一区二区三区 | www免费在线观看 | 99久久er热在这里只有精品15 | 夜色在线资源 | 2018亚洲男人天堂 | 开心激情综合网 | 精品国产一区二区在线 | av千婊在线免费观看 | 人交video另类hd | 最新日韩中文字幕 | 国产在线a免费观看 | 在线观看黄色 | 中文字幕 国产视频 | 久久精品国产一区二区三 | 91在线你懂的 | a特级毛片 | 亚洲欧美日韩不卡 | 精品视频9999 | 久久久久99999 | 国产成人黄色av | 国产精品美女久久久久久 | 在线免费高清视频 | 在线视频 你懂得 | 日韩精品中文字幕av | 久久婷婷综合激情 | 国产成人三级三级三级97 | 国产91精品看黄网站 | 黄色网址中文字幕 | 成人国产精品一区二区 | 欧美午夜激情网 | 99精品久久久 | 91亚洲精 | 国产一区视频在线播放 | 欧美日韩精品电影 | 久久久久久久久艹 | 91人人插| 国产精品地址 | 波多野结衣一区三区 | 成年人视频在线观看免费 | 五月婷在线观看 | 中文乱码视频在线观看 | 美女久久久久 | 激情深爱| 九热在线 | 91视频久久久久久 | 亚洲一区精品人人爽人人躁 | 亚洲国产激情 | 成年人看片网站 | 日韩精品黄 | 国产精品99久久免费观看 | 欧美午夜精品久久久久久孕妇 | 成人在线视 | 欧美国产亚洲精品久久久8v | 日韩欧美久久 | 天天爽天天射 | 久久久国内精品 | 91麻豆精品国产91久久久久久久久 | 欧美黄在线 | 婷婷5月激情5月 | 亚洲天堂精品视频 | 日韩黄色大片在线观看 | 久久精品国产免费 | 久久精品国产99国产 | 国产视频一区在线 | 日韩在线精品 | 国产精品久久久久久999 | 伊人五月婷 | 91丨九色丨蝌蚪丨老版 | 丁香视频 | 在线免费看片 | 国产精品99久久久久久久久久久久 | 久久刺激视频 | 精产嫩模国品一二三区 | 午夜91在线 | 欧美老女人xx | 欧美,日韩 | 国内精品久久久久影院一蜜桃 | 欧美精品视| 国产精品一区在线观看你懂的 | 久久国产手机看片 | 久久久久久免费 | 在线国产一区二区 | 久草在线最新 | 国产色啪| 国产黑丝一区二区 | 免费的成人av| 国内免费久久久久久久久久久 | 成人三级av| 亚洲精品一区中文字幕乱码 | 波多野结衣视频一区 | 91精品导航| 狠狠综合 | 久久国产精品一国产精品 | 国产成人亚洲在线电影 | 狠狠干狠狠插 | 日韩xxx视频 | av在线播放中文字幕 | 国产98色在线 | 日韩 | 亚洲国产操 | 国产日韩欧美视频 | 久久久久久久久久久国产精品 | 精品国产aⅴ一区二区三区 在线直播av | 麻豆成人网 | 在线播放亚洲 | 中文字幕在线播放第一页 | 久久精品www人人爽人人 | 久久久久久久久久久黄色 | 蜜桃麻豆www久久囤产精品 | 在线久热| 免费看污在线观看 | 97av在线视频 | 麻豆视频免费 | 五月婷婷毛片 | www91在线 | av高清在线 | 亚洲国产免费网站 | 国产精品日韩在线 | 精品欧美在线视频 | 久久婷婷精品 | 在线韩国电影免费观影完整版 | 日韩欧美69| 亚洲精品系列 | 日韩精品专区在线影院重磅 | 亚洲人成影院在线 | 国产在线美女 | 美女视频一区 | 久草在线免费新视频 | 国产亚洲午夜高清国产拍精品 | 毛片永久新网址首页 | 狠狠色丁香婷婷综合欧美 | 国产精品久久久久久久久久久久午夜 | 天天色天天爱天天射综合 | 日韩欧美在线观看一区二区三区 | www91在线| 天堂视频一区 | 亚洲人成免费网站 | 综合网婷婷 | 日本黄网站 | 四虎永久免费在线观看 | 国产中文字幕一区二区三区 | 婷婷深爱 | 久草| 久久亚洲福利视频 | 91av看片| 麻豆影视在线免费观看 | 国产在线视频资源 | freejavvideo日本免费 | 日日碰狠狠添天天爽超碰97久久 | 成人av在线直播 | 又黄又爽又色无遮挡免费 | 久久精品国产一区二区三区 | 国产精品va在线观看入 | 奇米网在线观看 | 中文字幕日韩国产 | 亚洲综合射 | 日韩亚洲在线观看 | 欧美久久久久久久久久久久久 | 亚洲视频在线观看免费 | 精品国产观看 | 人人澡人人爽 | 99久久精品国产一区二区三区 | 日日干,天天干 | 国产免费大片 | 国产精品专区h在线观看 | 欧美激情第一页xxx 午夜性福利 | 久久久久国产精品厨房 | 国产破处在线视频 | 激情片av| 91精品视频网站 | www.亚洲精品| 久99久中文字幕在线 | 久久亚洲成人网 | 国产精品久久久视频 | 伊人狠狠色丁香婷婷综合 | avcom在线| av中文字幕第一页 | 亚洲国产精品成人va在线观看 | 亚洲天堂社区 | 91精品国自产在线观看 | 欧美日韩三区二区 | 久久综合偷偷噜噜噜色 | 亚洲激情一区二区三区 | 国产小视频在线播放 | 国产又黄又爽无遮挡 | 日韩精品一二三 | 国产欧美日韩一区 | 日韩成人av在线 | 欧美极品xxxx| 久久综合九色九九 | 亚洲视频99| 天天操天天干天天操天天干 | 日韩电影中文,亚洲精品乱码 | 久久污视频 | 99久久精品免费看国产麻豆 | 麻豆免费在线视频 | 久久久天堂 | 韩国一区在线 | 伊人狠狠 | 一区二区三区动漫 | 亚洲欧美日本国产 | 久久九九精品 | 97色噜噜 | 日本中文字幕久久 | 九九热精 | 91九色免费视频 | 中文字幕在线观看视频一区 | 一区二区不卡高清 | 亚洲六月丁香色婷婷综合久久 | 日韩高清一区在线 | 亚洲激情在线观看 | 久久综合天天 | 久久99精品久久久久久久久久久久 | 日韩中文字幕在线看 | 国产成人黄色av | 婷婷日日| 69国产精品成人在线播放 | 人人干,人人爽 | 97超碰人人澡人人爱 | 亚洲视频 中文字幕 | 日本女人的性生活视频 | 国产69久久精品成人看 | 免费裸体视频网 | 久久精品国产久精国产 | 日日日爽爽爽 | 免费在线观看亚洲视频 | 国产一级二级三级视频 | 欧美一级片在线播放 | 国产精品久久久久婷婷 | 中文字幕在线播放第一页 | 在线观看av小说 | 久草在线资源观看 | 欧美日韩在线视频一区二区 | 国产黄色片免费在线观看 | 欧美日韩国产精品一区二区 | 免费高清av在线看 | 在线观看视频亚洲 | 精品 激情 | 亚洲精欧美一区二区精品 | 在线看毛片网站 | 91麻豆网站 | 麻豆果冻剧传媒在线播放 | 日韩大片免费观看 | 免费视频色 | 97av在线视频免费播放 | 在线观看视频日韩 | 久久久色 | av免费看电影 | 国产日产精品一区二区三区四区 | 国产视频日韩视频欧美视频 | 亚洲国产视频a | 97**国产露脸精品国产 | 国产日产欧美在线观看 | 国产小视频精品 | 亚州激情视频 | 久久久久久久国产精品 | 91爱爱中文字幕 | 天天爱天天 | 国产亚洲精品久久网站 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 久久久久久久久综合 | 久久精品成人热国产成 | 成人久久久久久久久久 | 国产精品一区二区精品视频免费看 | 亚洲精品在线一区二区 | 日韩在线观看中文 | 日韩在线视频国产 | 国产一区二区电影在线观看 | 亚洲精品在线播放视频 | 免费国产亚洲视频 | 四虎www | 欧美综合国产 | 亚洲欧洲国产日韩精品 | www久久久久| 国产精品毛片久久久 | 国产午夜在线观看 | 国产精品手机播放 | 日韩高清不卡在线 | 狠狠色丁香婷婷综合久小说久 | 国产午夜亚洲精品 | 五月在线视频 | 人人超碰在线 | 麻豆91在线 | 欧洲一区二区在线观看 | 久久第四色 | 久艹在线观看视频 | 欧美日韩中文国产一区发布 | 国产精久久久 | 日韩在线观看你懂得 | 久久久久久久综合色一本 | 国产精品久久久久久影院 | 国产精品亚洲片夜色在线 | 人人插人人艹 | 精品网站999www | 97操操操 | 伊人天天干 | 亚洲免费精品一区二区 | 成人久久毛片 | 亚洲美女视频在线 | 亚洲情婷婷 | 黄色综合 | 97香蕉久久超级碰碰高清版 | 欧美怡红院 | 综合色伊人| 超碰人人99| 中文字幕一区二 | 在线日韩精品视频 | 激情久久久久 | 国产不卡精品 | 天天综合网在线 | 丰满少妇在线 | 日韩二区三区在线 | 美女久久久久久久久久 | 99久久99久久精品国产片 | 麻豆av电影| 99久久久成人国产精品 | 精品久久久久久久久中文字幕 | 成人午夜电影免费在线观看 | 日日干天天射 | 五月婷婷在线视频观看 | 日本中文字幕在线电影 | 久久久久久久久久久电影 | 91九色蝌蚪视频在线 | 久久影院亚洲 | 精品国产激情 | 91麻豆精品国产自产在线 | 亚洲国内精品 | 激情视频在线观看网址 | 日本xxxx.com | 日韩免费一级电影 | 99精品在线播放 | 婷五月天激情 | 成人理论电影 | 97超碰国产精品 | 97超碰人人澡人人 | 日韩美女av在线 | 久久视屏网 | 99r在线| 精品一区二区在线免费观看 | 国产欧美综合视频 | 精品国精品自拍自在线 | 日韩中出在线 | 一区二区国产精品 | 人人爽人人爽人人爽人人爽 | 国产精品资源在线观看 | 婷婷丁香激情综合 | 欧美精品在线免费 | 国产高清免费观看 | 亚洲精品视频免费 | 在线国产99 | 97碰碰精品嫩模在线播放 | 中文字幕av最新 | 91免费观看视频网站 | 99久久精品国产一区二区成人 | 日韩电影一区二区三区 | 久章草在线| 久久免费大片 | 亚洲五月六月 | 精品久久久免费视频 | 国产一二区视频 | 天天操人人干 | 久久精品网站免费观看 | 亚州中文av | 日韩av午夜在线观看 | 亚洲一区二区三区在线看 | 国产精品入口麻豆 | 999成人| 午夜私人影院 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 成人宗合网 | 日韩aⅴ视频 | 婷婷色在线播放 | www免费看片com | 日韩电影久久 | 欧美一级日韩免费不卡 | 五月激情六月丁香 | 久久97视频 | 成x99人av在线www | 亚洲欧美日韩在线一区二区 | 欧美a级一区二区 | 91精品视频在线免费观看 | 中文字幕在线观看完整 | 亚洲狠狠婷婷综合久久久 | 亚洲极色 | 国产精品电影一区二区 | 91麻豆精品91久久久久同性 | 国产精品原创在线 | 99精品免费网 | 欧美日韩亚洲国产一区 | 日韩欧美大片免费观看 | 国产成人综合图片 | 波多野结衣一区二区 | 日本精品小视频 | 久久免费视频6 | 色 免费观看 | 天天干,天天操,天天射 | 四虎在线观看视频 | 最近乱久中文字幕 | 在线观看中文字幕一区 | 免费观看国产成人 | www..com黄色片 | 国产小视频免费在线网址 | 国产福利精品一区二区 | 欧美最猛性xxxx | 在线播放国产精品 | 最新中文字幕 | 在线免费观看成人 | 99r在线视频 | 国产成人在线免费观看 | 色.com| 久久69av| 亚洲 欧美 变态 国产 另类 | 国产一级免费av | 国产视频每日更新 | 国产成人黄色片 | 国产精品二区在线观看 | 国产最新视频在线观看 | 麻豆视频观看 | 97在线免费观看 | 日韩精品一区二区免费 | 亚洲乱码久久久 | 久久这里只有精品视频99 | 69视频在线| 中文字幕在线一区二区三区 | 天天色综合天天 | 国产中文字幕在线播放 | 日韩av电影一区 | 国产精品va在线观看入 | 欧美在线观看视频一区二区三区 | 亚洲综合五月天 | 国产精品毛片久久久久久久久久99999999 | 国产免费一区二区三区最新6 | 丁香视频在线观看 | 91精选在线观看 | 国产精品成人在线 | 91av在线播放 | 亚洲色图美腿丝袜 | 免费在线播放av电影 | 五月天国产精品 | 精品亚洲一区二区三区 | 日韩在线免费播放 | 欧美日韩午夜 | 国产精品第一页在线观看 | 在线观看日本韩国电影 | 久久久久久免费网 | 永久中文字幕 | 欧美一级黄色网 | 国产黄a三级三级三级三级三级 | 国产精品99久久久久久久久久久久 | 国产精品久久久久久久久久久免费看 | 欧洲亚洲精品 | 国产成人免费在线 | h视频在线看| 久久不色 | 成人亚洲精品久久久久 | 高清精品久久 | 亚洲一级片在线看 | 日韩在线免费播放 | 亚洲精品777| 超碰公开在线观看 | 碰超在线97人人 | 99久精品视频 | 黄色影院在线免费观看 | 国产91精品欧美 | 日韩电影黄色 | 天天射日| 九九九九精品 | 91在线视频观看 | 在线观看a视频 | 久久久久久久久久久久久久av | 91香蕉国产在线观看软件 | 99视频+国产日韩欧美 | 天堂在线一区 | 美女久久久久久久久久久 | 韩日视频在线 | 日本中文字幕系列 | 奇米网在线观看 | 综合网成人| 黄在线免费观看 | 午夜精品视频一区 | 亚洲在线视频网站 | 99久久国产免费,99久久国产免费大片 | 日韩高清免费电影 | 在线中文字幕观看 | 国产麻豆精品一区二区 | 成人在线网站观看 | 中文视频在线 | 黄色三级免费看 | 91久久偷偷做嫩草影院 | www.夜夜草 | 久久久久久久久久网站 | 激情综合久久 | 亚洲作爱| 欧美国产日韩一区二区三区 | 欧美日韩国产精品爽爽 | 亚洲艳情 | 国产亚洲成人精品 | 中文字幕视频网站 | 精品美女在线视频 | 中文字幕在线国产精品 | 久久久久免费精品国产 | 996久久国产精品线观看 | 国内精品久久久久久久影视简单 | 最新av在线免费观看 | 西西www4444大胆视频 | 99久久精品免费看国产一区二区三区 | 国产亚洲精品久久久久久久久久久久 | 99在线观看精品 | 国产自在线| 日日添夜夜添 | 久久久久国产成人免费精品免费 | www.伊人色.com | 国产精品第一页在线 | 激情丁香久久 | 91豆花在线| 国产精品一区二区av日韩在线 | www.黄色片.com| 久久在线播放 | 激情电影影院 | 在线视频国产区 | 狠狠色丁婷婷日日 | 久久国产精品色婷婷 | 国产一级黄 | 欧美成天堂网地址 | 中文字幕av全部资源www中文字幕在线观看 | 人人超碰人人 | 91人人在线 | 欧美极品少妇xxxx | 97超碰香蕉 | 国产精品青青 | 日韩电影一区二区在线 | 国内精品在线观看视频 | 国产精品亚洲精品 | 欧美亚洲三级 | 国产精品99久久久久久久久 | 国产精品视屏 | 亚洲精品午夜视频 | 日韩三级中文字幕 | 视频成人永久免费视频 | 91视频免费看片 | 日韩a在线看 | 精品视频亚洲 | 激情久久婷婷 | 99看视频在线观看 | 在线观看免费中文字幕 | 欧美精彩视频在线观看 | 国产精品成人一区二区三区吃奶 | 国产日韩中文在线 | 国产精品99久久久精品 | 日韩av福利在线 | 天天干天天干天天干天天干天天干天天干 | 日韩欧美国产免费播放 | 国产一区二区三区 在线 | 久久精品女人毛片国产 | 久久久免费精品视频 | 美女网站色在线观看 | 在线观看免费一级片 | 久久伊人精品一区二区三区 | 国产日韩视频在线观看 | 中文字幕免费一区二区 | 精品国产乱子伦一区二区 | 国产一区欧美在线 | 狠狠色丁香婷婷综合视频 | 久久久久国产成人免费精品免费 | 欧美三级在线播放 | 中文字幕传媒 | 在线视频你懂得 | 久久久久蜜桃 | 日本性xxx| 国产成人av一区二区三区在线观看 | 西西444www高清大胆 | 丁香六月伊人 | 五月天激情综合 | 国产精品麻豆欧美日韩ww | 91福利影院在线观看 | 欧美日韩后 | 成人中文字幕+乱码+中文字幕 | 97日日| 久久高清国产 | 午夜精品视频福利 | 欧美性大战久久久久 | 伊人久久av | 日韩av黄 | 久草在线免费在线观看 | 天天插天天干 | 西西4444www大胆艺术 | 韩国av一区二区三区在线观看 | 狠狠干美女 | 国产亚洲精品成人av久久ww | 99国产精品一区 | 五月婷影院 | 一区二区三区视频 | 日韩在线视 | 美州a亚洲一视本频v色道 | 国产精品毛片一区视频 | 激情五月婷婷综合网 | 综合色婷婷 | 一区视频在线 | 婷婷中文字幕在线观看 | 日本中文一级片 | 欧美a级片网站 | 久青草国产在线 | 久艹在线播放 | 在线免费观看黄网站 | 久久精品999 | 精品久久久久久亚洲综合网站 | 日韩精品中文字幕在线 | 麻豆传媒视频在线播放 | 国产 一区二区三区 在线 | 国产一区免费观看 | 97天堂 | 激情一区二区三区欧美 | 97色在线视频 | 日本在线精品视频 | 久久国产精品99久久久久久老狼 | 中文字幕在线播放av | 婷香五月| 99精品亚洲 | 天天色天天色 | 91av视频免费在线观看 | 中文字幕久久精品亚洲乱码 | 国产激情电影综合在线看 | 精品在线观看免费 | 免费视频成人 | 欧美另类v | 欧美一二三视频 | 婷婷六月在线 | 成人av免费看 | 亚洲精品久久久久999中文字幕 | 黄色片软件网站 | 国语麻豆 | 欧美在线观看视频 |