Android 布局为图片创建两行一列组合
Android layout creating two rows with one column combined for the picture
我正在尝试创建这样的布局。首先,GridLayout
是解决此问题的最佳方法吗?我尝试了许多不同的布局,但每个都有自己的问题。下面是我试过的代码。任何帮助表示赞赏。提前致谢。
<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:rowCount="2"
android:columnCount="3">
<ImageButton
android:src="@drawable/avatar_male_update"
android:scaleType="fitCenter"
android:adjustViewBounds="true"
android:layout_height="100dp"
android:layout_width="100dp"
android:layout_row="0"
android:layout_column="0"
android:id="@+id/imageButtonMale" />
<Button
android:text="Refresh"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:background="@drawable/mybutton"
android:layout_row="0"
android:layout_column="1"
android:id="@+id/btnCSRefresh" />
<Button
android:text="Change Avatar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/mybutton"
android:layout_row="0"
android:layout_column="2"
android:id="@+id/btnChangeAvatar" />
<LinearLayout
android:orientation="vertical"
android:layout_row="1"
android:layout_column="0"
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="50dp"
android:id="@+id/linearLayoutButtons">
<TextView
android:text="Welcome "
android:textAppearance="?android:attr/textAppearanceMedium"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/txtViewHeader"
android:background="#FE6A00" />
<ListView
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/lstViewSummary" />
</LinearLayout>
我不太清楚你真正想要的是什么,因为你在 xml 中使用了列表视图,所以请 post 更清楚地了解你的问题。
试试这个布局:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minHeight="100dp"
android:minWidth="100dp"
android:src="@drawable/ic_launcher" />
<RelativeLayout
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" />
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/button1" />
<Button
android:id="@+id/button3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/button1" />
<Button
android:id="@+id/button4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/button2"
android:layout_toRightOf="@+id/button3" />
</RelativeLayout>
</LinearLayout>
我应该否决你的问题,因为你的 xml 与你的照片不符!
但是如果你想要你在图片中画的东西:
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ImageView
android:align_parentLeft="true"
android:center_in_vertical="true"
android:id="@+id/imageButtonMale"
android:layout_height="100dp"
android:layout_width="100dp" />
<View
android:id="@+id/spacer1"
android:layout_width="match_parent"
android:layout_height="0dp"
android:align_toRightOf="@id/imageButtonMale"
android:center_vertical="true" />
<Button
android:text="Refresh"
android:id="@+id/btnCSRefresh"
android:layout_above="@id/spacer1"
android:align_toRightOf="@id/imageButtonMale"
android:layout_width="100dp"
android:layout_height="100dp" />
<Button
android:text="Change Avatar"
android:id="@+id/btnChangeAvatar"
android:layout_above="@id/spacer1"
android:align_toRightOf="@id/btnCSRefresh"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:text="Row2Col1"
android:id="@+id/button_below_refresh_button"
android:layout_below="@id/spacer1"
android:align_toRightOf="@id/imageButtonMale"
android:layout_width="100dp"
android:layout_height="100dp" />
<Button
android:text="Row2Col2"
android:id="@+id/button_below_change_avatar_button"
android:layout_below="@id/spacer1"
android:align_toRightOf="@id/button_below_in_col1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>
几点:
这将环绕,这意味着如果您希望它扩展到屏幕宽度,您可以将相对布局父宽度更改为 match_parent
。现在,根据您是否希望按钮宽度相等,您可以将它们的宽度更改为 match_parent
,但是您必须将 android:align_parentRight
更改为第 2 列中的两个按钮,并添加 android:align_toLeftOf="@id/button_in_col2"
到第一列中的按钮(即,第一列中的按钮位于图像视图的右侧和第二列中按钮的右侧;列中的按钮与其父级右对齐;两个按钮,匹配父级与上述对齐将占用相等的 space)。
我正在尝试创建这样的布局。首先,GridLayout
是解决此问题的最佳方法吗?我尝试了许多不同的布局,但每个都有自己的问题。下面是我试过的代码。任何帮助表示赞赏。提前致谢。
<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:rowCount="2"
android:columnCount="3">
<ImageButton
android:src="@drawable/avatar_male_update"
android:scaleType="fitCenter"
android:adjustViewBounds="true"
android:layout_height="100dp"
android:layout_width="100dp"
android:layout_row="0"
android:layout_column="0"
android:id="@+id/imageButtonMale" />
<Button
android:text="Refresh"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:background="@drawable/mybutton"
android:layout_row="0"
android:layout_column="1"
android:id="@+id/btnCSRefresh" />
<Button
android:text="Change Avatar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/mybutton"
android:layout_row="0"
android:layout_column="2"
android:id="@+id/btnChangeAvatar" />
<LinearLayout
android:orientation="vertical"
android:layout_row="1"
android:layout_column="0"
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="50dp"
android:id="@+id/linearLayoutButtons">
<TextView
android:text="Welcome "
android:textAppearance="?android:attr/textAppearanceMedium"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/txtViewHeader"
android:background="#FE6A00" />
<ListView
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/lstViewSummary" />
</LinearLayout>
我不太清楚你真正想要的是什么,因为你在 xml 中使用了列表视图,所以请 post 更清楚地了解你的问题。
试试这个布局:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minHeight="100dp"
android:minWidth="100dp"
android:src="@drawable/ic_launcher" />
<RelativeLayout
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" />
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/button1" />
<Button
android:id="@+id/button3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/button1" />
<Button
android:id="@+id/button4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/button2"
android:layout_toRightOf="@+id/button3" />
</RelativeLayout>
</LinearLayout>
我应该否决你的问题,因为你的 xml 与你的照片不符!
但是如果你想要你在图片中画的东西:
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ImageView
android:align_parentLeft="true"
android:center_in_vertical="true"
android:id="@+id/imageButtonMale"
android:layout_height="100dp"
android:layout_width="100dp" />
<View
android:id="@+id/spacer1"
android:layout_width="match_parent"
android:layout_height="0dp"
android:align_toRightOf="@id/imageButtonMale"
android:center_vertical="true" />
<Button
android:text="Refresh"
android:id="@+id/btnCSRefresh"
android:layout_above="@id/spacer1"
android:align_toRightOf="@id/imageButtonMale"
android:layout_width="100dp"
android:layout_height="100dp" />
<Button
android:text="Change Avatar"
android:id="@+id/btnChangeAvatar"
android:layout_above="@id/spacer1"
android:align_toRightOf="@id/btnCSRefresh"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:text="Row2Col1"
android:id="@+id/button_below_refresh_button"
android:layout_below="@id/spacer1"
android:align_toRightOf="@id/imageButtonMale"
android:layout_width="100dp"
android:layout_height="100dp" />
<Button
android:text="Row2Col2"
android:id="@+id/button_below_change_avatar_button"
android:layout_below="@id/spacer1"
android:align_toRightOf="@id/button_below_in_col1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>
几点:
这将环绕,这意味着如果您希望它扩展到屏幕宽度,您可以将相对布局父宽度更改为 match_parent
。现在,根据您是否希望按钮宽度相等,您可以将它们的宽度更改为 match_parent
,但是您必须将 android:align_parentRight
更改为第 2 列中的两个按钮,并添加 android:align_toLeftOf="@id/button_in_col2"
到第一列中的按钮(即,第一列中的按钮位于图像视图的右侧和第二列中按钮的右侧;列中的按钮与其父级右对齐;两个按钮,匹配父级与上述对齐将占用相等的 space)。