视图的填充和边距之间的区别

发布于 2024-10-11 02:37:30 字数 21 浏览 9 评论 0原文

视图的边距和填充有什么区别?

What is the difference between a View's Margin and Padding?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(15

〆凄凉。 2024-10-18 02:37:30

为了帮助我记住衬垫的含义,我想到了一件带有许多厚棉衬垫的大衣。我在外套里面,但我和我的棉衣是在一起的。我们是一个单位。

但要记住边距,我会想到,“嘿,给我一些边距!”这是我和你之间的空白空间。不要进入我的舒适区——我的边缘。

为了更清楚地说明,这是 TextView 中的填充和边距的图片:

在此处输入图像描述

上面图像的 xml 布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:text="TextView margin only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:text="TextView margin only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#c5e1b0"
        android:padding="10dp"
        android:textColor="#000000"
        android:text="TextView padding only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#f6c0c0"
        android:padding="10dp"
        android:textColor="#000000"
        android:text="TextView padding only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:padding="10dp"
        android:text="TextView padding and margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:padding="10dp"
        android:text="TextView padding and margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:text="TextView no padding no margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:text="TextView no padding no margin"
        android:textSize="20sp" />

</LinearLayout>

相关

To help me remember the meaning of padding, I think of a big coat with lots of thick cotton padding. I'm inside my coat, but me and my padded coat are together. We're a unit.

But to remember margin, I think of, "Hey, give me some margin!" It's the empty space between me and you. Don't come inside my comfort zone -- my margin.

To make it more clear, here is a picture of padding and margin in a TextView:

enter image description here

xml layout for the image above

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:text="TextView margin only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:text="TextView margin only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#c5e1b0"
        android:padding="10dp"
        android:textColor="#000000"
        android:text="TextView padding only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#f6c0c0"
        android:padding="10dp"
        android:textColor="#000000"
        android:text="TextView padding only"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:padding="10dp"
        android:text="TextView padding and margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:padding="10dp"
        android:text="TextView padding and margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#c5e1b0"
        android:textColor="#000000"
        android:text="TextView no padding no margin"
        android:textSize="20sp" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="#f6c0c0"
        android:textColor="#000000"
        android:text="TextView no padding no margin"
        android:textSize="20sp" />

</LinearLayout>

Related

怪我闹别瞎闹 2024-10-18 02:37:30

内边距是边框内部、边框与实际视图内容之间的空间。请注意,填充完全围绕内容:顶部、底部、右侧和左侧都有填充(可以是独立的)。

边距是边框外、边框与该视图旁边的其他元素之间的空间。在图像中,边缘是整个对象外部的灰色区域。请注意,与填充一样,边距完全围绕内容:顶部、底部、右侧和左侧都有边距。

一张图片包含超过 1000 个单词(摘自 Margin Vs Padding - CSS 属性):

alt text

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):

alt text

淡水深流 2024-10-18 02:37:30

填充位于视图内部。

边距位于视图之外。

这种差异可能与背景或尺寸属性有关。

Padding is inside of a View.

Margin is outside of a View.

This difference may be relevant to background or size properties.

┈┾☆殇 2024-10-18 02:37:30

内边距在视图内,边距在视图外。填充可用于所有视图。根据视图的不同,填充和边距之间可能存在也可能不存在视觉差异。

例如,对于按钮,特征按钮背景图像包括填充,但不包括边距。换句话说,添加更多的内边距会使按钮在视觉上看起来更大,而添加更多的边距只会使按钮和下一个控件之间的间隙更宽。

另一方面,对于 TextView 来说,填充和边距的视觉效果是相同的。

margin 是否可用由视图的容器决定,而不是由视图本身决定。在 LinearLayout 中支持边距,在 AbsoluteLayout 中(现在已被认为已过时)- 不支持。

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 TextViews, 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.

月亮是我掰弯的 2024-10-18 02:37:30

下图将让您了解填充和边距 -

在此处输入图像描述

Below image will let you understand the padding and margin-

enter image description here

青芜 2024-10-18 02:37:30

填充是指小部件和小部件原始框架之间的空间。但边距是小部件的原始框架与其他小部件框架之间的空间。在此处输入图像描述

Padding means space between widget and widget original frame. But the margin is space between widget's original frame to boundaries other widget's frame.enter image description here.

極樂鬼 2024-10-18 02:37:30

填充
Padding 位于 View 内部。例如,如果您指定 android:paddingLeft=20dp,则视图内的项目将从左侧以 20dp 宽度排列。您也可以使用paddingRightpaddingBottompaddingTop 分别从右、下、上进行填充。

