Project Icon

blurhash

高效图像占位符压缩算法

BlurHash是一种将图像压缩为20-30个字符的占位符算法。它可在实际图片加载前显示模糊预览,有效解决空白加载问题。该算法支持C、Swift、Kotlin等多种语言实现,简单高效且易于移植。BlurHash已被Wolt、Mastodon等项目采用,可显著提升用户体验。

BlurHash

BlurHash是图像占位符的一种紧凑表示形式。

为什么你需要它?

当你加载设计师精心设计的页面时,是否因为所有图像尚未加载而出现一堆空白框而让设计师伤心?当你想通过将小缩略图塞进数据中作为占位符来解决这个问题时,是否让数据库工程师伤心?

BlurHash将解决你的问题!怎么解决?就像这样:

你还可以在blurha.sh上看到很好的例子并亲自尝试!

它是如何工作的?

简而言之,BlurHash接收一张图像,并给你一个短字符串(仅20-30个字符!)来表示这个图像的占位符。你在服务器后端执行这个操作,并将字符串与图像一起存储。当你向客户端发送数据时,你同时发送图像的URL和BlurHash字符串。然后客户端获取这个字符串,并将其解码成一个图像,在真实图像通过网络加载时显示这个占位图。这个字符串足够短,可以轻松适应你使用的任何数据格式。例如,它可以轻松地作为JSON对象中的一个字段添加。

总结如下:

   

想了解所有技术细节?请阅读算法描述

实际上,实现这个算法非常简单!实现代码简短,容易移植到你喜欢的语言或平台。

实现

到目前为止,我们已经创建了以下实现:

  • C - 可移植C代码的编码器实现。
  • Swift - 编码器和解码器实现,以及提供高级功能的更大库。还有一个示例应用程序可以用来试验该算法。
  • Kotlin - 适用于Android的解码器实现。
  • TypeScript - 编码器和解码器实现,以及用于测试的示例页面。
  • Python - C编码器代码集成到Python中。

这些涵盖了我们的使用场景,但可能需要改进、扩展和完善。还有一些我们知道的第三方实现:

[列出了各种语言的第三方实现,包括Python、Go、PHP、Java、Clojure、Nim、Rust、Ruby、Crystal、Elm、Dart、.NET、JavaScript、Haskell、Scala、Elixir、ReScript、Xojo、React Native、Zig、Titanium SDK、BQN、Jetpack Compose、C++、Kotlin Multiplatform和OCaml]

找不到你需要的语言?试试GitHub搜索。例如,这里是名称中包含"blurhash"的仓库搜索结果

也许你想帮助扩展这个列表?这就引出了...

贡献

我们非常欢迎贡献!该算法非常简单 - 不到两百行代码 - 可以轻松移植到你选择的平台。支持更多平台将会很棒!所以,Java解码器?Golang编码器?Haskell?Rust?我们都想要!

我们也会尝试在我们的问题跟踪器上标记我们希望得到帮助的任何问题,所以如果你只想浅尝辄止,去看看吧。

你可以向我们提交拉取请求,或者如果你想自己运行所有内容,你可以启动自己的仓库和项目,我们不介意。

如果你想为这个项目做出贡献,我们有一个行为准则

用户

谁在使用BlurHash?以下是我们所知道的一些项目:

  • Wolt - 我们当然自己在使用它。BlurHash在iOS和Android的移动客户端以及网页上被用作图像加载时的占位符。
  • Mastodon - Mastodon去中心化社交媒体网络使用BlurHash作为加载占位符,以及隐藏标记为敏感的媒体内容。
  • Signal - Signal私密通讯使用Blurhash作为聊天对话中照片和视频消息下载前的占位符。
  • Jellyfin - Jellyfin自由软件媒体系统使用Blurhash作为电影和电视节目图片下载时的占位符。

常见问题

编码和解码的速度如何?

这些实现并未进行很多优化。在非常大的图像上运行可能会有点慢。对于相同的输入或输出大小,编码器和解码器的性能大致相同,所以在UI线程上解码非常大的占位符也可能会有点慢。

然而!高效使用该算法的诀窍是不要在全尺寸数据上运行它。图像的细节都被丢弃了,所以在运行BlurHash之前应该先缩小图像。如果你正在创建缩略图,就在缩略图上运行BlurHash,而不是在完整图像上运行。

同样,在显示占位符时,非常小的图像在放大时效果很好。我们通常解码宽度为32甚至20像素的占位符,然后让UI层将它们放大,这与以全尺寸解码它们是无法区分的。

我该如何选择X和Y组件的数量?

这在一定程度上取决于个人喜好。你选择的组件越多,占位符中保留的信息就越多,但BlurHash字符串就会越长。此外,组件过多时可能看起来不太好。我们通常选择4x3,这似乎达到了很好的平衡。

然而,你应该根据图像的宽高比来调整组件数量。例如,非常宽的图像应该有更多的X组件和更少的Y组件。

Swift示例项目包含一个测试应用,你可以在其中尝试不同的参数并查看结果。

在一些实现中的"punch"参数是什么?

它是一个调整解码图像对比度的参数。1表示正常,较小的值会使效果更微妙,较大的值会使效果更强烈。这基本上是一个设计参数,让你可以调整外观。

从技术上讲,它的作用是放大或缩小AC分量。

这只能用作图像加载占位符吗?

嗯,这最初是为此设计的,但事实证明它对其他一些事情也很有用:

  • 无需使用昂贵的模糊处理就可以遮罩图像 - Mastodon将其用于此目的。
  • 数据表示使得提取图像不同区域的颜色平均值变得相当容易。你可以轻松找到图像顶边或角落的近似平均颜色。Swift BlurHashKit实现中有一些代码可以用来试验这一点。此外,整个图像的平均颜色就是DC分量,甚至不需要实现任何更复杂的DCT就可以解码。
  • 我们一直打算尝试通过使用BlurHash并扩展边界来为UI元素实现带色调的阴影。不过到目前为止还没有时间实际实现这个功能。

为什么选择83进制?

首先,83似乎是在JSON、HTML和shell中都可以安全使用的低ASCII字符的数量。

其次,83 * 83非常接近,并且略大于19 * 19 * 19,这使得它非常适合用两个字符编码三个AC分量。

为什么不使用完整的Unicode字符集来获得更高效的编码?

我们还没有研究过UTF-8编码相对于单字节字符的83进制会引入多少开销,但编码和解码可能会复杂得多,所以本着简约的精神,BlurHash使用了更简单的选择。根据操作系统的功能,复制粘贴也可能会很麻烦。

不过,如果你认为可以做到并且值得一试,那就制作你自己的版本并展示给我们看!我们很乐意看到它的实际效果。

有没有其他基底表示方法可以替代DCT?

这是我们非常想尝试的事情。当你增加组件数量时,DCT看起来很丑,可能是因为基函数的形状变得太明显了。使用形状更美观的不同基底可能会是一个很大的进步。

然而,我们还没有想出一个。我们对针对将被裁剪成圆形的图像使用傅里叶-贝塞尔基进行了一些实验,但没有取得多大成功。在这里我们也很想看看你能想出什么!

作者

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号