4-13 油画特效

第三步灰度等级的划分。第四步灰度段中像素的个数统计。

# 1 gray 2 7*7 10*10 3 0-255 256 4 64 0-63 64-127
# 10 0-63 99 64-127
# 4 count 5 dst = result 
import cv2
import numpy as np
img = cv2.imread('image00.png',1)
cv2.imshow('src',img)
imgInfo = img.shape
height = imgInfo[0]
width = imgInfo[1]
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
dst = np.zeros((height,width,3),np.uint8)
for i in range(4,height-4):
    for j in range(4,width-4):
        array1 = np.zeros(8,np.uint8)
        for m in range(-4,4):
            for n in range(-4,4):
                p1 = int(gray[i+m,j+n]/32)
                array1[p1] = array1[p1]+1#表明当前的像素值完成了累加
        currentMax = array1[0]#获取array1中到底哪一个段内它的像素是最多
        l = 0#记录哪一个段
        for k in range(0,8):#遍历当前array1
            if currentMax<array1[k]:
                currentMax = array1[k]
                l = k#记录一下当前的k
                #获取了当前8个已经在灰度段中,哪一个段中像素最多,并且已经知道了到底是哪一个段的下标
        # 简化 均值
        for m in range(-4,4):
            for n in range(-4,4):
               if gray[i+m,j+n]>=(l*32) and gray[i+m,j+n]<=((l+1)*32):#如果这个像素值位于某一个灰度段内,那么我们就把这个像素值取出来
            #l它表明当前到底处于哪一个灰度段,32是它的灰度等级
                    (b,g,r) = img[i+m,j+n]
        dst[i,j] = (b,g,r)
cv2.imshow('dst',dst)
cv2.waitKey(0)

原文地址:https://www.cnblogs.com/ZHONGZHENHUA/p/9706689.html