欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenCV實(shí)現(xiàn)透視變換的示例代碼

 更新時(shí)間:2023年07月07日 09:22:33   作者:趙卓不凡  
本文主要介紹了OpenCV實(shí)現(xiàn)透視變換的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

1. 引言

今天我們將焦點(diǎn)聚焦在我在圖像處理中最喜歡的話(huà)題之一——透視變換。使用該技術(shù),可以靈活方便的實(shí)現(xiàn)各種各樣好玩的特效。

閑話(huà)少說(shuō),我們直接開(kāi)始吧!

2. 單應(yīng)矩陣

我們首先展開(kāi)對(duì)單應(yīng)矩陣的深入研究。作為圖像處理的基本工具,它在捕捉圖像中的幾何變換方面發(fā)揮著至關(guān)重要的作用。更具體地說(shuō),它是實(shí)現(xiàn)透視變換的秘密武器。

單應(yīng)矩陣被定義為圖像的兩個(gè)平面投影之間的映射。它由齊次坐標(biāo)空間中的3x3變換矩陣表示。這些變換可以是旋轉(zhuǎn)、平移、縮放等操作的組合。

我們用示意圖總結(jié)如下:

3. 舉個(gè)栗子

雖然上圖簡(jiǎn)明地定義了常見(jiàn)的轉(zhuǎn)換,但是如果我們將其應(yīng)用到輸入和輸出為圖像操作會(huì)怎樣?根據(jù)變換,我們需要幾個(gè)點(diǎn)來(lái)計(jì)算單應(yīng)矩陣。讓我們來(lái)做吧!像往常一樣,讓我們首先導(dǎo)入必要的庫(kù),如下:

# Import libraries
from skimage.io import imread, imshow
import matplotlib.pyplot as plt
import numpy as np
from skimage import transform

接著導(dǎo)入我們需要的測(cè)試圖像,代碼如下:

# Display the original image
image = imread('painting.png')
plt.figure(figsize=(20,20))
plt.imshow(image)
plt.title('Original Image', fontsize=20, weight='bold')
plt.axis('off')
plt.show()

結(jié)果如下:

4. 計(jì)算變換矩陣

接著我們想對(duì)這幅畫(huà)有一個(gè)自上而下的視圖。我們需要計(jì)算單應(yīng)矩陣。我們必須確定這幅畫(huà)明確的角點(diǎn)。在這種情況下,我使用畫(huà)圖應(yīng)用程序來(lái)識(shí)別畫(huà)的四個(gè)角點(diǎn)坐標(biāo):

# Source points
src = np.array([879, 625,                    # top left
                431, 2466,                   # bottom left
                3251, 61,                    # top right
                3416, 2767]).reshape((4, 2)) # bottom right

為了執(zhí)行單應(yīng)性變換,我們需要一組與源點(diǎn)相對(duì)應(yīng)的目標(biāo)點(diǎn)。這些目標(biāo)點(diǎn)表示我們希望源點(diǎn)在輸出圖像中的位置。對(duì)于自上而下的視圖,這里我們引用源點(diǎn)的最小值和最大值x和y:

# Destination points
dst = np.array([
    [np.min(src[:, 0]), np.min(src[:, 1])],  # top left
    [np.min(src[:, 0]), np.max(src[:, 1])],  # bottom left
    [np.max(src[:, 0]), np.min(src[:, 1])],  # top right
    [np.max(src[:, 0]), np.max(src[:, 1])],  # bottom right
])

接著我們用以下代碼計(jì)算單應(yīng)矩陣,如下:

tform = transform.estimate_transform('projective', src, dst)

5. 透視變換

經(jīng)過(guò)上述處理,我們有了執(zhí)行透視變換所需要的單應(yīng)性矩陣,接著我們來(lái)執(zhí)行對(duì)應(yīng)的透視變換,如下:

tf_img = transform.warp(image, tform.inverse)
fig, ax = plt.subplots(figsize=(20,20))
ax.imshow(tf_img)
_ = ax.set_title('projective transformation')

得到結(jié)果如下:

6. 美化顯示效果

觀察上圖,考慮到圖像外圍添加了白色像素,輸出看起來(lái)很奇怪,我們可以編輯出代碼來(lái)裁剪這些奇怪的墻和額外的像素:

# Load the image
image = imread('painting.png')
# Source points
src = np.array([879, 625,                    # top left
                431, 2466,                   # bottom left
                3251, 61,                    # top right
                3416, 2767]).reshape((4, 2)) # bottom right
