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

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

相关推荐
给算法爸爸上香18 小时前
yolo目标检测线程池高性能视频tensorrt推理(每秒1000+帧)
yolo·目标检测·音视频·线程池·tensorrt
大学生小郑18 小时前
sensor成像的原理
图像处理·音视频·视频
AI浩1 天前
学习语言驱动的序列级别模态不变表示用于视频可见光-红外行人重识别
学习·音视频
老陈聊架构1 天前
『AI视频创作』Remotion Skills 完全指南:用自然语言创作视频的革命
人工智能·音视频·skill·remotion
视频技术分享1 天前
2026年实时音视频服务选型深度解析
音视频·实时音视频·视频
三十_A2 天前
前端技术分享:基于 Canvas 实现视频帧截取与下载方案
前端·音视频
地狱为王2 天前
Unity使用NovaSR将沉闷的16kHz音频升频成清晰的48kHz音频
unity·游戏引擎·音视频·novasr
Dreams°1232 天前
进阶实战:Wan2.2-T2V-A5B 实现可点击跳转的互动式教育视频
算法·microsoft·ai·音视频
Coovally AI模型快速验证2 天前
YOLO26技术详解:原生NMS-Free架构设计与实现原理
人工智能·计算机视觉·开源·音视频·无人机
郭涤生2 天前
高斯滤波从入门到精通
linux·音视频