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