使用讯飞tts+ffmpeg自动生成视频

article/2025/8/21 22:08:01

起因

某日,看到一个营销号的视频说做视频日进斗金,大意是用软件识别文章小说,搭配一些图片转换成自己的视频。看完当时脑海里冒出一个念头,我也可以,于是有了这番尝试。

方案
首先文字方面,我选择了【聚合数据的笑话接口】(www.juhe.cn/docs/api/id… 其次需要将文字转换为音频,我选择了【讯飞的语音合成】,因为其有Windows离线版SDK,修改了一些就可以根据需要使用了 最后是音频转视频方面,采用了【FFmpeg】,为视频添加了封面图与滚动字幕

使用脚本实现自动生成视频

准备笑话文本

将笑话文本复制保存到一个文本中即可

下载讯飞语音合成离线包

  • 需要注册并身份认证后在控制台下载,下载地址
  • 安装文档中使用vs运行samples中的解决方案(使用的是VS2010),若项目加载失败则升级下项目的框架版本:项目右键->重定向项目->安装最新版本即可。

为了能够在后续可以直接调用sdk,则根据需要改动此示例即可,此处改动了入参和退出。

重新生成后,找到外层bin目录下的exe,就可以直接使用tts_offline_sample hello.wav "hello word"调用程序合成文本音频到指定路径。

将bin和libs目录拷贝到需要的地方,或者将bin目录添加到环境变量中,就可以在任意地方使用了

现在已经使用tts生成了音频文件,接下来使用 ffmpeg 将音频转换为视频并且生成字幕即可得到一个新鲜出炉的视频了 ffmpeg下载地址 下载解压后将ffmpeg所在目录设置到环境变量,这样就可以在任意地方使用

生成视频

先从pixabay获取一个无版权的素材图片保存为 cover.jpg 作为封面,执行以下命令即可生成视频

ffmpeg -y -loop 1 -i cover.jpg -i hello.wav -c:v libx264 -c:a aac -b:a 192k -shortest hello.mp4

生成滚动字幕

创建一个content.txt文件,写入内容“hello word,你好世界” x,y为坐标,根据需要调整即可,fontfile设置为中文字体,不设置,中文将会乱码,执行命令后即可得到一个带滚动字幕的视频。

ffmpeg -y -i hello.mp4 -vf "drawtext=fontfile=C\\:/Windows/Fonts/msyh.ttc:fontcolor=ffcc00:fontsize=40:shadowx=2:shadowy=2:textfile=./content.txt:reload=1:y=h/5:x=w-(mod(8*n\,w+tw)-tw/100)"  -c:a copy hellofull.mp4

注意vf参数中的路径需要特殊处理,Replace("\\", "/").Replace(":", "\\:")

自此,技术点已经说明完毕,后续的就是一些优化和脚本的组合了。

图片转视频

注意:./ 为图片目录,且 img_ 为前缀,%03d 为格式( C语言中的格式化输出 %0nd ),不足3位长度的左补齐0,即必须为img_001,img_002这种格式,并且图片需要从第一张图片开始的序号开始依次排列,图片后缀与其格式需要一致。否则都不能成功 以下命令正确执行文件名需要为:img_001.png,img_002.png,img_003.png... -r 0.500 ,1/0.500= 2秒 一张图片显示 -y 覆盖生成的文件 ffmpeg -y -r 0.500 -i ./img_%03d.png ./output.mp4

完整脚本

set coverPath=F:\\Project\\JokeBox\\cover.jpg
set contentPath=F:\\Project\\JokeBox\\content.txt
set /P jokeContent=<%contentPath%
set videoName=video%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%
set outDic=F:\\Project\\JokeBox\\output\\%videoName%
set voicePath=%outDic%\\voice.wav
set videoPath=%outDic%\\video.mp4
set videoFullPath=%outDic%\\每日笑话-%date:~5,2%-%date:~8,2%.mp4
set srtPath=F\\:/Project/JokeBox/zimu.txtecho 音频:%voicePath% 
echo 视频:%videoPath%
echo 字幕:%srtPath%
echo 文本:%jokeContent%echo 创建输出目录
mkdir %outDic%echo 生成音频
tts_offline_sample.exe "%voicePath%" "%jokeContent%"echo 生成视频
ffmpeg -loop 1 -i %coverPath% -i %voicePath%  -c:v libx264 -c:a aac -b:a 192k -shortest %videoPath%echo 生成字幕
ffmpeg -y -i %videoPath% -vf "drawtext=fontfile=C\\:/Windows/Fonts/msyh.ttc:fontcolor=ffcc00:fontsize=40:shadowx=2:shadowy=2:textfile=%srtPath%:reload=1:y=h/5:x=w-(mod(8*n\,w+tw)-tw/100)"  -c:a copy %videoFullPath%copy %contentPath% %outDic%echo 移除音频视频
del %voicePath:\\=\%
del %videoPath:\\=\%pause

参考

  • FFmpeg
  • 讯飞离线语音合成

原文 使用讯飞tts+ffmpeg自动生成视频 - 掘金

★文末名片可以免费领取音视频开发学习资料,内容包括(FFmpeg ,webRTC ,rtmp ,hls ,rtsp ,ffplay ,srs)以及音视频学习路线图等等。

见下方!↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

 


http://chatgpt.dhexx.cn/article/R6qtWfsZ.shtml

相关文章

构建简单的智能客服系统(三)——基于 UniMRCP 实现讯飞 TTS MRCP Server

上一篇我们封装了科大讯飞接口实现了 UniMRCP ASR Plugin&#xff0c;这篇文章我们再简单说一下 TTS 的实现。 MRCP plugin 以下内容请参考《基于 UniMRCP 实现讯飞 ASR MRCP Server》&#xff1a; UniMRCP 的编译、安装运行UniMRCP plugin 的加载、调用流程UniMRCP plugin 的…

ROS语音交互系统_(2)利用讯飞TTS实现ROS下语音合成播报

前言 - Writing a Simple Publisher and Subscriber (C++) - ubuntu16.04外接音箱无声音 1、先前准备 (1)在~/catkin_ws/src目录下执行 $ catkin_create_pkg voice_system roscpp rospy std_msgs (2࿰

讯飞tts调用

目标&#xff1a;能在arm开发板上运行 拿到arm版本libmcs.so库后尝试集成到开发板&#xff0c;导入库后运行10102错误&#xff0c;查找官方错误码。 注意到官方给的例子有两个参数&#xff1a; const char* session_begin_params "engine_type local,voice_namexiaoya…

讯飞tts语音引擎_讯飞输入法A.I.语音引擎再升级 更强大更实用!

时代在进步,用手打字已OUT,眼下是语音的大时代。近日,讯飞输入法Android版和iOS版更新A.I.语音引擎,进一步优化通用语音识别效果,同时还基于说话人和使用场景,重点提升语音候选词、噪声环境、轻声说话及专有名词的识别准确率。正是科大讯飞技术创新、成果落地的真实投映。…

基于ROS2和科大讯飞的文字转语音TTS入门教程

基于ROS2和科大讯飞的语音转文字入门教程 基于ROS2和科大讯飞的文字转语音TTS入门教程1.环境搭建2.创建工程3.编译和执行 基于ROS2和科大讯飞的文字转语音TTS入门教程 本文将展示&#xff0c;如何利用ROS2和科大讯飞的TTS模块&#xff0c;实现简单的文字转语音功能。利用ROS2&…

巧用讯飞TTS进行文本合成语音(LINUX操作系统)

因为工作需要用到文本转语音文件&#xff0c;然后进行播放的应用场景。 我先后研究了三种开源的框架程序&#xff0c;festival、ekho和espeak。但实际运行后&#xff0c;效果很差&#xff0c;也没精力训练调试它们。 后来我突然想起来在科大讯飞是语音处理的老大&#xff0c;TT…

初探机器学习之使用讯飞TTS服务实现在线语音合成

最近在调研使用各个云平台提供的AI服务&#xff0c;有个语音合成的需求因此就使用了一下科大讯飞的TTS服务&#xff0c;也用.NET Core写了一个小示例&#xff0c;下面就是这个小示例及其相关背景知识的介绍。 一、什么是语音合成&#xff08;TTS&#xff09; 1.1 What is 语音合…

麒麟系统虚拟机安装教程

作者&#xff1a;朱金灿 来源&#xff1a;clever101的专栏 为什么大多数人学不会人工智能编程&#xff1f;>>> 1.首先得安装VM Ware软件。 2.打开VM Ware&#xff0c;点击“文件”->“新建虚拟机”。 3.进入新建虚拟机向导&#xff0c;点击下一步。如下图&…

史上最最详细的win10虚拟机安装教程,手把手从头到尾

史上最最详细的win10虚拟机安装教程 1.安装VMware 12Pro 前天我安装了VM12&#xff0c;并安装了win10系统的虚拟机。遇到了很多问题&#xff0c;我想拿出来和大家分享一下解决办法。 首先&#xff0c;第一步先上下载地址&#xff1a; VMware 12下载地址 大家下载时记得选择普…

虚拟机安装教程

虚拟机安装教程   vmware10虚拟机是个软件&#xff0c;安装后可用来创建虚拟机&#xff0c;在虚拟机上再安装系统&#xff0c;在这个虚拟系统上再安装应用软件&#xff0c;所有应用就像操作一台真正的电脑&#xff0c;因此&#xff0c;我们可以利用虚拟机学习安装操作系统、…

Fedora虚拟机安装教程

Fedora虚拟机安装教程 &#xff08;作者&#xff1a;Baron_wu 禁止转载&#xff09; 获取VMware14 链接&#xff1a; https://pan.baidu.com/s/1WQuajxl2KOtcn9WYendglQ 提取码&#xff1a;2K32获取Fedora安装镜像 64bit &#xff1a; https://download.fedoraproject.org/pu…

win10虚拟机安装教程

win10虚拟机安装 下载iso镜像文件win10镜像安装步骤拍摄快照 下载iso镜像文件 首先我们需要准备一个win10的iso镜像系统&#xff0c;下载地址&#xff1a;https://msdn.itellyou.cn/ 我们选择最新版本就可以了&#xff0c;选择consumer editions版本&#xff08;其实选择两个…

VMware16虚拟机安装教程

一、VMware下载 VMware下载地址&#xff1a;https://www.vmware.com/cn/products/workstation-pro/workstation-pro-evaluation.html 我的电脑是Windows电脑&#xff0c;所以选择Workstation 16 Pro for Windows下载&#xff0c;如果你的电脑事Linux系统&#xff0c;选择Work…

deepin虚拟机安装教程

deepinISO镜像&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1yzxtAetA9eccO6pNFO6wTg 提取码&#xff1a;az78 --来自百度网盘超级会员V5的分享 deepin是Linux内核的&#xff0c;里面附带办公软件&#xff0c;今天小编就在虚拟机上体验一波&#xff01;开车&#x…

CentOS7虚拟机安装教程

第一步&#xff1a;打开虚拟机找到创建新的虚拟机 第二步&#xff1a;进入向导选择典型 第三步&#xff1a;选择稍后添加操作系统 第四步&#xff1a;选择linux CentOS 7的版本 第五步&#xff1a;自定义虚拟机名称和安装地址 第六步&#xff1a;指定磁盘大小&#xff0c;默认选…

Ubuntu 20.04 虚拟机安装教程

首先你需要下载 VMware&#xff0c;建议不要放于C盘&#xff0c;不会下载的建议看 哔哩哔哩Frank。下载 Ubuntu 20.04 镜像&#xff0c;也是建议不放于C盘&#xff0c;我放在了 E:\Ubuntu 20.04 iso 完成上诉步骤&#xff0c;打开VMware&#xff0c;点击创建新的虚拟机。选择 自…

Linux虚拟机安装教程

一、虚拟机的创建 我们在工作中会需要用到Linux环境&#xff0c;但Linux系统毕竟没有Windows系统用起来顺手。处于这种考虑&#xff0c;我们可以在电脑上安装一个Linux虚拟机&#xff0c;在虚拟机上虚拟出一套电脑所需要的资源。现在就开始进行VMware的安装。 我们下载完VMw…

虚拟机安装(详细教程)

我这个主要是前期的下载安装&#xff0c;后面的操作大家可以参考VirtualBox 安装Kali linux最新版&#xff08;超详细&#xff09;_Jokong的博客-CSDN博客_virtualbox安装kali 这个作者写的超级详细&#xff0c;小白完全跟得上 目录 官网地址&#xff1a; VirtualBox6.1.3…

最强卸载神器,使你的Windows绝对干净

前言 Uninstall Tool 是一款超级强大的软件卸载工具&#xff0c;它完全可以替代您Windows自带的”添加/删除程序”功能&#xff0c;超强的卸载能力可以卸载您安装的任何第三方软件应用&#xff0c;也可卸载注册表相关项让你的系统更清洁干净&#xff0c;但它有一个更加强大的功…

2345文件粉碎,文件强力删除工具无捆绑纯净提取版

前言 对比起其余文件粉碎工具来说&#xff0c;这款速度更快&#xff0c;成功率也更高&#xff0c;还是不错的 这里提供无捆绑并且纯净的2345文件粉碎工具&#xff0c;除去AvShellExt64.dll和AvShellExt.dll修改过几处十六进制&#xff0c;其余都是软件原版文件&#xff0c;可…