Quiero obtener algo asi

aim

Pero he obtenido esto

:(.

Fragment toma toda la pantalla. ¿Cómo puedo configurarlo, por ejemplo, para una altura de 500 ppp y para el diseño de la lista para la pantalla de descanso?

Pregunta 2. ¿Existe alguna posibilidad de mostrar / ocultar anuncios Button, que cambiará el tamaño de Fragment (al mostrar el elemento, la altura de Fragment aumentó y ocultará la lista)

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.k.guides4art20.MainActivity"
>
<TableLayout
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:shrinkColumns="*"
    android:stretchColumns="0"
    android:orientation="vertical" >


    <TableRow android:id="@+id/tableRow1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center_horizontal"
        android:padding="5dip" >


        <EditText
            android:layout_height="wrap_content"
            android:hint="szukaj"
            android:gravity="center"
            android:textSize="25sp"
            android:id="@+id/search_bar"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:maxLines="1" />

        <Button
            android:id="@+id/filters"
            android:layout_width="80dp"
            android:layout_height="wrap_content"
            android:text="filtry"
            android:textSize="15sp"
            android:minHeight="0dp"
            android:minWidth="10dp"
            android:layout_gravity="right" />

    </TableRow>

    <TableRow
        android:id="@+id/tableRow2"
        android:layout_width="fill_parent"
        android:layout_height="400dp"
         >

        <fragment xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:map="http://schemas.android.com/apk/res-auto"
            xmlns:tools="http://schemas.android.com/tools"
            android:id="@+id/map"
            android:name = "com.google.android.gms.maps.SupportMapFragment"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            tools:context="com.example.k.guides4art20.MapsActivity"
            android:layout_above="@+id/textView"
            android:layout_alignParentStart="true"
            android:layout_span="2" />

    </TableRow>

    <TableRow
        android:id="@+id/tableRow4"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="5dip" >


        <ListView
            android:id="@+id/listView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_span="2">

        </ListView>
        </TableRow>

</TableLayout>
0
Expiredmind 13 sep. 2016 a las 14:02

3 respuestas

La mejor respuesta

Inserte el fragmento en el diseño y configure layout_height

      <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    tools:context="com.example.k.guides4art20.MainActivity"
    android:id="@id/main"
    android:orientation="vertical">
    <LinearLayout
        android:orientation="horizontal"
        android:minWidth="25px"
        android:minHeight="25px"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/searchBarLay">
        <EditText
            android:hint="szukaj"
            android:gravity="center"
            android:textSize="25sp"
            android:id="@+id/search_bar"
            android:maxLines="1"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:layout_weight="1" />
        <Button
            android:id="@+id/filters"
            android:text="filtry"
            android:textSize="15sp"
            android:minHeight="0dp"
            android:minWidth="10dp"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:autoText="false" />
    </LinearLayout>
    <LinearLayout
        android:orientation="vertical"
        android:minWidth="25px"
        android:minHeight="25px"
        android:layout_width="match_parent"
        android:layout_height="280dp"
        android:id="@+id/mapLay"
        android:background="@color/blue25">
        <fragment xmlns:map="http://schemas.android.com/apk/res-auto"
            android:id="@+id/map"
            android:name="com.google.android.gms.maps.SupportMapFragment"
            tools:context="com.example.k.guides4art20.MapsActivity"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>
    <LinearLayout
        android:orientation="vertical"
        android:minWidth="25px"
        android:minHeight="25px"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/listLay">
        <ListView
            android:id="@+id/listView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>
</LinearLayout>

Pregunta 2 Sí, puede hacer esto. Cambiando el parámetro Visibilidad.

layMap.Visibility = ViewStates.Gone;
layList.Visibility = ViewStates.Visible;
1
M. Wiśnicki 13 sep. 2016 a las 12:14

Usaría LinearLayout o RelativeLayout como contenedor de sus elementos en lugar de TableLayout, luego en su conjunto de fragmentos

android:layout_height="500dp"
0
Julián Martínez 13 sep. 2016 a las 11:13

Tome el diseño lineal como padre y divida la pantalla en porciones utilizando el atributo de peso. En una toma un fragmento y en el otro lado toma un fragmento de mapa. Esto resolverá tu problema. De lo contrario, el mapa ocupará toda la pantalla. O puede mover el cajón deslizante de navegación para mantenerlo abierto fijo para dispositivos de gran tamaño y para los pequeños mantenerlo oculto y controlarlo con el icono de hamburguesa.

0
Preetika Kaur 13 sep. 2016 a las 11:12