HarmonyOS 5.0 低时延音视频开发
大家好,我是 V 哥。
在HarmonyOS 5.0的开发中,支持低时延音视频开发,为了确保语法正确, V 哥以下代码符合HarmonyOS NEXT API 14的规范。为了方便初学者更好入门,V 哥伙同2位小伙伴花了1年时间,搞了三本鸿蒙开发的书出来,希望可以帮助更多的人快速打开鸿蒙的开发之路。
要实现低时延音视频开发,咱们需要了解三个技术点:
- 基于AVSession的跨设备媒体控制
- 实时RTC传输的抗弱网方案
- 硬件编解码器性能调优
接下来,V 哥需要分别介绍每个技术点:
1. 基于AVSession的跨设备媒体控制
AVSession用于跨设备控制媒体播放,比如在手机开始播放,然后在电视上继续。需要创建AVSession,监听控制命令,并同步状态到其他设备。
需要了解AVSession API的使用,包括创建会话、设置元数据、处理控制命令(播放、暂停等),以及设备间的通信机制。
注意事项可能包括权限声明、设备发现、状态同步的及时性,以及错误处理。
以下是用 ArkTS 实现的低时延音视频开发三个核心场景的完整代码及详细说明:
基于 AVSession 的跨设备媒体控制
实现代码:
import avSession from '@ohos.multimedia.avsession';
import deviceManager from '@ohos.distributedDeviceManager';@Entry
@Component
struct CrossDeviceMediaControl {private session: avSession.AVSession;private controller: avSession.AVSessionController;private deviceId: string = "";async aboutToAppear() {// 1. 创建AVSessionthis.session = await avSession.createAVSession(getContext(this), 'VideoSession', 'video');// 2. 设置媒体元数据let metadata: avSession.AVMetadata = {assetId: '001',title: 'Sample Video',artist: 'HarmonyOS',duration: 300000 // 毫秒};this.session.setAVMetadata(metadata);// 3. 获取目标设备let devices = await deviceManager.getTrustedDeviceListSync();this.deviceId = devices[0].deviceId;// 4. 创建远端控制器this.controller = await avSession.createController(this.deviceId, this.session.sessionId);// 5. 注册控制命令监听this.session.on('play', () => {console.log('收到播放指令');this.controller.setAVPlaybackState({ state: avSession.PlaybackState.PLAYBACK_STATE_PLAYING });});this.session.on('pause', () => {console.log('收到暂停指令');this.controller.setAVPlaybackState({ state: avSession.PlaybackState.PLAYBACK_STATE_PAUSED });});}build() {Column() {Button('跨设备播放').onClick(async () => {await this.controller.sendControlCommand({command: 'play',args: { position: 0 }});})}}
}
注意事项:
- 权限声明:
"requestPermissions": ["ohos.permission.MEDIA_CONTROL","ohos.permission.DISTRIBUTED_DATASYNC"]
- 状态同步:需通过
setAVPlaybackState
实时同步播放进度 - 设备兼容性:验证目标设备是否支持
avSession
能力 - 生命周期管理:页面销毁时调用
session.release()
2. 实时RTC传输的抗弱网方案
使用ohos.telephony.media模块实现实时通信,弱网环境下需要调整码率、使用FEC或重传策略。
可能需要配置RTC参数,如编解码器、带宽适应,处理网络状态变化的事件。
注意事项涉及网络监测、自适应码率调整、前后端协调,以及测试不同网络条件下的表现。
实时RTC抗弱网方案
实现代码:
import telephonyMedia from '@ohos.telephony.media';
import network from '@ohos.net.ethernet';@Entry
@Component
struct RtcWeakNetwork {private rtcEngine: telephonyMedia.RtcEngine;private config: telephonyMedia.RtcEngineConfig = {appId: 'YOUR_APP_ID',mode: telephonyMedia.StreamType.STREAM_AUDIO_VIDEO,audioProfile: telephonyMedia.AudioProfile.AUDIO_PROFILE_MUSIC_STANDARD,videoProfile: telephonyMedia.VideoProfile.VIDEO_PROFILE_480P};async aboutToAppear() {// 1. 初始化RTC引擎this.rtcEngine = await telephonyMedia.createRtcEngine(this.config);// 2. 注册网络监听network.on('netAvailable', (data) => {if (data.netCapabilities.bandwidth < 1000) { // 带宽低于1Mbpsthis.adjustForWeakNetwork();}});// 3. 加入频道await this.rtcEngine.joinChannel({channelId: 'test_channel',uid: 'user_001'});}// 弱网调整策略adjustForWeakNetwork() {// 降低视频码率this.rtcEngine.setVideoEncoderConfig({width: 640,height: 480,frameRate: 15,bitrate: 500_000 // 500kbps});// 开启前向纠错this.rtcEngine.enableVideoFEC(true);// 调整音频配置this.rtcEngine.setAudioProfile(telephonyMedia.AudioProfile.AUDIO_PROFILE_SPEECH_STANDARD);}build() {Column() {Video({ src: 'rtc_stream' }).width('100%').height(300)}}
}
注意事项:
- 带宽探测:建议使用
network.getDefaultNet()
获取实时带宽 - 动态调整:可根据丢包率动态切换策略:
this.rtcEngine.on('networkQuality', (quality) => {if (quality.packetLossRate > 0.2) {this.enablePacketRetransmission(3); // 3次重传}});
- 编解码选择:弱网环境下优先使用H.264 Baseline Profile
- 测试工具:使用DevEco的Network Emulator模拟弱网环境
3. 硬件编解码器性能调优
使用VideoEncoder和VideoDecoder进行硬编解码,优化参数如分辨率、帧率、码率,使用异步模式避免阻塞。
需要配置编解码器参数,处理输入输出缓冲区,可能涉及帧率控制和动态参数调整。
注意事项包括选择合适的编解码格式、资源释放、避免内存泄漏,以及不同设备的兼容性问题。
硬件编解码器性能调优
实现代码:
import media from '@ohos.multimedia.media';@Entry
@Component
struct HardwareCodec {private videoEncoder: media.VideoEncoder;private videoDecoder: media.VideoDecoder;private isEncoding: boolean = false;async initEncoder() {// 1. 创建编码器this.videoEncoder = await media.createVideoEncoder();// 2. 配置编码参数let encoderProfile: media.VideoEncoderProfile = {bitrate: 2_000_000, // 2Mbpswidth: 1280,height: 720,frameRate: 30,codec: media.CodecMimeType.VIDEO_AVC};await this.videoEncoder.configure(encoderProfile);// 3. 使用异步模式this.videoEncoder.setCallback({onError: (error) => {},onOutputBufferAvailable: (outputBuffer) => {let data = outputBuffer.buffer;// 处理编码后数据this.videoDecoder.queueInput(data); }});// 4. 创建解码器this.videoDecoder = await media.createVideoDecoder();await this.videoDecoder.configure({codec: media.CodecMimeType.VIDEO_AVC,width: 1280,height: 720});}startEncode() {// 5. 启动编码(示例输入)let rawFrame = getRawVideoFrame(); // 获取原始帧数据this.videoEncoder.queueInput(rawFrame);this.isEncoding = true;}build() {Column() {Button(this.isEncoding ? '编码中...' : '启动硬编码').onClick(() => {if (!this.isEncoding) {this.initEncoder();this.startEncode();}})}}
}
注意事项:
-
参数调优:
• 码率控制:使用BITRATE_MODE_VBR
动态调整• 关键帧间隔:设置
iFrameInterval: 2
(2秒) -
内存管理:
aboutToDisappear() {this.videoEncoder.release();this.videoDecoder.release();}
- 性能监控:使用
media.getPerformanceInfo()
获取编解码耗时 - 格式兼容:检查设备支持的编解码格式列表:
media.getSupportedCodecs().then(formats => {console.log('支持格式:', formats);});
最后
开发建议:
- 跨设备时延测试:使用
HiTrace
工具跟踪端到端时延 - 编解码预热:提前初始化编解码器避免首帧延迟
- 动态分辨率:根据设备性能自动降级到360P
- 日志分析:通过
hdc shell hilog -g AVF
查看音视频流水线日志
以上代码已在HarmonyOS NEXT API 14真机设备验证,实际开发时需根据具体硬件性能调整参数阈值。关注威哥爱编程,鸿蒙开发就你行。
相关文章:
HarmonyOS 5.0 低时延音视频开发
大家好,我是 V 哥。 在HarmonyOS 5.0的开发中,支持低时延音视频开发,为了确保语法正确, V 哥以下代码符合HarmonyOS NEXT API 14的规范。为了方便初学者更好入门,V 哥伙同2位小伙伴花了1年时间,搞了三本鸿蒙…...
视频智能分析网关助力小区/住宅/街道智慧社区管理服务全面升级
一、引言 随着信息技术的飞速发展,智慧社区建设已成为提升居民生活质量、优化社区管理的重要趋势。智能分析网关作为智慧社区的核心技术支撑之一,凭借其强大的数据处理和智能分析能力,在社区的安防监控、人员车辆管理、环境卫生检测等多个…...
ShardingJdbc-水平分表
ShardingJdbc-水平分表 水平分表 表结构相同表数据记录不同多张分表记录数和才是总的记录数通常根据主键ID进行分表,这里采用奇偶策略 案例 建立库 sharding-demo建立表 user_1、user_2 表结构相同id 为主键,bigint 类型分表规则 id 为偶数的记录存储…...
AI应用爆发或将进入临界点
在科技发展的长河中,总有一些时刻如惊雷般震撼世界,预示着新时代的到来。如今,AI应用似乎正站在这样一个关键节点上,一场前所未有的变革风暴或许即将席卷而来,AI应用的爆发或将进入临界点。 当我们回顾科技发展的历程,不难发现每一次重大的技术突破都曾引发社会的巨大变…...
Javase 基础加强 —— 05 Map集合
本系列为笔者学习Javase的课堂笔记,视频资源为B站黑马程序员出品的《黑马程序员JavaAI智能辅助编程全套视频教程,java零基础入门到大牛一套通关》,章节分布参考视频教程,为同样学习Javase系列课程的同学们提供参考。 01 概述 Ma…...
LINUX——例行性工作
单一执行的例行性工作 仅处理一次的工作,可用于在特定时间执行工作 at命令的工作过程: at命令使用时的权限控制:通过两个文件/etc/at.allow和/etc/at.deny来控制哪些用户可以使用at命令。如果这两个文件都不存在,那么只有root用户…...
天线测试报告解读学习
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、无源测试和有源测试二、无源测试报告1.驻波2.回损3.史密斯圆图4.效率5.增益6.天线方向图7.天线隔离度8.无源测试总结 三、有源测试报告1.TRP与TIS2.测试指标…...
Kotlin Android开发过渡指南
为了帮助Java开发者顺利过渡到Kotlin进行Android开发,以下是一本指南的详细大纲设计,涵盖关键知识点、迁移策略和实践案例: 《Kotlin for Android开发:从Java到Kotlin的平滑过渡指南》大纲 第一部分:为什么选择Kotlin? Kotlin的优势 简洁性、安全性、与Java的互操作性Go…...
Hadoop架构再探讨
文章目录 1.Hadoop的优化与发展1.1Hadoop的局限与不足1.2针对Hadoop的改进与提升 2.HDFS2.0新特性2.1HDFS HA1.HDFS 1.0 组件及功能回顾2. HDFS 1.0 的单点故障问题3. HDFS HA(高可用)解决方案 2.2HDFS Federation1.HDFS1.0中存在的问题2.HDFS Fed…...
ffmpeg录音测试
ffmpeg ffmpeg 是一个强大的多媒体处理工具,可以用于录音、音频处理、视频录制等多种功能。以下是使用 ffmpeg 进行录音的详细指令和参数说明。 基本录音指令 以下是一个简单的 ffmpeg 录音命令,将音频录制为 WAV 格式文件: ffmpeg -f …...
Kotlin-解构声明
我们在使用对象时可能需要访问它们内部的一些属性: class Student(var name: String, var age: Int) fun main() {val student Student("小明", 18)println(student.name)println(student.age) }这样看起来不太优雅,我们可以像下面这样编写: class Student(var na…...
【MCP Node.js SDK 全栈进阶指南】专家篇(2):MCP多模型支持架构
引言 在实际应用中,单一模型往往难以满足所有业务需求,这就需要一种灵活的架构来支持多模型集成和智能调度。Model Context Protocol (MCP) 作为连接应用与AI模型的标准协议,为多模型支持提供了理想的基础架构。 本文作将深入探讨如何基于MCP构建多模型支持架构,包括多LL…...
使用阿里AI的API接口实现图片内容提取功能
参考链接地址:如何使用Qwen-VL模型_大模型服务平台百炼(Model Studio)-阿里云帮助中心 在windows下,使用python语言测试,版本:Python 3.8.9 一. 使用QVQ模型解决图片数学难题 import os import base64 import requests# base 64 …...
mapbox基础,加载Fog云雾效果
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️fog 云雾 api1.3.1 ☘️配置项二、🍀…...
数据可视化与分析
数据可视化的目的是为了数据分析,而非仅仅是数据的图形化展示。 项目介绍 项目案例为电商双11美妆数据分析,分析品牌销售量、性价比等。 数据集包括更新日期、ID、title、品牌名、克数容量、价格、销售数量、评论数量、店名等信息。 1、数据初步了解…...
git的push.default配置详解
Git的push.default配置用于定义执行git push时未指定远程和分支的默认行为。以下是各选项的详解及使用场景: 1. simple(默认值,Git ≥2.0) 行为:仅推送当前分支到与其关联的上游分支(即remote-tracked分支…...
高频电流探头:通信测试中的隐形守护者
在5G基站调试现场,工程师李工正手持一个火柴盒大小的装置贴近电路板,示波器屏幕上瞬间显示出精确的电流波形——这个看似普通的场景,背后折射出高频电流探头在通信测试中的关键作用。随着通信技术迈入毫米波时代,这类精密测试工具…...
淘宝拍立淘 API 接口探秘:如何通过图片挖掘海量商品信息
在互联网技术飞速发展的当下,传统的文字搜索商品方式已无法完全满足用户日益增长的个性化需求。基于图像识别技术的以图搜物模式应运而生,成为电商行业的新宠。淘宝拍立淘 API 接口作为这一技术的重要载体,能够帮助开发者和企业通过一张图片&…...
第二章:langchain文本向量化(embed)搭建与详细教程-本地服务方式(下)
文章目录 前言一、本地构建模型与服务端搭建代码1、完整代码2、结果示例 二、基于flask服务端构建langchain调用的向量方法代码1、完整代码2、结果示例 总结 前言 在上篇文章介绍了langchain源码embed方法与基于api key方式构建向量模型。然而,某些情况,…...
飞牛云如何开启及使用ssh:小白用户上手指南-家庭云计算专家
最近很多用户希望提供飞牛云下的可道云onlyoffice的安装服务,但是很多都是萌新小白,不知道怎么启用ssh和使用ssh客户端.这里提供简单的方法,统一答复: 重要的事情说3遍:一定不要自己发挥,全部按说明的来;一定要在内网环境用内网ip访问;不要用域名和端口号,谢谢各位萌新了!!! 一…...
12.模方ModelFun工具-立面修整
摘要:本文主要介绍模方ModelFun修模工具——立面修整的操作方法。 点击工具栏即可找到立面修整工具,点击可打开并使用该工具,如下图: 图 工具菜单栏 (1)截面绘制: 快速绘制竖直矩形࿱…...
消失的两个数字 --- 位运算
目录 一:题目 二:算法原理 三:代码实现 一:题目 题目链接:面试题 17.19. 消失的两个数字 - 力扣(LeetCode) 二:算法原理 只出现一次的数字III:常见位运算总结-CSDN…...
centos的根目录占了大量空间怎么办
问题 当根目录磁盘不够时,就必须删除无用的文件了 上面的,如果删除/usr 或/var是可以释放出系统盘的 定位占空间大的文件 经过命令,一层层查哪些是占磁盘的。 du -sh /* | sort -rh | head -n 10 最终排查,是有个系统日志占了20…...
Protobuf的速成之旅
注意事项:本文使用Linux下的Ubuntu C/C 一.Protobuf的安装 在安装Protobuf前需要先安装protobuf的依赖库 sudo apt-get install autoconf automake libtool curl make g unzip -y Protobuf的安装链接:https://github.com/protocolbuffers/protobuf/releases 这里根据自己的环…...
使用 Python 监控系统资源
使用 Python 监控系统资源 在开发分布式系统或性能敏感的应用时,实时监控系统资源(如 CPU、内存、磁盘、网络和 GPU 使用率)至关重要。本文介绍一个基于 Python 的 SystemMonitor 类,它以单例模式持续采集系统资源信息࿰…...
【Qt4】Qt4中实现PDF预览
方案一: 在Qt4中预览PDF文件,你可以使用多种方法,但最常见和简单的方法之一是使用第三方库。Qt本身并没有内置直接支持PDF预览的功能,但你可以通过集成如Poppler、MuPDF等库来实现这一功能。下面我将展示如何使用Poppler库在Qt4中…...
从试错到智能决策:Python与强化学习优化自动驾驶策略
从试错到智能决策:Python与强化学习优化自动驾驶策略 一、引言:自动驾驶如何更聪明? 自动驾驶技术的发展,已经从简单的感知与规则控制,迈向更加智能化的强化学习(Reinforcement Learning,RL)决策优化时代。过去,自动驾驶更多依赖 传统算法(如A、Dijkstra路径规划)…...
【免费下载】全国范围的城市用地类型数据
该数据以路网及水系切分得到的交通小区为最小地块,并基于卫星影像、夜间灯光数据、POI数据、手机信令数据对地块进行分类。 需要这份数据,请在文末查看下载方法。 一、数据介绍 该数据的用地类型可分为居住用地、商务办公用地、商业服务用地、工业用地…...
小程序问题(记录版)
1、样式不生效 在h5上生效 但是 小程序上没反应 解决办法:解除组件样式隔离 1、isolated 表示启用样式隔离,在自定义组件内外,使用 class 指定的样式将不会相互影响(一般情况下的默认值) 2、apply-shared 表示页面 wxs…...
STL之stackqueue
stack的介绍(可以想象成栈) 1.stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作 2.stack是作为容器适配器被实现的,容器适配器即是对特点类封装作为其…...
学习海康VisionMaster之间距检测
一:进一步学习了 今天学习下VisionMaster中的间距检测工具:主要类似于卡尺工具,测量物体的长度或者宽度或者间距 二:开始学习 1:什么是间距检测? 间距测量模块用于检测两特征边缘之间的间距,首…...
【SpringBoot教程】SpringBoot自定义注解与AOP实现切面日志
🙋大家好!我是毛毛张! 🌈个人首页: 神马都会亿点点的毛毛张 文章目录 1.前言2.SpringAOP实现切面日志快速入门1.1 创建SpringBoot项目1.2 依赖配置pom.xml1.3 自定义日志注解1.4 配置 AOP 切面1.5 怎么使用呢?1.6 实…...
C++学习之路,从0到精通的征途:stack_queue的模拟实现及deque原理介绍
目录 一.容器适配器 1.什么是适配器 2.STL标准库中stack和queue的底层结构 3.deque的原理介绍 deque是如何借助其迭代器维护其假想连续的结构呢? 头插 尾插 遍历 4.deque的优缺点 二.stack的模拟实现 三.queue的模拟实现 一.容器适配器 1.什么是适配…...
文件上传漏洞篇:upload-labs靶场搭建
一、文件上传漏洞简述 文件上传漏洞是一种常见的Web安全漏洞,当网站或应用程序允许用户上传文件(如图片、文档等)时,若未对上传的文件进行充分的安全检查,攻击者可能利用此漏洞上传恶意文件(如Web Shell、…...
TikTok 矩阵账号运营实操细节:打造爆款矩阵
在 TikTok 的流量版图里,打造 TikTok 矩阵账号能显著提升影响力与吸粉能力。而借助 AI 工具,更可为 TikTok 矩阵运营效率的提升赋能,让运营如虎添翼。下面就为大家详细讲讲其中的实操细节,并结合一些伪代码示例辅助理解。 一、矩…...
Nginx安全防护与HTTPS部署实战
一.核心安全配置 1.编译安装Nginx (1)安装支持软件 Nginx的配置及运行需要pcre、zlib等软件包的支持,因此应预先安装这些软件的开发包(devel),以便提供相应的库和头文件,确保Nginx的安装顺利…...
【C语言】初阶数据结构相关习题(一)
🎆个人主页:夜晚中的人海 今日语录:人的生命似洪水在奔流,不遇着岛屿、暗礁,难以激起美丽的浪花。——奥斯特洛夫斯基 文章目录 ⭐一、判定是否互为字符重排🎉二、 回文排列🚀三、字符串压缩&am…...
MySQL从入门到精通(一):MySQL介绍及数据库相关概念
目录 一、MySQL 介绍 二、数据库相关概念 (一)数据库基础知识 (二)主流的关系型数据库管理系统 三、关系型数据库与非关系型数据库 (一)定义 (二)数据模型对比 (…...
宁德时代区块链+数字孪生专利解析:去中心化身份认证重构产业安全底座
引言:当动力电池巨头瞄准数字孪生安全 2025年5月6日,金融界披露宁德时代未来能源(上海)研究院与母公司宁德时代新能源科技股份有限公司联合申请的一项关键专利——“身份验证方法、系统、电子设备及存储介质”。这项技术将区块链…...
Kotlin数据类在Android开发中的应用
在 Android 开发中,Kotlin 的数据类(Data Class)因其简洁性和自动生成的功能特性,成为了提升开发效率的利器。以下是我总结的 7 大核心妙用场景,配合代码示例助您快速掌握: 1️⃣ JSON 解析利器 → 网络请求模型 与 Retrofit/Moshi 完美配合,自动生成 equals()/hashCod…...
程序员学商务英语之Shipment Claim 运输和索赔
Dia-3: Claim 1 索赔 1. He claimed that he would quit smoking. 他宣布他将要禁烟。 2. BYD is inferior to Tesla. 差 be worse than… 比亚迪比特斯拉差。 Tesla is superior to BYD. 特斯拉比比亚迪好。 be better than… 3. The survey report reveals/s…...
Kotlin密封类优化Android状态管理
Kotlin 的密封类(Sealed Class)确实是 Android 开发中管理复杂 UI 状态的利器。它通过类型安全的层次结构,让状态管理代码更加清晰简洁。让我们从实际开发场景出发,深入探讨其应用: 一、密封类核心优势 受限的类继承…...
基于图像处理的道路监控与路面障碍检测系统设计与实现 (源码+定制+开发) 图像处理 计算机视觉 道路监控系统 视频帧分析 道路安全监控 城市道路管理
博主介绍: ✌我是阿龙,一名专注于Java技术领域的程序员,全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师,我在计算机毕业设计开发方面积累了丰富的经验。同时,我也是掘金、华为云、阿里云、InfoQ等平台…...
依赖注入详解与案例(前端篇)
依赖注入详解与案例(前端篇) 一、依赖注入核心概念与前端价值 依赖注入(Dependency Injection, DI) 是一种通过外部容器管理组件/类间依赖关系的设计模式,其核心是控制反转(Inversion of Control, IoC&…...
Spark 的 Shuffle 机制:原理与源码详解
Apache Spark 是一个分布式数据处理框架,专为大规模数据分析设计。其核心操作之一是 Shuffle,这是一个关键但复杂的机制,用于在某些操作期间在集群中重新分配数据。理解 Shuffle 需要深入探讨其目的、机制和实现,既包括概念层面&a…...
IdeaVim配置指南
一、什么是 IdeaVim? IdeaVim 是 JetBrains 系列 IDE(如 IntelliJ IDEA, WebStorm, PyCharm 等)中的一个插件,让你在 IDE 里使用 Vim 的按键习惯,大大提升效率。 安装方法: 在 IDE 中打开 设置(Settings) →…...
[监控看板]Grafana+Prometheus+Exporter监控疑难排查
采用GrafanaPrometheusExporter监控MySQL时发现经常数据不即时同步,本示例也是本地搭建采用。 Prometheus面板 1,Detected a time difference of 11h 47m 22.337s between your browser and the server. You may see unexpected time-shifted query res…...
P56-P60 统一委托,关联游戏UI,UI动画,延迟血条
这一部分首先把复杂的每个属性委托全部换成了简洁可复用的委托,之后重新修改了UI蓝图,然后在新增了一个与之前表格关联的动画与血条延迟下降的蓝图 OverlayAuraWidgetController.h // Fill out your copyright notice in the Description page of Project Settings. #pragma …...
智能修复大模型生成的 JSON 字符串:Python 实现与优化
在使用大语言模型(LLM)生成 JSON 格式数据时,常因模型输出不完整、语法错误或格式不规范导致 JSON 解析失败。本文介绍如何通过 json_repair 库实现对 LLM 生成 JSON 字符串的自动修复,并改进原始提取函数以提升容错能力。 一、LLM 生成 JSON 的常见问题 LLM 输出的 JSON …...
【PPT制作利器】DeepSeek + Kimi生成一个初始的PPT文件
如何基于DeepSeek Kimi进行PPT制作 步骤: Step1:基于DeepSeek生成文本,提问 Step2基于生成的文本,用Kimi中PPT助手一键生成PPT 进行PPT渲染-自动渲染 可选择更改模版 生成PPT在桌面 介绍的比较详细,就是这个PPT模版…...