python代码裁剪tiff影像图和转换成png格式+裁剪Png图片

先来看一下需要转换的tiff原始图的信息,如下图所示。

tiff转换成png和裁剪tiff的代码(opencv)

import cv2 as cv
import os

"""
    转换tiff格式为png + 横向裁剪tiff遥感影像图
"""
def Convert_To_Png_AndCut(dir):
    files = os.listdir(dir)
    ResultPath1 = "./RS_ToPngDir/"  # 定义转换格式后的保存路径
    ResultPath2 = "./RS_Cut_Result/"  # 定义裁剪后的保存路径
    ResultPath3 = "./RS_Cut_Result/"  # 定义裁剪后的保存路径
    for file in files:  # 这里可以去掉for循环
        a, b = os.path.splitext(file)  # 拆分影像图的文件名称
        this_dir = os.path.join(dir + file)  # 构建保存 路径+文件名
        
        img = cv.imread(this_dir, 1)  # 读取tif影像
        # 第二个参数是通道数和位深的参数,
        # IMREAD_UNCHANGED = -1  # 不进行转化,比如保存为了16位的图片,读取出来仍然为16位。
        # IMREAD_GRAYSCALE = 0  # 进行转化为灰度图,比如保存为了16位的图片,读取出来为8位,类型为CV_8UC1。
        # IMREAD_COLOR = 1   # 进行转化为RGB三通道图像,图像深度转为8位
        # IMREAD_ANYDEPTH = 2  # 保持图像深度不变,进行转化为灰度图。
        # IMREAD_ANYCOLOR = 4  # 若图像通道数小于等于3,则保持原通道数不变;若通道数大于3则只取取前三个通道。图像深度转为8位
        
        cv.imwrite(ResultPath1 + a + "_" + ".png", img)  # 保存为png格式
        
        # 下面开始裁剪-不需要裁剪tiff格式的可以直接注释掉
        hight = img.shape[0]  #opencv写法,获取宽和高
        width = img.shape[1]
        #定义裁剪尺寸
        w = 480  # 宽度
        h = 360  # 高度
        _id = 1  # 裁剪结果保存文件名:0 - N 升序方式
        i = 0
        while (i + h <= hight):  # 控制高度,图像多余固定尺寸总和部分不要了
            j = 0
            while (j + w <= width):   # 控制宽度,图像多余固定尺寸总和部分不要了
                cropped = img[i:i + h, j:j + w]  # 裁剪坐标为[y0:y1, x0:x1]
                cv.imwrite(ResultPath2 + a + "_" + str(_id) + b, cropped)
                _id += 1
                j += w
            i = i + h
"""
    横向裁剪PNG图
"""
def toCutPng(dir):
    files = os.listdir(dir)
    ResultPath = "./RS_CutPng_Result/"  # 定义裁剪后的保存路径
    for file in files:
        a, b = os.path.splitext(file)  # 拆分影像图的文件名称
        this_dir = os.path.join(dir + file)
        img = Image.open(this_dir)  # 按顺序打开某图片
        width, hight = img.size
        w = 480  # 宽度
        h = 360  # 高度
        _id = 1  # 裁剪结果保存文件名:0 - N 升序方式
        y = 0
        while (y + h <= hight):  # 控制高度,图像多余固定尺寸总和部分不要了
            x = 0
            while (x + w <= width):   # 控制宽度,图像多余固定尺寸总和部分不要了
                new_img = img.crop((x, y, x + w, y + h))
                new_img.save(ResultPath + a + "_" + str(_id) + b)
                _id += 1
                x += w
            y = y + h

if __name__ == '__main__':
    _path = r"./RS_TiffDir/"   # 遥感tiff影像所在路径
    # 裁剪影像图
    Convert_To_Png_AndCut(_path)

将转换成png后的图加载到软件中(专业软件ENVI5.3)查看结果详细信息如下图所示,成功的转换成png格式了。

下面是加载裁剪后的影像图(Tiff格式的)
python代码裁剪tiff影像图和转换成png格式+裁剪Png图片_第1张图片
def toCutPng(dir):函数效果图如下图所示。
python代码裁剪tiff影像图和转换成png格式+裁剪Png图片_第2张图片

你可能感兴趣的:(tiff遥感影像格式转换及裁剪)