What is the difference between a View's Margin and Padding?
This question is related to
android
user-interface
view
padding
margin
Padding is the space inside the border, between the border and the actual view's content. Note that padding goes completely around the content: there is padding on the top, bottom, right and left sides (which can be independent).
Margins are the spaces outside the border, between the border and the other elements next to this view. In the image, the margin is the grey area outside the entire object. Note that, like the padding, the margin goes completely around the content: there are margins on the top, bottom, right, and left sides.
An image says more than 1000 words (extracted from Margin Vs Padding - CSS Properties):
In simple words:
Margin refers to the extra space outside of an element. Padding refers to the extra space within an element. The margin is the extra space around the control. The padding is extra space inside the control.
It's hard to see the difference with margin and padding with a white fill, but with a colored fill you can see it fine.
Padding is within the view, margin is outside. Padding is available for all views. Depending on the view, there may or may not be a visual difference between padding and margin.
For buttons, for example, the characteristic button background image includes the padding, but not the margin. In other words, adding more padding makes the button look visually bigger, while adding more margin just makes the gap between the button and the next control wider.
For TextView
s, on the other hand, the visual effect of padding and margin is identical.
Whether or not margin is available is determined by the container of the view, not by the view itself. In LinearLayout
margin is supported, in AbsoluteLayout
(considered obsolete now) - no.
Padding is inside of a View.
Margin is outside of a View.
This difference may be relevant to background or size properties.
In simple words:
padding changes the size of the box (with something).
margin changes the space between different boxes
Padding is the space inside the border between the border and the actual image or cell contents. Margins are the spaces outside the border, between the border and the other elements next to this object.
Sometimes you can achieve the same result by playing only with padding OR margin. Example :
Say View X contains view Y (aka : View Y is inside View X).
-View Y with Margin=30 OR View X with Padding=30 will achieve the same result: View Y will have an offset of 30.
Padding
Padding is inside of a View.For example if you give android:paddingLeft=20dp
, then the items inside the view will arrange with 20dp
width from left.You can also use paddingRight
, paddingBottom
, paddingTop
which are to give padding from right, bottom and top respectively.
Margin
Margin is outside of a View
. For example if you give android:marginLeft=20dp
, then the view will be arranged after 20dp
from left.
In addition to all the correct answers above, one other difference is that padding increases the clickable area of a view, whereas margins do not. This is useful if you have a smallish clickable image but want to make the click handler forgiving.
For eg, see this image of my layout with an ImageView
(the Android icon) where I set the paddingBotton
to be 100dp
(the image is the stock launcher mipmap ic_launcher
). With the attached click handler I was able to click way outside and below the image and still register a click.
Let's just suppose you have a button in a view and the size of the view is 200 by 200, and the size of the button is 50 by 50, and the button title is HT. Now the difference between margin and padding is, you can set the margin of the button in the view, for example 20 from the left, 20 from the top, and padding will adjust the text position in the button or text view etc. for example, padding value is 20 from the left, so it will adjust the position of the text.
Below image will let you understand the padding and margin-
Source: Stackoverflow.com