当前位置: 首页 > article >正文

手把手教你用Flutter和OpenHarmony 4.0搭建一个离线视频通话App(附完整源码)

Flutter与OpenHarmony 4.0离线视频通话开发实战在企业内部通信、教育机构互动等需要数据完全本地化的场景中离线视频通话功能正成为刚需。本文将带你从零开始基于Flutter框架和OpenHarmony 4.0原生能力构建一个完全不依赖云服务的端到端视频通话应用。1. 环境准备与项目初始化首先需要配置开发环境确保以下工具已安装Flutter SDK 3.0支持空安全DevEco Studio 3.1OpenHarmony开发IDEOpenHarmony 4.0 SDKAPI Version 9创建混合工程结构flutter_ohos_video_call/ ├── android/ # 空目录Flutter要求 ├── ios/ # 空目录Flutter要求 ├── ohos/ # OpenHarmony原生模块 │ ├── entry # 主模块 │ └── rtc_native # 音视频核心库 └── lib/ # Flutter Dart代码提示使用flutter create --templatemodule创建工程可避免平台目录冲突2. OpenHarmony原生能力配置2.1 权限声明在ohos/entry/config.json中添加必要权限reqPermissions: [ { name: ohos.permission.CAMERA, reason: 视频通话需要摄像头权限 }, { name: ohos.permission.MICROPHONE, reason: 语音采集需要麦克风权限 }, { name: ohos.permission.DISTRIBUTED_DATASYNC, reason: 设备间数据传输 } ]2.2 原生媒体库集成OpenHarmony的媒体子系统提供完整音视频处理能力组件功能描述对应APIAVSession会话状态管理ohos.multimedia.avsessionCameraKit摄像头控制ohos.multimedia.cameraAudioCapturer音频采集ohos.multimedia.audioMediaCodec音视频编解码ohos.multimedia.media3. NAPI桥接层实现3.1 摄像头与麦克风控制创建rtc_bridge.cpp实现设备控制#include hilog/log.h #include napi/native_api.h #include camera_kit.h static napi_value StartPreview(napi_env env, napi_callback_info info) { // 获取Flutter传入的Surface ID napi_value args[1]; size_t argc 1; napi_get_cb_info(env, info, argc, args, nullptr, nullptr); int32_t surfaceId; napi_get_value_int32(env, args[0], surfaceId); // 初始化OHOS摄像头 CameraKit* cameraKit CameraKit::GetInstance(); CameraDevice* camera cameraKit-GetCamera(CAMERA_POSITION_BACK); camera-StartPreview(surfaceId); return nullptr; }3.2 视频编码与传输使用OpenHarmony MediaCodec进行H.264编码void EncodeVideoFrame(const uint8_t* yuvData, int width, int height) { MediaCodec* encoder MediaCodec::CreateVideoEncoder( video/avc, width, height, 15, // fps 500000 // bitrate ); AVMemory* inputBuffer encoder-GetInputBuffer(); memcpy(inputBuffer-GetBytes(), yuvData, width*height*3/2); encoder-QueueInputBuffer(inputBuffer); AVMemory* outputBuffer encoder-GetOutputBuffer(); if (outputBuffer) { SendEncodedVideo(outputBuffer-GetBytes(), outputBuffer-GetSize()); } }4. Flutter UI集成4.1 视频渲染界面使用Flutter的Texture widget显示视频流class VideoView extends StatefulWidget { final int textureId; const VideoView({Key? key, required this.textureId}) : super(key: key); override _VideoViewState createState() _VideoViewState(); } class _VideoViewState extends StateVideoView { override Widget build(BuildContext context) { return Texture( textureId: widget.textureId, filterQuality: FilterQuality.medium, ); } }4.2 通话控制逻辑实现完整的通话状态管理class CallController { static const _channel MethodChannel(com.example/rtc); static Futureint createSurface() async { return await _channel.invokeMethod(createSurface); } static Futurevoid startCall(String peerId) async { final localTextureId await createSurface(); await _channel.invokeMethod(startCall, { peerId: peerId, surfaceId: localTextureId }); } static Futurevoid endCall() async { await _channel.invokeMethod(endCall); } }5. 性能优化技巧在实际测试中我们总结了以下优化点分辨率动态调整弱网环境下自动降级到320p使用MediaCodec.CONFIGURE_FLAG_ENCODE动态调整参数帧率控制// 根据网络状况调整帧率 if (networkQuality POOR) { camera-SetFrameRate(10); } else { camera-SetFrameRate(24); }音频优先策略网络拥塞时保持音频传输视频帧使用IDR帧请求快速恢复6. 典型问题解决方案问题1Flutter纹理与OHOS Surface绑定失败解决方案确保NAPI线程与UI线程同步检查ohos.permission.CAMERA权限是否获取验证Surface格式是否匹配通常使用IMAGE_PIXEL_FORMAT_RGBA_8888问题2设备发现与连接使用OpenHarmony的分布式能力实现设备发现void discoverDevices() { DistributedDeviceManager.registerDeviceListCallback((devices) { setState(() { _availableDevices devices.where((d) d.type pad).toList(); }); }); }7. 进阶功能扩展对于企业级应用可以考虑添加多路通话使用AVSessionManager管理多个会话实现简单的MCU混流逻辑屏幕共享// 在OHOS端 auto screenSource MediaSource::CreateScreenCapture(); screenSource-SetFrameRate(5);通话录制使用MediaRecorder同步保存音视频流实现pause/resume录制功能在实际项目中我们发现OpenHarmony的原生媒体栈相比Android有更低的延迟表现在相同硬件条件下端到端延迟可降低30-50ms。特别是在教育场景中这种低延迟特性显著提升了互动体验。

