コードからlayout_weight属性を動的に設定する方法は?


244

layout_weightAndroidのボタンの属性の値をJavaコードから動的に設定するにはどうすればよいですか?


:それは非常にこの質問/答えのようになりますstackoverflow.com/questions/4638832/...と、この1:stackoverflow.com/questions/4637233/...
リッチシュラー

layout(xml)ファイルですでにビューを定義している場合、新しいLayoutParamsを作成すると、xmlファイルで定義されている他のパラメーターが上書きされます。したがって、最初に「getLayoutParams」を使用する必要があります。完全な回答を参照してくださいstackoverflow.com/questions/4641072/...
Shirish Herwade

回答:


462

LinearLayout.LayoutParamsコンストラクタの一部として渡すことができます:

LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(
    LayoutParams.MATCH_PARENT,
    LayoutParams.MATCH_PARENT,
    1.0f
);
YOUR_VIEW.setLayoutParams(param);

最後のパラメーターは重量です。


2
それはする必要がありますparam = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT, (float) 1.0);
Mithun Sreedharan

49
ダブルからフロートにキャストしたくない場合は、1.0fを入力してください
Xample

8
または1f、小数点以下の桁数がない場合は、もっと簡単に言えます
Sandalone 2013

4
親のレイアウトがどうなった場合Relative
プラティックブタニ2014年

9
@pratik親レイアウトが相対的である場合は、重みを使用しません
invertigo

121

使用LinearLayout.LayoutParams

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
    LayoutParams.WRAP_CONTENT, LayoutParams.MATCH_PARENT);
params.weight = 1.0f;
Button button = new Button(this);
button.setLayoutParams(params);

編集:ああ、エーリッヒの答えは簡単です!


27
エーリッヒのアンサーの方が書きやすいかもしれませんが、あなたの方が読みやすいです。1.0fがどの属性に使用されるかを示しているからです。
ヨハン

3
'view.getLayoutParams()'を呼び出してその場でウェイトを変更してから値を変更できることを確認しました。
RobGThai 2013

1
FILL_PARENTは非推奨であり、MATCH_PARENT代わりに使用する必要があります。
Simon Forsberg、2013年

2
@LocalPCGuy真実ではありません。SDK> = 8(絶対にそうする必要があります)をターゲットにしている限り、古いデバイスMATCH_PARENTFILL_PARENTも使用できます。
Kevin Coppock 2014

2
@LocalPCGuy API 7以下を使用する人はもういません。アプリをAPI 7以下と互換性を持たせようとしている場合、FILL_PARENTvs MATCH_PARENT。を心配する前に、他の多くの問題に遭遇するでしょう。
Simon Forsberg、2014

82

すでにlayout(xml)ファイルでビューを定義していて、プログラムでウェイトを変更したいだけの場合、この方法がより良いです

LinearLayout.LayoutParams params = (LinearLayout.LayoutParams)   
mButton.getLayoutParams();
params.weight = 1.0f;
mButton.setLayoutParams(params);

新しいLayoutParamsは、マージンなど、xmlファイルで定義された他のパラメーターを上書きするか、LayoutParamsですべてを指定する必要があります。


2
「params.weight = 1f;」の場合 LayoutParamsオブジェクトにすでにウェイトを設定しています。「mButton.setLayoutParams(params);」を呼び出す必要はありません。
MrMaffen 2015年

2
いいえ、setLayoutParamsを呼び出す必要があります
SIr Codealot

1
これは実際には最もエレガントな答えであり、特定のUIオブジェクトを直接変更します。最良の答えも良いですし、この投稿よりも古いです。だから、それは最良の答えに値する。私はこの投稿に賛成しました。
オリジナルのAndroid

素晴らしくてシンプルなソリューション!
ジェレミー

魅力的な作品!
どうも

26

幅、高さ、重量のコンストラクタが機能しない場合は、幅と高さのコンストラクタを使用してみてください。そして、手動で重量を設定します。

また、幅をウェイトに応じて設定する場合は、コンストラクターで幅を0に設定します。高さについても同様です。以下のコードは私のために働きます。

LinearLayout.LayoutParams childParam1 = new LinearLayout.LayoutParams(0,LinearLayout.LayoutParams.MATCH_PARENT);
childParam1.weight = 0.3f;
child1.setLayoutParams(childParam1);

