mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
vsrc_testsrc: use AV_OPT_TYPE_IMAGE_SIZE.
This commit is contained in:
parent
2ec3e5767e
commit
16a44b41ab
@ -39,11 +39,10 @@
|
|||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
const AVClass *class;
|
const AVClass *class;
|
||||||
int h, w;
|
int w, h;
|
||||||
unsigned int nb_frame;
|
unsigned int nb_frame;
|
||||||
AVRational time_base;
|
AVRational time_base;
|
||||||
int64_t pts, max_pts;
|
int64_t pts, max_pts;
|
||||||
char *size; ///< video frame size
|
|
||||||
char *rate; ///< video frame rate
|
char *rate; ///< video frame rate
|
||||||
char *duration; ///< total duration of the generated video
|
char *duration; ///< total duration of the generated video
|
||||||
AVRational sar; ///< sample aspect ratio
|
AVRational sar; ///< sample aspect ratio
|
||||||
@ -58,8 +57,8 @@ typedef struct {
|
|||||||
#define OFFSET(x) offsetof(TestSourceContext, x)
|
#define OFFSET(x) offsetof(TestSourceContext, x)
|
||||||
|
|
||||||
static const AVOption testsrc_options[]= {
|
static const AVOption testsrc_options[]= {
|
||||||
{ "size", "set video size", OFFSET(size), AV_OPT_TYPE_STRING, {.str = "320x240"}, 0, 0 },
|
{ "size", "set video size", OFFSET(w), AV_OPT_TYPE_IMAGE_SIZE, {.str = "320x240"}, 0, 0 },
|
||||||
{ "s", "set video size", OFFSET(size), AV_OPT_TYPE_STRING, {.str = "320x240"}, 0, 0 },
|
{ "s", "set video size", OFFSET(w), AV_OPT_TYPE_IMAGE_SIZE, {.str = "320x240"}, 0, 0 },
|
||||||
{ "rate", "set video rate", OFFSET(rate), AV_OPT_TYPE_STRING, {.str = "25"}, 0, 0 },
|
{ "rate", "set video rate", OFFSET(rate), AV_OPT_TYPE_STRING, {.str = "25"}, 0, 0 },
|
||||||
{ "r", "set video rate", OFFSET(rate), AV_OPT_TYPE_STRING, {.str = "25"}, 0, 0 },
|
{ "r", "set video rate", OFFSET(rate), AV_OPT_TYPE_STRING, {.str = "25"}, 0, 0 },
|
||||||
{ "duration", "set video duration", OFFSET(duration), AV_OPT_TYPE_STRING, {.str = NULL}, 0, 0 },
|
{ "duration", "set video duration", OFFSET(duration), AV_OPT_TYPE_STRING, {.str = NULL}, 0, 0 },
|
||||||
@ -84,12 +83,6 @@ static av_cold int init(AVFilterContext *ctx, const char *args, void *opaque)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((ret = av_parse_video_size(&test->w, &test->h, test->size)) < 0) {
|
|
||||||
av_log(ctx, AV_LOG_ERROR, "Invalid frame size: '%s'\n", test->size);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
av_freep(&test->size);
|
|
||||||
|
|
||||||
if ((ret = av_parse_video_rate(&frame_rate_q, test->rate)) < 0 ||
|
if ((ret = av_parse_video_rate(&frame_rate_q, test->rate)) < 0 ||
|
||||||
frame_rate_q.den <= 0 || frame_rate_q.num <= 0) {
|
frame_rate_q.den <= 0 || frame_rate_q.num <= 0) {
|
||||||
av_log(ctx, AV_LOG_ERROR, "Invalid frame rate: '%s'\n", test->rate);
|
av_log(ctx, AV_LOG_ERROR, "Invalid frame rate: '%s'\n", test->rate);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user