相关文章:

手把手教你用Flutter和OpenHarmony 4.0搭建一个离线视频通话App(附完整源码)

Flutter与OpenHarmony 4.0离线视频通话开发实战 在企业内部通信、教育机构互动等需要数据完全本地化的场景中,离线视频通话功能正成为刚需。本文将带你从零开始,基于Flutter框架和OpenHarmony 4.0原生能力,构建一个完全不依赖云服务的端到端视…...

RT-DETR Decoder里的‘去噪’与‘软标签’:加速训练收敛的实战技巧

RT-DETR Decoder里的‘去噪’与‘软标签’:加速训练收敛的实战技巧 在目标检测领域,RT-DETR凭借其出色的实时性能和检测精度,正逐渐成为工业界和学术界的热门选择。然而,许多实践者在模型训练过程中常常遇到收敛速度慢、训练不稳定…...

图书管理系统(增删改查,附源码,包含数据库交互以及图形化界面)

前言:本文旨在用面向对象的思想编程实现图书管理系统,功能包括增删改查,完整源码放在文末,大家有需自取,一共3个版本: 1.0版本:基础的Java单机程序2.0版本:提供了web图形化页面&…...

Qt Windows自定义GUI界面自动化测试——uiautomatio通过树节点属性定位控件

Qt Windows自定义GUI界面自动化测试 提示:点击链接跳转其他相关文章 Windows自定义GUI界面自动化测试框架选择 autoit uiautomatio基本使用 uiautomatio通过树节点属性定位控件 uiautomatio通过树节点属性定位控件Qt Windows自定义GUI界面自动化测试前言一、实现方式…...

仲景大语言模型:传承中医智慧的AI创新实践

仲景大语言模型:传承中医智慧的AI创新实践 【免费下载链接】CMLM-ZhongJing 首个中医大语言模型——“仲景”。受古代中医学巨匠张仲景深邃智慧启迪,专为传统中医领域打造的预训练大语言模型。 The first-ever Traditional Chinese Medicine large langu…...

[资料整理]魔法师传奇 MagicMayhem

魔法师传奇 Magic&Mayhem魔法师传奇中文站网站魔法师传奇2023版介绍魔法师传奇中文站网站 网站地址:魔法师传奇中文站 http://zb.l4d.top:1983/magic 备用链接:http://zb.my.to:1983/magic 论坛地址:魔法师传奇中文论坛 http://zb.l4d.t…...

Unity-URP-Outlines完全指南:7个实用技巧让你轻松实现专业级描边效果

Unity-URP-Outlines完全指南:7个实用技巧让你轻松实现专业级描边效果 【免费下载链接】Unity-URP-Outlines A custom renderer feature for screen space outlines 项目地址: https://gitcode.com/gh_mirrors/un/Unity-URP-Outlines 核心价值:为什…...

SwitchButton自定义样式完全教程:从基础到高级的完整指南

SwitchButton自定义样式完全教程:从基础到高级的完整指南 【免费下载链接】SwitchButton SwitchButton.An beautifullightweightcustom-style-easy switch widget for Android,minSdkVersion > 11 项目地址: https://gitcode.com/gh_mirrors/swi/SwitchButton …...

如何利用Clef Handbook进行有效会议管理:5个关键原则 [特殊字符]

