簡體   English   中英

Android Horizo​​ntalScrollView內容拉伸

[英]Android HorizontalScrollView content Stretch

我有一個帶有某些按鈕的Horizo​​ntalScrollView,我試圖拉伸這些按鈕以填充Horizo​​ntalScrollView的整個寬度,以便它們可以看起來井井有條,彼此之間等距。 這是我的圖像。 Horizo​​ntalScrollView內容未拉伸

我希望這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>

您應該遵循正確的解決方案,即將HorizontalScrollView (或Vertical)設置為FillViewPort而不是與LinearLayout FillViewPort

XML:

android:fillViewport="true"

編程方式:

hsv.setFillViewport(true);

嘗試使容器成為水平滾動視圖。 之后,添加表格布局,並在表格的每一行中添加水平線性層。 現在將發生的事情是,滾動視圖將被拉伸以適合您設置的按鈕大小,並且在無需編寫任何東西的情況下應該滾動,並且您應該已經有效地創建了網格。 試試類似的東西:

<?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>

同樣,也許您可​​以將水平滾動視圖包裝在垂直滾動視圖中,然后可以向上/向下,向左/向右滾動並根據需要進行操作。

對於相等的分布,請設置父級的weightSum值,然后將layout_weight分配給其子級。

對於4個大小相等的按鈕,將android:weightSum="1"到LinearLayout。 為每個按鈕設置android:layout_width="0dp" ,然后添加android:layout_weight="0.25"

這就是代碼中發生的情況,但是根據視圖,Eclipse GUI中的“平均分配權重”按鈕也可以提供幫助。

但是, Horizo​​ntalScrollView只能容納一個直子,我想知道這種布局的結構...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM