一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Python實(shí)現(xiàn)圖像的垂直投影示例

Python實(shí)現(xiàn)圖像的垂直投影示例

2020-04-18 10:36Saul Zhang Python

今天小編就為大家分享一篇Python實(shí)現(xiàn)圖像的垂直投影示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

Python + OpenCV 直接上代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import cv2
import numpy as np
from matplotlib import pyplot as plt
from PIL import Image
 
img=cv2.imread('0002.jpg') #讀取圖片,裝換為可運(yùn)算的數(shù)組
GrayImage=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)  #將BGR圖轉(zhuǎn)為灰度圖
ret,thresh1=cv2.threshold(GrayImage,130,255,cv2.THRESH_BINARY) #將圖片進(jìn)行二值化(130,255)之間的點(diǎn)均變?yōu)?55(背景)
# print(thresh1[0,0])#250 輸出[0,0]這個(gè)點(diǎn)的像素值                #返回值ret為閾值
# print(ret)#130
(h,w)=thresh1.shape #返回高和寬
# print(h,w)#s輸出高和寬
a = [0 for z in range(0, w)]
print(a) #a = [0,0,0,0,0,0,0,0,0,0,...,0,0]初始化一個(gè)長(zhǎng)度為w的數(shù)組,用于記錄每一列的黑點(diǎn)個(gè)數(shù)
 
#記錄每一列的波峰
for j in range(0,w): #遍歷一列
  for i in range(0,h): #遍歷一行
    if thresh1[i,j]==0: #如果改點(diǎn)為黑點(diǎn)
      a[j]+=1       #該列的計(jì)數(shù)器加一計(jì)數(shù)
      thresh1[i,j]=255 #記錄完后將其變?yōu)榘咨?
  # print (j)     
 
#     
for j in range(0,w): #遍歷每一列
  for i in range((h-a[j]),h): #從該列應(yīng)該變黑的最頂部的點(diǎn)開(kāi)始向最底部涂黑
    thresh1[i,j]=0  #涂黑
 
#此時(shí)的thresh1便是一張圖像向垂直方向上投影的直方圖
#如果要分割字符的話,其實(shí)并不需要把這張圖給畫(huà)出來(lái),只需要的到a=[]即可得到想要的信息
 
 
# img2 =Image.open('0002.jpg')
# img2.convert('L')
# img_1 = np.array(img2)
plt.imshow(thresh1,cmap=plt.gray())
plt.show()
cv2.imshow('img',thresh1)
cv2.waitKey(0)
cv2.destroyAllWindows()

原圖:

Python實(shí)現(xiàn)圖像的垂直投影示例

運(yùn)行結(jié)果:

Python實(shí)現(xiàn)圖像的垂直投影示例

在水平方向上進(jìn)行投影,代碼如下所示(原理同上):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import cv2
import numpy as np
from matplotlib import pyplot as plt
from PIL import Image
 
img=cv2.imread('C:/Users/Jet Zhang/Desktop/50/50/cut.png')
GrayImage=cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
ret,thresh1=cv2.threshold(GrayImage,130,255,cv2.THRESH_BINARY)
 
(h,w)=thresh1.shape #返回高和寬
 
a = [0 for z in range(0, h)]
print(a)
 
for j in range(0,h):
  for i in range(0,w):
    if thresh1[j,i]==0:
      a[j]+=1
      thresh1[j,i]=255
     
for j in range(0,h):
  for i in range(0,a[j]): 
    thresh1[j,i]=0
 
plt.imshow(thresh1,cmap=plt.gray())
plt.show()

效果圖如下所示:

Python實(shí)現(xiàn)圖像的垂直投影示例

以上這篇Python實(shí)現(xiàn)圖像的垂直投影示例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/qq_37053885/article/details/79248986

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品日本亚洲777 | 国产v日韩v欧美v精品专区 | 久久人妻无码毛片A片麻豆 久久热这里只有 精品 | 男女啪啪gif| 国产精品成人亚洲 | 精品国产日韩一区三区 | 男人疯狂进女人下部视频动漫 | 色橹| 国产成人久久精品推最新 | 国产一线天 | 狠狠色96视频 | 99ri精品| 美女主播免费观看 | 日本无翼乌漫画 | 亚洲网站在线观看 | 美女扒开屁股让男人进去 | 农村脱精光一级 | 色天天综合色天天碰 | 精品免费tv久久久久久久 | 亚洲国产区中文在线观看 | 久久视频这有精品63在线国产 | 亚洲精品久久久成人 | 亚洲男男video | 99精品全国免费7观看视频 | aaa在线| 婷婷久久热99在线精品 | 干b视频在线观看 | 色老女人 | 成人免费观看一区二区 | 蜜桃破解版免费看nba | 91私密保健女子养生spa | 午夜伦理电影在线观免费 | 国产在线欧美日韩精品一区二区 | 国产日韩综合 | 黑人biglackon10十 | 日本日日黄 | 亚洲欧美日本在线观看 | 五月天色综合 | 国产黄频在线观看高清免费 | 日韩视频免费一区二区三区 | 国产视频在线一区 |