如何利用Clef Handbook进行有效会议管理:5个关键原则 🚀 【免费下载链接】handbook An employee handbook built for inclusion 项目地址: https://gitcode.com/gh_mirrors/handbook6/handbook 在当今快节奏的工作环境中,高效会议管理…...

ABAP ALV负数导出到Excel后无法合计

对金额字段进行以下处理即可CALL FUNCTION BAPI_CURRENCY_CONV_TO_EXTERN_9EXPORTINGcurrency <fs_alv>-waersamount_internal <fs_alv>-dmbtrIMPORTINGamount_external lv_external.<fs_alv>-dmbtr lv_external....

5分钟快速解锁QQ音乐加密文件:qmc-decoder终极使用指南

5分钟快速解锁QQ音乐加密文件&#xff1a;qmc-decoder终极使用指南 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经在QQ音乐下载了喜欢的歌曲&#xff0c;却发现…...

python绘制智能网格天气预报产品

python绘制智能网格天气预报产品 1.产品说明 智能网格天气预报业务化下发产品包括&#xff1a; PRE/GUST/FOG/HZ/SNOW/TMAX/TMIN/VIS/R24/RH/CLOUD/TA/TMP/WIN/PRS/TCC/SAND/SOIL/SUNLIGHT/HOURS: 固定代码&#xff0c;表示产品内容是降水/阵风/雾/霾/积雪/最高气温/最低气温…...

学习记录:从零开始学AI(二)——Scikit-learn加州房价机器学习例子学习笔记:继续补全代码运行成功

后记&#xff1a;之前一直以为用的是TensorFlow&#xff0c;原来我用的是 Scikit-learn。两者都可以实现机器学习。前者更适合实现深度神经网络。更正题目。已经搭建好环境&#xff0c;开始学习加州房价机器学习例子&#xff0c;目标理解相关概念&#xff0c;掌握机器学习例子开…...

EcomGPT-中英文-7B电商模型在Vue.js前端项目中的集成:打造实时智能客服聊天组件

EcomGPT-中英文-7B电商模型在Vue.js前端项目中的集成&#xff1a;打造实时智能客服聊天组件 最近在做一个电商后台的升级项目&#xff0c;客户提了个需求&#xff0c;希望能在用户端和管理后台都加上一个智能客服&#xff0c;能实时回答商品咨询、订单状态这些常见问题。一开始…...

mysql 常用sql

# 导出除指定表外的所有数据 要在mysql bin目录下 cmd mysqldump -h 数据库地址 -u 用户名 -p 数据库 --ignore-table表名 --ignore-table表名 > output.sql# 追加5个表的结构 mysqldump -h 数据库地址 -u 用户名 -p --no-data 数据库 表名 表名 表名 表名 表名 >> o…...

多少家庭不是穷,是被面子慢慢拖垮的

——《清醒日常&#xff1a;隐形账本系列》 开篇你可能也经历过这样的时刻。婚礼现场灯光闪得人眼睛发花。你端着酒杯&#xff0c;一边笑着跟老同学说“恭喜恭喜”&#xff0c;一边脑子里飞快算着——这次随多少才不丢人&#xff1f;回家路上&#xff0c;你老婆小声问一句&…...

解决VirtualBox/VMware虚拟机在win10下运行ensp时AR启动卡死问题

未经授权&#xff0c;禁止转载&#xff01;1.环境准备与确认首先 &#xff0c;确认你的虚拟机是否是windows10&#xff0c;例如我的虚拟机操作系统如下&#xff1a;2.然后&#xff0c;确认你的环境是否正确&#xff0c;重点查看VirtualBox是否是"VirtualBox-5.2.44-139111…...

UBANTU安装Duckietown细节操作与错误记录

一&#xff0c;安装 1.虚拟机安装VM&#xff0c;安装UBUNTU系统&#xff0c;按照VMware虚拟机安装Ubuntu教程(超详细)_vmware安装ubuntu-CSDN博客 去操作就可以&#xff0c;绝对详细&#xff0c;而且不坑。 2.个人建议使用搜狗输入法。 3.打开系统文件夹 例如我的叫tuoni&a…...

终极揭秘:Bloaty的RangeMap数据结构如何实现精准二进制尺寸分析

终极揭秘&#xff1a;Bloaty的RangeMap数据结构如何实现精准二进制尺寸分析 【免费下载链接】bloaty Bloaty: a size profiler for binaries 项目地址: https://gitcode.com/gh_mirrors/bl/bloaty Bloaty是一款强大的二进制尺寸分析工具&#xff0c;能够帮助开发者深入了…...

