Tiff文件解析和PackBits解压缩

2024-05-12 05:12
文章标签 解压缩 解析 tiff packbits

本文主要是介绍Tiff文件解析和PackBits解压缩,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现了Tiff图片文件格式的解析,对Tiff文件中的PackBits压缩格式进行解压缩,对Tiff文件中每一个Frame转换成BufferedImage显示。

Java语言实现,Eclipse下开发,AWT显示图片。

public static TIFF Parse(final byte[] bytes) throws IllegalAccessException {BinaryBuffer is = new BinaryBuffer(bytes);TIFF tiff = new TIFF();FileHeader header = new FileHeader();header.setByteOrder( is.ReadAsciiString(2));if (header.getByteOrder().equals("II"))is.SetByteOrder(ByteOrder.LITTLE_ENDIAN);else if (header.getByteOrder().equals( "MM"))is.SetByteOrder(ByteOrder.BIG_ENDIAN);elsethrow new java.lang.IllegalAccessException(header.getByteOrder());header.setLabel( is.ReadBytes(2));header.setOffset( is.ReadUInt32());tiff.setHeader(header);int position = (int) header.getOffset();			while (position != 0 ) {is.SetPosition(position);FileDirectory ifd = new FileDirectory();ifd.setEntryCount( is.ReadUInt16() );for (int i=0; i<ifd.getEntryCount(); i++) {Entry entry = new Entry();entry.setTag( is.ReadUInt16() );entry.setType( is.ReadUInt16() );entry.setCount( is.ReadInt32() );entry.setValue( is.ReadInt32() );if (entry.getType() == 1) { // 8-bit unsigned integerint count = 1 * entry.getCount();if (count <=4)entry.setData(new byte[] {  });else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadAsciiChar(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 2) { // 8-bit, NULL-terminated stringint count = 1 * entry.getCount();if (count <=4)entry.setData(new char[] {  });else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadAsciiChar(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 3) { // 16-bit unsigned integerint count = 2 * entry.getCount();if (count <= 4) {entry.setData( entry.getValue());}else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadUInt16(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 4) { // 32-bit unsigned integerint count = 4 * entry.getCount();if (count <= 4 )entry.setData(entry.getValue());else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadUInt32(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 5) { // Two 32-bit unsigned integersis.SavePoint();is.SetPosition(entry.getValue());entry.setData( 1.0 * is.ReadUInt32() / is.ReadUInt32() );is.RestorePoint();}else if (entry.getType() == 6) { // 8-bit signed integerthrow new java.lang.UnsupportedOperationException();}else if (entry.getType() == 7) { // 8-bit byteint count = 1 * entry.getCount();if (count <=4)entry.setData(new byte[] {  });else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadAsciiChar(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 9) { // 32-bit signed integerint count = 4 * entry.getCount();if (count <= 4 )entry.setData(entry.getValue());else {is.SavePoint();is.SetPosition(entry.getValue());entry.setData( is.ReadInt32(entry.getCount()));is.RestorePoint();}}else if (entry.getType() == 10) { // Two 32-bit signed integersentry.setData( 1.0 * is.ReadInt32() / is.ReadInt32() );}else if (entry.getType() == 11) { // 4-byte single-precision IEEE throw new java.lang.UnsupportedOperationException();}else if (entry.getType() == 12) { // 8-byte double-precision IEEE throw new java.lang.UnsupportedOperationException();}else throw new java.lang.IllegalArgumentException(entry.getType() + "");ifd.getEntrys().add(entry);}ifd.setNext( is.ReadInt32());tiff.getDirectorys().add(ifd);position = ifd.getNext();}return tiff;}

解析Tiff文件第1个Frame的结构:

PackBits解压缩代码:

	public static byte[] uncompress(byte[] input) {ByteArrayOutputStream os = new ByteArrayOutputStream();int i = 0;do {byte n = input[i++];if (n < 0 && n > -128) {byte b = input[i++];for (int j=0; j<-n+1; j++)os.write(b);}else if (n >= 0 && n<=127) {int count = n + 1;for (int j=0; j<count; j++)os.write(input[i++]);}} while (i<input.length);return os.toByteArray();}

在AWT显示Tiff图像中32个Frame图像,采用GridLayout布局,效果如下

这篇关于Tiff文件解析和PackBits解压缩的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/981695

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

Java解析JSON的六种方案

《Java解析JSON的六种方案》这篇文章介绍了6种JSON解析方案,包括Jackson、Gson、FastJSON、JsonPath、、手动解析,分别阐述了它们的功能特点、代码示例、高级功能、优缺点... 目录前言1. 使用 Jackson:业界标配功能特点代码示例高级功能优缺点2. 使用 Gson:轻量

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动