java输出单片机ARGB8565格式的图片文件

ARGB8565格式的定义

ARGB8565 是一种颜色编码格式,它结合了 alpha(透明度)通道和 RGB(红绿蓝)颜色通道。在这种格式中,每个像素由 32 位表示,其中 alpha 通道占用 8 位,红色、绿色和蓝色通道分别占用 5 位、6 位和 5 位。这样的分配意味着你可以有 256 个不同的透明度级别(从完全透明到完全不透明),以及相对较少的 RGB 颜色级别。

具体来说,ARGB8565 的位布局可能如下:

Alpha 通道(透明度): 8 位,范围从 0(完全透明)到 255(完全不透明)。
Red(红色): 5 位,范围从 0 到 31。
Green(绿色): 6 位,范围从 0 到 63。
Blue(蓝色): 5 位,范围从 0 到 31。
由于红色和蓝色通道只有 5 位,而绿色通道有 6 位,这种格式可能不是最适合显示所有颜色的情况,特别是在需要丰富色彩的场景中。然而,对于某些特定的图形硬件或应用场景(比如嵌入式系统、某些视频游戏控制台或图形加速器),使用 ARGB8565 可能会提供足够的颜色深度和透明度信息,同时减少内存使用和/或提高性能。

需要注意的是,ARGB8565 并不是一种广泛使用的标准颜色编码格式。相反,更常见的格式可能是 ARGB8888,其中每个颜色通道都有 8 位,提供了更丰富的颜色范围。然而,对于需要节省内存或提高性能的应用,使用 ARGB8565 或类似的较低位深度格式可能是有意义的。

在使用或处理 ARGB8565 格式的数据时,了解相关的硬件或软件文档非常重要,因为不同的系统可能会以不同的方式解释和存储这些位。此外,当在这种格式和其他格式之间转换时,可能需要进行颜色空间转换或缩放操作,以确保颜色信息的准确表示。

ARGB8565文件头的定义

ARGB8565图像文件组成:文件头(4字节)+像素信息(每像素3字节)

图片信息头组装(基于原理)
  • step1:将高度数值截取其二进制的低11bit形成【段1】
  • step2:将宽度数值截取其二进制的低11bit形成【段2】
  • step3:2bit"00"作为【段3】
  • step4:3bit"000"作为【段4】
  • step5:取图像编码方式枚举二进制形式的低5bit形成【段5】
  • step6:将【段1】【段2】【段3】【段4】【段5】按顺序连接起来(得到4字节数据)
  • step7:将上一步的4字节数据按照【低字节-次低字节-次高字节-高字节】的顺序排列写入文件
图片信息头组装(简化)
  • step1:高度数值左移21位得到【结果1】
  • step2:宽度数值左移10位得到【结果2】
  • step3:常量0x00000005作为【结果3】
  • step4:将【结果1】【结果2】【结果3】加起来得到【结果4】(4字节)
  • step5:将上一步的4字节数据按照【低字节-次低字节-次高字节-高字节】的顺序排列写入文件

实现代码

使用java工具包hutool进行了图片的压缩

