将文件压缩成PNG图像存储方法是什么
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,本篇内容介绍了"将文件压缩成PNG图像存储方法是什么"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!这
千家信息网最后更新 2025年11月09日将文件压缩成PNG图像存储方法是什么
本篇内容介绍了"将文件压缩成PNG图像存储方法是什么"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
这样可以做到很高的压缩比,到底有多高,下面会提到。这种方法用到了 canvas 控件,这也意味着只有支持 canvas 控件的浏览器下才有效。
现在你可以看到,上面的图像类似一个噪声图像,但它实际上是一个由124K的 prototype 框架代码转化成的30K的8位PNG图像(压缩比还不错吧)。
其实,要将代码转化为图像的格式存储,可以转化成GIF和PNG格式。PNG格式的图像有24位和8位,用24位的RGB图像,每个像素可以存储3字节的数据,如果是用8位的RGB图像,每个像素可以存储1字节的数据。
在PHOTOSHOP中做测试发现:一个300x100的纯色杂点8位图像可以压缩到5K,而同样的纯色杂点图像,如果是100x100的24位图像只能压缩到20K。如果是同样图案的8位GIF图像,压缩效果比PNG要差一些。所以,我们选择用8位的PNG图像作为压缩和解压缩的存储格式。
现在,我们就需要开始压缩图像了,下面是用PHP写的压缩文件地址。
$filename = "prototype-1.6.0.2.js"; if (file_exists($filename)) { $iFileSize = filesize($filename); $iWidth = ceil(sqrt($iFileSize / 1)); $iHeight = $iWidth; $im = imagecreatetruecolor($iWidth, $iHeight); $fs = fopen($filename, "r"); $data = fread($fs, $iFileSize); fclose($fs); $i = 0; for ($y=0;$y<$iHeight;$y++) { for ($x=0;$x<$iWidth;$x++) { $ord = ord($data[$i]); imagesetpixel($im, $x, $y, imagecolorallocate($im, $ord, $ord, $ord ) ); $i++; } } header("Content-Type: image/png"); imagepng($im); imagedestroy($im); } ?>它读取JS文件并创建一个PNG图像,图像中的每个像素中是一个0-255之间的值,而这个值对应的是JS字符的ascII的值。
当然,除了压缩,还要有解压缩,也就是将图像读取为JS文件的过程。这个函数是用JS写的,可以从下面的位置下载这个文件。
function loadPNGData(strFilename, fncCallback) { // test for canvas and getImageData var bCanvas = false; var oCanvas = document.createElement("canvas"); if (oCanvas.getContext) { var oCtx = oCanvas.getContext("2d"); if (oCtx.getImageData) { bCanvas = true; } } if (bCanvas) { var oImg = new Image(); oImg.style.position = "absolute"; oImg.style.left = "-10000px"; document.body.appendChild(oImg); oImg.onload = function() { var iWidth = this.offsetWidth; var iHeight = this.offsetHeight; oCanvas.width = iWidth; oCanvas.height = iHeight; oCanvas.style.width = iWidth+"px"; oCanvas.style.height = iHeight+"px"; var oText = document.getElementById("output"); oCtx.drawImage(this,0,0); var oData = oCtx.getImageData(0,0,iWidth,iHeight).data; var a = []; var len = oData.length; var p = -1; for (var i=0;i 0) a[++p] = String.fromCharCode(oData[i]); }; var strData = a.join(""); if (fncCallback) { fncCallback(strData); } document.body.removeChild(oImg); } oImg.src = strFilename; return true; } else { return false; } } "将文件压缩成PNG图像存储方法是什么"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
图像
文件
存储
格式
方法
像素
代码
位图
内容
字节
实际
控件
数据
更多
知识
纯色
过程
面的
不错
实用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
药品广告数据库鼻炎康粤视
从源头上杜绝网络安全隐患
数据库原理及医学应用课后答案
lol无法连接服务器请稍后重试
网络安全招聘网
工信部是管网络安全的吗
河南安卓软件开发价钱是多少
软件开发macmini值得买吗
不同数据库查询速度
微软认证软件开发专家是什么
软件开发上班规定
浙江企业软件开发需要多少钱
服务器沉了
深圳网络安全的发展优势
计算机网络技术主要有哪些
k2p怎么配置dns服务器
网络技术的野蛮文明
锐捷云服务器如何恢复云桌面
大飞哥网络安全29
单表导入数据库表
数据库应用技术是后端吗
网络技术工程学习地点
暨大网络技术中心
服务器主动防护系统价格
刀塔传奇 服务器
33岁学软件开发晚吗
当然翻译软件开发
甘肃省网络安全公开课心得
滁州医疗软件开发费用
网络安全中跳板