#!/usr/bin/env python
#-*- coding: utf-8 -*-
#code:myhaspl@qq.com
import cv2
import numpy as np
fn="test1.jpg"
if __name__ == '__main__':
print 'http://blog.csdn.net/myhaspl'
print 'myhaspl@qq.com'
print
print 'loading %s ...' % fn
print 'working',
myimg1 = cv2.imread(fn)
w=myimg1.shape[1]
h=myimg1.shape[0]
sz1=w
sz0=h
#创建空白图像
myimg2=np.zeros((sz0,sz1,3), np.uint8)
#对比产生线条
black=np.array([0,0,0])
white=np.array([255,255,255])
centercolor=np.array([125,125,125])
for y in xrange(0,sz0-1):
for x in xrange(0,sz1-1):
mydown=myimg1[y+1,x,:]
myright=myimg1[y,x+1,:]
myhere=myimg1[y,x,:]
lmyhere=sum(myhere)/3
lmyright=sum(myright)/3
lmydown=sum(mydown)/3
if abs(lmyhere-lmydown)>20 and abs(lmyhere-lmyright)>20:
myimg2[y,x,:]=black
elif abs(lmyhere-lmydown)<=20 and abs(lmyhere-lmyright)<=20:
myimg2[y,x,:]=white
else:
myimg2[y,x,:]=centercolor
print '.',
cv2.namedWindow('img2')
cv2.imshow('img2', myimg2)
cv2.waitKey()
cv2.destroyAllWindows()
本博客所有内容是原创,未经书面许可,严禁任何形式的转载
http://blog.csdn.net/u010255642
python opencv边缘检测的简单算法,直接与下面和右边的像素进行比较