# Estimate the width and height from the source points
width = np.max(src[:, 0]) - np.min(src[:, 0])
height = np.max(src[:, 1]) - np.min(src[:, 1])
# Destination points (forming a box shape)
dst = np.array([
    [0, 0],
    [0, height],
    [width, 0],
    [width, height]
])
# Compute the projective transform
tform = transform.estimate_transform('projective', src, dst)
# Apply the transformation
warped_image = transform.warp(image, tform.inverse, output_shape=(height, width))
# Convert the warped image to uint8
warped_image_uint8 = (warped_image * 255).astype(np.uint8)
# Display the transformed and cropped image
plt.figure(figsize=(20,20))
plt.imshow(warped_image_uint8)
plt.title('Transformed and Cropped Image', fontsize=20, weight='bold')
plt.axis('off')
plt.show()

最終的顯示效果如下:

7. 總結(jié)

經(jīng)過(guò)我們一步一步的優(yōu)化,我們最終得到了,一幅美麗而干凈的自上而下的油畫(huà)。一般來(lái)說(shuō),一旦我們有了單應(yīng)矩陣,我們也可以用它來(lái)變換一幅圖像,使其與另一幅圖像的視角對(duì)齊。這對(duì)于圖像拼接等應(yīng)用非常有用!

到此這篇關(guān)于OpenCV實(shí)現(xiàn)透視變換的示例代碼的文章就介紹到這了,更多相關(guān)OpenCV 透視變換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python匿名函數(shù)詳情

    Python匿名函數(shù)詳情

    這篇文章主要介紹了Python匿名函數(shù),在python中,除了一般使用def定義的函數(shù)外,還有一種使用lambda定義的匿名函數(shù),這種函數(shù)可以用在任何普通函數(shù)可以使用的地方,但在定義時(shí)被嚴(yán)格限定為單一表達(dá)式,下面來(lái)看詳細(xì)內(nèi)容吧
    2021-11-11
  • Python?字符替換的四方法

    Python?字符替換的四方法

    本文主要介紹了Python?字符替換的四方法,主要包括replace、translate、maketrans?和正則這是四種方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • python切割圖片的示例

    python切割圖片的示例

    這篇文章主要介紹了利用python切割圖片的示例,幫助大家更好的利用python處理圖片,感興趣的朋友可以了解下
    2020-11-11
  • 使用11行Python代碼盜取了室友的U盤(pán)內(nèi)容

    使用11行Python代碼盜取了室友的U盤(pán)內(nèi)容

    這篇文章主要介紹了使用11行Python代碼盜取了室友的U盤(pán)內(nèi)容的相關(guān)資料,需要的朋友可以參考下
    2018-10-10
  • Python計(jì)算兩個(gè)矩形重合面積代碼實(shí)例

    Python計(jì)算兩個(gè)矩形重合面積代碼實(shí)例

    這篇文章主要介紹了Python 實(shí)現(xiàn)兩個(gè)矩形重合面積代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Python 專(zhuān)題四 文件基礎(chǔ)知識(shí)

    Python 專(zhuān)題四 文件基礎(chǔ)知識(shí)

    本文主要講述了Python文件基礎(chǔ)知識(shí),包括文件的打開(kāi)、讀寫(xiě)、關(guān)閉操作、使用循環(huán)讀寫(xiě)文件及迭代器的知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • python?format格式化和數(shù)字格式化

    python?format格式化和數(shù)字格式化

    這篇文章主要介紹了python?format格式化和數(shù)字格式化,格式化字符串的函數(shù)?str.format(),它增強(qiáng)了字符串格式化的功能,基本語(yǔ)法是通過(guò){}?和?:?來(lái)代替以前的?%?,下面內(nèi)容介紹,需要的朋友可以參考一下
    2022-02-02
  • 基于OpenCV(python)的實(shí)現(xiàn)文本分割之垂直投影法

    基于OpenCV(python)的實(shí)現(xiàn)文本分割之垂直投影法

    本文主要介紹了基于OpenCV(python)的實(shí)現(xiàn)文本分割之垂直投影法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 如何用Python將圖片轉(zhuǎn)為字符畫(huà)

    如何用Python將圖片轉(zhuǎn)為字符畫(huà)

    本文主要介紹了用Python將圖片轉(zhuǎn)為黑白字符畫(huà)的方法,使用ascii字符把圖片轉(zhuǎn)為黑白字符畫(huà),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Python對(duì)象的生命周期源碼學(xué)習(xí)

    Python對(duì)象的生命周期源碼學(xué)習(xí)

    這篇文章主要為大家介紹了Python對(duì)象的生命周期源碼學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05

最新評(píng)論