2013-05-19 126 views
0

我想使三個按鈕應該對齊'+ id/imageRecorder'的中心。但3個按鈕現在開始從屏幕的邊緣,希望有所幫助Android線性佈局(3個按鈕)不能居中屏幕

這裏是xml代碼,如何使三個按鈕是屏幕的中心。

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:background="@color/myBackground" 
    android:orientation="vertical" > 


    <ImageView 
     android:id="@+id/imageRecorder" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_centerHorizontal="true" 
     android:layout_marginTop="10dp" 
     android:src="@drawable/recorder" /> 

    <RadioGroup 
     android:id="@+id/radioGroupAudio" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_centerHorizontal="true"   
     android:layout_marginTop="20dp" 
     android:layout_below="@+id/imageRecorder" 
     android:orientation="horizontal" > 

     <RadioButton 
      android:id="@+id/radiowav" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:onClick="onRadioButtonClicked" 
      android:text="@string/wav" 
      android:textAppearance="?android:attr/textAppearanceMedium" 
      android:textColor="@color/myText" /> 

     <RadioButton 
      android:id="@+id/radiomp3" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:onClick="onRadioButtonClicked" 
      android:text="@string/mp3" 
      android:textAppearance="?android:attr/textAppearanceMedium" 
      android:textColor="@color/myText" /> 
    </RadioGroup> 

    <LinearLayout 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:layout_marginTop="30dp" 
     android:layout_centerHorizontal="true"     
     android:layout_below="@+id/radioGroupAudio" 
     android:orientation="horizontal" > 

     <ImageButton 
      android:id="@+id/buttonStart" 
      android:layout_width="76dp" 
      android:layout_height="44dp" 
      android:background="#00FFFFFF" 
      android:scaleType="fitXY" 
      android:layout_marginRight="20dp" 
      android:layout_toLeftOf="@+id/buttonPause" 
      android:src="@drawable/play_off" /> 

     <ImageButton 
      android:id="@+id/buttonPause" 
      android:layout_width="76dp" 
      android:layout_height="44dp" 
      android:background="#00FFFFFF" 
      android:scaleType="fitXY" 
      android:layout_below="@+id/imageRecorder" 
      android:layout_centerInParent="true"    
      android:src="@drawable/pause_off" /> 

     <ImageButton 
      android:id="@+id/buttonStop" 
      android:layout_width="76dp" 
      android:layout_height="44dp" 
      android:background="#00FFFFFF" 
      android:scaleType="fitXY" 
      android:layout_marginLeft="20dp" 
      android:layout_toRightOf="@+id/buttonPause" 
      android:src="@drawable/stop_off" /> 
    </LinearLayout> 

</RelativeLayout> 

回答

1

嘗試改變:

android:layout_centerHorizontal="true" 

到:

android:gravity="center_horizontal" 

在LinearLayout中與3個按鈕

2

改變你的LinearLayoutwrap_contentwidth應該照顧它。隨着fill_parent將要佔據整個width所以自然會開始在屏幕的開始

<LinearLayout 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_marginTop="30dp" 
    android:layout_centerHorizontal="true"     
    android:layout_below="@+id/radioGroupAudio" 
    android:orientation="horizontal" > 

此外,height改爲wrap_content因爲你不想讓它佔據整個屏幕。需要注意的是fill_parent已被棄用,所以你應該使用match_parent代替

+0

它的作品!非常感謝 !!! –

+0

不客氣!請接受的時候會讓你:) – codeMagic