]> git.sesse.net Git - vlc/blobdiff - modules/video_filter/rotate.c
A bit of headers cleanup
[vlc] / modules / video_filter / rotate.c
index ad2e4be7137a9936452b6925e044d89ec3720fdc..4fd405d32053f0ee54ba33b2524c4bae9b5ec90b 100644 (file)
@@ -30,7 +30,7 @@
 #include <math.h>                                            /* sin(), cos() */
 
 #include <vlc/vlc.h>
-#include <vlc/decoder.h>
+#include <vlc_vout.h>
 
 #include "vlc_filter.h"
 
@@ -42,6 +42,10 @@ static void Destroy   ( vlc_object_t * );
 
 static picture_t *Filter( filter_t *, picture_t * );
 
+static int RotateCallback( vlc_object_t *p_this, char const *psz_var,
+                           vlc_value_t oldval, vlc_value_t newval,
+                           void *p_data );
+
 #define ANGLE_TEXT N_("Angle in degrees")
 #define ANGLE_LONGTEXT N_("Angle in degrees (0 to 359)")
 
@@ -77,6 +81,9 @@ static const char *ppsz_filter_options[] = {
 struct filter_sys_t
 {
     int     i_angle;
+    int     i_cos;
+    int     i_sin;
+
     mtime_t last_date;
 };
 
@@ -108,6 +115,12 @@ static int Create( vlc_object_t *p_this )
                                                FILTER_PREFIX "angle" );
     p_filter->p_sys->last_date = 0;
 
+    var_Create( p_filter->p_libvlc, "rotate_angle", VLC_VAR_INTEGER );
+    var_AddCallback( p_filter->p_libvlc,
+                     "rotate_angle", RotateCallback, p_filter->p_sys );
+    var_SetInteger( p_filter->p_libvlc, "rotate_angle",
+                    p_filter->p_sys->i_angle );
+
     return VLC_SUCCESS;
 }
 
@@ -119,6 +132,9 @@ static int Create( vlc_object_t *p_this )
 static void Destroy( vlc_object_t *p_this )
 {
     filter_t *p_filter = (filter_t *)p_this;
+
+    var_DelCallback( p_filter->p_libvlc,
+                     "rotate_angle", RotateCallback, p_filter->p_sys );
     free( p_filter->p_sys );
 }
 
@@ -132,9 +148,9 @@ static void Destroy( vlc_object_t *p_this )
 static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
 {
     picture_t *p_outpic;
+    filter_sys_t *p_sys = p_filter->p_sys;
     int i_index;
-    double f_angle;
-    double f_sin, f_cos;
+    int i_sin = p_sys->i_sin, i_cos = p_sys->i_cos;
     mtime_t new_date = mdate();
 
     if( !p_pic ) return NULL;
@@ -148,10 +164,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
         return NULL;
     }
 
-    p_filter->p_sys->last_date = new_date;
-    f_angle = (((double)p_filter->p_sys->i_angle)*M_PI)/180.;
-    f_sin = sin( f_angle );
-    f_cos = cos( f_angle );
+    p_sys->last_date = new_date;
 
     for( i_index = 0 ; i_index < p_pic->i_planes ; i_index++ )
     {
@@ -169,17 +182,18 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
 
         black_pixel = ( i_index == Y_PLANE ) ? 0x00 : 0x80;
 
-        /* Ok, we do 3 times the sin() calculation for each line. So what ? */
         for( i_line = 0 ; i_line < i_num_lines ; i_line++ )
         {
             for( i_col = 0; i_col < i_num_cols ; i_col++ )
             {
                 int i_line_orig, i_col_orig;
-                i_line_orig = (int)( f_cos * (double)(i_line-i_line_center)
-                                   + f_sin * (double)(i_col-i_col_center) )
+                i_line_orig = ( ( i_cos * (i_line-i_line_center)
+                                + i_sin * (i_col-i_col_center)
+                                + 128 )>>8 )
                               + i_line_center;
-                i_col_orig = (int)(-f_sin * (double)(i_line-i_line_center)
-                                  + f_cos * (double)(i_col-i_col_center) )
+                i_col_orig = ( (-i_sin * (i_line-i_line_center)
+                               + i_cos * (i_col-i_col_center)
+                               + 128 )>>8 )
                              + i_col_center;
 
                 if(    0 <= i_line_orig && i_line_orig < i_num_lines
@@ -208,3 +222,22 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
 
     return p_outpic;
 }
+
+static int RotateCallback( vlc_object_t *p_this, char const *psz_var,
+                           vlc_value_t oldval, vlc_value_t newval,
+                           void *p_data )
+{
+    filter_sys_t *p_sys = (filter_sys_t *)p_data;
+
+    if( !strcmp( psz_var, "rotate_angle" ) )
+    {
+        double f_angle;
+
+        p_sys->i_angle = newval.i_int;
+
+        f_angle = (((double)p_sys->i_angle)*M_PI)/180.;
+        p_sys->i_sin = (int)(sin( f_angle )*256.);
+        p_sys->i_cos = (int)(cos( f_angle )*256.);
+    }
+    return VLC_SUCCESS;
+}