无码av一区二区三区无码,在线观看老湿视频福利,日韩经典三级片,成 人色 网 站 欧美大片在线观看

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

【BadApple】提取矢量化邊界

2023-08-24 09:34 作者:落魄小程序員  | 我要投稿

BadApple提取矢量化邊界使用Python,OpenCV處理,通過

cap = cv.VideoCapture(fileName)

while True:

? ? ? ? hasFrame, frame = cap.read()

? ? ? ? if not hasFrame:

? ? ? ? ? ? break

提取視頻中每幀圖像,

并進行兩步處理:

  • 提取邊緣

# 轉(zhuǎn)二值圖像

? ? ? ? ret, img_threshold = cv.threshold(frame, 128, 255, cv.THRESH_BINARY)

? ? ? ? # 使用canny提取邊界

? ? ? ? img_canny = cv.Canny(img_threshold, 128, 255)


  • 第一步提取的邊界信息為二維數(shù)組表示的圖像,其中高亮度值為邊界。這一步將第一步提取的邊界信息轉(zhuǎn)換為矢量數(shù)據(jù),采用的方法為:搜索

這里采用了四個方向的搜索(adjacent),導(dǎo)致產(chǎn)生很多碎線,應(yīng)當采用八方向,純屬失誤

# 廣搜

def Bfs(img, w, h, i, j):

? ? ret = [[i, j]]

? ? queue = [[i, j]]

? ? img[i, j] = 0

? ? adjacent = [[0, 1], [0, -1], [1, 0],[-1, 0]] # 四向搜索

? ? while (len(queue) > 0):

? ? ? ? cnt = queue.pop()

? ? ? ? for k in range(len(adjacent)):

? ? ? ? ? ? x = cnt[0] + adjacent[k][0]

? ? ? ? ? ? y = cnt[1] + adjacent[k][1]

? ? ? ? ? ? if (x < 0 or x >= w or y < 0 and y >= h):

? ? ? ? ? ? ? ? continue

? ? ? ? ? ? if (img[x, y] == 255):

? ? ? ? ? ? ? ? img[x, y] = 0

? ? ? ? ? ? ? ? queue.append([x, y])

? ? ? ? ? ? ? ? ret.append([x, y])

? ? return ret

# 矢量化邊界

def Ve****************(img, w, h):

? ? ret = []

? ? for i in range(w):

? ? ? ? for j in range(h):

? ? ? ? ? ? if (img[i, j] == 255):

? ? ? ? ? ? ? ? # BFS 搜索邊界

? ? ? ? ? ? ? ? line = Bfs(img, w, h, i, j)

? ? ? ? ? ? ? ? ret.append(line)

? ? return ret


此時已提取出矢量化的邊界信息,不過數(shù)據(jù)量相當大,可以使用曲線抽稀算法再處理一步(有損壓縮)

【BadApple】提取矢量化邊界的評論 (共 條)

分享到微博請遵守國家法律
嘉黎县| 凤山市| 伊金霍洛旗| 吉首市| 菏泽市| 云梦县| 开鲁县| 庆云县| 闵行区| 石泉县| 玛曲县| 绥芬河市| 鄂托克旗| 手游| 敦煌市| 酒泉市| 洪雅县| 古蔺县| 广宁县| 武城县| 嵊州市| 娄烦县| 图片| 南木林县| 潼关县| 靖边县| 梓潼县| 洪泽县| 博客| 大渡口区| 临邑县| 清水河县| 广东省| 北海市| 拜泉县| 金塔县| 佛教| 惠东县| 松潘县| 肇庆市| 武隆县|