成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > Python圖片處理之圖片裁剪教程

Python圖片處理之圖片裁剪教程

熱門(mén)標(biāo)簽:手機(jī)網(wǎng)頁(yè)嵌入地圖標(biāo)注位置 河北防封卡電銷卡 400電話辦理哪種 電銷機(jī)器人的風(fēng)險(xiǎn) 開(kāi)封語(yǔ)音外呼系統(tǒng)代理商 開(kāi)封自動(dòng)外呼系統(tǒng)怎么收費(fèi) 天津電話機(jī)器人公司 地圖標(biāo)注線上如何操作 應(yīng)電話機(jī)器人打電話違法嗎

一、操作流程

首先復(fù)制代碼會(huì)吧?

1.有張照片

這是網(wǎng)上隨便找的一張照片,自行保存測(cè)試

2.看看照片

運(yùn)行代碼,其中show_img函數(shù)是展示照片

3.選擇角點(diǎn)

按照左上,右上,右下,左下的順序選擇四個(gè)角點(diǎn)

如果擔(dān)心自己選不好,可以直接去除我代碼里的points的注釋,那是我自己用的原版

4.最終結(jié)果

二、代碼分析

import 沒(méi)什么好說(shuō)的

#如果python沒(méi)有安裝cv2,那么就安裝python-opencv就好
import cv2 as cv
import numpy as np

獲取圖片的長(zhǎng)寬

#輸入cv.imread后的圖片,通過(guò)點(diǎn)擊四個(gè)點(diǎn)選擇要裁剪的部分
def get_window_size(src, bound=600):
    h,w = src.shape[0], src.shape[1]
    if h > w:
        h, w = bound, int(w*bound/h)
    else:
        h, w = int(h*bound/w), bound
    return (h, w)

通過(guò)鼠標(biāo)獲取圖片的坐標(biāo)點(diǎn),順序是左上,右上,右下,左下

class Indexer:
    def __init__(self, bound=4):
        self.id = 0
        self.bound = bound

    def get_id(self):
        self.id = (self.id + 1)
        return (self.id)


def on_EVENT_LBUTTONDOWN(event, x, y, flags, param):
    if event == cv.EVENT_LBUTTONDOWN:
        img = param['src']
        win_name = param['window']
        indexer = param['indexer']
        points = param['points']

        curr_id = indexer.get_id()
        points.append((x, y))
        print('第{}個(gè)頂點(diǎn): ({},{})'.format(curr_id, x, y))

        cv.circle(img, (x, y), 10, (0, 0, 255), thickness=2)
        cv.putText(
            img,
            str(curr_id),  # 文字
            (x, y),  # 坐標(biāo)
            cv.FONT_HERSHEY_PLAIN,
            5,  # 字號(hào)
            (0, 0, 255),  # 字體顏色
            thickness=2  # 粗細(xì)
        )

        cv.imshow(win_name, img)

#輸入cv.imread后的圖片,通過(guò)點(diǎn)擊四個(gè)點(diǎn)選擇要裁剪的部分
def get_points(src):
    points = []
    indexer = Indexer()
    h, w=get_window_size(src)
    win_name = 'get_points'
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=w, height=h)
    cv.imshow(win_name, src)
    cv.setMouseCallback(win_name, on_EVENT_LBUTTONDOWN,
                        param={'src': src, 'window': win_name, 'indexer': indexer, 'points': points})
    cv.waitKey(0)
    cv.destroyAllWindows()
    if len(points)>4:
        return points[0:4]
    # print(points)
    # points=[(2, 14), (90, 50), (87, 194), (1, 204)]
    return points

#輸入cv.imread后的圖片,展示圖片長(zhǎng)什么樣
def show_img(src):
    win_name = 'show_img'
    h, w=get_window_size(src)
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=w, height=h)
    cv.imshow(win_name, src)
    cv.waitKey(0)
    cv.destroyAllWindows()

將圖片截取,并按照指定的長(zhǎng)寬比恢復(fù)成矩形

