Flutter for OpenHarmony:Flutter 三方库 riverbloc — 融合 Bloc 与 Riverpod 的架构实践(适配鸿蒙 HarmonyOS Next ohos)

Flutter for OpenHarmony:Flutter 三方库 riverbloc — 融合 Bloc 与 Riverpod 的架构实践(适配鸿蒙 HarmonyOS Next ohos)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net

在这里插入图片描述

前言

在鸿蒙(OpenHarmony)中大型项目中,开发者常在 Bloc 的严谨性与 Riverpod 的灵活性之间权衡。riverbloc 作为桥接库,允许将 Bloc 作为 Provider 管理,兼具了事件溯源与全局依赖注入的优势,是构建可维护业务中枢的理想选择。

一、核心价值

1.1 基础概念

riverbloc 引入了 BlocProvider 系列函数,使 Bloc 融入 Riverpod 的依赖树。

State 输出

ref.watch

ref.read.add(Event)

Riverpod ProviderContainer

riverbloc 桥接层

触发业务逻辑

Riverpod 监听者

鸿蒙 UI 页面

1.2 进阶概念

  • State Sync (状态同步):Riverpod 会自动监听 Bloc 的状态流,并将最新状态同步给订阅的 Widget,无需显式的 BlocBuilder
  • Scoped Injection:利用 Riverpod 轻松在鸿蒙应用的不同层级注入特定的 Bloc 实例。

二、核心 API / 组件详解

2.1 创建 Bloc 并定义 Provider

在鸿蒙工程中,先写好经典的 Cubit:

import'package:riverbloc/riverbloc.dart';// 1. 定义基础的 CubitclassCounterCubitextendsCubit<int>{CounterCubit():super(0);voidincrement()=>emit(state +1);}// 2. ✅ 重点:将其包装为 Riverpod Providerfinal counterProvider =BlocProvider((ref)=>CounterCubit());
在这里插入图片描述

2.2 在 UI 中通过 Provider 操作 Bloc

