android - 防止 child 离开屏幕边界

标签 android android-layout

我有一个 layout,里面有 textview 和另一个 layout。我需要 textview 作为 wrap_content 但可以拉伸(stretch)到父级宽度,而它旁边的布局不会离开屏幕。

我尝试使用 relativeLinearLayout,无论我做什么,message_indicators 布局都会在 message_text< 时离开屏幕 延伸到 match_parent。我在这里想要的是 message_text 随内容延伸,并且 message_indicators 需要紧挨着它,而不会在消息内容增加时离开屏幕。

这是我的代码:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:padding="10dp" >

<TextView
    android:id="@+id/message_text"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_toLeftOf="@+id/message_indicators"
    android:autoLink="all"
    android:background="@drawable/text_bubble_left"
    android:clickable="true"
    android:paddingBottom="10dp"
    android:paddingLeft="20dp"
    android:paddingRight="10dp"
    android:paddingTop="10dp"
    android:text="@string/message_text_hint"
    android:textAppearance="?android:attr/textAppearanceMedium"
    android:textColor="@color/white" />

<LinearLayout
    android:id="@+id/message_indicators"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/message_text"
    android:layout_alignParentRight="true"
    android:orientation="vertical"
    android:paddingLeft="10dp" >

    <ImageView
        android:id="@+id/message_lock_indicator"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_lock"
        android:contentDescription="@string/message_locked_content_description"
        android:paddingBottom="5dp"/>

    <TextView
        android:id="@+id/message_time"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/message_time_hint"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="@color/gray" />
</LinearLayout>

</RelativeLayout>

这是截图。顶部消息表示长消息的外观,中间是当前布局的短消息,底部是短消息的外观:

最佳答案

我找到了执行此操作的最佳方法。

这是解决方案。

<?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="wrap_content"
    android:orientation="vertical" >

<include
    android:id="@+id/message_section_header"
    layout="@layout/message_section_header" />

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center_vertical"
    android:paddingBottom="10dp"
    android:paddingTop="10dp" >

    <View
        android:id="@+id/message_bubble_arrow"
        android:layout_width="20dp"
        android:layout_height="20dp"
        android:background="@drawable/message_bubble_left_arrow"
        android:rotation="-90" />

    <TextView
        android:id="@+id/message_text"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:autoLink="all"
        android:background="@drawable/message_bubble_left"
        android:clickable="true"
        android:padding="10dp"
        android:text="@string/message_text_hint"
        android:textAppearance="?android:attr/textAppearanceMedium"
        android:textColor="@color/white" />

    <LinearLayout
        android:id="@+id/message_indicators"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:minWidth="60dp"
        android:orientation="vertical"
        android:overScrollMode="always"
        android:paddingLeft="10dp" >

        <ImageView
            android:id="@+id/message_lock_indicator"
            style="@style/Layout.Wrap"
            android:contentDescription="@string/message_locked_content_description"
            android:paddingBottom="5dp"
            android:src="@drawable/ic_lock" />

        <TextView
            android:id="@+id/message_time"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/message_time_hint"
            android:textAppearance="?android:attr/textAppearanceSmall"
            android:textColor="@color/gray" />
    </LinearLayout>
</LinearLayout>

关于android - 防止 child 离开屏幕边界,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22859790/

相关文章:

android - Android ImageView 上的减法滤镜(从图像或 View 对象中切出羽毛状椭圆)

android - 在哪里放置 uiautomator 测试

java - 在 string.xml 中调用变量

android - 以编程方式完成时来自 SOAP 的响应不正确

android - 根据设备使用的布局动态使用 ListView 或 GridView

android - 如何指定在软键盘上显示哪些键? (安卓)

android - 如何在 React Native 中实现类似 CoordinatorLayout 的功能?

java - "Catch"一种方法的多个按钮

相当于早期 sdk 的 Android gridview

同时检测父 View 和 subview 的 Android-Touch 事件