2013-03-24 80 views
0

我正在使用一系列ImageButton和TextView对象作为标题。我想以统一的尺寸显示图像,填充屏幕的宽度(用户界面强制进入横向模式)。 我的XML布局包括以下内容: 在嵌套的线性布局对象中显示均匀的图像视图

 <LinearLayout 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonHolidays" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:contentDescription="@string/holidays" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/hagim" /> 

      <TextView 
       android:id="@+id/EditTextHoliday" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:gravity="center" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:background="@color/White" 
       android:textColor="@color/Black" 
       android:text="@string/holidays" /> 

     </LinearLayout> 

     <LinearLayout 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonPeople" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:contentDescription="@string/people" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/people" /> 

      <TextView 
       android:id="@+id/editTextPeople" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:gravity="center" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:background="@color/White" 
       android:textColor="@color/Black" 
       android:text="@string/professions" /> 

     </LinearLayout> 

    </LinearLayout> 

据我所知,这两个垂直的LinearLayout对象包含有完全相同的参数配置的对象,除了文本和实际的图像对象。图像对象的大小完全相同。尽管如此,UI显示以下内容:

Screenshot

任何解释,将不胜感激。

回答

0

您可以使用weights来避免这种情况。您必须将LinearLayouts的宽度设置为0dp并设置权重1.现在,两个子视图都将占用父视图宽度的50%(这是我假设的LinearLayout,否则这将不起作用) 。

 <LinearLayout 
      android:layout_width="0dp" 
      android:layout_height="wrap_content" 
      android:layout_weight="1" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonHolidays" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:contentDescription="@string/holidays" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/hagim" /> 

      <TextView 
       android:id="@+id/EditTextHoliday" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:gravity="center" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:background="@color/White" 
       android:textColor="@color/Black" 
       android:text="@string/holidays" /> 

     </LinearLayout> 

     <LinearLayout 
      android:layout_width="0dp" 
      android:layout_height="wrap_content" 
      android:layout_weight="1" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonPeople" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:contentDescription="@string/people" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/people" /> 

      <TextView 
       android:id="@+id/editTextPeople" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:gravity="center" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:background="@color/White" 
       android:textColor="@color/Black" 
       android:text="@string/professions" /> 

     </LinearLayout> 

    </LinearLayout> 
+0

好的,这有帮助,但我仍然有灰色填充图像上方和下方,尽管事实上,我将LinearLayout高度设置为wrap_content(同样对于儿童) – 2013-03-24 16:04:37

0

硬编码ImageButton的宽度会产生所需的效果。没有我想要的那样优雅或灵活,但它可以在多个平台上运行,所以我想我可以忍受它。

 <LinearLayout 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:orientation="horizontal" > 

     <LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_margin="@dimen/chooser_bottom_margin" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonVegFruit" 
       android:layout_width="200dp" 
       android:layout_height="150dp" 
       android:layout_gravity="center" 
       android:contentDescription="@string/vegetables" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/fruitveg" /> 

      <TextView 
       android:id="@+id/EditTextVegFruit" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:background="@color/White" 
       android:gravity="center_horizontal" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:text="@string/VegFruit" 
       android:textColor="@color/Black" /> 
     </LinearLayout> 

     <LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_margin="@dimen/chooser_bottom_margin" 
      android:orientation="vertical" > 

      <ImageButton 
       android:id="@+id/imageButtonClothes" 
       android:layout_width="200dp" 
       android:layout_height="150dp" 
       android:layout_gravity="center" 
       android:contentDescription="@string/clothing" 
       android:gravity="center" 
       android:onClick="chooseType" 
       android:scaleType="fitCenter" 
       android:src="@drawable/clothes" /> 

      <TextView 
       android:id="@+id/EditTextClothes" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:background="@color/White" 
       android:gravity="center_horizontal" 
       android:inputType="none" 
       android:onClick="chooseType" 
       android:text="@string/clothing" 
       android:textColor="@color/Black" /> 
     </LinearLayout> 
    </LinearLayout> 
相关问题