ok113i平台——多媒体播放器适配

1. 视频播放支持

1.1 在Linux平台交叉编译ffmpeg动态库,详情查看《ok113i平台------交叉编译音视频动态库

提取如下动态库:

复制代码
libavcodec.so.58.134.100
libavdevice.so.58.13.100
libavfilter.so.7.110.100
libavformat.so.58.76.100
libavutil.so.56.70.100
libswresample.so.3.9.100
libswscale.so.5.9.100

实际程序运行时关联的动态库不是上面这些名字,但文件是上面这些,只需将名字改为如下即可:

复制代码
libavcodec.so.58
libavdevice.so.58
libavfilter.so.7
libavformat.so.58
libavutil.so.56
libswresample.so.3
libswscale.so.5

为什么改为这个名字?可以在Ubuntu下编译qt程序,得到可执行文件后,用ldd命令查看可执行程序的关联库;

接着再把这几个动态库放到开发板的/usr/lib中验证;

播放视频适配完成;

1.2 为了出厂系统就包含ffmpeg动态库,需要将上面的文件复制到如下目录:

/home/forlinx/OK113i-linux-sdk/platform/framework/auto/rootfs/usr/lib/

重新编译系统就能更新到系统镜像里;

1.3 问题

视频播放卡顿,因为cpu解码视频时导致cpu占用100%

2 音频播放支持

2.1 音频打开失败

报错信息: Couldn't set hardware audio parameters: Operation not permitted

gpt解释是:SDL2 可能会尝试设置的音频采样率与系统支持的采样率不兼容。尝试使用不同的采样率配置(例如 44100Hz 或 48000Hz)来创建音频设备。

解决方案:SDL_OpenAudioDevice调用时指定采样率为48000HZ,但是如果音频文件是其他采样率的,则声音会变;

声音会变的原因是重解码时采样次数计算错误了;将下面代码改一下就可以:

c 复制代码
    // 原始代码,采样次数计算错误
    int nb_samples = av_rescale_rnd(swr_get_delay(swrCtx, in_sample_rate) + aFrame->nb_samples, out_sample_rate, in_sample_rate, AV_ROUND_UP);
    // 更改后
    int nb_samples = aFrame->nb_samples;

上面采样次数计算错误的公式是gpt和文心一言都推荐的计算方法,且它在x86_64平台运行的很正常;在t113i就是会错误;

2.2 问题

报错信息:ALSA lib pcm.c:8424:(snd_pcm_recover) underrun occurred

当视频卡顿时,声音会一顿一顿的,此时就会这个报错。这就是由于卡顿导致的。只要不卡顿就不会有报这个错误信息;

相关推荐
EasyCVR1 天前
国标GB28181视频监控平台EasyCVR夏季安防高风险场景的解决方案
人工智能·音视频
学术头条1 天前
清华团队开源SCAIL-2:角色动画告别骨骼依赖,端到端还原视频中动作细节
人工智能·科技·机器学习·ai·开源·音视频·agi
做萤石二次开发的哈哈1 天前
AI 陪护机器人硬件如何接入萤石ERTC 实现实时通话?
人工智能·音视频·实时音视频·萤石开放平台
禹亮科技1 天前
上海临港100㎡大型跨国会议室音视频集成方案(思科Webex+思必驰AI音频)
人工智能·音视频·思必驰吸顶麦·禹亮科技
爱吃骨头的鱼儿1 天前
h264码流结构
音视频·h.264
大蚂蚁2号1 天前
深度解析:2026短视频批量生成底层技术、架构演进与企业落地实战
架构·音视频
sitellla1 天前
Pydub:用 Python 处理音频,不写废话
开发语言·python·其他·音视频
大蚂蚁2号2 天前
短视频批量生成技术深度解析与实战方案
python·aigc·音视频
chase。2 天前
【学习笔记】Unified World Models:基于视频-动作耦合扩散的机器人预训练新范式
笔记·学习·音视频