保证金
边距位于视图之外。例如,如果您指定 android:marginLeft=20dp ,则视图将排列在左侧 20dp 之后。

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.

一身仙ぐ女味 2024-10-18 02:37:30

填充是边框内部与实际图像或单元格内容之间的空间。
边距是边框外部、边框与该对象旁边的其他元素之间的空间。

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.

妄司 2024-10-18 02:37:30

有时,您可以通过仅使用填充或边距来实现相同的结果。示例:

假设视图 X 包含视图 Y(又名:视图 Y 在视图 X 内部)。

-Margin=30 的视图 Y 或 Padding=30 的视图 X 将获得相同的结果:视图 Y 的偏移量为 30。

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.

睡美人的小仙女 2024-10-18 02:37:30

除了上述所有正确答案之外,另一个区别是内边距增加了视图的可点击区域,而边距则增加了视图的可点击区域。不是。。如果您有一个较小的可点击图像但想让点击处理程序宽容,这非常有用。

例如,请查看带有 ImageView (Android 图标)的布局图像,其中我将 paddingBotton 设置为 100dp (图像为库存启动器 mipmap ic_launcher)。通过附加的点击处理程序,我可以点击图像外部和下方,并且仍然注册一次点击。

输入图片此处描述

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.

enter image description here

梅窗月明清似水 2024-10-18 02:37:30

简单来说:

  1. Padding - 在视图边框内创建空间。
  2. 边距 - 在视图边界之外创建空间。

In simple words:

  1. Padding - creates space inside the view's border.
  2. Margin - creates space outside the view's border.
一口甜 2024-10-18 02:37:30

我们假设视图中有一个按钮,视图的大小为 200 x 200,按钮的大小为 50 x 50,按钮标题为 HT。现在margin和padding之间的区别是,您可以在视图中设置按钮的边距,例如从左侧20,从顶部20,而padding会调整按钮或文本视图中的文本位置等。例如,padding值为从左边算起20,所以它会调整文本的位置。

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.

你怎么这么可爱啊 2024-10-18 02:37:30

边距是指元素外部的额外空间。填充是指元素内的额外空间。边距是控件周围的额外空间。填充是控件内部的额外空间。

使用白色填充很难看出边距和填充的差异,但使用彩色填充时您可以很好地看到它。

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.

柠檬色的秋千 2024-10-18 02:37:30

简单来说:
填充会改变盒子的大小(带有某些东西)。
margin 改变不同盒子之间的空间

In simple words:
padding changes the size of the box (with something).
margin changes the space between different boxes

陌生 2024-10-18 02:37:30

Padding 用于在视图及其内容之间添加空白区域。

输入图片这里的描述

边距用于在不同视图之间添加空间。

输入图片此处描述
对于填充和边距,我们有两种方法来设置它们,

  • 将所有边设置为相等值
  • ,根据要求设置边特定值

所有边具有相等值:

您可以使用 android:padding="15dp"用于设置所有边 15dp 的内边距

android:layout_margin="15dp" 用于设置所有边 15dp 的边距

具有特定值的边:

Padding

  • android:paddingBottom 设置底部边缘的填充
  • android:paddingStart 设置起始边缘的填充意味着在视图的左侧
  • android:paddingEnd 设置底部边缘的填充结束边缘表示在视图的右侧
  • android:paddingTop 设置顶部边缘的填充

Margin

  • android:layout_marginBottom 指定底部的额外空间此视图的侧面。
  • android:layout_marginEnd 指定末端的额外空间,即在此视图的右侧。
  • android:layout_marginStart 指定起始侧的额外空间,即在此视图的左侧。
  • android:layout_marginTop 指定此视图顶部的额外空间。

Padding is used to add a blank space between a view and its contents.

enter image description here

Margin is used to add a space between different views.

enter image description here
For both padding and margin, we have two way to set those,

  • setting all sides with equal value
  • setting side specific values as per requirement

All sides with equal values:

You can use android:padding="15dp" for setting padding of 15dp all the sides

and android:layout_margin="15dp" for setting margin of 15dp all the sides

Sides with specific values:

Padding

  • android:paddingBottom Sets the padding at the bottom edge
  • android:paddingStart Sets the padding at the start edge means at the left side of view
  • android:paddingEnd Sets the padding at the end edge means at the right side of view
  • android:paddingTop Sets the padding at the top edge

Margin

  • android:layout_marginBottom Specifies extra space on the bottom side of this view.
  • android:layout_marginEnd Specifies extra space on the end side, means at the right side of this view.
  • android:layout_marginStart Specifies extra space on the start side, means at the left of this view.
  • android:layout_marginTop Specifies extra space on the top side of this view.
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文