實現步驟:
1、通過水平投影對圖形進行水平分割,獲取每一行的圖像;
2、通過垂直投影對分割的每一行圖像進行垂直分割,最終確定每一個字符的坐標位置,分割出每一個字符;
先簡單介紹一下投影法:分別在水平和垂直方向對預處理(二值化)的圖像某一種像素進行統計,對于二值化圖像非黑即白,我們通過對其中的白點或者黑點進行統計,根據統計結果就可以判斷出每一行的上下邊界以及每一列的左右邊界,從而實現分割的目的。
下面通過Python+opencv來實現該功能
首先來實現水平投影:
import cv2 import numpy as np '''水平投影''' def getHProjection(image): hProjection = np.zeros(image.shape,np.uint8) #圖像高與寬 (h,w)=image.shape #長度與圖像高度一致的數組 h_ = [0]*h #循環統計每一行白色像素的個數 for y in range(h): for x in range(w): if image[y,x] == 255: h_[y]+=1 #繪制水平投影圖像 for y in range(h): for x in range(h_[y]): hProjection[y,x] = 255 cv2.imshow('hProjection2',hProjection) return h_ if __name__ == "__main__": #讀入原始圖像 origineImage = cv2.imread('test.jpg') # 圖像灰度化 #image = cv2.imread('test.jpg',0) image = cv2.cvtColor(origineImage,cv2.COLOR_BGR2GRAY) cv2.imshow('gray',image) # 將圖片二值化 retval, img = cv2.threshold(image,127,255,cv2.THRESH_BINARY_INV) cv2.imshow('binary',img) #水平投影 H = getHProjection(img)
當前標題:Python+opencv實現圖片文字的分割的方法示例-創新互聯
文章源于:http://www.yijiale78.com/article36/dppcsg.html
成都網站建設公司_創新互聯,為您提供定制開發、網站營銷、網站改版、Google、定制網站、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