]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
attempt to optimize patch function
authorMike Jerris <mike@jerris.com>
Thu, 30 Jul 2015 02:03:02 +0000 (21:03 -0500)
committerMichael Jerris <mike@jerris.com>
Thu, 30 Jul 2015 02:03:02 +0000 (21:03 -0500)
src/include/switch_core_video.h
src/switch_core_video.c

index 43a96e87ac1f51ff560dc8f428b8ea41c062035b..62506ef1fca21f91a5a60cb3d0ce62f1630753f0 100644 (file)
@@ -285,20 +285,6 @@ SWITCH_DECLARE(void) switch_color_set_rgb(switch_rgb_color_t *color, const char
 */
 SWITCH_DECLARE(void) switch_color_set_yuv(switch_yuv_color_t *color, const char *color_str);
 
-/*!\brief Convert RGB color to YUV
-*
-* \param[in]    rgb       RGB color pointer
-* \param[out]   yuv       YUV color pointer
-*/
-SWITCH_DECLARE(void) switch_color_rgb2yuv(switch_rgb_color_t *rgb, switch_yuv_color_t *yuv);
-
-/*!\brief Convert YUV color to RGB
-*
-* \param[in]    yuv       YUV color pointer
-* \param[out]   rgb       RGB color pointer
-*/
-SWITCH_DECLARE(void) switch_color_yuv2rgb(switch_yuv_color_t *yuv, switch_rgb_color_t *rgb);
-
 /*!\brief Created a text handle
 *
 * \param[out]   handleP     Pointer to the text handle pointer
@@ -345,10 +331,6 @@ SWITCH_DECLARE(switch_status_t) switch_img_write_png(switch_image_t *img, char *
 SWITCH_DECLARE(switch_status_t) switch_png_open(switch_png_t **pngP, const char *file_name);
 SWITCH_DECLARE(void) switch_png_free(switch_png_t **pngP);
 
-SWITCH_DECLARE(void) switch_img_get_yuv_pixel(switch_image_t *img, switch_yuv_color_t *yuv, int x, int y);
-
-SWITCH_DECLARE(void) switch_img_get_rgb_pixel(switch_image_t *img, switch_rgb_color_t *rgb, int x, int y);
-
 /*!\brief put a small img over a big IMG at position x,y, with alpha transparency
 *
 * Both IMG and img must be non-NULL
index 52fb1c8b9945c50c684601ca020401aea7545542..a1b11fe5a298d8a2ba38bdb4664de92933ff109b 100644 (file)
 #include <gd.h>
 #endif
 
+static inline void switch_img_get_yuv_pixel(switch_image_t *img, switch_yuv_color_t *yuv, int x, int y);
+
+static inline void switch_img_get_rgb_pixel(switch_image_t *img, switch_rgb_color_t *rgb, int x, int y);
+
+
+/*!\brief Convert RGB color to YUV
+*
+* \param[in]    rgb       RGB color pointer
+* \param[out]   yuv       YUV color pointer
+*/
+static inline void switch_color_rgb2yuv(switch_rgb_color_t *rgb, switch_yuv_color_t *yuv);
+
+/*!\brief Convert YUV color to RGB
+*
+* \param[in]    yuv       YUV color pointer
+* \param[out]   rgb       RGB color pointer
+*/
+static inline void switch_color_yuv2rgb(switch_yuv_color_t *yuv, switch_rgb_color_t *rgb);
+
 struct pos_el {
        switch_img_position_t pos;
        const char *name;
@@ -249,12 +268,16 @@ SWITCH_DECLARE(void) switch_img_patch(switch_image_t *IMG, switch_image_t *img,
                                        switch_img_get_rgb_pixel(IMG, &RGB, x + j, y + i);
                                        rgb = (switch_rgb_color_t *)(img->planes[SWITCH_PLANE_PACKED] + i * img->stride[SWITCH_PLANE_PACKED] + j * 4);
 
-                                       RGB.a = 255;
-                                       RGB.r = ((RGB.r * (255 - alpha)) >> 8) + ((rgb->r * alpha) >> 8);
-                                       RGB.g = ((RGB.g * (255 - alpha)) >> 8) + ((rgb->g * alpha) >> 8);
-                                       RGB.b = ((RGB.b * (255 - alpha)) >> 8) + ((rgb->b * alpha) >> 8);
+                                       if (alpha < 255) {
+                                               RGB.a = 255;
+                                               RGB.r = ((RGB.r * (255 - alpha)) >> 8) + ((rgb->r * alpha) >> 8);
+                                               RGB.g = ((RGB.g * (255 - alpha)) >> 8) + ((rgb->g * alpha) >> 8);
+                                               RGB.b = ((RGB.b * (255 - alpha)) >> 8) + ((rgb->b * alpha) >> 8);
 
-                                       switch_img_draw_pixel(IMG, x + j, y + i, &RGB);
+                                               switch_img_draw_pixel(IMG, x + j, y + i, &RGB);
+                                       } else {
+                                               switch_img_draw_pixel(IMG, x + j, y + i, rgb);
+                                       }
                                }
                        }
                }
