2016-09-12 4 views
0

Я работаю над приложением Xamarin, но я считаю, что эта концепция также применима к Android.LinearLayout под GridView не обертывает содержимое

Я хотел бы показать свои обернутые LinearLayout элементы в GridView, как показано ниже. Но это не выглядит так, как я ожидал.

Есть ли что-нибудь, что мне не хватает здесь?

LinearLayout

Код:

Main.axml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:orientation="vertical" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:minWidth="25px" 
android:minHeight="25px"> 
<GridView 
    android:minWidth="25px" 
    android:minHeight="25px" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:id="@+id/gridViewHomeItems" 
    android:horizontalSpacing="10px" 
    android:verticalSpacing="10px" 
    /> 

HomeItem.axml

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:minWidth="25px" 
    android:minHeight="25px" 
    android:padding="25px"> 
    <ImageView 
     android:src="@android:drawable/ic_menu_gallery" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:id="@+id/homeItemImage" /> 
    <TextView 
     android:text="Item Title" 
     android:textAppearance="?android:attr/textAppearanceMedium" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:id="@+id/homeItemTitle" /> 
</LinearLayout> 
+0

Вы пробовали с моим ответом? –

ответ

1

Удалите px со свойствами. Используйте вместо этого sp или dp. То же самое относится и к Grid View layout.

Like this.

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:minHeight="25dp" 
    android:minWidth="25dp" 
    android:orientation="vertical" 
    android:padding="25dp"> 

    <ImageView 
     android:id="@+id/homeItemImage" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:src="@android:drawable/ic_btn_speak_now" /> 

    <TextView 
     android:id="@+id/homeItemTitle" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:text="Item Title" 
     android:textAppearance="?android:attr/textAppearanceMedium" /> 
</LinearLayout> 

Grid View как этот

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:minHeight="25dp" 
    android:minWidth="25dp" 
    android:orientation="vertical"> 


     <GridView 
     android:id="@+id/gridViewHomeItems" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:columnWidth="96dp" 
     android:horizontalSpacing="10dp" 
     android:minHeight="25dp" 
     android:minWidth="25dp" 
     android:numColumns="auto_fit" 
     android:verticalSpacing="10dp" />  



</LinearLayout> 
+1

Это отлично работает, спасибо! –

0

Попробуйте добавить этот atributes. Main.axml # GridView:

android:columnWidth="96dp" 
android:numColumns="auto_fit" 

HomeItem.axml (#ImageView и #TextView):

android:layout_centerHorizontal="true" 
0

Попробуйте приведенный ниже код в макете.

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

    <GridView 
     android:numColumns="auto_fit" 
     android:gravity="center" 
     android:columnWidth="100dp" 
     android:stretchMode="columnWidth" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:id="@+id/gridViewHomeItems" 
     /> 

</LinearLayout> 

Изменение пользовательского макета, как показано ниже:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:minHeight="25dp" 
       android:minWidth="25dp" 
       android:orientation="vertical" 
       android:padding="10dp"> 

    <ImageView 
     android:id="@+id/homeItemImage" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:src="@android:drawable/ic_menu_gallery"/> 

    <TextView 
     android:id="@+id/homeItemTitle" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:text="Item Title" 
     android:textAppearance="?android:attr/textAppearanceMedium"/> 
</LinearLayout> 

Также убедитесь, что вы используете dp вместо px согласно андроида стандартам.

Смежные вопросы