1 回答
TA贡献1744条经验 获得超4个赞
更新:事实证明问题是-ss需要时间而不是帧索引。
我试图重现这个问题,但它似乎对我有用。也许添加cmd.Stderr = os.Stderr以查看 ffmpeg 输出是否提供了线索。您还可以发布一个完全可运行的示例吗?
package main
import (
"bytes"
"image"
"log"
"os"
"os/exec"
_ "golang.org/x/image/bmp"
)
func main() {
cmd := exec.Command(
"docker", "run",
"--rm",
"mwader/static-ffmpeg",
"-ss", "5",
"-f", "lavfi",
"-i", "testsrc",
"-frames:v", "1",
"-f", "image2",
"-vcodec", "bmp",
"pipe:1",
)
var out bytes.Buffer
cmd.Stderr = os.Stderr
cmd.Stdout = &out
err := cmd.Run()
if err != nil {
log.Fatal(err)
}
img, imgFormat, imgErr := image.Decode(&out)
log.Printf("img.Bounds(): %#+v\n", img.Bounds())
log.Printf("imgFormat: %#+v\n", imgFormat)
log.Printf("imgErr: %#+v\n", imgErr)
}
- 1 回答
- 0 关注
- 160 浏览
添加回答
举报