- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道之前有人问过这个问题,但我还找不到快速准确的解决方案,我想剪裁最长 15 秒的视频。到目前为止,这是我尝试过的方法,我正在使用此视频作为示例:http://www.sample-videos.com/video/mp4/720/big_buck_bunny_720p_30mb.mp4
最快的方法
这是迄今为止最快的方法,因为它不需要重新编码视频,但它在这个视频中非常不准确,因为关键帧是每 5-10 秒一次:
ffmpeg -i SampleVideo_1280x720_30mb.mp4 -ss 30 -to 50 -c copy -y out.mp4
以下是我如何检查此视频中的关键帧:
ffprobe -select_streams v -show_frames -show_entries frame=pict_type -of csv SampleVideo_1280x720_30mb.mp4 | grep -n I | cut -d ':' -f 1
通过这个命令,我发现第二个关键帧在第 211 帧,这意味着第一个关键帧和第二个关键帧之间有 210 帧,知道这是一个 25fps 视频,关键帧之间大约有 8 秒,所以1-8 秒之间的任何剪辑都会落入其中一个帧,这对于 15 秒的视频来说是一个巨大的差异。
准确的方法
这种方式是准确的,但需要重新编码视频:
ffmpeg -i SampleVideo_1280x720_30mb.mp4 -ss 30 -to 50 -preset ultrafast -y out.mp4
问题是这个命令需要超过 20 秒才能完成使用超快预设,在三星 Galaxy s6 edge plus 中,这在其他设备中可能会更多。
不过,如果我在 Instagram 中打开 SampleVideo_1280x720_30mb.mp4 并对其进行修剪,它们会在不到 2 秒的时间内得到准确的修剪。
我也尝试每秒强制关键帧,但它也需要重新编码视频并且会影响视频质量:
ffmpeg -i SampleVideo_1280x720_30mb.mp4 -force_key_frames "expr:gte(t,n_forced*1)" out.mp4
有人知道 Instagram 如何修剪视频或使用 FFMpeg 进行快速准确修剪的方法吗?
最佳答案
我想通了 Instagram 是做什么的,基本上没有办法更快更准确地修剪视频。因此,为了向用户展示预览,我执行了以下操作:
当用户移动拇指以设置新的剪切位置时,我会截取视频播放器显示的当前图像。
用微调器将一个与视频播放器大小相同的 ImageView 放在它上面,这样视频播放器就不再可见了。
将视频播放器静音并在用户所需位置之前寻找最近的关键帧。
从关键帧开始播放视频,并计算从关键帧到所需位置的时间。
隐藏 ImageView 并取消视频静音。
因此,在我用作示例的视频中,第一个关键帧在第 0 秒,第二个关键帧在第 8 秒。假设用户想在第二个 3 进行剪辑,那么我会寻找到第二个 0 的关键帧并等待 3 秒,然后取消静音并显示视频。这样,用户只需等待 3 秒即可看到预览。
当用户接受预览时,真正的修剪稍后在后台进程中进行。
关于android - 使用 FFmpeg Android 快速准确地修剪视频,如 Instagram,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37626341/
当然,您可以将剩余文件大小除以当前下载速度,但如果您的下载速度波动(而且它会波动),这不会产生很好的结果。有什么更好的算法可以产生更平滑的倒计时? 最佳答案 安exponential moving a
对于一个业余项目,我正在尝试对齐照片并创建 3D 图片。我基本上在一个钻机上有 2 个相机,我用来拍照。我会自动尝试以您获得 3D SBS 图像的方式对齐图像。 它们是高分辨率图像,这意味着需要处理大
当然,您可以将剩余的文件大小除以当前的下载速度,但如果您的下载速度波动(而且会波动),这不会产生很好的结果。什么是产生更平滑倒计时的更好算法? 最佳答案 安exponential moving ave
我有一个数据集,其中包含患有糖尿病和未患有糖尿病的人。我想使用这些数据训练一个模型来计算糖尿病状况未知的人的风险概率。我知道在培训中没有被诊断出糖尿病的人大多数都没有糖尿病,但很可能其中一些人可能患有
let parent = path[row-1] let child = path[row] let indexOfChild = matrix[parent.obje
我正在编写一些使用 Element.getBoundingClientRect 的代码(gBCR),加上内联样式更新,以执行计算。 这不适用于一般网站,我不关心或不感兴趣是否有“更好的 CSS 方式”
我有一个很大的 csv 文件,其中包含大量脏数据,我想通过消除所有不是绝对必要的值来稍微清理一下它。 Here是我正在谈论的文件。 它有以下组件: 网站,标题,开始日期,开始日期,雇主,地点,纬度,
有谁知道一个库,它为 Java 提供了一个错误不高于 1-2 毫秒的 Thread.sleep()? 我尝试了 sleep 、错误测量和 BusyWait 的混合,但在不同的 Windows 机器上我
UiApp有DateBox和 DateTimeFormat 对于那个类(class)。但是,不存在诸如 TimePicker 或 TimeBox 这样的东西,用户可以通过明确指定的方式(例如通过使用
因此,我使用 sklearn 的 svm.SVC 模块编写了一个程序来学习 mnist 数据集,出于某种原因,每当我计算其准确性为 100% 时。这似乎好得令人难以置信,这是预期的吗? from sk
我当前找到了 gpytorch ( https://github.com/cornellius-gp/gpytorch )。它似乎是将 GPR 集成到 pytorch 中的一个很棒的包。第一次测试也呈
我正在使用 QT Creator 5.9 创建一个简单的 Web 浏览器模型,我的 EditLine/Text Box 有问题: 1.如何在转到不同的网站/页面后自动更新显示的 URL 字符串。 2。
我在 Linux 上尝试 time -p 命令,我写了一些代码来浪费 CPU 周期: #include using namespace std; int main() { long int c;
亲爱的程序员/脚本编写者/工程师/其他人, 问题:我目前正在为 Android 3.2 平板电脑开发增强现实应用程序,但在获取准确的罗盘读数方面遇到一些问题。我需要确切地知道平板电脑所面向的 (z)
我最近一直在尝试了解 Apache Spark 作为 Scikit Learn 的替代品,但在我看来,即使在简单的情况下,Scikit 收敛到准确模型的速度也远远快于 Spark。例如,我使用以下脚本
如果不是,它的准确性如何? 我想在下载之前知道图片的大小。 最佳答案 HTTP Content-length header 是否格式错误?是的。 您是否应该相信它能公平地表示消息正文的大小?是的。 关
这是一个关于 ngram 线性回归的问题,使用 Tf-IDF(术语频率 - 逆文档频率)。为此,我使用 numpy 稀疏矩阵和 sklearn 进行线性回归。 使用一元语法时,我有 53 个案例和 6
对于某些给定的固定宽度,如何计算特定标签 (NSTextField) 中字符串的高度? 我用谷歌搜索了各种方法并尝试了 this method from Apple .它的工作原理,除了高度变成一行对
我是一名优秀的程序员,十分优秀!