import java.awt.Color;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import javax.imageio.ImageIO;import cn.hutool.core.img.ImgUtil;/*** 图片处理类* 图像文件组成:文件头(4字节)+像素信息(每像素3字节)* 图片信息头组装(基于原理) * step1:将高度数值截取其二进制的低11bit形成【段1】 * step2:将宽度数值截取其二进制的低11bit形成【段2】 * step3:2bit"00"作为【段3】 * step4:3bit"000"作为【段4】 * step5:取图像编码方式枚举二进制形式的低5bit形成【段5】 * step6:将【段1】【段2】【段3】【段4】【段5】按顺序连接起来(得到4字节数据) * step7:将上一步的4字节数据按照【低字节-次低字节-次高字节-高字节】的顺序排列写入文件 * 图片信息头组装(简化) * step1:高度数值左移21位得到【结果1】 * step2:宽度数值左移10位得到【结果2】 * step3:常量0x00000005作为【结果3】 * step4:将【结果1】【结果2】【结果3】加起来得到【结果4】(4字节) * step5:将上一步的4字节数据按照【低字节-次低字节-次高字节-高字节】的顺序排列写入文件 * 图片像素格式 * 5bitR取R的高5bit * 6bitG取R的高6bit * 5bitB取R的高5bit * 5bitR + 6bitG + 5bitB + 8bitAlpha 组成3字节* @ClassName: ImageUtils */
public class ImageUtils {private static ImageUtils instance = new ImageUtils();public static ImageUtils getInstance() {return instance;}public static void main(String[] args) {//ImageUtils.getInstance().ARGB8565("C:\\Users\\Administrator\\Pictures\\123.jpg","00000000",200);}/*** 图片转ARGB8565* @param path 文件的绝对路径* @param maxWidth 最大宽度,大于这个宽度会成比例缩小*/public String ARGB8565(String path,int maxWidth) {return ARGB8565(new File(path) ,maxWidth);}/*** 图片转ARGB8565* @param file* @param maxWidth 最大宽度,大于这个宽度会成比例缩小*/public String  ARGB8565(File file,int maxWidth){if(!file.exists()) { //这里给了一个默认的图片file = new File("默认的图片地址");}BufferedImage image = null;try {image = ImageIO.read(file);} catch (IOException e) {e.printStackTrace();}int width = image.getWidth();if(width > maxWidth) {float scale = (float) maxWidth / (float) width;image = ImgUtil.copyImage(ImgUtil.scale(image, scale),BufferedImage.TYPE_INT_ARGB_PRE, Color.WHITE);}return getARGB8565(image);}/*** 图片转ARGB8565* @param file* @param width      缩放后的宽度* @param height     缩放后的高度* @param fixedColor 比例不对时补充的颜色,不补充为{@code null}*/public String  ARGB8565(File file,int width, int height, Color fixedColor){if(!file.exists()) { //这里给了一个默认的图片file = new File("默认的图片地址");}BufferedImage image = null;try {image = ImageIO.read(file);} catch (IOException e) {e.printStackTrace();}int srcWidth = image.getWidth();int srcHeight = image.getHeight();if(srcWidth > width || srcHeight > height) {image = ImgUtil.copyImage(ImgUtil.scale(image, width,height,fixedColor),BufferedImage.TYPE_INT_ARGB_PRE, fixedColor);}return getARGB8565(image);}/*** 获取argb8565* @param image 要转变的图像* @return*/private String getARGB8565(BufferedImage image) {StringBuilder sBuffer = new StringBuilder();int width = image.getWidth();int height = image.getHeight();int res1 = (width << 10) + (height << 21) + 5;String data = HexZeroFillUtil.getHex(Integer.toHexString(res1), 8, 1);sBuffer.append(data.substring(6) + data.substring(4,6) + data.substring(2,4) + data.substring(0,2));int[] res = new int[width * height];image.getRGB(0, 0, width, height, res, 0, width);for (int i = 0; i < res.length; i++) {int alpha = (res[i] >> 24) & 0xFF; // 获取透明度的值(A)int red = (res[i] >> 16) & 0xFF; // 获取红色分量的值(R)int green = (res[i] >> 8) & 0xFF; // 获取绿色分量的值(G)int blue = res[i] & 0xFF; // 获取蓝色分量的值(B)int red565 = (red >> 3) & 0x1F; // 将红色分量转换为5位(R)int green565 = (green >> 2) & 0x3F; // 将绿色分量转换为6位(G)int blue565 = (blue >> 3) & 0x1F; // 将蓝色分量转换为5位(B)int rgb565Pixel = (red565 << 11) | (green565 << 5) | blue565;//3字节转为2字节sBuffer.append(HexZeroFillUtil.getHex(rgb565Pixel,4,1));sBuffer.append(HexZeroFillUtil.getHex(alpha,2,1));}image.flush();return sBuffer.toString();}/*** 获取文件是否是图片类型的一种gif png jpg 其他都返回null* @param srcFilePath* @return*/public String getImageType(File srcFilePath) {FileInputStream imgFile;byte[] b = new byte[10];int l = -1;try {imgFile = new FileInputStream(srcFilePath);l = imgFile.read(b);imgFile.close();} catch (Exception e) {return null;}if (l == 10) {byte b0 = b[0];byte b1 = b[1];byte b2 = b[2];byte b3 = b[3];byte b6 = b[6];byte b7 = b[7];byte b8 = b[8];byte b9 = b[9];if (b0 == (byte) 'G' && b1 == (byte) 'I' && b2 == (byte) 'F') {return "gif";} else if (b1 == (byte) 'P' && b2 == (byte) 'N' && b3 == (byte) 'G') {return "png";} else if (b6 == (byte) 'J' && b7 == (byte) 'F' && b8 == (byte) 'I' && b9 == (byte) 'F') {return "jpg";} else {return null;}} else {return null;}}}

补齐字符串的工具

import java.io.UnsupportedEncodingException;
import java.util.Arrays;
/*** 16进制字符串补零* * @ClassName: HexZeroFillUtil*/
public class HexZeroFillUtil {/*** @param hex      要补零的字符串* @param length   要补齐的长度* @param position 要补的位置 1零在前 2 零在后* @return* @throws Exception*/public static String getHex(String hex, int length, int position) {return getHex(hex, length, position, "0");}/*** @param num      要补零的十进制数* @param length   要补齐的长度* @param position 要补的位置 1零在前 2 零在后* @return* @throws Exception*/public static String getHex(int num, int length, int position) {String hex = Integer.toHexString(num);return getHex(hex, length, position,"0");}/*** @param hex      要补*的字符串* @param length   要补齐的长度* @param position 要补的位置 1*在前 2 *在后* @param t        要补的字符,只能是一个字符* @return* @throws Exception*/public static String getHex(String hex, int length, int position, String t) {if (StrKit.isBlank(hex) || hex.length() >= length || (position != 1 && position != 2)) {return hex;}StringBuffer zeroBuffer = new StringBuffer();for (int i = 0, l = length - hex.length(); i < l; i++) {zeroBuffer.append(t);}if (position == 1) {return zeroBuffer.append(hex).toString();} else {return hex + zeroBuffer.toString();}}/** 在getBytes("UTF-8")16进制字符串后面添加20(空格的ASCII码是20)* @param hex      要补*.getBytes("UTF-8")的字节16进制字符串* @param length   要补齐的字节数量* @return * @throws Exception*/public static String getHex(String hex, int length) {if (StrKit.isBlank(hex) || hex.length() / 2 >= length) {return hex;}StringBuffer resBuffer = new StringBuffer();for (int i = 0, l = length - hex.length() / 2; i < l; i++) {resBuffer.append("20");}return hex + resBuffer.toString();}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/720673.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

YOLOv9独家改进|使用HWD(小波下采样)模块改进ADown

专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;主力高效涨点&#xff01;&#xff01;&#xff01; 一、改进点介绍 HWD是一种下采样模型&#xff0c;应用了小波变换的方法。 ADown是YOLOv9中的下采样模块&#xff0c;对不同的数据场景具有一定的可学…

no declaration can be found for element ‘rabbit:connection-factory‘

spring-mvc 配置 rabbitmq 出现问题。 我的解决方案如下&#xff1a; 1 找到配置文件 spring-rabbitmq.xml 我的配置文件叫&#xff1a;spring-rabbitmq.xml&#xff0c;你们按照自己的查找。 2 定位如下URI 接着 Ctrl鼠标左键 3 确定spring-rabbit-x.x.xsd 按照步骤2 &…

uniapp同步将本地图片转换为base64,支持微信、H5、APP

接上篇&#xff0c;少了一个方法的源代码。 先上代码&#xff1a; ploadFilePromiseSync (url) > { return new Promise((resolve, reject) > { // #ifdef MP-WEIXIN uni.getFileSystemManager().readFile({ filePath: url, encoding: base64, success: res > { let …

Rabbitmq消息丢失-生产者消息丢失(一)

说明&#xff1a;消息生产者在将数据发送到Mq的时候&#xff0c;可能由于网络等原因造成数据投递失败。 消息丢失大致分三种&#xff1a;这里说的是生产者消息丢失&#xff01; 分析原因&#xff1a; 1.有没有一种可能&#xff0c;我刚发送消息&#xff0c;消息还没有到交换…

MySQL中有事务无法回滚的语句?

目录 0.从修改表结构语句开始 1.DDL(Data Definition Language) 数据定义语言 2.DCL(Data Control Language) 数据控制语言 3.在该事务还没提交时开启新事务 4.锁操作 5.行政声明语句 6.主从复制的从机操作 7.如何避免出现隐式提交导致的错误 0.从修改表结构语句开始 试…

tomcat nginx 动静分离

实验目的:当访问静态资源的时候&#xff0c;nginx自己处理 当访问动态资源的时候&#xff0c;转给tomcat处理 第一步 关闭防火墙 关闭防护 代理服务器操作&#xff1a; 用yum安装nginx tomcat &#xff08;centos 3&#xff09;下载 跟tomcat&#xff08;centos 4&#xff0…

Ansible-Playbook

目录 1、概念介绍 roles 角色 playbook 核心元素 ansible-playbook 命令 playbook 简单案例 2、Ansible 变量 自定义变量 facts 变量 Palybook 部署 LAMP ansible 端安装 LAMP playbook 系统环境脚本 构建 httpd 任务 构建 mariadb 任务 构建 php 任务 编写整个任务…

2024年【陕西省安全员C证】考试资料及陕西省安全员C证找解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 陕西省安全员C证考试资料根据新陕西省安全员C证考试大纲要求&#xff0c;安全生产模拟考试一点通将陕西省安全员C证模拟考试试题进行汇编&#xff0c;组成一套陕西省安全员C证全真模拟考试试题&#xff0c;学员可通过…

Netty权威指南——基础篇4 网络通信基础

1 TCP粘包/拆包 TCP是个“流”协议&#xff0c;所谓流&#xff0c;就是没有界限的一串数字。可以想象河里流水&#xff0c;是连成一片的&#xff0c;其间没有分界线。TCP底层并不了解上层业务数据的具体含义&#xff0c;它会根据TCP缓冲区的实际情况进行包的划分&#xff0c;一…

Vue.js的单向数据流:让你的应用更清晰、更可控

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

全局渐变滚动条样式

效果如下&#xff1a; APP.vue<style> /* 整个滚动条 */ ::-webkit-scrollbar {width: 5px;height: 10px; } /* 滚动条上的滚动滑块 */ ::-webkit-scrollbar-thumb {background-color: #49b1f5;/* 关键代码 */background-image: -webkit-linear-gradient(45deg,rgba(255,…

使用Go的encoding/asn1库处理复杂数据:技巧与最佳实践

使用Go的encoding/asn1库处理复杂数据&#xff1a;技巧与最佳实践 引言ASN.1 基础ASN.1与Go语言的关系ASN.1数据类型 encoding/asn1库概览主要功能和特性关键API应用场景 基本使用方法序列化&#xff08;编码&#xff09;反序列化&#xff08;解码&#xff09;处理复杂数据结构…

npm、cnpm、pnpm使用详细

简介&#xff1a; npm&#xff1a;npm&#xff08;Node Package Manager&#xff09;是Node.js的包管理工具&#xff0c;用于安装、更新、卸载Node.js的模块和包。它提供了一个命令行界面&#xff0c;使得开发者可以轻松地管理项目依赖。npm 是 nodejs 中的一部分&#xff0c;…

AWS认证

AWS新增DEA-C01认证考试知识要点 原创 云计算狂魔 云计算狂魔 2024-03-04 23:58 北京 由于AWS将于3月12日正式启动DEA-C01认证考试&#xff0c;我们整理了相关考试知识要点&#xff0c;请各位考生了解。

Pytorch学习 day01(Jupyter安装、常用函数、三种编辑器的对比)

Jupyter 安装过程中遇到的问题&#xff1a; Anaconda的base环境会自动安装Jupyter&#xff0c;但是如果我们要在其他环境中安装Jupyter&#xff0c;就需要注意&#xff0c;该环境的python版本不能高于3.11&#xff0c;且用以下代码安装&#xff1a; conda install nb_conda_…

什么是跨站脚本攻击(XSS)

厦门微思网络​​​​​​https://www.xmws.cn 华为认证\华为HCIA-Datacom\华为HCIP-Datacom\华为HCIE-Datacom Linux\RHCE\RHCE 9.0\RHCA\ Oracle OCP\CKA\K8S\ CISP\CISSP\PMP\ ​ 跨站脚本攻击&#xff08;Cross-site Scripting&#xff0c;通常称为XSS&#xff09;&#xf…

SpringCloud-RabbitMQ消息模型

本文深入介绍了RabbitMQ消息模型&#xff0c;涵盖了基本消息队列、工作消息队列、广播、路由和主题等五种常见消息模型。每种模型都具有独特的特点和适用场景&#xff0c;为开发者提供了灵活而强大的消息传递工具。通过这些模型&#xff0c;RabbitMQ实现了解耦、异步通信以及高…

序列化和反序列化简介

1、序列化和反序列化说明&#xff1a; 序列化&#xff1a;把对象转化为可传输的字节序列过程称为序列化。 反序列化&#xff1a;把字节序列还原为对象的过程称为反序列化。 序列化&#xff08;serialization&#xff09;是将对象的状态信息转换为可以存储或传输的形式的过程。在…

python基础教程十 再谈抽象

文章预览&#xff1a; 章节前导1. 对象魔法1.1 多态1.1.1 多态和方法 1.2 封装1.3 继承 2. 类2.1 类到底是什么2.2 创建自定义类2.3 属性&#xff0c;函数&#xff0c;方法2.3再谈隐藏 章节前导 在前几章学习了python的内置的主要对象类型&#xff08;数&#xff0c;字符串&am…

深度学习系列61:在CPU上运行大模型

1. 快速版 1.1 llamafile https://github.com/Mozilla-Ocho/llamafile 直接下载就可以用&#xff0c;链接为&#xff1a;https://huggingface.co/jartine/llava-v1.5-7B-GGUF/resolve/main/llava-v1.5-7b-q4.llamafile?downloadtrue 启动&#xff1a;./llava-v1.5-7b-q4.lla…