diff options
author | Stefano Sabatini <stefano.sabatini-lala@poste.it> | 2010-06-27 22:35:35 +0000 |
---|---|---|
committer | Stefano Sabatini <stefano.sabatini-lala@poste.it> | 2010-06-27 22:35:35 +0000 |
commit | a52e2c3a4654f47aa0e06e7249aa2056e7a6c07e (patch) | |
tree | fb3aad613be5b354f92d92e2a1df35b41f716f4d /libavfilter | |
parent | 8e094dd6674e3fd503e1fc2f68883fd3f73a5bd1 (diff) | |
download | ffmpeg-a52e2c3a4654f47aa0e06e7249aa2056e7a6c07e.tar.gz |
Extend color syntax, make it accept an alpha component specifier.
Originally committed as revision 23835 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavfilter')
-rw-r--r-- | libavfilter/parseutils.c | 60 | ||||
-rw-r--r-- | libavfilter/parseutils.h | 10 |
2 files changed, 62 insertions, 8 deletions
diff --git a/libavfilter/parseutils.c b/libavfilter/parseutils.c index 07fa5b880f..71fb70ea34 100644 --- a/libavfilter/parseutils.c +++ b/libavfilter/parseutils.c @@ -24,6 +24,7 @@ #include <strings.h> #include "libavutil/avutil.h" +#include "libavutil/avstring.h" #include "libavutil/random_seed.h" #include "parseutils.h" @@ -216,22 +217,31 @@ static int color_table_compare(const void *lhs, const void *rhs) return strcasecmp(lhs, ((const ColorEntry *)rhs)->name); } +#define ALPHA_SEP '@' + int av_parse_color(uint8_t *rgba_color, const char *color_string, void *log_ctx) { - if (!strcasecmp(color_string, "random") || !strcasecmp(color_string, "bikeshed")) { + char *tail, color_string2[128]; + const ColorEntry *entry; + av_strlcpy(color_string2, color_string, sizeof(color_string2)); + if ((tail = strchr(color_string2, ALPHA_SEP))) + *tail++ = 0; + rgba_color[3] = 255; + + if (!strcasecmp(color_string2, "random") || !strcasecmp(color_string2, "bikeshed")) { int rgba = av_get_random_seed(); rgba_color[0] = rgba >> 24; rgba_color[1] = rgba >> 16; rgba_color[2] = rgba >> 8; rgba_color[3] = rgba; } else - if (!strncmp(color_string, "0x", 2)) { + if (!strncmp(color_string2, "0x", 2)) { char *tail; - int len = strlen(color_string); - unsigned int rgba = strtoul(color_string, &tail, 16); + int len = strlen(color_string2); + unsigned int rgba = strtoul(color_string2, &tail, 16); if (*tail || (len != 8 && len != 10)) { - av_log(log_ctx, AV_LOG_ERROR, "Invalid 0xRRGGBB[AA] color string: '%s'\n", color_string); + av_log(log_ctx, AV_LOG_ERROR, "Invalid 0xRRGGBB[AA] color string: '%s'\n", color_string2); return AVERROR(EINVAL); } if (len == 10) { @@ -242,18 +252,39 @@ int av_parse_color(uint8_t *rgba_color, const char *color_string, void *log_ctx) rgba_color[1] = rgba >> 8; rgba_color[2] = rgba; } else { - const ColorEntry *entry = bsearch(color_string, + entry = bsearch(color_string2, color_table, FF_ARRAY_ELEMS(color_table), sizeof(ColorEntry), color_table_compare); if (!entry) { - av_log(log_ctx, AV_LOG_ERROR, "Cannot find color '%s'\n", color_string); + av_log(log_ctx, AV_LOG_ERROR, "Cannot find color '%s'\n", color_string2); return AVERROR(EINVAL); } memcpy(rgba_color, entry->rgb_color, 3); } + if (tail) { + unsigned long int alpha; + const char *alpha_string = tail; + if (!strncmp(alpha_string, "0x", 2)) { + alpha = strtoul(alpha_string, &tail, 16); + } else { + alpha = strtoul(alpha_string, &tail, 10); + if (*tail) { + double d = strtod(alpha_string, &tail); + alpha = d * 255; + } + } + + if (tail == alpha_string || *tail || alpha > 255) { + av_log(log_ctx, AV_LOG_ERROR, "Invalid alpha value specifier '%s' in '%s'\n", + alpha_string, color_string); + return AVERROR(EINVAL); + } + rgba_color[3] = alpha; + } + return 0; } @@ -421,6 +452,21 @@ int main(void) "0xffXXee", "0xfoobar", "0xffffeeeeeeee", + "red@foo", + "random@10", + "0xff0000@1.0", + "red@", + "red@0xfff", + "red@0xf", + "red@2", + "red@0.1", + "red@-1", + "red@0.5", + "red@1.0", + "red@256", + "red@10foo", + "red@-1.0", + "red@-0.0", }; av_log_set_level(AV_LOG_DEBUG); diff --git a/libavfilter/parseutils.h b/libavfilter/parseutils.h index 8ad7b8b5e6..f699e9d34a 100644 --- a/libavfilter/parseutils.h +++ b/libavfilter/parseutils.h @@ -46,7 +46,15 @@ char *av_get_token(const char **buf, const char *term); * Puts the RGBA values that correspond to color_string in rgba_color. * * @param color_string a string specifying a color. It can be the name of - * a color (case insensitive match) or a 0xRRGGBB[AA] sequence. + * a color (case insensitive match) or a 0xRRGGBB[AA] sequence, + * possibly followed by "@" and a string representing the alpha + * component. + * The alpha component may be a string composed by "0x" followed by an + * hexadecimal number or a base-10 number between 0 and 255, or a + * decimal number between 0.0 and 1.0, which represents the opacity + * value (0/0x00/0.0 means completely transparent, 255/0xff/1.0 + * completely opaque). + * If the alpha component is not specified then 255 is assumed. * The string "random" will result in a random color. * @return >= 0 in case of success, a negative value in case of * failure (for example if color_string cannot be parsed). |