RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 643197
Accepted
RareScrap
RareScrap
Asked:2020-03-23 17:33:42 +0000 UTC2020-03-23 17:33:42 +0000 UTC 2020-03-23 17:33:42 +0000 UTC

只有一个元素时如何使用layout_weight(相对布局题)

  • 772

下午好。有标记

<ImageView
    android:id="@+id/imageView4"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    myapp:srcCompat="@mipmap/ic_launcher"
    android:layout_weight="9" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_gravity="center_horizontal"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Button
        android:id="@+id/button"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="OK" />

    <Button
        android:id="@+id/button2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Отмена" />
</LinearLayout>

此布局使用 layout_weight 在 90%(图片)和 10%(按钮栏)之间拆分屏幕。我在 css 中使用 layout_weight 之类的百分比

如何使 10% 的屏幕高度仍然分配在带有按钮的面板下,但同时使 ImageView 不出现在布局中(如果从上面的标记中删除它,则面板带有按钮将占据整个屏幕)? 在此处输入图像描述

为什么我需要这个:我想为我的列表 制作这样一个元素在此处输入图像描述

在我看来,这件事是这样完成的:图片被拉伸到屏幕的宽度和高度(不要忘记我们只是从列表中输入ELEMENT),从下面添加一个 FrameLayout,其中一个透明图片设置为背景参数。然后将 TextView 放在 FrameLayout 上

在此处输入图像描述

我不想以特定数字设置 FrameLayout 的高度,因为我认为这会影响应用程序在小屏幕上的外观。而且我一开始用的方法也不合适,因为。图片也显示在 FrameLayout 下。当上面没有元素时,如何将 FrameLayout 的高度设置为百分比?您如何看待这种方法?我是设计和布局的新手,所以我很想听听您的意见和建议。

提前致谢!

android
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    pavlofff
    2020-03-23T19:39:21Z2020-03-23T19:39:21Z

    我建议不要太聪明并使用以下标记:

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="4dp">
    
    
        <ImageView
            android:id="@+id/imageView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:adjustViewBounds="true"
            android:scaleType="centerCrop"
            android:src="@drawable/sushi" />
    
        <TextView
            android:id="@+id/textView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_alignParentLeft="true"
            android:background="@color/backgraundAlpha"
            android:paddingBottom="20dp"
            android:paddingLeft="8dp"
            android:paddingRight="8dp"
            android:paddingTop="20dp"
            android:text="Loren Ipsum" />
    </RelativeLayout>
    

    res/values/colors.xml 文件:

    <resources>
    
        <color name="backgraundAlpha">#50000000</color>
    </resources>
    

    ImageView用 CenterCrop 填充占据整个可用宽度和所需的高度空间,并确定父容器的大小(其高度wrap_content)。
    TextView捕捉到容器的底部边缘并具有半透明背景和填充以增加高度。它们不会正好是 10%,但它们看起来总是与文本和谐。你可以自己选择一个特定的值(我有20dp)。

    相反TextView,你可以使用 horizo​​ntal LinearLayout,例如,如果你想在底部放置几个元素

    这是最后发生的事情:

    在此处输入图像描述

    • 2
  2. zTrap
    2020-03-23T17:46:13Z2020-03-23T17:46:13Z

    对于百分比的相对布局,Android support percentGoogle 的库非常棒。可以在habrahabr.ru上找到使用它的示例

    • 1
  3. Eugene Troyanskii
    2020-03-24T19:29:31Z2020-03-24T19:29:31Z

    当然,对于这种野蛮的做法,我深表歉意,但为什么不直接将 ImageView 替换为空格,以免与第三方库打交道,而不必面对它们带来的问题。space 是一种轻量级标记元素,旨在填充像您这样的情况下的空白空间。

    <android.support.v4.widget.Space

    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="9" />
    
    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5