7

我试图做什么

我尝试通过 Java 代码设置我ImageButton的 's ,我想要的方式如下图橙色框架内的方式所示:layout_gravityImageButton

图片

蓝色框架是作为“基础”布局的垂直LinearLayout行为,这是我尝试添加子布局的布局。

橙色红色都是水平的LinearLayout

橙色布局是我想要放置的方式,ImageButton这个TextView是通过 XML 设置的

红色布局是我试图通过 Java 代码模仿橙色布局结果。

相关代码

这是设置Orange布局的 XML 代码,这是我想通过 Java 代码实现的效果:

        <!-- Begin the Orange Layout -->
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginLeft="@dimen/info_left_padding"
            android:layout_marginRight="@dimen/info_right_padding" >

            <TextView
                android:id="@+id/textView1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_vertical"
                android:gravity="center_vertical"
                android:minHeight="@dimen/detail_min_line_item_height"
                android:text="TextView" />

            <FrameLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content" >

                <ImageButton
                    android:id="@+id/imageButton1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="right|center_vertical"
                    android:adjustViewBounds="true"
                    android:maxHeight="@dimen/abs__action_bar_default_height"
                    android:scaleType="fitCenter"
                    android:src="@drawable/navigation_cancel" />
            </FrameLayout>
        </LinearLayout>

这是设置红色布局的 Java 代码

        int textHeight = (int)getResources().getDimension(R.dimen.detail_min_line_item_height);
        int imgHeight = (int)getResources().getDimension(R.dimen.abs__action_bar_default_height);

        TextView mTextView = new TextView(this);
        ImageButton mDeleteButton = new ImageButton(this);

        // Set Delete Button Padding
//      mDeleteButton.setPadding(buttonPadding, buttonPadding, buttonPadding, buttonPadding);

        // Set Imagebutton Scale type as fitCentre
        mDeleteButton.setScaleType(ScaleType.FIT_CENTER);

        // Set AdjustViewBounds
        mDeleteButton.setAdjustViewBounds(true);

        // Set max height of the image
        mDeleteButton.setMaxHeight(imgHeight);

        // Set the text appearance to be "large"
        mTextView.setTextAppearance(this, android.R.style.TextAppearance_Large);
        mTextView.setText(text);

        // Set the minimum height of this textview
        mTextView.setMinHeight(textHeight);

        // Set the content of the textview to be centred
        mTextView.setGravity(Gravity.CENTER_VERTICAL);

        // Set the ImageButton's background image
        mDeleteButton.setImageResource(R.drawable.navigation_cancel);

        LinearLayout.LayoutParams hParams = new LinearLayout.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);

        LinearLayout hLayout = new LinearLayout(this);
        // Set Margins
        hParams.leftMargin = (int) getResources().getDimension(R.dimen.info_left_padding);
        hParams.rightMargin = (int) getResources().getDimension(R.dimen.info_right_padding);
        hParams.bottomMargin = (int) getResources().getDimension(R.dimen.text_layout_margin);

        hLayout.setLayoutParams(hParams);
        // Set orientation to horizontal
        hLayout.setOrientation(LinearLayout.HORIZONTAL);

        // The settings below is actually setting up some of the button's parameters        
        LinearLayout.LayoutParams buttonParams = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
        buttonParams.gravity = Gravity.RIGHT;
        mDeleteButton.setLayoutParams(buttonParams);

        hLayout.addView(mTextView);
        hLayout.addView(mDeleteButton);

        layout_blue.addView(hLayout);

到目前为止我尝试过的

根据这样的一些 SO 帖子:Java method for android:layout_gravity我最初尝试先将 myImageButton放入 aFrameLayout然后设置 this 的参数FrameLayout,如下所示:

FrameLayout buttonFrame = new FrameLayout(this);
FrameLayout.LayoutParams buttonParams = new FrameLayout.LayoutParams(android.widget.FrameLayout.LayoutParams.WRAP_CONTENT, 
                                                                            android.widget.FrameLayout.LayoutParams.WRAP_CONTENT, 
                                                                            Gravity.RIGHT | Gravity.CENTER_VERTICAL);
buttonFrame.setLayoutParams(buttonParams);
buttonFrame.addView(mDeleteButton);

但我得到了与上面显示的图像相同的结果。后来我还尝试将LayoutParams宽度更改为 MATCH_PARENT only to find theImageButton`被水平拉伸(是的,它被拉伸了)

然后我尝试了这两个SO帖子中发布的方法:

如何以编程方式设置 layout_gravity?

如何以编程方式设置按钮的参数

他们的方法是先设置一个LinearLayout.Params,然后将此参数应用于按钮(我在相关代码部分发布的代码应用了此方法)。简而言之就是:

    // The settings below is actually setting up some of the button's parameters        
    LinearLayout.LayoutParams buttonParams = new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    buttonParams.gravity = Gravity.RIGHT;
    mDeleteButton.setLayoutParams(buttonParams);

但是,结果仍然与上面显示的图像相同。

问题

由于稍后我需要以编程方式将更多子视图添加到蓝色布局,我想知道是否有一种方法可以设置每个子布局,如图像中的橙色布局?

终于

我找到了一个与@Permita 的答案非常相似的解决方案。

这是我的解决方案:

    LinearLayout.LayoutParams textParams = new LinearLayout.LayoutParams(0, LayoutParams.WRAP_CONTENT);
    textParams.weight = 1.0f;
    mTextView.setLayoutParams(textParams);
4

3 回答 3

1

添加以下代码,它将所有可用空间分配给 texView,将按钮移动到布局的右侧,使其看起来像 orangeLayout。

mTextView.setLayoutParams(LayoutParams param = new LinearLayout.LayoutParams(
                         LayoutParams.MATCH_PARENT,
                         LayoutParams.MATCH_PARENT, 1.0f));
于 2013-04-10T09:27:00.027 回答
0

为 TextView 尝试 layout_width = "0dp" layout_weight="1"。这告诉 TextView 占据整个可用宽度,因此带有 ImageView 的 FrameLayout 将与右边框对齐。

    <TextView
        android:id="@+id/textView1"
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical"
        android:gravity="center_vertical"
        android:minHeight="@dimen/detail_min_line_item_height"
        android:text="TextView" />
于 2013-04-09T11:28:30.907 回答
0

与其使用标准LinearLayout,不如尝试使用更复杂的RelativeLayout?有了它,您可以调整每个单独视图相对于其他视图的位置。您可以将ImageButton橙色布局中的 设置为android:layout_alignParentRight="true",这会将附加到父布局右侧的按钮设置为,RelativeLayout在我的情况下,但LinearLayout在您的情况下。是 Android 开发者网站上相对布局的 API 指南的链接。

于 2013-04-09T14:15:54.087 回答