def photo_cut_restore(src,points,H,W):

    target_points = [(0, 0), (W, 0), (W, H), (0, H)]
    points, target_points = np.array(points, dtype=np.float32), np.array(target_points, dtype=np.float32)
    M = cv.getPerspectiveTransform(points, target_points)
    # print('透視變換矩陣:', M)

    result = cv.warpPerspective(src_copy, M, (0, 0))
    result = result[:H, :W]
    win_name = 'Result'
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=W, height=H)
    cv.imshow(win_name,result)
    cv.waitKey(0)
    cv.destroyAllWindows()
    return  result

主程序

if __name__ == '__main__':

    path = './1.jpg'
    src = cv.imread(path)
    src_copy = src.copy()

     show_img(src)


    W = 20
    H = 20
    # points=[(112, 308), (175, 310), (176, 369), (113, 369)]
    
    points=get_points(src)
    n = 20
    W = int(W * n)
    H = int(H * n)

    result=photo_cut_restore(src_copy,points,H,W)

    output_file = 'result.jpg'
    cv.imwrite(output_file, result)

三、懶人一鍵復(fù)制代碼

誒,氣不氣,好不容易一段段復(fù)制完,結(jié)果最后居然有一鍵復(fù)制的地方

import cv2 as cv
import numpy as np

#輸入cv.imread后的圖片,通過(guò)點(diǎn)擊四個(gè)點(diǎn)選擇要裁剪的部分
def get_window_size(src, bound=600):
    h,w = src.shape[0], src.shape[1]
    if h > w:
        h, w = bound, int(w*bound/h)
    else:
        h, w = int(h*bound/w), bound
    return (h, w)


class Indexer:
    def __init__(self):
        self.id = 0

    def get_id(self):
        self.id = (self.id + 1)
        return (self.id)


def on_EVENT_LBUTTONDOWN(event, x, y, flags, param):
    if event == cv.EVENT_LBUTTONDOWN:
        img = param['src']
        win_name = param['window']
        indexer = param['indexer']
        points = param['points']

        curr_id = indexer.get_id()
        points.append((x, y))
        print('第{}個(gè)頂點(diǎn): ({},{})'.format(curr_id, x, y))

        cv.circle(img, (x, y), 10, (0, 0, 255), thickness=2)
        cv.putText(
            img,
            str(curr_id),  # 文字
            (x, y),  # 坐標(biāo)
            cv.FONT_HERSHEY_PLAIN,
            5,  # 字號(hào)
            (0, 0, 255),  # 字體顏色
            thickness=2  # 粗細(xì)
        )

        cv.imshow(win_name, img)

#輸入cv.imread后的圖片,通過(guò)點(diǎn)擊四個(gè)點(diǎn)選擇要裁剪的部分
def get_points(src):
    points = []
    indexer = Indexer()
    h, w=get_window_size(src)
    win_name = 'get_points'
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=w, height=h)
    cv.imshow(win_name, src)
    cv.setMouseCallback(win_name, on_EVENT_LBUTTONDOWN,
                        param={'src': src, 'window': win_name, 'indexer': indexer, 'points': points})
    cv.waitKey(0)
    cv.destroyAllWindows()
    if len(points)>4:
        return points[0:4]
    # print(points)
    # points=[(2, 14), (90, 50), (87, 194), (1, 204)]
    return points

#輸入cv.imread后的圖片,展示圖片長(zhǎng)什么樣
def show_img(src):
    win_name = 'show_img'
    h, w=get_window_size(src)
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=w, height=h)
    cv.imshow(win_name, src)
    cv.waitKey(0)
    cv.destroyAllWindows()

def photo_cut_restore(src,points,H,W):

    target_points = [(0, 0), (W, 0), (W, H), (0, H)]
    points, target_points = np.array(points, dtype=np.float32), np.array(target_points, dtype=np.float32)
    M = cv.getPerspectiveTransform(points, target_points)
    # print('透視變換矩陣:', M)

    result = cv.warpPerspective(src_copy, M, (0, 0))
    result = result[:H, :W]
    win_name = 'Result'
    cv.namedWindow(win_name, cv.WINDOW_NORMAL)
    cv.resizeWindow(win_name, width=W, height=H)
    cv.imshow(win_name,result)
    cv.waitKey(0)
    cv.destroyAllWindows()
    return  result


if __name__ == '__main__':

    path = './3.jpg'
    src = cv.imread(path)
    src_copy = src.copy()

    # show_img(src)


    W = 20
    H = 20
    # points=[(124, 182), (181, 177), (180, 243), (125, 266)]
    points=get_points(src)
    print(points)
    n = 20
    W = int(W * n)
    H = int(H * n)

    result=photo_cut_restore(src_copy,points,H,W)

    output_file = 'result.jpg'
    cv.imwrite(output_file, result)

到此這篇關(guān)于Python圖片處理之圖片裁剪教程的文章就介紹到這了,更多相關(guān)Python圖片裁剪內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python圖像處理之圖片拼接和堆疊案例教程
  • python圖片灰度化處理的幾種方法
  • Python圖像處理之圖像拼接
  • Python圖片檢索之以圖搜圖
  • python圖片合成的示例
  • 昨晚我用python幫隔壁小姐姐P證件照然后發(fā)現(xiàn)

標(biāo)簽:常州 宿遷 成都 駐馬店 六盤(pán)水 江蘇 山東 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python圖片處理之圖片裁剪教程》,本文關(guān)鍵詞  Python,圖片,處理,之,裁剪,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python圖片處理之圖片裁剪教程》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python圖片處理之圖片裁剪教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日本中文字幕一区二区| 亚洲乱码视频| eeuss影院在线播放| www.黄色国产| 91精品国产99久久久久久红楼| 97超碰人人爱| 欧美激情无毛| www在线观看免费视频| 99久久久久国产精品免费| 欧美久久综合性欧美| 亚洲va欧美va国产va天堂影院| 国产女同91疯狂高潮互磨| 精品一区毛片| 亚洲欧洲午夜一线一品| 视频一区视频二区在线观看| 欧美巨大黑人极品精男| 欧美日韩精品在线观看视频| 国产精品综合在线视频| 亚洲成人av中文字幕| 在线播放中文一区| 暖暖影院日本高清...免费| 成人国产一区二区| 性欧美videos高清hd4k| 一区二区三区在线观看动漫| 欧美日韩亚洲高清一区二区| 精品国模一区二区三区欧美| 欧美日韩综合色| 国产精品久久久久久亚洲毛片| 97香蕉久久超级碰碰高清版| 毛片aaaaa| 欧美日韩激情| 成人免费网站在线| 亚洲日本一区二区| 成人手机视频在线| 欧美日韩在线一| 91精品国产全国免费观看| 欧美日韩在线一区二区| 综合区小说区图片区在线一区| 免费av一区二区三区四区| 综合自拍亚洲综合图不卡区| 日本a级片在线观看| 久久久久久一区二区三区| 在线观看久久久久久| 亚洲黄网站黄| 久久777国产线看观看精品| 日韩欧美中文字幕电影| 国产一区三区在线播放| 亚洲欧美在线综合| 久久久久无码精品国产sm果冻| 男人天堂新地址| 黄色小视网站| 国产hs免费高清在线观看| 国产成人丝袜美腿| 国产麻豆一区二区三区| 日韩精品一区二区三区视频| 国产精品最新在线观看| 欧美日韩一区二区三区四区不卡| 国产免费嫩草影院| 精品久久久99| av网站免费播放| 99国产精品免费视频| 亚洲裸体俱乐部裸体舞表演av| 一本一道久久综合狠狠老精东影业| 香蕉久久夜色精品国产更新时间| 国产一级揄自揄精品视频| 成人做爰免费视频免费看| www.国产免费| 精品无码国产一区二区三区51安| 欧美大片日本大片免费观看| 青草国产精品| 欧美wwwwwww| 成人羞羞国产免费网站| 亚洲黄色有码视频| 一本色道久久综合亚洲| 欧美日韩美少妇| 综合精品久久久| 久久久精品免费视频| 国产精品熟女久久久久久| 国产一区二区三区在线| baoyu135国产精品免费| 国产一区在线免费| 99re6在线视频精品免费| 香蕉视频禁止18| 91亚洲国产成人久久精品麻豆| 激情五月播播久久久精品| 17c精品麻豆一区二区免费| 女人又爽又黄免费女仆| 欧美另类极品videosbest视频| 欧美成人一二三区| 国产一区二区免费在线观看| 欧美日韩一区二区免费在线观看| 国内偷自视频区视频综合| 亚洲毛片av在线| 日韩在线视频免费观看高清中文| 国产精品69页| 亚洲欧美视频在线播放| 精品视频免费看| 免费v片在线观看| 精品欧美一区二区久久久久| 国产麻豆视频一区| 美女免费久久| 精品国产一区二区三区麻豆小说| 97中文字幕在线观看| 激情视频小说图片| 91传媒视频免费| 久久综合免费视频| 久草.com| 日本黄色不卡视频| 91精品国产高清久久久久久91裸体| 美国做受三级的视频播放| 国产野外战在线播放| 国产精品99久久久久久董美香| 天干天干啦夜天天天视频| 黄页在线观看免费| 97在线看免费观看视频在线观看| 激情五月婷婷久久| 国产免费av网站| 国产精品成人**免费视频| 蜜桃视频m3u8在线观看| 国产精品极品在线观看| 日韩一级片在线播放| 欧美性受xxxx黑人猛交88| 国产亚洲无码精品| 日本在线视频免费| 深夜做爰性大片蜜桃| 欧美日韩大陆一区二区| 好男人社区在线视频| 欧洲精品一区二区三区久久| 久久精品国产2020观看福利| 91美女免费看| 国产精品综合在线视频| 91天堂素人约啪| 黄色网址视频在线观看| 国产精品一级在线| 一区二区视频在线观看免费的| 99re6热在线精品视频播放速度| 蜜乳av一区二区三区| 日韩精品国产精品| 九色网友自拍视频手机在线| 亚洲夜晚福利在线观看| 人人妻人人藻人人爽欧美一区| 国产精品丝袜久久久久久消防器材| 成人在线视频亚洲| 9l亚洲国产成人精品一区二三| 亚洲综合色区另类av| 欧美在线视频一区二区| 国产自产2019最新不卡| 在线观看不卡av| 狠狠色丁香久久综合频道| 亚洲欧美国产不卡| 国产精品色婷婷| aaaa黄色片| 在线日韩欧美视频| 91在线视频观看免费| 在线国产电影不卡| 欧美黑人巨大精品一区二区| 久久久噜噜噜久久中文字免| 男同互操gay射视频在线看| 亚洲色图视频在线观看| 手机免费看av片| 思思久久99热只有频精品66| 国产精品久久久一区麻豆最新章节| av手机在线播放| 亚洲成人精品一区二区三区| 亚洲欧美国产精品久久久久久久| 狠狠干成人综合网| 欧美zozo另类异族| 中文字幕免费在线观看视频| 天天躁日日躁狠狠躁超碰2020| 欧美又粗又大又爽| 一级特黄aaa大片在线观看| 国产裸体无遮挡| 91美女在线视频| 精品无人区卡一卡二卡三乱码免费卡| 欧美高清视频在线观看| 国产精品日韩久久久| 99精品99久久久久久宅男| 青草热久免费精品视频| www.亚洲视频| 国产精品一区二区在线观看不卡| 日韩伦理在线观看| 国产精品久久久高清免费| 欧美日韩亚洲综合一区二区三区| 小说区图片区综合久久88| 国产一区日韩欧美| 欧美国产偷国产精品三区| 伊人久久在线| 黄色精品一区二区| 99久久婷婷国产综合精品电影| 永久免费精品视频| 黄动漫在线免费观看| 免费高清在线观看电视| 精品欧美一区二区久久久| 奇米4444一区二区三区| 国产bdsm| 91av视频在线| 91成人国产综合久久精品| 国产中文一区| 伊人精品在线| 在线日本制服中文欧美| 亚洲人成网77777色在线播放| 高清毛片aaaaaaaa**| 成人在线精品视频| 午夜精品福利视频| 国产极品美女高潮无套久久久| a级片国产精品自在拍在线播放| 久久黄色av网站| 亚洲国产日韩欧美在线| 在线免费国产视频| 综合一区中文字幕| 国产精品论坛| 国产精品777777在线播放| 国产精品日韩精品欧美在线| 国产欧美精品久久久| 国产三级国产精品国产国在线观看| 亚洲国产成人精品女人| 亚洲精品免费在线看| av在线播放成人| 色网站在线免费观看| 亚洲欧洲国产伦综合| 进去里视频在线观看| 亚洲精品午夜久久久| 最近中文字幕在线免费观看| 成人av免费在线观看| 国产福利在线播放麻豆| 国产成人免费在线视频| 国产成人在线精品| 黑人巨大精品欧美一区二区三区| 久久综合九色九九| 亚洲日本在线观看| 在线观看成人av电影| 黄网在线观看网址入口| 亚洲国产精品va在线看黑人动漫| 国产高清一级片| 视频免费裸体网站| 国产乱码精品一区二三区蜜臂| 亚洲熟妇av一区二区三区| 一区二区成人网| 最近中文字幕在线| 国产99精品一区| 国内精品视频一区| 亚洲精品一区二区三区在线播放| 日本一区二区免费在线观看| 丁香花在线高清完整版视频| 国产精品久久久久久久久久久不卡| 亚洲人成小说网站色在线| 欧美一区二区三区喷汁尤物| 91九色蝌蚪91por成人| 91国偷自产一区二区三区观看| 狠狠久久伊人中文字幕| 日本午夜免费福利视频| 日本在线免费观看视频| 亚洲日本青草视频在线怡红院| 国产精品无码电影| 少妇av在线| 男女猛烈无遮挡| 日本又骚又刺激的视频在线观看| 欧日韩不卡在线视频| 亚洲精品第一| 欧美牲交a欧美牲交aⅴ免费下载| 午夜视频在线免费播放| 91精彩刺激对白露脸偷拍| 亚洲成人在线网站| 三大队在线观看| 日韩欧美一区二区在线视频| 成人自拍偷拍| 欧美日韩在线观看视频| 男女曰b免费视频| 欧洲av一区| 久久在线视频免费观看| 国精产品一区一区三区有限在线| 国产专区欧美精品| 亚洲免费成人在线| 好吊色视频在线观看| 91成人福利| 夜夜添无码一区二区三区| 91av视频在线免费观看| 欧美亚洲一区二区在线观看| 少妇高潮一区二区三区69| 欧美大片欧美激情性色a∨久久| 成视频免费在线看| 久草福利资源站| 九一精品国产| www五月天com| 激情六月综合| 中国老熟女重囗味hdxx| 亚洲欧美日韩久久久久久| 在线观看老湿视频福利| 日本www在线视频| 日韩小视频在线播放| 亚洲石原莉奈一区二区在线观看| 久久精品国产99久久6| 亚洲视频一二三| 丁香花电影在线观看完整版| 国产精品一区视频| 欧美xxxx性猛交bbbb| 91丨九色丨蝌蚪丨老版| 国产精品剧情一区二区在线观看| 欧美日本视频在线观看| 亚洲国产日韩一区二区| 中文字幕在线不卡| 成人激情视频在线播放| 久草视频国产| 人人干在线视频| 天堂www中文在线资源| 二区三区在线播放| 日韩高清第一页| 亚洲免费在线看| 91成人午夜| 高h视频在线观看| 欧美videosex性欧美黑吊| 日韩—二三区免费观看av| 中文字幕亚洲无线码在线一区| 天天操天天干天天综合网| 日韩欧美专区在线| 国产精品极品美女在线观看免费| 欧美日韩在线播放一区二区| 欧美精品黑人性xxxx| 蜜臀av免费在线观看| 又黄又爽的视频在线观看| 成人黄色免费网址| 先锋影音在线播放av| 欧美二区三区91| 欧美国产小视频| 日韩少妇高潮抽搐| 日韩av自拍偷拍| 男女猛烈无遮挡午夜视频| 中文字幕亚洲一区二区av在线|