2016-05-08 11 views
0

1つのレイアウトの後に2つの線形レイアウトを追加したいと思います。問題は、私はこれらのレイアウトの重みをプログラマチックに設定できないということです。私はxmlの中でこれを行うことができましたが、私はプログラムでこれをしたいと思います。ここで私が何をしたいです:カスタムデザイン用のAndroidネスト型線形レイアウト

all are button

最初のボタンは、画面の全幅が含まれていますが、この2つのボタンの後に等しい幅を共有するというように...

は明らかに、プログラム的にそれを行う必要があります。

私のレイアウト:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:background="@drawable/background" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    xmlns:tools="http://schemas.android.com/tools" 
    tools:context=".HomeActivity"> 

    <ScrollView 
     android:id="@+id/scrollView1" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"> 

     <LinearLayout 
      android:id="@+id/linearLayout1" 
      android:orientation="vertical" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent"> 
     </LinearLayout> 


    </ScrollView> 
</LinearLayout> 

コード尻:

Button button = new Button(HomeActivity.this); 
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, 564); 
         layoutParams.setMargins(60, 80, 60, 40); 

Drawable drawable = Drawable.createFromStream(getAssets().open("image/GridButton/NovoTel_IGW_lg.png"), null); 
button.setBackground(drawable); 
button.setLayoutParams(layoutParams); 

linearLayout.addView(button); 

私はこのような出力を得た:

enter image description here

最良の方法である、提案してください。

答えて

1

ここに答えがあります。私はそれを味わった。それが満たされている場合は、答えとして

try { 

    DisplayMetrics dm = new DisplayMetrics(); 
    this.getWindow().getWindowManager().getDefaultDisplay().getMetrics(dm); 
    int width = dm.widthPixels; 
    int j = 0 ; 
    String image; 
    for(int i=0;i<(**JsonArray**).length();i++) { 

     JSONObject jsonObject1 = **JsonArray**.getJSONObject(i); 


     if(i==0) { 
      image = //DrawableImage; 
      drawable = Drawable.createFromStream(getAssets().open(image), null); 
      Button button = new Button(HomeActivity.this); 
      LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 564); 
      layoutParams.setMargins(60, 80, 60, 40); 
      button.setBackground(drawable); 
      button.setLayoutParams(layoutParams); 
      linearLayout.addView(button); 
     } 
     else 
     { 
      if(i%2 == 1) 
      { 
       image = //DrawableImage; 
       drawable = Drawable.createFromStream(getAssets().open(image), null); 
       LinearLayout linearLayout1=new LinearLayout(this); 
       linearLayout1.setOrientation(LinearLayout.HORIZONTAL); 
       Button button = new Button(HomeActivity.this); 
       LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(width/2-120, 564); 
       layoutParams.setMargins(60, 80, 60, 40); 
       button.setBackground(drawable); 
       button.setLayoutParams(layoutParams); 
       linearLayout1.addView(button); 


       if(i+1 < data.length()) 
       { 
        JSONObject jsonObject2 = data.getJSONObject(i+1); 
        image = //DrawableImage; 
        drawable = Drawable.createFromStream(getAssets().open(image), null); 
        Button button2 = new Button(HomeActivity.this); 
        button2.setBackground(drawable); 
        button2.setLayoutParams(layoutParams); 
        linearLayout1.addView(button2); 

       } 

       linearLayout.addView(linearLayout1); 

      } 
      else 
      { 
       continue; 
      } 

     } 


    } 




}catch (IOException ex) 
{ 
    return; 
} 
+0

ありがとうございました。それは私の質問を満たす。 –

2

これを実現する最も簡単な方法は、体重のあるLinearLayoutを使用することです。ここでは基本的な例です:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin" 
android:paddingBottom="@dimen/activity_vertical_margin" 
android:orientation="vertical" 
android:weightSum="3"> 


    <Button android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"/> 
    <LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:orientation="horizontal" 
      android:layout_weight="1" 
      android:weightSum="2"> 
     <Button android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> 
     <Button android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> 
    </LinearLayout> 
    <LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="0dp" 
      android:orientation="horizontal" 
      android:layout_weight="1" 
      android:weightSum="2"> 
     <Button android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> 
     <Button android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1"/> 
    </LinearLayout> 
</LinearLayout> 

出力: enter image description here

次に、あなたのグラフィックスの実装を開始することができます。推奨レイアウトではScrollViewは必要ありませんが、必要になった場合は後で追加することができます。

+1

ありがとう、私はそれをプログラムで必要とします。それは問題です。もし1つのアイテムなら、それはトップのように見えますが、それよりも1つ小さいパーツがそれに追加されます。 –

+0

'layoutParam.weight = 1;'を使ってみましたか? –

+0

私は試みましたが、変更はありませんでした。詳細コードを教えてください。 –

関連する問題