Можно ли разместить один вид поверх другого в Android? - PullRequest
20 голосов
/ 29 сентября 2010

Можем ли мы разместить небольшой вид поверх другого большого вида?Например, у меня есть VideoView, который воспроизводит файл в фоновом режиме.За это, где-то в середине / углу, я хочу разместить еще один ImageView.

Но в линейном / относительном расположении представления могут быть размещены только один за другим или относительно друг друга, и AbsoluteLayout не рекомендуется.Так что мне делать?

Ответы [ 5 ]

27 голосов
/ 15 сентября 2016

FrameLayout является самым простым ViewGroup и укладывает Views в том порядке, в котором они определены в XML макета (или добавлены программно); первый будет ниже, а последний будет сверху.

Вот пример, где два Views сложены и смещены для лучшей иллюстрации точки:

enter image description here

Вот фактический макет XML с двумя перекрывающимися TextView блоками. Смещение двух полей выполняется с помощью android:layout_gravity, в то время как android:gravity используется для центрирования текста внутри каждого поля.

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="100dp"
    android:layout_height="100dp">

    <TextView
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_gravity="top|left"
        android:background="@android:color/holo_blue_light"
        android:gravity="center"
        android:text="First is below"/>

    <TextView
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_gravity="bottom|right"
        android:background="@android:color/holo_green_light"
        android:gravity="center"
        android:text=" Last is on top"/>

</FrameLayout>
15 голосов
/ 29 сентября 2010

FrameLayouts позволяет вам складывать каждый вид сверху того, что ниже. Это также может быть достигнуто с помощью RelativeLayout.

8 голосов
/ 28 марта 2018

На всякий случай, если вы хотите разместить представление поверх ButtonView, используйте это;android:elevation="7dp" для представления, которое должно быть расположено сверху кнопки.

2 голосов
/ 12 апреля 2017
<?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="match_parent"
    android:padding="@dimen/dp_20"
    android:background="@color/yellow"
    >
        <VideoView
            android:id="@+id/videoview"
            android:layout_width="wrap_content"
            android:layout_centerInParent="true"
            android:layout_height="300dp"
            android:contentDescription="@string/app_name"
             />

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/camera"
            android:layout_margin="30dp"
            android:layout_alignParentEnd="true"
            android:layout_centerVertical="true"
            android:id="@+id/imageView" />

</RelativeLayout>
1 голос
/ 27 апреля 2017

Вы также можете сделать это, используя ConstraintLayout новый макет, представленный Google.

ConstraintLayout позволяет создавать большие и сложные макеты с плоской иерархией видов (без вложенных групп видов).

 <?xml version="1.0" encoding="utf-8"?>
  <android.support.constraint.ConstraintLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/container"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  android:layout_weight="4"
  tools:context="com.edalat.example.MainActivity">
  <VideoView
    android:id="@+id/videoView"
    android:layout_width="283dp"
    android:layout_height="349dp"
    app:layout_constraintBottom_toBottomOf="parent"
    android:layout_marginBottom="24dp"
    app:layout_constraintTop_toTopOf="parent"
    android:layout_marginTop="24dp"
    android:layout_marginRight="24dp"
    app:layout_constraintRight_toRightOf="parent"
    android:layout_marginLeft="24dp"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintHorizontal_bias="0.509"/>
  <ImageView
     android:id="@+id/imageView"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     app:srcCompat="@mipmap/ic_launcher"
     app:layout_constraintTop_toTopOf="parent"
     android:layout_marginTop="24dp"
     app:layout_constraintBottom_toBottomOf="parent"
     android:layout_marginBottom="24dp"
     android:layout_marginLeft="24dp"
     app:layout_constraintLeft_toLeftOf="parent"
     android:layout_marginRight="24dp"
     app:layout_constraintRight_toRightOf="parent"/>
   </android.support.constraint.ConstraintLayout>
...