gpt4 book ai didi

带有 NVENC 和 DVB 字幕和叠加选项的 FFMPEG

转载 作者:行者123 更新时间:2023-12-04 22:55:29 28 4
gpt4 key购买 nike

您好我有一些关于 NVENC、DVB 潜艇和覆盖功能的问题。

我设法将 dvb 字幕刻录到输入视频,但我注意到这无法在 GPU 上完全执行,因为我使用的是 FFMPEG 的叠加功能,这只能通过软件实现。

当前代码 在应用覆盖之前将字幕缩放到 1920x1080。我注意到这比直接在视频上覆盖字幕使用更多的 CPU。问题是我想覆盖 中的字幕中底 .当前代码将字幕置于屏幕中央(有点烦人)

最终我想要一个完整的硬件转码选项(猜这是不可能的吗?是吗)

我想要在中心底部未缩放的字幕(cpu 负载减少 50%)
我希望字幕在中心底部缩放 50%(cpu 负载减少 30%),这使字幕更易读。

当前缩放到视频大小的字幕代码(如何完整的硬件转码?):

代码字幕未缩放但居中。如何更改为中底:

-hwaccel_device 4 -hwaccel cuvid -vcodec h264_cuvid -resize 1920x1080 -deint 2 -drop_second_field 1 -i 'http://stream' -filter_complex "[i:0x1389]hwdownload,format=nv12[base];[base][i:0x13ee]overlay=(main_w-overlay_w)/2:(main_h-overlay_h)/2[v];[v]hwupload_cuda[k]" -map "[k]" -map i:0x1393 -acodec libfdk_aac -b:a 96k -c:v h264_nvenc -gpu 4 -preset llhq -vprofile high -rc:v vbr -qmin:v 26 -qmax:v 32 -b:v 4M -maxrate 4M -bufsize 8M -threads 0 -r 25 -g 100 -f flv 'rtmp://127.0.0.1:8001/input/nvenctest.stream'

ffprobe 输出:
[mpegts @ 0x3786200] sub2video: using 1920x1080 canvas
[Parsed_showinfo_0 @ 0x3785340] config in time_base: 1/90000, frame_rate: 0/1
[Parsed_showinfo_0 @ 0x3785340] config out time_base: 0/0, frame_rate: 0/0
No information about the input framerate is available. Falling back to a default value of 25fps for output stream #0:0. Use the -r option if you want a different framerate.
Output #0, null, to 'pipe:':
Metadata:
encoder : Lavf58.3.100
Stream #0:0: Video: wrapped_avframe, bgra, 1920x1080, q=2-31, 200 kb/s, 25 fps, 25 tbn, 25 tbc
Metadata:
encoder : Lavc58.9.100 wrapped_avframe
[Parsed_showinfo_0 @ 0x3785340] n: 0 pts: 0 pts_time:0 pos: -1 fmt:bgra sar:0/1 s:1920x1080 i:P iskey:1 type:? checksum:00000000 plane_checksum:[00000000] mean:[0] stdev:[0.0]
[Parsed_showinfo_0 @ 0x3785340] n: 1 pts: 0 pts_time:0 pos: -1 fmt:bgra sar:0/1 s:1920x1080 i:P iskey:1 type:? checksum:00000000 plane_checksum:[00000000] mean:[0] stdev:[0.0]
[Parsed_showinfo_0 @ 0x3785340] n: 2 pts: 39599 pts_time:0.439989 pos: -1 fmt:bgra sar:0/1 s:1920x1080 i:P iskey:1 type:? checksum:00000000 plane_checksum:[00000000] mean:[0] stdev:[0.0]
[graph 0 input from stream 0:2 @ 0x37c9340] Changing frame properties on the fly is not supported by all filters.
Segmentation fault (core dumped)

最佳答案

要重新定位缩放的字幕,请提供 x 和 y 表达式:overlay=x=0:y=H/2
要重新定位未缩放的字幕,overlay=x=(W-w)/2:y=H-h-20 .

可以使用 OpenCL 覆盖过滤器,但它不会提供太多好处,因为字幕流仍然需要在软件中解码,并且上传/下载步骤会占用资源。

关于带有 NVENC 和 DVB 字幕和叠加选项的 FFMPEG,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51045003/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com