@@ -509,7 +532,7 @@ SWITCH_DECLARE(void) switch_img_fill(switch_image_t *img, int x, int y, int w, i
 #endif
 }
 
-SWITCH_DECLARE(void) switch_img_get_yuv_pixel(switch_image_t *img, switch_yuv_color_t *yuv, int x, int y)
+static inline void switch_img_get_yuv_pixel(switch_image_t *img, switch_yuv_color_t *yuv, int x, int y)
 {
 #ifdef SWITCH_HAVE_YUV         
        // switch_assert(img->fmt == SWITCH_IMG_FMT_I420);
@@ -521,7 +544,7 @@ SWITCH_DECLARE(void) switch_img_get_yuv_pixel(switch_image_t *img, switch_yuv_co
 #endif 
 }
 
-SWITCH_DECLARE(void) switch_img_get_rgb_pixel(switch_image_t *img, switch_rgb_color_t *rgb, int x, int y)
+static inline void switch_img_get_rgb_pixel(switch_image_t *img, switch_rgb_color_t *rgb, int x, int y)
 {
 #ifdef SWITCH_HAVE_YUV         
        if (x < 0 || y < 0 || x >= img->d_w || y >= img->d_h) return;
@@ -544,7 +567,7 @@ SWITCH_DECLARE(void) switch_img_get_rgb_pixel(switch_image_t *img, switch_rgb_co
 SWITCH_DECLARE(void) switch_img_overlay(switch_image_t *IMG, switch_image_t *img, int x, int y, uint8_t alpha)
 {
        int i, j, len, max_h;
-       switch_rgb_color_t RGB, rgb, c;
+       switch_rgb_color_t RGB = {0}, rgb = {0}, c;
        int xoff = 0, yoff = 0;
 
        switch_assert(IMG->fmt == SWITCH_IMG_FMT_I420);
@@ -666,7 +689,7 @@ SWITCH_DECLARE(void) switch_color_set_rgb(switch_rgb_color_t *color, const char
        }
 }
 
-SWITCH_DECLARE(void) switch_color_rgb2yuv(switch_rgb_color_t *rgb, switch_yuv_color_t *yuv)
+static inline void switch_color_rgb2yuv(switch_rgb_color_t *rgb, switch_yuv_color_t *yuv)
 {
 #ifdef SWITCH_HAVE_YUV         
        yuv->y = (uint8_t)(((rgb->r * 4897) >> 14) + ((rgb->g * 9611) >> 14) + ((rgb->b * 1876) >> 14));
@@ -677,7 +700,7 @@ SWITCH_DECLARE(void) switch_color_rgb2yuv(switch_rgb_color_t *rgb, switch_yuv_co
 
 #define CLAMP(val) MAX(0, MIN(val, 255))
 
-SWITCH_DECLARE(void) switch_color_yuv2rgb(switch_yuv_color_t *yuv, switch_rgb_color_t *rgb)
+static inline void switch_color_yuv2rgb(switch_yuv_color_t *yuv, switch_rgb_color_t *rgb)
 {
 #ifdef SWITCH_HAVE_YUV 
 #if 0
@@ -879,7 +902,7 @@ static void draw_bitmap(switch_img_txt_handle_t *handle, switch_image_t *img, FT
                        if (handle->use_bgcolor) {
                                switch_img_draw_pixel(img, i, j, &handle->gradient_table[gradient * MAX_GRADIENT / 256]);
                        } else {
-                               switch_rgb_color_t rgb_color;
+                               switch_rgb_color_t rgb_color = {0};
                                switch_rgb_color_t c;
                                switch_img_get_rgb_pixel(img, &rgb_color, i, j);