2012-03-01 62 views
1

我有一个带有自定义项目视图的ListView。项目布局由ImageView,3xTextViews和3x小型ImageView(代码如下)组成。问题是我希望所有ImageView始终可见,并强制TextViews调整它们的宽度和文本以正确分解为多行。下面是它的样子:ListView项目布局问题 - 将ImageView和TextView结合起来

Layout problem

下面是版面项目的xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_height="wrap_content" android:id="@+id/linearLayout1" android:layout_width="fill_parent"> 
    <ImageView android:layout_width="85dp" android:layout_height="85dp" android:id="@+id/imageView1" ></ImageView> 
    <LinearLayout android:layout_height="match_parent" android:id="@+id/linearLayout2" android:layout_width="wrap_content" android:orientation="vertical" android:paddingLeft="3dp"> 
     <TextView android:text="aa24324234" android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textStyle="bold" android:textColor="@android:color/primary_text_dark"></TextView> 
     <TextView android:text="bb22222" android:id="@+id/textView2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textStyle="italic" ></TextView> 
     <TextView android:text="ccvvvvbb" android:id="@+id/textView3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textStyle="italic"></TextView> 
    </LinearLayout> 

    <LinearLayout 
     android:id="@+id/linearLayout3" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:orientation="horizontal" 
     android:gravity="bottom|right"> 

     <ImageView 
      android:id="@+id/imageView4" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:src="@android:drawable/ic_menu_save" /> 

     <ImageView 
      android:id="@+id/imageView3" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:src="@android:drawable/ic_lock_lock" /> 

     <ImageView 
      android:id="@+id/imageView2" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:src="@android:drawable/ic_lock_lock" /> 

    </LinearLayout> 

</LinearLayout> 

回答

1

试试这个布局:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/linearLayout1" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" > 

    <ImageView 
     android:id="@+id/imageView1" 
     android:layout_width="85dp" 
     android:layout_height="85dp" 
     android:src="@drawable/ic_launcher" > 
    </ImageView> 

    <LinearLayout 
     android:id="@+id/linearLayout2" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_toRightOf="@id/imageView1" 
     android:orientation="vertical" > 

     <TextView 
      android:id="@+id/textView1" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="Jopek" 
      android:textColor="@android:color/primary_text_dark" 
      android:textStyle="bold" > 
     </TextView> 

     <TextView 
      android:id="@+id/textView2" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="3 items" > 
     </TextView> 

     <TextView 
      android:id="@+id/textView3" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="Modified: 24-02-2012 20:11 asd asd asd a asdad asd " > 
     </TextView> 
    </LinearLayout> 

    <LinearLayout 
     android:id="@+id/linearLayout3" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:gravity="right" 
     android:orientation="horizontal" > 

     <ImageView 
      android:id="@+id/imageView4" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:background="@drawable/ic_launcher" /> 

     <ImageView 
      android:id="@+id/imageView3" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:background="@drawable/ic_launcher" /> 

     <ImageView 
      android:id="@+id/imageView2" 
      android:layout_width="24dp" 
      android:layout_height="24dp" 
      android:background="@drawable/ic_launcher" /> 
    </LinearLayout> 

</RelativeLayout> 
+0

在XML视图3个图像看起来就像它们在屏幕底部,但在运行时,它看起来perfect.Try吧! – Pankaj 2012-03-01 16:02:39

0

尽量减少TextView的大小在纵向布局

0

使用了一个相对布局列表行的主要根目录布局,首先将ImageView设置在右侧,并将一个图像视图显示在文件夹图标上,将其放置在行的左侧,然后将ImageView(s)的左侧设置为textview(s)和Ima的权利geView(文件夹)。