É possível colocar um ponto de vista em detrimento de outro em android?
-
26-09-2019 - |
Pergunta
Podemos colocar uma sobre a outra grande exibição?Por exemplo, eu tenho um VideoView que é a reprodução de um ficheiro em segundo plano.Sobre isso, em algum lugar no meio/canto, eu quero colocar outro ImageView.
Mas no Linear Relativo/Layout, pontos de vista só podem ser colocados um após o outro, ou em relação ao outro, e AbsoluteLayout é desaconselhada.Então, o que eu faço?
Solução
FrameLayouts
Deixe você empilhar cada vista sobre a abaixo. Isso também pode ser alcançado com um RelativeLayout
.
Outras dicas
O FrameLayout
é o mais simples ViewGroup
e empilha o Views
na ordem em que eles são definidos no esquema XML (ou adicionados por programação);o primeiro será menor, e o último será em cima.
Aqui está um exemplo onde duas Views
são empilhadas e o deslocamento para melhor ilustrar o ponto:
Aqui é o atual layout XML com dois sobrepostos TextView
caixas.O deslocamento das duas caixas é feito usando android:layout_gravity
enquanto android:gravity
é usado para centralizar o texto em si dentro de cada caixa.
<?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>
Apenas se você deseja colocar uma exibição em cima de um ButtonView, use isso;android:elevation="7dp"
Para a visualização que precisa ser colocada em cima do botão.
Você também pode fazer isso usando Restantlayout Um novo layout introduzido pelo Google.
A RectrainLayout permite criar layouts grandes e complexos com uma hierarquia de visão plana (sem grupos de visão aninhada).
<?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>
<?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>