img_enhance

# -*- coding: utf-8 -*-

import cv2
import numpy as np
import os.path
import copy
from PIL import Image


# 椒盐噪声
def SaltAndPepper(src, percetage):
    SP_NoiseImg = src.copy()
    SP_NoiseNum = int(percetage * src.shape[0] * src.shape[1])
    for i in range(SP_NoiseNum):
        randR = np.random.randint(0, src.shape[0] - 1)
        randG = np.random.randint(0, src.shape[1] - 1)
        randB = np.random.randint(0, 3)
        if np.random.randint(0, 1) == 0:
            SP_NoiseImg[randR, randG, randB] = 0
        else:
            SP_NoiseImg[randR, randG, randB] = 255
    return SP_NoiseImg


# 高斯噪声
def addGaussianNoise(image, percetage):
    G_Noiseimg = image.copy()
    w = image.shape[1]
    h = image.shape[0]
    G_NoiseNum = int(percetage * image.shape[0] * image.shape[1])
    for i in range(G_NoiseNum):
        temp_x = np.random.randint(0, h)
        temp_y = np.random.randint(0, w)
        G_Noiseimg[temp_x][temp_y][np.random.randint(3)] = np.random.randn(1)[0]
    return G_Noiseimg


# 昏暗
def darker(image, percetage=0.9):
    image_copy = image.copy()
    w = image.shape[1]
    h = image.shape[0]
    # get darker
    for xi in range(0, w):
        for xj in range(0, h):
            image_copy[xj, xi, 0] = int(image[xj, xi, 0] * percetage)
            image_copy[xj, xi, 1] = int(image[xj, xi, 1] * percetage)
            image_copy[xj, xi, 2] = int(image[xj, xi, 2] * percetage)
    return image_copy


# 亮度
def brighter(image, percetage=1.5):
    image_copy = image.copy()
    w = image.shape[1]
    h = image.shape[0]
    # get brighter
    for xi in range(0, w):
        for xj in range(0, h):
            image_copy[xj, xi, 0] = np.clip(int(image[xj, xi, 0] * percetage), a_max=255, a_min=0)
            image_copy[xj, xi, 1] = np.clip(int(image[xj, xi, 1] * percetage), a_max=255, a_min=0)
            image_copy[xj, xi, 2] = np.clip(int(image[xj, xi, 2] * percetage), a_max=255, a_min=0)
    return image_copy


# 旋转
def rotate(image, angle, center=None, scale=1.0):
    (h, w) = image.shape[:2]
    # If no rotation center is specified, the center of the image is set as the rotation center
    if center is None:
        center = (w / 2, h / 2)
    m = cv2.getRotationMatrix2D(center, angle, scale)
    rotated = cv2.warpAffine(image, m, (w, h))
    return rotated


# 翻转
def flip(image):
    flipped_image = np.fliplr(image)
    return flipped_image


# 图片文件夹路径
file_dir = r'C:\Users\SV00253771\Downloads\NeicexiaCI/'
for img_name in os.listdir(file_dir):
    img_path = file_dir + img_name
    img = cv2.imread(img_path)
    # cv2.imshow("1",img)
    # cv2.waitKey(5000)
    # 旋转
    rotated_3 = rotate(img, 3)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r3.jpg', rotated_3)
    rotated_5 = rotate(img, 5)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r5.jpg', rotated_5)
    rotated_8 = rotate(img, 8)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r8.jpg', rotated_8)
    rotated_10 = rotate(img, 10)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r10.jpg', rotated_10)
    rotated_12 = rotate(img, 12)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r12.jpg', rotated_12)
    rotated_15 = rotate(img,15 )
    cv2.imwrite(file_dir + img_name[0:-4] + '_r15.jpg', rotated_15)
    rotated_18 = rotate(img, 18)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r18.jpg', rotated_18)
    rotated_20 = rotate(img, 20)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r20.jpg', rotated_20)
    rotated_22 = rotate(img, 22)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r22.jpg', rotated_22)
    rotated_25 = rotate(img,25 )
    cv2.imwrite(file_dir + img_name[0:-4] + '_r25.jpg', rotated_25)
    rotated_28 = rotate(img, 28)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r28.jpg', rotated_28)
    rotated_30 = rotate(img, 30)
    cv2.imwrite(file_dir + img_name[0:-4] + '_r30.jpg', rotated_30)


for img_name in os.listdir(file_dir):
    img_path = file_dir + img_name
    img = cv2.imread(img_path)
    # 镜像
    flipped_img = flip(img)
    cv2.imwrite(file_dir + img_name[0:-4] + '_fli.jpg', flipped_img)
    # filp_x_img = img.transpose(Image.FLIP_LEFT_RIGHT)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_fli_x.jpg', filp_x_img)
    # filp_y_img = img.transpose(Image.FLIP_LEFT_RIGHT)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_fli_y.jpg', filp_y_img)



    # # 增加噪声
    # img_salt = SaltAndPepper(img, 0.3)
    # cv2.imwrite(file_dir + img_name[0:7] + '_salt.jpg', img_salt)
    # img_gauss = addGaussianNoise(img, 0.3)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_noise.jpg', img_gauss)
    #
    # # 变亮、变暗
    # img_darker = darker(img)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_darker.jpg', img_darker)
    # img_brighter = brighter(img)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_brighter.jpg', img_brighter)
    #
    # blur = cv2.GaussianBlur(img, (7, 7), 1.5)
    # #      cv2.GaussianBlur(图像,卷积核,标准差)
    # cv2.imwrite(file_dir + img_name[0:-4] + '_blur.jpg', blur)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值