voidonAction(WidgetRef ref){// 💡 获取 Bloc 实例执行逻辑 ref.read(counterProvider.notifier).increment();}
在这里插入图片描述

三、场景示例

3.1 场景一:鸿蒙级应用的“多模块复合”状态

当一张复杂的订单页面需要同时引用“用户信息 Bloc”和“商品明细 Bloc”动态计算总价时。

final totalPriceProvider =Provider((ref){// 💡 技巧:利用 Riverpod 的 ref.watch 聚合多个 Bloc 的状态final userOrder = ref.watch(orderBlocProvider);final discount = ref.watch(couponBlocProvider);return userOrder.total - discount.value;});
在这里插入图片描述

四、OpenHarmony 平台适配挑战

4.1 内存自动释放与单例膨胀

Bloc 往往包含大量的业务缓冲区。如果在一个鸿蒙长生命周期的应用中无节制使用。

适配策略建议

  1. Auto-Disposeriverbloc 支持 BlocProvider.autoDispose。当鸿蒙页面销毁后,Bloc 实例也会自动执行 close(),防止内存泄露。
  2. Provider Scope 隔离:在鸿蒙的分屏(Multi-Window)或特定 Tab 页面下,利用 ProviderScope 的覆盖能力为不同的小窗口提供独立的业务 Bloc。

五、综合实战示例代码

这是一个包含了“自动增量”逻辑的鸿蒙业务计算器:

import'package:flutter/material.dart';import'package:flutter_riverpod/flutter_riverpod.dart';import'package:riverbloc/riverbloc.dart';// 1. 定义业务逻辑classThemeCubitextendsCubit<Color>{ThemeCubit():super(Colors.blue);voidtoggle()=>emit(state ==Colors.blue ?Colors.orange :Colors.blue);}// 2. 注入 Providerfinal themeBlocProvider =BlocProvider((ref)=>ThemeCubit());classHarmonyAppextendsConsumerWidget{constHarmonyApp({super.key});@overrideWidgetbuild(BuildContext context,WidgetRef ref){// 💡 监听状态变化:直接像 Riverpod 一样使用 watchfinal currentColor = ref.watch(themeBlocProvider);returnScaffold( appBar:AppBar(backgroundColor: currentColor, title:constText('Riverbloc 鸿蒙架构实战')), body:Center( child:ElevatedButton( onPressed:()=> ref.read(themeBlocProvider.notifier).toggle(), child:constText('点击切换 Bloc 状态(Riverpod 观察)'),),),);}}
在这里插入图片描述

六、总结

riverbloc 满足了鸿蒙开发者对“严谨性”和“灵活性”的双重追求。它让复杂的 BLoC 设计模式能在 Riverpod 及其便捷的 DI 环境中重获新生。

核心建议

  1. 涉及核心财务、交易等需要严密审计的逻辑,用 Bloc 编写并用 riverbloc 注入。
  2. 每一个 Bloc 业务块都尽量开启 autoDispose

Read more

AI视频生成模型从无到有:构建、实现与调试完全指南

AI视频生成模型从无到有:构建、实现与调试完全指南

文章目录 * **引言:从理论到实践的跃迁** * **第一部分:理论基石——视频生成模型的核心思想** * **第二部分:开发环境搭建与工具链** * **第三部分:亲手构建一个简易视频生成模型** * **第四部分:系统调试与效果评估** * **第五部分:模型优化与进阶探索** * **第六部分:从玩具到应用——部署与展望** * **结语:你的创造之旅,刚刚开始** 引言:从理论到实践的跃迁 在人工智能内容生成(AIGC)浪潮中,视频生成正成为最具挑战性和想象力的前沿领域。从几秒的动图到理论上无限时长的电影级叙事,技术的边界正在被快速突破。然而,对于大多数开发者和研究者而言,前沿模型如Sora、SkyReels-V2或Wan看似高不可攀,其背后动辄千亿级的数据和庞大的算力需求让人望而却步。 本指南的核心目标,正是要打破这种认知壁垒。我将引导你从最基础的原理出发,亲自动手构建一个具备完整AI特性的视频生成模型。这个模型将遵循“简单但完整”的原则:它可能无法生成好莱坞大片,但会清晰地展现扩散模型如何将噪声转化为连贯的动态序列,以及如何通过注意力机制维

By Ne0inhk
当 AI 嚼碎数据吐模块,人类开发者的创意还能留几行?—— 老码农的反编译式安心剂

当 AI 嚼碎数据吐模块,人类开发者的创意还能留几行?—— 老码农的反编译式安心剂

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 * 当 AI 嚼碎数据吐模块,人类开发者的创意还能留几行?—— 老码农的反编译式安心剂 * 📚 一、那些被 AI 吓得半夜查招聘网站的日子 * 📚 二、AI 生成功能模块的底层逻辑:它不是创意家,是数据缝合怪 * 📘 2.1 AI 生成功能的三板斧:统计、模仿与排列组合 * 📘 2.2 人类创意 vs AI 生成:核心差异在哪? * 📘 2.3 代码演示:AI 能生成 "正确" 的代码,但生成不了 "贴心&

By Ne0inhk
OpenClaw视觉操作实战:不写接口,让AI直接点按钮、操作软件

OpenClaw视觉操作实战:不写接口,让AI直接点按钮、操作软件

文章目录 * 前言 * 一、OpenClaw是啥?你的数字长工 * 二、视觉操作的核心:Snapshot快照系统 * 1. 告别元素定位地狱 * 2. 自适应界面变化 * 3. 跨应用操作 * 三、实战:手把手教你让AI自动填表 * 步骤1:安装与环境准备 * 步骤2:启动视觉模式 * 步骤3:编写自动化脚本 * 步骤4:进阶:自动下载报表 * 四、不止浏览器:桌面软件也能点 * 五、定时任务:让AI自己起床干活 * 六、数据安全:你的隐私留在本地 * 七、避坑指南:新手常踩的雷 * 1. 动态加载的坑 * 2. 弹窗处理 * 3. API额度控制 * 4. 元素编号会变 * 八、总结:从“码农”

By Ne0inhk
人工智能:自然语言处理在医疗领域的应用与实战

人工智能:自然语言处理在医疗领域的应用与实战

人工智能:自然语言处理在医疗领域的应用与实战 学习目标 💡 理解自然语言处理(NLP)在医疗领域的应用场景和重要性 💡 掌握医疗领域NLP应用的核心技术(如电子病历分析、医学文本分类、智能问答) 💡 学会使用前沿模型(如BERT、GPT-3)进行医疗文本分析 💡 理解医疗领域的特殊挑战(如数据隐私、多语言处理、专业术语) 💡 通过实战项目,开发一个电子病历分析应用 重点内容 * 医疗领域NLP应用的主要场景 * 核心技术(电子病历分析、医学文本分类、智能问答) * 前沿模型(BERT、GPT-3)在医疗领域的使用 * 医疗领域的特殊挑战 * 实战项目:电子病历分析应用开发 一、医疗领域NLP应用的主要场景 1.1 电子病历分析 1.1.1 电子病历分析的基本概念 电子病历分析是对电子病历中的文本内容进行分析和处理的过程。在医疗领域,电子病历分析的主要应用场景包括: * 病历摘要:自动生成病历摘要(如“患者基本信息”、“病情描述”

By Ne0inhk