- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用 HTML5 + JS 编写应用程序,有时我需要上传 <canvas>
的内容元素,上面绘制了一些 PNG 文件。所以我在做:
$('#img').val(canvasElement.toDataURL());
如您所见,我没有为 toDataURL 函数提供任何参数,因此提取的图像将采用 PNG 格式。 #img
是一个文本输入(具有名称属性“img”),稍后用于将从 Canvas 中提取的图像的 base64 表示上传到服务器。我使用 AJAX 来实现,请求一个包含以下代码的 PHP 文件:
$data = explode(',', $_POST['img']);
$imgdata = base64_decode($data[1]);
$ifp = fopen('superGraphicFile.png', "wb");
fwrite($ifp, $imgdata);
fclose($ifp);
这行得通,但不幸的是,300x600 的 PNG 文件足以让 AJAX 请求持续很长时间(比如 20 秒),因为那时文件大小约为 400 kB。就我而言,所需的时间量是 Not Acceptable 。
我想知道如何减少发送到服务器的数据量,我认为以 JPG 格式发送它会很酷,因为我们可以指定从 Canvas 中提取的 JPEG 图像的质量。例如,调用 toDataURL('image/jpeg',0.7)
, 使文件比不带参数调用它小 10 倍。但是,我必须保留原始 PNG 文件的透明度信息,由于 JPG 无法做到这一点,我想发明一些方法在服务器端重新创建原始 PNG。
起初,我想用某种特定颜色填充原始 PNG 中的所有透明像素,将其转换为 JPG,发送到服务器,然后用透明像素替换所有具有该颜色的像素。然而,这可能行不通,因为我还需要保留原始图像的半透明像素。也许有一些方法可以从原始图像中提取 alpha channel ,将其作为另一个 JPG 发送到服务器并在服务器端将其用作蒙版,以这种方式重新创建原始 PNG?还是我遗漏了一些其他解决方案?
我提前感谢您的所有建议。
编辑: 我写的 20 秒可能是我的互联网连接出现了一些问题,因为我没有做任何更改,现在传输 400 kb 的数据大约需要一秒钟。但我仍然认为,将服务器资源节省十倍并提高应用程序的运行速度将是一件很酷的事情。
最佳答案
恐怕您正在尝试使用肮脏的解决方法(无意冒犯)来解决您的问题。将 PNG 转换为 JPEG 然后再转换回 PNG 将始终是一种有损转换(包括 alpha channel 的丢失),并且会比仅发送原始文件消耗更多的 CPU 周期。
最好的办法可能是查看代码内部并尝试以某种方式对其进行优化。在当今的网络和 PC 中,400kB 的传输/处理不应花费 20 秒。同样在某些情况下,JPEG 可能比 PNG 大得多 - 例如窗口的屏幕截图将是例如PNG 格式为 141kB,JPEG 格式为 245kB。
另一方面,如果使用有损格式真的更好,那么您可以看看这个。我发现,还有一些其他的 types支持透明度。也许您可以尝试使用 tiff 图像格式,它可以包括图像数据和 alpha channel (希望使用 JPEG 压缩)。唯一的问题是,我只知道一种开箱即用的支持 TIFF 的浏览器 (Safari)。
最好的选择可能是转换为 GIF。它是无损的,并且会保持透明度。当然没有半透明和有限的颜色。
另一种选择是使用 JPEG 2000因为它具有更高的压缩率和更低的质量损失,并且还支持 alpha channel 。 Safari 再次支持它,但 Firefox 需要一个插件。我记得几年前我有一个用于 JPEG 2k 的 M$ Internet Explorer 插件。我不知道有任何其他支持 JPEG 2k 的“主要”浏览器。
关于javascript - 如何将 PNG 转换为 JPG(客户端),然后再转换回 PNG(服务器端),同时保留全透明和半透明像素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22483512/
Apache服务器全局配置之服务器标识配置篇 服务器标识相关指令: ServerName ServerAdmin ServerSignature ServerTokens UseCanonical
//校验是否全由数字组成 ? 1
具体内容如下: 1 os.system 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc.conf') min=disab
基本操作 查看数据库 ? 1
Xcode使用教程详细讲解是本文要介绍的内容,Xcode是一个款强大的IDE开发环境,就像你在写Windows程序时需要VS2005一样 需要要Xcode为你写Mac程序提供环境。因此,如果你要成为
就如今天遇到随即函数rand();脑海中想到用它做点啥好呢,最后想起了验证码,数字验证码,字母验证码,中文验证码,可是自己不会呀,咋办呢,上网搜,看别人的代码,开不懂,看视频,听老师讲,将其中所遇到
pcre-7.8.tar.gz 正则表达式下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
IDEA常用设置(提高开发效率) 本人也是IDEA编译器的忠实用户了,但是有时出于各种原因,比如更换设备等等,IDEA总是需要重新安装配置。这就让我比较苦恼,因为总是记不全自己之前都修改了
? 1 2
1、 操作环境搭建 系统:Windows7 旗舰版 64位 PHP环境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 去年关闭。 Improve th
我已经为我在 Adobe Fireworks Cs5 中构建的页面生成了 css,我想知道如何为我的标题和其他 div 设置完整宽度。我将显示标题部分的 css 代码。 @charset "utf
您好,我希望表单宽度为 100%。我希望文本框几乎延伸整个页面的宽度,并在文本框的右侧直接放置小的“GO”按钮,所有按钮都在同一行(或 block )上。 现在我的文本框只有其中文本的宽度(“在此处输
我没有设法将全宽页脚粘贴到网页底部。当页脚上方的主要内容低于一定高度时,页脚下方有一个空白区域。我尝试使用各种解决方案,例如以下 css 代码: html,body { margin:0; padd
我想要一个全宽的表格。当我给 position:fixed; 它变成全宽但可滚动不起作用。 简而言之,我需要一个与浏览器主体没有任何边距的表格。 body { font-family: "Helv
我注意到很多大型网站(如 Google 和 Facebook)在查看页面源代码时 99% 的源代码都是 JavaScript。 有人知道这种方法相对于常规 HTML+JavaScript 页面的优势吗
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this q
由于某种原因,我网站上的图片不再是全宽的。 据我所见,所有内容都设置为 100% 宽度。 http://cargocollective.com/btatest 我是不是什么地方都没有? 最佳答案 我认
我正在创建一个菜单并尝试使用 CSS 制作全宽菜单。但是,我不确定菜单项将如何出现在菜单中。 这是问题的截图: 问题出在我得到的“GAP”中。 如果我有固定数量的元素,我知道我可以使用这个逻辑: ul
这个问题在这里已经有了答案: Puzzle: Find largest rectangle (maximal rectangle problem) (6 个答案) 关闭 9 年前。 给定一个二元矩阵
我是一名优秀的程序员,十分优秀!