Fix fit-size calculation.
This commit is contained in:
@ -87,10 +87,16 @@ eek_gtk_renderer_real_render_key_icon (EekRenderer *self,
|
|||||||
width = gdk_pixbuf_get_width (pixbuf);
|
width = gdk_pixbuf_get_width (pixbuf);
|
||||||
height = gdk_pixbuf_get_height (pixbuf);
|
height = gdk_pixbuf_get_height (pixbuf);
|
||||||
|
|
||||||
if (bounds.width * height < bounds.height * width)
|
if (bounds.height * width / bounds.width <= height)
|
||||||
scale = bounds.width / width;
|
scale = width / bounds.width;
|
||||||
else
|
else if (bounds.width * height / bounds.height <= width)
|
||||||
scale = bounds.height / height;
|
scale = height / bounds.height;
|
||||||
|
else {
|
||||||
|
if (bounds.width * height < bounds.height * width)
|
||||||
|
scale = bounds.width / width;
|
||||||
|
else
|
||||||
|
scale = bounds.height / height;
|
||||||
|
}
|
||||||
|
|
||||||
cairo_save (cr);
|
cairo_save (cr);
|
||||||
cairo_translate (cr,
|
cairo_translate (cr,
|
||||||
|
|||||||
@ -880,8 +880,17 @@ eek_renderer_set_allocation_size (EekRenderer *renderer,
|
|||||||
priv->allocation_height = height;
|
priv->allocation_height = height;
|
||||||
|
|
||||||
eek_element_get_bounds (EEK_ELEMENT(priv->keyboard), &bounds);
|
eek_element_get_bounds (EEK_ELEMENT(priv->keyboard), &bounds);
|
||||||
scale = width > height ? height / bounds.height :
|
|
||||||
width / bounds.width;
|
if (bounds.height * width / bounds.width <= height)
|
||||||
|
scale = width / bounds.width;
|
||||||
|
else if (bounds.width * height / bounds.height <= width)
|
||||||
|
scale = height / bounds.height;
|
||||||
|
else {
|
||||||
|
if (bounds.width * height < bounds.height * width)
|
||||||
|
scale = bounds.width / width;
|
||||||
|
else
|
||||||
|
scale = bounds.height / height;
|
||||||
|
}
|
||||||
|
|
||||||
if (scale != priv->scale) {
|
if (scale != priv->scale) {
|
||||||
priv->scale = scale;
|
priv->scale = scale;
|
||||||
|
|||||||
Reference in New Issue
Block a user