资源简介
一般直接将tif转成jpg会造成图片变暗或者色彩差异较大,主要是因为直接线性拉伸导致了,这里我使用C#加gdal,将tif影像先进行百分比截断拉伸,再转jpg,效果直接类似于在arcgis中截图。另外,这个类中因为使用了gdal,所以如果直接用的话,还需要你的VS中引用gdal的类库,但最主要的是,我想介绍这个C# 百分比截断拉伸的算法
代码片段和文件信息
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using OSGeo.GDAL;
using OSGeo.OSR;
namespace ImgProcess
{
class TifToJpg
{
public void ConvertToJpg(string tifPath string jpgPath)
{
//gdal读取影像
Dataset imgDatasat = Gdal.Open(tifPath Access.GA_ReadOnly);
int bandCount = imgDatasat.RasterCount;
int XSize = imgDatasat.RasterXSize;
int YSize = imgDatasat.RasterYSize;
Band[] bandArray = new Band[bandCount]; //用于存放三个波段
List bandData = new List(); //存放三个波段进行百分比截断之后的结果
//对每个波段进行处理
for (int j = 0; j < bandCount; j++)
{
int min = 0 max = 0;
Band band = imgDatasat.GetRasterBand(j + 1);
bandArray[j] = band;
int pixelCount = XSize * YSize;
//读取波段数据
int[] dataBuffer = new int[pixelCount];
band.ReadRaster(0 0 XSize YSize dataBuffer XSize YSize 0 0);
min = dataBuffer.Min();
max = dataBuffer.Max();
int[] histImg = new int[max - min];
band.GetHistogram(min - 0.5 max + 0.5 max - min histImg 1 0 null null); //生成直方图
int[] data = PercentClipStretchImg(dataBuffer pixelCount histImg 0.005 0.995); //百分比截断
bandData.Add(data);
}
//使用百分比截断后的数值依次对应rgb,生成bitmap
Bitmap bm = new Bitmap(XSize YSize);
for (int j = 0; j < YSize; j++)
{
for (int i = 0; i < XSize; i++)
{
int[] rgb = new int[3];
for (int k = 0; k < bandCount; k++)
{
rgb[k] = bandData[k][j * XSize + i];
}
Color color = Color.FromArgb(rgb[0] rgb[1] rgb[2]);
bm.SetPixel(i j color);
}
}
Graphics g = Graphics.FromImage(bm);
bm.Save(jpgPath System.Dr
- 上一篇:学生成绩管理系统C#实现
- 下一篇:VS2010下 C#最小二乘法图形界面及源代码
相关资源
- VS2010下 C#最小二乘法图形界面及源代
- 学生成绩管理系统C#实现
- C#代码创建Access数据库和表
- C# 全局钩子 ()
- C#:汉王人脸通SDK五获取考勤记录
- C# 调用笔记本摄像头,制作简易监控
- C# 八数码 源码
- C# 矩阵算法
- Emgucv3.0(c#)简单入门
- C# 道格拉斯线压缩算法 Douglas一Pe
- 佳博打印机.net平台下的开发API
- WPF写的一个简单截屏工具
- C# 守护进程的服务
- 漂亮的C#软件启动界面特效源码
- C#通讯录项目学生期末作业+C#.通讯录
- 将一个容器中控件拖到另一个容器中
- c# backgroundworker+process进度条
- C# 解决双击TreeView表里checkbox本身Bug问
- C#版学生管理系统源代码
- C#基于joyGetPos的主动方式手柄控制
- 三层架构实现图书管理系统
- (源代码)C#作为上位机,控制51单片
- C#实现的股票交易模拟系统
- C# modbus浮点数处理
- C# 安全移除USB设备
- c# winform 串口收发数据 demo
- 微软C# OleDbHelper.cs 源码
- 利用C#语言实现MSChart控件中图形拖拽
- C# 设计模式 DEMO(供学习参考)
- C#自动升级程序
评论
共有 条评论