# 还在用灰秃秃的图片占位符?快来试试这款神器

还在用灰秃秃的图片占位符?快来试试这款神器

每次你加载设计师精心设计的界面,结果因为图片都没加载出来,满屏都是灰秃秃的占位图,这是不是让设计师很抓狂?当你想往数据里塞小缩略图当占位图来解决这个问题时,数据库工程师是不是也会很头疼?那还不快来试试flutter_blurhash

工作原理

BlurHash 是一种紧凑的表示形式,可将图像转换为简短的字符串,借助这些字符串能快速生成图像的模糊占位图,这样在高分辨率图像加载期间,用户就能看到一个模糊的预览图像,进而提升用户体验。 BlurHash的字符串长度通常在20-30个,既可以在JSON中使用也可以存放到数据库,所以可以随着API一起返回。

这个字符串长度取决你设置的比例

BlurHash生成

获取图片的 BlurHash 的一种快速简便的方法是将其上传到blursha.sh

当然也可以使用官方开源代码实现,也有第三方代码实现,支持cSwiftpython等语言具体可以看blurhash

使用及实际效果

flutter_blurhas目前只有解码功能,并不支持对图片编码。

dart 复制代码
class ExampleApp extends StatelessWidget {
  const ExampleApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: const Text("BlurHash")),
        body: const SizedBox.expand(
          child: Center(
            child: AspectRatio(
              aspectRatio: 1.7,
              child: BlurHash(hash: "LNF5L5^*F@Nt}^-oOtR*EVS8V[ac"),
            ),
          ),
        ),
      ),
    );
  }
}

实际运行效果

原图

优化模式

  • BlurHashOptimizationMode.none:原始算法,用于向后兼容。
  • BlurHashOptimizationMode.standard:优化后的解码模式,具有更好的缓存局部性和性能。
  • BlurHashOptimizationMode.approximation:最快模式,使用近似的sRGB转换,结果略暗但性能显著提升。
dart 复制代码
class BlurHashApp extends StatelessWidget {
  const BlurHashApp({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) => MaterialApp(
    home: Scaffold(
      appBar: AppBar(title: const Text("BlurHash")),
      body: const SizedBox.expand(
        child: Center(
          child: AspectRatio(
            aspectRatio: 1.6,
            child: BlurHash(
              hash: "LNF5L5^*F@Nt}^-oOtR*EVS8V[ac",
              optimizationMode: BlurHashOptimizationMode.approximation,
            ),
          ),
        ),
      ),
    ),
  );
}

结束语

顺便提一下,欢迎关注我的微信公众号OpenFlutter。

相关推荐
一豆羹19 小时前
macOS 环境下 ADB 无线调试连接失败、Protocol Fault 及端口占用的深度排查
flutter
行者9619 小时前
OpenHarmony上Flutter粒子效果组件的深度适配与实践
flutter·交互·harmonyos·鸿蒙
双向3319 小时前
RAG的下一站:检索增强生成如何重塑企业知识中枢?
前端
拖拉斯旋风19 小时前
从零开始:使用 Ollama 在本地部署开源大模型并集成到 React 应用
前端·javascript·ollama
asing20 小时前
🤯 为什么我的收银台在鸿蒙系统“第一次返回”死活拦不住?一次差点背锅的排查实录
前端·harmonyos
德育处主任20 小时前
『NAS』在群晖部署图片压缩工具-Squoosh
前端·javascript·docker
Hao_Harrision20 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨| ThreeDBackgroundBoxes(3D背景盒子组件)
前端·3d·typescript·react·tailwindcss·vite7
加个鸡腿儿20 小时前
经验分享2:SSR 项目中响应式组件的闪动陷阱与修复实践
前端·css·架构
心.c20 小时前
如何基于 RAG 技术,搭建一个专属的智能 Agent 平台
开发语言·前端·vue.js
智航GIS20 小时前
10.7 pyspider 库入门
开发语言·前端·python