25

Here is a picture that will help you understand my problem:

It's a "1"

I want to stretch the image shown inside ImageButton to the whole area of the ImageButton. As you can see, the picture with the number 1 only take about 95% of the ImageButton and you can also see the boundaries of the ImageButton.

I still want to maintain the image button style

Here's how I am using ImageView:

<ImageButton
    android:id="@+id/secondActivityBbuttonDownRight"
    android:layout_width="0dip"
    android:layout_height="match_parent"
    android:layout_weight="0.5"
    android:scaleType="fitStart"
    android:src="@drawable/111" />

I think I found out what is my problem. I need a custom component that can contain only an image and have a clicking effect.

Laurel
  • 5,965
  • 14
  • 31
  • 57
user2051993
  • 276
  • 1
  • 3
  • 6

7 Answers7

66

ImageButton is ImageView.
If you want your image to fill button
than set android:scaleType="fitXY", so the image you set in android:src will be stretched to fill whole image button.

ImageButton has a background under your image and padding.
If you do not want background
set android:background="@android:color/transparent".
If you do not want padding
set android:padding="0" or set background without padding.

none
  • 4,669
  • 14
  • 62
  • 102
Leonidos
  • 10,482
  • 2
  • 28
  • 37
7

android:scaleType="fitXY" tested and works correctly.

Pranav Karnik
  • 3,318
  • 3
  • 35
  • 47
danny117
  • 5,581
  • 1
  • 26
  • 35
7

You can also use

android:scaleType="centerCrop"
android:padding="0dp"
zackygaurav
  • 4,369
  • 5
  • 26
  • 40
2

Use below code :-

<ImageButton
        android:id="@+id/secondActivityBbuttonDownRight"
        android:layout_width="0dip"
        android:layout_height="match_parent"
        android:layout_weight="0.5"
        android:scaleType="fitStart"
        android:background="@drawable/111" />
duggu
  • 37,851
  • 12
  • 116
  • 113
1

You should consider creating a 9-patch image to make the image fit correctly on an ImageButton in case you need to stretch it, but you don't want the image to become distorted.

To have a button with an image that completely covers it, you can use something like this:

<ImageButton android:id="@+id/iconBtn"
  android:layout_width="64dip"
  android:layout_height="64dip"
  android:src="@drawable/icon_button"
  android:scaleType="fitCenter"
  android:background="#00000000"/>

For a full tutorial on creating buttons with custom skins and the use of selectors to manage their states, you can check a tutorial I've written some time ago here (Creating a custom Android button with a resizable skin).

Andrea Bresolin
  • 186
  • 1
  • 3
0

If your image "111" has no padding itself then simply use android:background"@drawable/111"

Josh
  • 2,122
  • 1
  • 21
  • 28
0

Just set this two attributes on the ImageButton:

android:background="?attr/selectableItemBackgroundBorderless"
android:scaleType="centerCrop"

With those, you will get the provided src to be stretched, and also if you put some specific width and height on that ImageButton you won't get a rectangle around it.

M. Wojcik
  • 2,301
  • 3
  • 23
  • 31