HardSourceWebpackPlugin插件生态:ExcludeModulePlugin和ParallelModulePlugin深度解析

HardSourceWebpackPlugin插件生态&#xff1a;ExcludeModulePlugin和ParallelModulePlugin深度解析 【免费下载链接】hard-source-webpack-plugin 项目地址: https://gitcode.com/gh_mirrors/ha/hard-source-webpack-plugin HardSourceWebpackPlugin是Webpack生态中一款…...

我的编程启程之路

一、自我简绍我是一名大三数学专业学生&#xff0c;在学习一点Python后对于代码有了兴趣&#xff0c;从而开始依据网上的视频学习编程。二、编程目标短期内目标是学习c语言等去准备408备战2027考研争取上岸。长期目标是能够进入一个大厂工作。三、学习规划脚踏实地&#xff0c;…...

React-share源码架构揭秘:从TypeScript到Vite构建的完整技术栈

React-share源码架构揭秘&#xff1a;从TypeScript到Vite构建的完整技术栈 【免费下载链接】react-share Social media share buttons and share counts for React 项目地址: https://gitcode.com/gh_mirrors/re/react-share React-share是一个功能强大的React社交媒体分…...

Lepton AI农业监测:作物生长分析服务构建实践

Lepton AI农业监测&#xff1a;作物生长分析服务构建实践 【免费下载链接】leptonai A Pythonic framework to simplify AI service building 项目地址: https://gitcode.com/gh_mirrors/le/leptonai Lepton AI是一个Pythonic框架&#xff0c;专为简化AI服务构建而设计&…...

提升效率:用快马生成自动化工具批量处理战网更新睡眠问题

最近在游戏开发测试过程中&#xff0c;经常遇到战网更新服务进入睡眠模式的问题。每次手动唤醒不仅耗时&#xff0c;还容易遗漏步骤。经过多次实践&#xff0c;我总结出一套自动化处理方案&#xff0c;显著提升了工作效率。下面分享具体实现思路和工具设计要点。 后台监控模块设…...

终极Mach-O文件分析指南:使用Bloaty深度剖析苹果应用大小

终极Mach-O文件分析指南&#xff1a;使用Bloaty深度剖析苹果应用大小 【免费下载链接】bloaty Bloaty: a size profiler for binaries 项目地址: https://gitcode.com/gh_mirrors/bl/bloaty Bloaty是一个强大的二进制文件大小分析工具&#xff0c;专门用于深度剖析可执行…...

Dankoe新作《使命与收益》读书笔记11|一人公司,不是找风口,是成为解决问题的人

你有没有过这种感觉—— 市场在变&#xff0c;AI在变&#xff0c;流量规则在变&#xff0c;你每天盯着行业动态&#xff0c;生怕错过什么风口。但越盯越焦虑&#xff0c;越焦虑越没有行动。 Dan Koe在《使命与收益》这最后的一个章节告诉我们一个事实&#xff1a; "有两…...

终极指南:3步永久解密科学文库PDF文档,告别7天访问限制

终极指南&#xff1a;3步永久解密科学文库PDF文档&#xff0c;告别7天访问限制 【免费下载链接】ScienceDecrypting 破解CAJViewer带有效期的文档&#xff0c;支持破解科学文库、标准全文数据库下载的文档。无损破解&#xff0c;保留文字和目录&#xff0c;解除有效期限制。 …...

终极Zotero中文文献管理指南:茉莉花插件让效率提升80%

终极Zotero中文文献管理指南&#xff1a;茉莉花插件让效率提升80% 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件&#xff0c;用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 在学术研究中&a…...

Android系统栏透明模式终极指南:如何实现沉浸式UI设计

Android系统栏透明模式终极指南&#xff1a;如何实现沉浸式UI设计 【免费下载链接】SystemBarTint [DEPRECATED] Apply background tinting to the Android system UI when using KitKat translucent modes 项目地址: https://gitcode.com/gh_mirrors/sy/SystemBarTint …...

从隔离菜谱到通用烹饪指南:Cook用户体验设计的完整演进之路

从隔离菜谱到通用烹饪指南&#xff1a;Cook用户体验设计的完整演进之路 【免费下载链接】cook &#x1f372; 好的&#xff0c;今天我们来做菜&#xff01;OK, Lets Cook! 项目地址: https://gitcode.com/gh_mirrors/co/cook 在数字化时代&#xff0c;烹饪应用已成为厨房…...