[xcode] Use ffmpeg's "image2pipe" muxer instead of "image2"

With ffmpeg 4.3 it seems image2 no longer works for non-file output, so use
image2pipe instead.

Closes #1061
This commit is contained in:
ejurgensen 2020-07-19 23:52:42 +02:00
parent d0a7d5114b
commit e8bdcd2365

View File

@ -233,7 +233,15 @@ init_settings(struct settings_ctx *settings, enum transcode_profile profile, str
case XCODE_JPEG: case XCODE_JPEG:
settings->encode_video = 1; settings->encode_video = 1;
settings->silent = 1; settings->silent = 1;
// With ffmpeg 4.3 (> libavformet 58.29) "image2" only works for actual file
// output. It's possible we should have used "image2pipe" all along, but since
// "image2" has been working we only replace it going forward.
#if (LIBAVFORMAT_VERSION_MAJOR > 58) || ((LIBAVFORMAT_VERSION_MAJOR == 58) && (LIBAVFORMAT_VERSION_MINOR > 29))
settings->format = "image2pipe";
#else
settings->format = "image2"; settings->format = "image2";
#endif
settings->in_format = "mjpeg"; settings->in_format = "mjpeg";
settings->pix_fmt = AV_PIX_FMT_YUVJ420P; settings->pix_fmt = AV_PIX_FMT_YUVJ420P;
settings->video_codec = AV_CODEC_ID_MJPEG; settings->video_codec = AV_CODEC_ID_MJPEG;
@ -242,7 +250,12 @@ init_settings(struct settings_ctx *settings, enum transcode_profile profile, str
case XCODE_PNG: case XCODE_PNG:
settings->encode_video = 1; settings->encode_video = 1;
settings->silent = 1; settings->silent = 1;
// See explanation above
#if (LIBAVFORMAT_VERSION_MAJOR > 58) || ((LIBAVFORMAT_VERSION_MAJOR == 58) && (LIBAVFORMAT_VERSION_MINOR > 29))
settings->format = "image2pipe";
#else
settings->format = "image2"; settings->format = "image2";
#endif
settings->pix_fmt = AV_PIX_FMT_RGB24; settings->pix_fmt = AV_PIX_FMT_RGB24;
settings->video_codec = AV_CODEC_ID_PNG; settings->video_codec = AV_CODEC_ID_PNG;
break; break;
@ -572,8 +585,11 @@ encode_write(struct encode_ctx *ctx, struct stream_ctx *s, AVFrame *filt_frame)
ret = av_interleaved_write_frame(ctx->ofmt_ctx, ctx->encoded_pkt); ret = av_interleaved_write_frame(ctx->ofmt_ctx, ctx->encoded_pkt);
if (ret < 0) if (ret < 0)
{
DPRINTF(E_WARN, L_XCODE, "av_interleaved_write_frame() failed: %s\n", err2str(ret));
break; break;
} }
}
return ret; return ret;
} }