LinearLayout.LayoutParams childParam2 = new LinearLayout.LayoutParams(0,LinearLayout.LayoutParams.MATCH_PARENT);
childParam2.weight = 0.7f;
child2.setLayoutParams(childParam2);

parent.setWeightSum(1f);
parent.addView(child1);
parent.addView(child2);

ちょうど私が必要なもの!ここではすべての人がウェイトの設定について話しているため、ウェイト付けされた子が親ビューに追加されたときに何が起こるかは誰にも表示されませんでした。ParentViewにweightSumを追加する方法を実際に探していました!ありがとう!
sud007 2016年

14

私が誰かが答えを探しているなら、これを使ってください:

LinearLayout.LayoutParams lay = (LinearLayout.LayoutParams) myLayout.getLayoutParams();
lay.weight = 0.5;

xmlファイルからレイアウトを初期化する場合、これは線形レイアウトに新しいレイアウトパラメータを提供するよりもはるかに便利です。


これは、幅/高さ/マージン/パディングなどの以前に設定された変数を変更しないため、受け入れられる答えになるはずです。重みが変更されている間、すべてが保持され、再利用されます。
MrMaffen 2015年

1
設定するビューlayout_weightがすでにレイアウトされている場合は、View.requestLayout()更新を呼び出す必要があります。
攻撃的2015

6

いずれかLinearLayout.LayoutParamsと、TableLayout.LayoutParams右の1があるボタンに、私のために働きましたTableRow.LayoutParams。あれは:

            TableRow.LayoutParams buttonParams = new TableRow.LayoutParams(
                    TableRow.LayoutParams.MATCH_PARENT,
                    TableRow.LayoutParams.WRAP_CONTENT, 1f);

使用について、MATCH_PARENTまたはWRAP_CONTENT同じであること。


3
FILL_PARENTは非推奨であり、MATCH_PARENT代わりに使用する必要があります。
Simon Forsberg、2013年

私はLayoutParams.MATCH_PARENTが0に変更されるべきだと思う
CoolMind

LayoutParams直接の親と呼びます。LinearLayout.LayoutParams親なしで使用しようとしたクラッシュがあったと思いますLinearLayout
放棄されたカート

4

layout(xml)ファイルでビューすでに定義しいて、重みのみを変更したい場合、プログラムで場合、新しいLayoutParamsを作成すると、xmlファイルで定義されている他のパラメーターが上書きされます。

したがって、最初に「getLayoutParams」を使用してから、setLayoutParamsを使用する必要があります。

LinearLayout.LayoutParams params = (LinearLayout.LayoutParams) mButton.getLayoutParams(); params.weight = 4f; mButton.setLayoutParams(params);


3

layoutparamsが(XMLまたは動的に)既に定義されている場合は、次のようになります。

((LinearLayout.LayoutParams) mView.getLayoutParams()).weight = 1;

過小評価された回答
アダムヒギンズ

0

Kotlinを使用すると、次のようなことができます。

import android.content.Context
import android.support.v4.content.ContextCompat
import android.support.v7.widget.CardView
import android.widget.*

import android.widget.LinearLayout

class RespondTo : CardView {
    constructor(context: Context) : super(context) {
        init(context)
    }

    private fun init(context: Context) {


        val parent = LinearLayout(context)

        parent.apply {
            layoutParams = LinearLayout.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT,
                    FrameLayout.LayoutParams.WRAP_CONTENT, 1.0f).apply {
                orientation = LinearLayout.HORIZONTAL

                addView(EditText(context).apply {
                    id = generateViewId()
                    layoutParams = LinearLayout.LayoutParams(0,
                            LinearLayout.LayoutParams.WRAP_CONTENT, 0.9f).apply {
                    }
                })
                addView(ImageButton(context).apply({
                    layoutParams = LinearLayout.LayoutParams(0,
                            LinearLayout.LayoutParams.WRAP_CONTENT, 0.1f)
                    background = null
                    setImageDrawable(ContextCompat.getDrawable(context, R.drawable.ic_save_black_24px))
                    id = generateViewId()
                    layoutParams = RelativeLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,
                            LinearLayout.LayoutParams.WRAP_CONTENT).apply {
                        addRule(RelativeLayout.ALIGN_PARENT_RIGHT)
                        // addRule(RelativeLayout.LEFT_OF, myImageButton.id)
                    }
                }))
            }
        }
        this.addView(parent)
    }
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.