# HG changeset patch # User Eugene Paskevich # Date 1198059810 -7200 # Node ID 708f89aaee069ff6cbd818f25ea7a593551b2d0e # Parent 94dae4df1e10a49c0e9e3ec6dc6a8d85c504c997# Parent a95b6a94682dd55c667bb562951c73a591ec4529 Automated merge with ssh://hg.atheme.org//hg/audacious-plugins diff -r a95b6a94682d -r 708f89aaee06 src/aosd/aosd_osd.c --- a/src/aosd/aosd_osd.c Mon Dec 17 19:45:15 2007 -0600 +++ b/src/aosd/aosd_osd.c Wed Dec 19 12:23:30 2007 +0200 @@ -179,7 +179,7 @@ aosd_osd_create ( void ) { gint max_width, layout_width, layout_height; - PangoRectangle ink; + PangoRectangle ink, log; GdkScreen *screen = gdk_screen_get_default(); gint pos_x = 0, pos_y = 0; gint pad_left = 0 , pad_right = 0 , pad_top = 0 , pad_bottom = 0; @@ -229,9 +229,9 @@ pango_layout_set_ellipsize( osd_data->pango_layout , PANGO_ELLIPSIZE_NONE ); pango_layout_set_justify( osd_data->pango_layout , FALSE ); pango_layout_set_width( osd_data->pango_layout , PANGO_SCALE * max_width ); - pango_layout_get_pixel_extents( osd_data->pango_layout , &ink , NULL ); - layout_width = ink.x + ink.width; - layout_height = ink.y + ink.height; + pango_layout_get_pixel_extents( osd_data->pango_layout , &ink , &log ); + layout_width = ink.width; + layout_height = log.height; /* osd position */ switch ( osd_data->cfg_osd->position.placement ) diff -r a95b6a94682d -r 708f89aaee06 src/aosd/aosd_style.c --- a/src/aosd/aosd_style.c Mon Dec 17 19:45:15 2007 -0600 +++ b/src/aosd/aosd_style.c Wed Dec 19 12:23:30 2007 +0200 @@ -161,6 +161,22 @@ } +// sizing helper +static void +aosd_layout_size( PangoLayout * layout , gint * width , gint * height , gint * bearing ) +{ + PangoRectangle ink, log; + + pango_layout_get_pixel_extents( layout , &ink , &log ); + + if ( width != NULL ) + *width = ink.width; + if ( height != NULL ) + *height = log.height; + if ( bearing != NULL ) + *bearing = -ink.x; +} + /* RENDER FUNCTIONS */ @@ -178,9 +194,9 @@ aosd_color_t textcolor0 = data->text->fonts_color[0]; aosd_color_t shadowcolor0 = data->text->fonts_shadow_color[0]; gboolean draw_shadow = data->text->fonts_draw_shadow[0]; - gint width = 0, height = 0; + gint width = 0, height = 0, bearing = 0; - pango_layout_get_pixel_size( osd_layout , &width , &height ); + aosd_layout_size( osd_layout , &width , &height , &bearing ); /* draw rectangle container */ cairo_set_source_rgba( cr , (gdouble)color0.red / 65535 , (gdouble)color0.green / 65535 , @@ -201,7 +217,7 @@ cairo_set_source_rgba( cr , (gdouble)shadowcolor0.red / 65535 , (gdouble)shadowcolor0.green / 65535 , (gdouble)shadowcolor0.blue / 65535 , (gdouble)shadowcolor0.alpha / 65535 ); cairo_move_to( cr, - aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.left + 2 , + aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.left + bearing + 2 , aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.top + 2 ); pango_cairo_show_layout( cr , osd_layout ); } @@ -210,7 +226,7 @@ cairo_set_source_rgba( cr , (gdouble)textcolor0.red / 65535 , (gdouble)textcolor0.green / 65535 , (gdouble)textcolor0.blue / 65535 , (gdouble)textcolor0.alpha / 65535 ); cairo_move_to( cr, - aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.left , + aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.left + bearing , aosd_deco_styles[AOSD_DECO_STYLE_RECT].padding.top ); pango_cairo_show_layout( cr , osd_layout ); } @@ -230,9 +246,9 @@ aosd_color_t textcolor0 = data->text->fonts_color[0]; aosd_color_t shadowcolor0 = data->text->fonts_shadow_color[0]; gboolean draw_shadow = data->text->fonts_draw_shadow[0]; - gint width = 0, height = 0; + gint width = 0, height = 0, bearing = 0; - pango_layout_get_pixel_size( osd_layout , &width , &height ); + aosd_layout_size( osd_layout , &width , &height , &bearing ); /* draw rounded-rectangle container */ cairo_set_source_rgba( cr , (gdouble)color0.red / 65535 , (gdouble)color0.green / 65535 , @@ -262,7 +278,7 @@ cairo_set_source_rgba( cr , (gdouble)shadowcolor0.red / 65535 , (gdouble)shadowcolor0.green / 65535 , (gdouble)shadowcolor0.blue / 65535 , (gdouble)shadowcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.left + 2 , + aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.left + bearing + 2 , aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.top + 2 ); pango_cairo_show_layout( cr , osd_layout ); } @@ -271,7 +287,7 @@ cairo_set_source_rgba( cr , (gdouble)textcolor0.red / 65535 , (gdouble)textcolor0.green / 65535 , (gdouble)textcolor0.blue / 65535 , (gdouble)textcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.left , + aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.left + bearing , aosd_deco_styles[AOSD_DECO_STYLE_ROUNDRECT].padding.top ); pango_cairo_show_layout( cr , osd_layout ); } @@ -291,9 +307,9 @@ aosd_color_t textcolor0 = data->text->fonts_color[0]; aosd_color_t shadowcolor0 = data->text->fonts_shadow_color[0]; gboolean draw_shadow = data->text->fonts_draw_shadow[0]; - gint width = 0, height = 0; + gint width = 0, height = 0, bearing = 0; - pango_layout_get_pixel_size( osd_layout , &width , &height ); + aosd_layout_size( osd_layout , &width , &height , &bearing ); /* draw jigsaw-piece-like container */ cairo_set_source_rgba( cr , (gdouble)color0.red / 65535 , (gdouble)color0.green / 65535 , @@ -323,7 +339,7 @@ cairo_set_source_rgba( cr , (gdouble)shadowcolor0.red / 65535 , (gdouble)shadowcolor0.green / 65535 , (gdouble)shadowcolor0.blue / 65535 , (gdouble)shadowcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.left + 2 , + aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.left + bearing + 2 , aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.top + 2 ); pango_cairo_show_layout( cr , osd_layout ); } @@ -332,7 +348,7 @@ cairo_set_source_rgba( cr , (gdouble)textcolor0.red / 65535 , (gdouble)textcolor0.green / 65535 , (gdouble)textcolor0.blue / 65535 , (gdouble)textcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.left , + aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.left + bearing , aosd_deco_styles[AOSD_DECO_STYLE_CONCAVERECT].padding.top ); pango_cairo_show_layout( cr , osd_layout ); } @@ -350,9 +366,9 @@ aosd_color_t textcolor0 = data->text->fonts_color[0]; aosd_color_t shadowcolor0 = data->text->fonts_shadow_color[0]; gboolean draw_shadow = data->text->fonts_draw_shadow[0]; - gint width = 0, height = 0; + gint width = 0, height = 0, bearing = 0; - pango_layout_get_pixel_size( osd_layout , &width , &height ); + aosd_layout_size( osd_layout , &width , &height , &bearing ); if ( draw_shadow == TRUE ) { @@ -360,7 +376,7 @@ cairo_set_source_rgba( cr , (gdouble)shadowcolor0.red / 65535 , (gdouble)shadowcolor0.green / 65535 , (gdouble)shadowcolor0.blue / 65535 , (gdouble)shadowcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.left + 2 , + aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.left + bearing + 2 , aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.top + 2 ); pango_cairo_show_layout( cr , osd_layout ); } @@ -369,7 +385,7 @@ cairo_set_source_rgba( cr , (gdouble)textcolor0.red / 65535 , (gdouble)textcolor0.green / 65535 , (gdouble)textcolor0.blue / 65535 , (gdouble)textcolor0.alpha / 65535 ); cairo_move_to( cr , - aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.left , + aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.left + bearing , aosd_deco_styles[AOSD_DECO_STYLE_NONE].padding.top ); pango_cairo_show_layout( cr , osd_layout ); } diff -r a95b6a94682d -r 708f89aaee06 src/modplug/fastmix.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/it_defs.h diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_669.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_amf.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_ams.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_dbm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_dmf.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_dsm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_far.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_it.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_mdl.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_med.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_mod.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_mt2.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_mtm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_okt.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_psm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_ptm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_s3m.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_stm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_ult.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_wav.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/load_xm.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/snd_dsp.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/snd_flt.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/snd_fx.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/sndfile.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/sndfile.h diff -r a95b6a94682d -r 708f89aaee06 src/modplug/sndmix.cxx diff -r a95b6a94682d -r 708f89aaee06 src/modplug/stdafx.h diff -r a95b6a94682d -r 708f89aaee06 src/modplug/tables.cxx