Android 为滚动视图使用布局权重
我有三个滚动视图,应该相邻放置。我给每个人1磅。但他们所处的领域并不相同。第一个是占用总可用空间的1/2。接下来的两个将平均占用剩余的一半空间。这是Android 为滚动视图使用布局权重,android,scrollview,Android,Scrollview,我有三个滚动视图,应该相邻放置。我给每个人1磅。但他们所处的领域并不相同。第一个是占用总可用空间的1/2。接下来的两个将平均占用剩余的一半空间。这是xml文件。我哪里做错了 <TableLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/Ststus" andr
xml
文件。我哪里做错了
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/Ststus"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Search for Bluetooth devices"
android:layout_weight="1"/>
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ScrollView
android:id="@+id/ScrollView01"
android:layout_width="wrap_content"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_mobile"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Mobiles"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView02"
android:layout_width="wrap_content"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_laptops"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Computers"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView03"
android:layout_width="wrap_content"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_headset"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Headsets"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
</TableRow>
</TableLayout>
布局权重机制仅在第一次布局传递后分配剩余空间。在第一个布局过程中,滚动视图的宽度为
wrap\u content
wide。表行剩余的水平空间将根据重量分布
将宽度设为0px,使每个宽度占空间的1/3。将ScrollView的
android:layout\u width=“wrap\u content”
更改为android:layout\u width=“0dip”
试试这个
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/Ststus"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Search for Bluetooth devices"
android:layout_weight="1"/>
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ScrollView
android:id="@+id/ScrollView01"
android:layout_width="0dip"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_mobile"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Mobiles"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView02"
android:layout_width="0dip"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_laptops"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Computers"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView03"
android:layout_width="0dip"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_headset"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Headsets"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
</TableRow>
我认为使用线性布局而不是表格布局对您有好处。此外,滚动视图必须包含其所有子视图的父视图组。文本视图不是视图组。将线性布局或相对布局作为父级添加到滚动视图内的文本视图中。如果要为scrollView分配权重,请将布局宽度设置为“0dp”。更多参考请参见此。下面是示例代码:-
<ScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@id/bnext"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_alignStart="@id/bnext" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textView1"
android:visibility="gone" />
</LinearLayout>
最好使用线性布局而不是表格布局。。
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/Ststus"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Search for Bluetooth devices"
android:layout_weight="1"/>
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ScrollView
android:id="@+id/ScrollView01"
android:layout_width="0dp"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_mobile"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Mobiles"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView02"
android:layout_width="0dp"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_laptops"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Computers"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView03"
android:layout_width="0dp"
android:layout_height="150dip"
android:layout_weight="1">
<TextView
android:id="@+id/tv_headset"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Headsets"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
</TableRow>
</TableLayout>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/Ststus"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity"
android:orientation="horizontal" >
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Search for Bluetooth devices"
android:layout_weight="1"/>
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<ScrollView
android:id="@+id/ScrollView01"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:layout_weight="1" >
<TextView
android:id="@+id/tv_mobile"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Mobiles"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView02"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:layout_weight="1" >
<TextView
android:id="@+id/tv_laptops"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Computers"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
<ScrollView
android:id="@+id/ScrollView03"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:layout_weight="1" >
<TextView
android:id="@+id/tv_headset"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center|center_vertical"
android:text="Headsets"
android:textAppearance="?android:attr/textAppearanceLarge" />
</ScrollView>
</TableRow>