Android Horizo​​ntalScrollView内容Stretch

时间:2012-07-11 00:44:46

标签: java android android-xml horizontalscrollview

我有一个带有一些按钮的Horizo​​ntalScrollView,我试图拉伸这些按钮来填充Horizo​​ntalScrollView的整个宽度,这样它们就可以看起来有条理并且彼此间隔相等。这是我的形象。 HorizontalScrollView content Unstretched

我希望这4个按钮在整个宽度上拉伸!这是我的代码

    <HorizontalScrollView
    android:id="@+id/items_HorizontalBar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/vf"
    android:background="#80000000"
    android:fillViewport="true" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="fill_parent"
        android:orientation="horizontal" >

        <Button
            android:layout_width="90dp"
            android:layout_height="fill_parent"
            android:layout_margin="5dp"
            android:background="@android:color/transparent"
            android:drawableTop="@drawable/rss"
            android:text="Light"
            android:textColor="@color/green_color"
            android:textSize="20sp" />

        <Button
            android:layout_width="90dp"
            android:layout_height="fill_parent"
            android:layout_margin="5dp"
            android:background="@android:color/transparent"
            android:drawableTop="@drawable/rss"
            android:text="Door"
            android:textColor="@color/green_color"
            android:textSize="20sp" />

        <Button
            android:layout_width="90dp"
            android:layout_height="fill_parent"
            android:layout_margin="5dp"
            android:background="@android:color/transparent"
            android:drawableTop="@drawable/rss"
            android:text="Alarms"
            android:textColor="@color/green_color"
            android:textSize="20sp" />

        <Button
            android:layout_width="90dp"
            android:layout_height="fill_parent"
            android:layout_margin="5dp"
            android:background="@android:color/transparent"
            android:drawableTop="@drawable/rss"
            android:text="Window"
            android:textColor="@color/green_color"
            android:textSize="20sp" />
    </LinearLayout>
</HorizontalScrollView>

3 个答案:

答案 0 :(得分:1)

您应该遵循将LinearLayout(或垂直)设置为 HorizontalScrollView 的正确解决方案,而不是弄乱FillViewPort

<强> XML:

android:fillViewport="true"

<强>编程:

hsv.setFillViewport(true);

答案 1 :(得分:0)

尝试使容器成为水平滚动视图。之后添加表格布局,并在表格的每一行中添加一个水平线性图层。现在会发生什么,是滚动视图将被拉伸以适应您设置的按钮大小,并且应该滚动w / o您必须编程一个东西,并且您应该有效地创建了一个网格。 尝试类似的东西:

<?xml version="1.0" encoding="utf-8"?>
<HorizontalScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/sc1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="horizontal" >

<TableLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <TableRow
        android:id="@+id/tableRow1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

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



            <Button
                android:id="@+id/button1"
                android:layout_width="180dp"
                android:layout_height="wrap_content"
                android:text="Button" />



            <Button
                android:id="@+id/button2"
                android:layout_width="180dp"
                android:layout_height="wrap_content"
                android:text="Button" />



            <Button
                android:id="@+id/button3"
                android:layout_width="230dp"
                android:layout_height="wrap_content"
                android:text="Button" />



            <Button
                android:id="@+id/button4"
                android:layout_width="233dp"
                android:layout_height="wrap_content"
                android:text="Button" />

        </LinearLayout>

    </TableRow>

    <TableRow
        android:id="@+id/tableRow2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
    </TableRow>

    <TableRow
        android:id="@+id/tableRow3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
    </TableRow>

    <TableRow
        android:id="@+id/tableRow4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >
    </TableRow>
</TableLayout>

也许您可以在垂直滚动视图中包裹水平滚动视图,然后您可以向上/向下,向左/向右滚动并根据需要进行操作。

答案 2 :(得分:0)

对于相等的分布,请设置父级的 weightSum 值,并为其子级分配 layout_weight

对于4个相同大小的按钮,将android:weightSum="1"添加到LinearLayout。对于设置android:layout_width="0dp"的每个按钮,然后添加android:layout_weight="0.25"

这是代码中发生的情况,但根据视图,Eclipse GUI中的“均匀分布权重”按钮也可以提供帮助。

但是,HorizontalScrollView只能托管一个直接子项,我不知道这个布局的结构......