zoukankan      html  css  js  c++  java
  • 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)

  • 相关阅读:
    python学习(二十三) String(下) 分片和索引
    python学习(二十二) String(上)
    微服务网关
    【转】linux 软连接 硬链接
    设计模式--观察者模式
    设计模式--策略模式
    ubuntu-server 安装redis
    【转】linux的hostname修改详解
    【转】ftp的两种模式
    【转】linux下find查找命令用法
  • 原文地址:https://www.cnblogs.com/ZHONGZHENHUA/p/9706689.html
Copyright © 2011-2022 走看看