On 24 Jul 2023, at 23:11, Marvin Scholz wrote:

> ---
>  libavfilter/vf_xfade_vulkan.c | 43 +++++++++++++++++++++++++++++++++++
>  1 file changed, 43 insertions(+)
>
> diff --git a/libavfilter/vf_xfade_vulkan.c b/libavfilter/vf_xfade_vulkan.c
> index 8825717890..d044714199 100644
> --- a/libavfilter/vf_xfade_vulkan.c
> +++ b/libavfilter/vf_xfade_vulkan.c
> @@ -76,6 +76,8 @@ enum XFadeTransitions {
>      SLIDEUP,
>      SLIDELEFT,
>      SLIDERIGHT,
> +    CIRCLEOPEN,
> +    CIRCLECLOSE,
>      NB_TRANSITIONS,
>  };
>
> @@ -178,6 +180,43 @@ static const char transition_slideright[] = {
>      C(0, }                                                                   
>   )
>  };
>
> +#define SHADER_HYPOT_FUNC                                                    
>   \
> +    C(0, float hypot(ivec2 v) {                                              
> ) \
> +    C(1,     ivec2 sqr = v * v;                                              
> ) \
> +    C(1,     return sqrt(sqr.x + sqr.y);                                     
> ) \
> +    C(0, }                                                                   
> )
> +
> +#define SHADER_CIRCLE_COMMON                                                 
>     \
> +    SHADER_HYPOT_FUNC                                                        
>     \
> +    C(0, void circle(int idx, ivec2 pos, float progress, bool open)          
>   ) \
> +    C(0, {                                                                   
>   ) \
> +    C(1,     const ivec2 half_size = imageSize(output_images[idx]) / 2;      
>   ) \
> +    C(1,     const float z = hypot(half_size);                               
>   ) \
> +    C(1,     float p = ((open ? (1.0 - progress) : progress) - 0.5) * 3.0;   
>   ) \
> +    C(1,     float sm = hypot(pos - half_size) / z + p;                      
>   ) \
> +    C(1,     vec4 a = texture(a_images[idx], pos);                           
>   ) \
> +    C(1,     vec4 b = texture(b_images[idx], pos);                           
>   ) \
> +    C(1,     imageStore(output_images[idx], pos, \
> +                        mix(open ? b : a, open ? a : b, \
> +                            smoothstep(0.f, 1.f, sm)));                      
>   ) \
> +    C(0, }                                                                   
>   )
> +
> +static const char transition_circleopen[] = {
> +    SHADER_CIRCLE_COMMON
> +    C(0, void transition(int idx, ivec2 pos, float progress)                 
>   )
> +    C(0, {                                                                   
>   )
> +    C(1,     circle(idx, pos, progress, true);                               
>   )
> +    C(0, }                                                                   
>   )
> +};
> +
> +static const char transition_circleclose[] = {
> +    SHADER_CIRCLE_COMMON
> +    C(0, void transition(int idx, ivec2 pos, float progress)                 
>   )
> +    C(0, {                                                                   
>   )
> +    C(1,     circle(idx, pos, progress, false);                              
>   )
> +    C(0, }                                                                   
>   )
> +};
> +
>  static const char* transitions_map[NB_TRANSITIONS] = {
>      [FADE]      = transition_fade,
>      [WIPELEFT]  = transition_wipeleft,
> @@ -188,6 +227,8 @@ static const char* transitions_map[NB_TRANSITIONS] = {
>      [SLIDEUP]   = transition_slideup,
>      [SLIDELEFT] = transition_slideleft,
>      [SLIDERIGHT]= transition_slideright,
> +    [CIRCLEOPEN]= transition_circleopen,
> +    [CIRCLECLOSE]=transition_circleclose,
>  };
>
>  static av_cold int init_vulkan(AVFilterContext *avctx)
> @@ -538,6 +579,8 @@ static const AVOption xfade_vulkan_options[] = {
>          { "slideup",   "slide up transition", 0, AV_OPT_TYPE_CONST, 
> {.i64=SLIDEUP}, 0, 0, FLAGS, "transition" },
>          { "slideleft", "slide left transition", 0, AV_OPT_TYPE_CONST, 
> {.i64=SLIDELEFT}, 0, 0, FLAGS, "transition" },
>          { "slideright","slide right transition", 0, AV_OPT_TYPE_CONST, 
> {.i64=SLIDERIGHT}, 0, 0, FLAGS, "transition" },
> +        { "circleopen","circleopen transition", 0, AV_OPT_TYPE_CONST, 
> {.i64=CIRCLEOPEN}, 0, 0, FLAGS, "transition" },
> +        { "circleclose","circleclose transition", 0, AV_OPT_TYPE_CONST, 
> {.i64=CIRCLECLOSE}, 0, 0, FLAGS, "transition" },
>      { "duration", "set cross fade duration", OFFSET(duration), 
> AV_OPT_TYPE_DURATION, {.i64=1000000}, 0, 60000000, FLAGS },
>      { "offset",   "set cross fade start relative to first input stream", 
> OFFSET(offset), AV_OPT_TYPE_DURATION, {.i64=0}, INT64_MIN, INT64_MAX, FLAGS },
>      { NULL }
> -- 
> 2.39.2

Please ignore this set, I've posted an update but messed up using git send-email
properly so it is not marked v2 and the in-reply-to header is messed up, hence
not being threaded properly here…

Sorry for the noise.
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".

Reply via email to