基础复习——文本显示——TextView——设置视图的宽高——设置视图之间的间距:layout_margin以及padding——设置视图的对其方式:layout_gravity以及gravity...

本文详细介绍了Android中设置视图宽高、间距和对齐方式的方法。视图宽度和高度可通过match_parent、wrap_content或dp值来设定。margin属性用于设置视图间间距,padding属性用于设置内部间距。同时,layout_gravity决定视图在上级视图的位置,而gravity则决定了下级视图在当前视图的位置。通过实例展示了不同设置的效果。

设置视图的宽高: 

视图宽度通过属性android:layout_width表达,视图高度通过属性android:layout_height表达,宽高的取值主要有下列三种:


(1)match_parent:表示与上级视图保持一致。
(2)wrap_content:表示与内容自适应。
(3)以dp为单位的具体尺寸。

手机屏幕是长方形区域:短的叫宽,长的叫高:

(1)、控件宽度通过--------android:layout_width-----------设置

(2)、控件高度通过--------android:layout_height-----------设置

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ 

宽和高的取值,主要有3种:

(1)、match_parent:表示与上级视图保持一致。上级视图的尺寸有多大,当前视图的尺寸就有多大。

(2)、wrap_content:表示与内容自适应。对于文本视图来说,内部文字需要多大的显示空间,当前视图就要占据多大的尺寸。

                                      但最宽不能超过上级视图的宽度,一旦超过,就会换行;最高不能超过上级视图的高度,一旦超过就会隐藏。

(3)、以dp为单位的具体尺寸,比如300dp,表示宽度和高度就这么大。

布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:background="#00ffff"
        android:text="视图宽度采用wrap_content定义"
        android:textColor="#000000"
        android:textSize="17sp" />

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:background="#00ffff"
        android:text="视图宽度采用match_parent定义"
        android:textColor="#000000"
        android:textSize="17sp" />

    <TextView
        android:layout_width="300dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:background="#00ffff"
        android:text="视图宽度采用固定大小"
        android:textColor="#000000"
        android:textSize="17sp" />

    <TextView
        android:id="@+id/tv_code"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="5dp"
        android:background="#00ffff"
        android:text="通过代码指定视图宽度"
        android:textColor="#000000"
        android:textSize="17sp" />
</LinearLayout>

 

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

设置视图之间的间距:

设置视图的间距有两种方式:

(1)采用layout_margin属性,它指定了当前视图与周围平级视图之间的距离(包括上级视图和平级视图)

        包括:layout_margin、layout_marginLeft、layout_marginTop、layout_marginRight、layout_marginBottom;

(2)采用padding属性,它指定了当前视图与内部下级视图之间的距离(包括下级视图和内部文本)

       包括:padding、paddingLeft、paddingTop、paddingRight、paddingBottom;

android:layout_margin="30dp"  ———— 一次性设置四周的间距
android:layout_marginTop="30dp"  -----该属性的作用是让当前视图与上方间隔一段距离

android:layout_marginBottom="30dp"-----该属性的作用是让当前视图与下方间隔一段距离

android:layout_marginLeft="30dp"-----该属性的作用是让当前视图与左边间隔一段距离

android:layout_marginRight="30dp"-----该属性的作用是让当前视图与右边间隔一段距离

 注意:layout_margin不单单用于文本视图,还可以用于所有视图,包括各类布局和各类控件。

           因为不管是布局还是控件,它们统统由视图基类View派生而来,而layout_margin正式View的一个通用属性。

           除了layout_margin外,padding也是View的一个通用属性,它用来设置视图的内部间距。

 布局:

<!-- 最外层的布局背景为蓝色 -->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="300dp"
android:background="#00aaff"
android:orientation="vertical">

<!-- 中间层的布局背景为黄色 -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="60dp" 指定当前视图与周围平级视图之间的间距
android:background="#ffff99"
android:padding="10dp"> 指定当前视图与内部下级视图之间的距离

<!-- 最内层的视图背景为红色 -->
<View
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ff0000" />
</LinearLayout>

</LinearLayout>
<!-- 最外层的布局背景为蓝色 -->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="300dp"
    android:background="#00aaff"
    android:orientation="vertical">

    <!-- 中间层的布局背景为黄色 -->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_margin="60dp"
        android:background="#ffff99"
        android:padding="10dp">

        <!-- 最内层的视图背景为红色 -->
        <View
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="#ff0000" />
    </LinearLayout>

</LinearLayout>

 

 

 ===================================================================================================

 设置视图的对齐方式:

 设置视图的对齐方式有两种途径:

(1)采用layout_gravity属性,它指定了当前视图相对于上级视图的对齐方式

(2)采用gravity属性,它指定了下级视图相对于当前视图的对齐方式

layout_gravity与gravity的取值包括:left、top、right、bottom,还可以用竖线连接各取值,例如“left|top”表示即靠左又靠上,也就是朝左上角对齐。

 布局:

<!-- 最外层的布局背景为橙色,它的下级视图在水平方向排列 -->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="300dp"
    android:background="#ffff99"
    android:padding="10dp">

    <!-- 第一个子布局背景为红色,它在上级视图中朝下对齐,它的下级视图则靠左对齐 -->
    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="200dp"
        android:layout_weight="1"
        android:layout_gravity="bottom"
        android:gravity="left"
        android:background="#ff0000"
        android:layout_margin="10dp"
        android:padding="10dp">

        <!-- 内部视图的宽度和高度都是100dp,且背景色为青色 -->
        <View
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:background="#00ffff" />
    </LinearLayout>

    <!-- 第二个子布局背景为红色,它在上级视图中朝上对齐,它的下级视图则靠右对齐 -->
    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="200dp"
        android:layout_weight="1"
        android:layout_gravity="top"
        android:gravity="right"
        android:background="#ff0000"
        android:layout_margin="10dp"
        android:padding="10dp">

        <!-- 内部视图的宽度和高度都是100dp,且背景色为青色 -->
        <View
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:background="#00ffff" />
    </LinearLayout>
</LinearLayout>

 

 

由效果图可见,第一个子布局朝下,并且它的内部视图靠左;而第二个子布局朝上,并且它的内部视图靠右。

对比 XML 文件中的 layout_gravity 和 gravity 取值,证明了二者的对齐情况正如之前所言:layout_ gravity 决定当前视图位于上级视图的哪个方位,而 gravity 决定了下级视图位于当前视图的哪个方位。

<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent"> <GridLayout android:layout_width="match_parent" android:layout_height="match_parent" android:columnCount="3" android:rowCount="16"> <TextView android:id="@+id/TCU_id" android:text="设备地址" android:layout_row="0" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/TCU_id_1" android:layout_width="0dp" android:layout_row="0" android:layout_rowWeight="1" android:layout_column="1" android:layout_columnWeight="1" android:layout_gravity="fill" android:hint="请输入设备地址" android:padding="10dp" /> <Button android:id="@+id/TCU_id_set" android:layout_width="0dp" android:layout_row="0" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="地址设置" /> <TextView android:id="@+id/TCU_type" android:text="TCU类型" android:layout_row="1" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <Spinner android:id="@+id/TCU_type_1" android:hint="请选择" android:layout_row="1" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:spinnerMode="dropdown" android:entries="@array/tcu_types" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/TCU_type_set" android:layout_width="0dp" android:layout_row="1" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="类型选择" /> <TextView android:id="@+id/accuracy" android:text="跟踪精度" android:layout_row="3" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/accuracy_1" android:hint="请输入跟踪精度" android:layout_row="3" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/accuracy_set" android:layout_width="0dp" android:layout_row="3" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="精度设置" /> <TextView android:id="@+id/electricity_over" android:text="过流值" android:layout_row="4" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/electricity_over_1" android:hint="请输入过流值" android:layout_row="4" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/electricity_over_set" android:layout_width="0dp" android:layout_row="4" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="过流值设置" /> <TextView android:id="@+id/text_1" android:text="天文参数" android:layout_row="5" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <TextView android:id="@+id/longitude" android:text="经度" android:layout_row="6" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/longitude_1" android:hint="请输入经度" android:layout_row="6" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <TextView android:id="@+id/latitude" android:text="纬度" android:layout_row="7" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/latitude_1" android:hint="请输入纬度" android:layout_row="7" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/twcs_set" android:layout_width="0dp" android:layout_row="7" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="天文参数设置" /> <TextView android:id="@+id/time" android:text="时间" android:layout_row="8" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/time_set" android:layout_width="0dp" android:layout_row="8" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="时间同步" /> <TextView android:id="@+id/timezone" android:text="时区" android:layout_row="9" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/timezone_1" android:hint="请输入时区" android:layout_row="9" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/timezone_set" android:layout_width="0dp" android:layout_row="9" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="时区设置" /> <TextView android:id="@+id/text_2" android:text="无线模块参数" android:layout_row="10" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <TextView android:id="@+id/module" android:text="无线模块" android:layout_row="11" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <Spinner android:id="@+id/module_1" android:hint="请选择" android:layout_row="11" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:spinnerMode="dropdown" android:entries="@array/tcu_types" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/module_set" android:layout_width="0dp" android:layout_row="11" android:layout_column="2" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:backgroundTint="#C8142D" android:padding="10dp" android:text="模块选择" /> <TextView android:id="@+id/route" android:text="信道" android:layout_row="12" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/routewang_1" android:hint="请输入信道" android:layout_row="12" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <TextView android:id="@+id/PINID" android:text="网络ID" android:layout_row="13" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/PINID_1" android:hint="请输入网络ID" android:layout_row="13" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> <TextView android:id="@+id/address" android:text="模块地址" android:layout_row="14" android:layout_column="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <EditText android:id="@+id/address_1" android:hint="请输入模块地址" android:layout_row="14" android:layout_column="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="fill" android:padding="10dp" android:layout_width="0dp"/> </GridLayout> </FrameLayout>页面只显示一行,不能滑动
12-24
那接下来几个界面也像这样修改成这种形式,只用最小量修改。首先是fragment_home.xml:<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".ui.home.HomeFragment" android:fitsSystemWindows="true" android:background="@color/surface_background"> <!-- 🔍 输入框 --> <EditText android:id="@+id/home_input" android:layout_width="0dp" android:layout_height="wrap_content" android:hint="请输入需要查询的公交线路或站点" android:textColorHint="#777777" android:textColor="@color/black" android:background="@drawable/rounded_edittext" android:minHeight="48dp" android:textSize="16sp" android:padding="12dp" app:layout_constraintTop_toTopOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toStartOf="@id/home_search" app:layout_constraintHorizontal_chainStyle="packed" android:layout_marginStart="16dp" android:layout_marginEnd="8dp" android:layout_marginTop="88dp" /> <!-- 🔎 搜索按钮 --> <Button android:id="@+id/home_search" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="搜索" app:layout_constraintTop_toTopOf="@id/home_input" app:layout_constraintBottom_toBottomOf="@id/home_input" app:layout_constraintStart_toEndOf="@id/home_input" app:layout_constraintEnd_toEndOf="parent" android:layout_marginEnd="16dp" /> <!-- 🚌 图片:居中偏上 --> <ImageView android:id="@+id/image_bus" android:layout_width="wrap_content" android:layout_height="wrap_content" android:scaleType="fitCenter" android:src="@drawable/bus" app:layout_constraintTop_toBottomOf="@id/home_input" app:layout_constraintBottom_toTopOf="@+id/text_home" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:layout_marginTop="144dp" android:layout_marginBottom="144dp"/> <!-- ℹ️ 底部说明文字 --> <TextView android:id="@+id/text_home" android:textColor="#777777" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginStart="8dp" android:layout_marginEnd="8dp" android:textAlignment="center" android:textSize="11sp" app:layout_constraintTop_toBottomOf="@id/image_bus" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintBottom_toBottomOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout> 其次是fragment_map.xml:<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".ui.map.MapFragment" android:fitsSystemWindows="true" android:background="@color/surface_background"> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline_top_offset" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="horizontal" app:layout_constraintGuide_percent="0.015" /> <!-- 🔹 起点输入框 --> <EditText android:id="@+id/map_input1" android:layout_width="0dp" android:layout_height="48dp" android:hint="请输入起点" android:textColorHint="#777777" android:textColor="@color/black" android:background="@drawable/rounded_edittext" android:padding="12dp" android:layout_marginStart="16dp" android:layout_marginEnd="8dp" android:layout_marginTop="32dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toStartOf="@id/guideline_search" app:layout_constraintTop_toTopOf="@id/guideline_top_offset" /> <!-- 🔹 终点输入框 --> <EditText android:id="@+id/map_input2" android:layout_width="0dp" android:layout_height="48dp" android:hint="请输入终点" android:textColorHint="#777777" android:textColor="@color/black" android:background="@drawable/rounded_edittext" android:padding="12dp" android:layout_marginStart="16dp" android:layout_marginEnd="8dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toStartOf="@id/guideline_search" app:layout_constraintTop_toBottomOf="@id/map_input1" /> <!-- ✅ 分割线:75% 处(原样保留) --> <androidx.constraintlayout.widget.Guideline android:id="@+id/guideline_search" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical" app:layout_constraintGuide_percent="0.75" /> <!-- 🔍 搜索按钮:纵向拉高,覆盖两个输入框 --> <Button android:id="@+id/map_search" android:layout_width="0dp" android:layout_height="0dp" android:text="搜索" android:textSize="16sp" android:gravity="center" app:layout_constraintStart_toStartOf="@id/guideline_search" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintTop_toTopOf="@id/map_input1" app:layout_constraintBottom_toBottomOf="@id/map_input2" android:layout_marginEnd="16dp" /> <!-- 🗺️ 地图视图:从终点输入框下方开始,延伸到底部 --> <com.amap.api.maps.MapView android:id="@+id/map_view" android:text="Bus-1.0" android:textColor="#777777" android:layout_width="0dp" android:layout_height="0dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintTop_toBottomOf="@id/map_input2" app:layout_constraintBottom_toBottomOf="parent" android:layout_marginTop="4dp" android:layout_marginBottom="0dp"/> </androidx.constraintlayout.widget.ConstraintLayout> 接着是fragment_settings.xml:<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".ui.settings.SettingsFragment" android:fitsSystemWindows="true" android:background="@color/surface_background"> <!-- 🔹 Material Design 按钮组 --> <Button android:id="@+id/btn_gps" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="权限设置" app:layout_constraintTop_toTopOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="56dp" /> <Button android:id="@+id/btn_apps" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="关于公交查询系统" app:layout_constraintTop_toBottomOf="@id/btn_gps" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="16dp" /> <Button android:id="@+id/btn_user" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="用户调研" app:layout_constraintTop_toBottomOf="@id/btn_apps" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="16dp" /> <Button android:id="@+id/btn_exit" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="退出程序" app:layout_constraintTop_toBottomOf="@id/btn_user" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" android:layout_marginStart="16dp" android:layout_marginEnd="16dp" android:layout_marginTop="16dp" /> <!-- 🔹 图片:放在按钮下方 --> <ImageView android:id="@+id/image_bus" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="64dp" android:layout_marginBottom="64dp" android:src="@drawable/bus" app:layout_constraintBottom_toTopOf="@+id/text_settings" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toBottomOf="@id/btn_exit" /> <!-- 🔹 底部 TextView --> <TextView android:id="@+id/text_settings" android:text="Bus-1.0" android:textColor="#777777" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginStart="8dp" android:layout_marginEnd="8dp" android:textAlignment="center" android:textSize="11sp" app:layout_constraintTop_toBottomOf="@id/image_bus" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintBottom_toBottomOf="parent" /> </androidx.constraintlayout.widget.ConstraintLayout> 还有activity_survey.xml:<?xml version="1.0" encoding="utf-8"?> <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="16dp" android:fitsSystemWindows="true" android:background="@color/surface_background"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <!-- 问题1:评分 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:layout_marginBottom="32dp" android:text="🚌 用户体验调研" android:textColor="#777777" android:textSize="24sp" android:textStyle="bold" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1. 您对本应用的整体评分是?" android:textStyle="bold" android:textColor="#777777" android:layout_marginBottom="8dp" /> <RadioGroup android:id="@+id/radioGroupRating" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="24dp"> <RadioButton android:text="⭐ 1分 - 非常不满意" android:textColor="@color/black" android:id="@+id/rb1" android:layout_height="match_parent" android:layout_width="match_parent"/> <RadioButton android:text="⭐⭐ 2分 - 不满意" android:textColor="@color/black" android:id="@+id/rb2" android:layout_height="match_parent" android:layout_width="match_parent"/> <RadioButton android:text="⭐⭐⭐ 3分 - 一般" android:textColor="@color/black" android:id="@+id/rb3" android:layout_height="match_parent" android:layout_width="match_parent"/> <RadioButton android:text="⭐⭐⭐⭐ 4分 - 满意" android:textColor="@color/black" android:id="@+id/rb4" android:layout_height="match_parent" android:layout_width="match_parent"/> <RadioButton android:text="⭐⭐⭐⭐⭐ 5分 - 非常满意" android:textColor="@color/black" android:id="@+id/rb5" android:layout_height="match_parent" android:layout_width="match_parent"/> </RadioGroup> <!-- 问题2:满意度 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="2. 您对以下哪些方面或功能感到满意?(可多选)" android:textColor="#777777" android:textStyle="bold" android:layout_marginBottom="8dp" /> <CheckBox android:id="@+id/cb_ui" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="界面美观易用" android:textColor="@color/black"/> <CheckBox android:id="@+id/cb_speed" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="加载速度快" android:textColor="@color/black"/> <CheckBox android:id="@+id/cb_information" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="查询信息准确" android:textColor="@color/black"/> <CheckBox android:id="@+id/cb_other" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="其他" android:textColor="@color/black"/> <!-- 问题3:建议 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="3. 您有什么改进建议?" android:textColor="#777777" android:textStyle="bold" android:layout_marginTop="24dp" android:layout_marginBottom="8dp" /> <EditText android:id="@+id/et_suggestion" android:layout_width="match_parent" android:layout_height="120dp" android:gravity="top" android:hint="请输入您的建议..." android:textColorHint="#777777" android:textColor="@color/black" android:inputType="textMultiLine" android:minLines="3" /> <!-- 提交按钮 --> <Button android:id="@+id/btn_submit" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="提交反馈" android:textSize="18sp" android:layout_marginTop="32dp" style="?android:attr/buttonStyle" /> </LinearLayout> </ScrollView> 和activity_about.xml:<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:gravity="center" android:padding="20dp" android:fitsSystemWindows="true" android:background="@color/surface_background"> <!-- 软件名称 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="公交查询系统" android:textSize="28sp" android:textStyle="bold" android:textColor="#000" android:layout_marginBottom="10dp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Bus" android:textSize="18sp" android:textColor="#555555" android:layout_marginBottom="80dp" /> <!-- 软件图片 --> <ImageView android:layout_width="match_parent" android:layout_height="wrap_content" android:src="@drawable/bus" android:layout_marginBottom="100dp"/> <!-- 版本信息 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="版本:1.0" android:textSize="16sp" android:textColor="#777777" android:layout_marginBottom="20dp" /> <!-- 开发信息 --> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="开发团队:white luminous" android:textSize="16sp" android:textColor="#777777" android:layout_marginBottom="10dp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="邮箱:support@busapp.cn" android:textColor="#777777" android:textSize="16sp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="hao" android:textSize="8sp" android:layout_marginTop="100dp" android:textColor="#EEE"/> </LinearLayout> 以及activity_route_plan.xml: <!-- res/layout/activity_route_plan.xml --> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:fitsSystemWindows="true" android:background="@color/surface_background"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="正在规划公交路线..." android:textSize="16sp" android:gravity="center" android:padding="16dp" android:textColor="#555" /> <com.amap.api.maps.MapView android:id="@+id/map_view" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout>
11-07
<TextView android:id="@+id/text2" android:text="工作模式:" android:layout_column="0" android:layout_row="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/button1" android:text="参数写入" android:layout_column="0" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button2" android:text="参数写入" android:layout_column="1" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button3" android:text="参数写入" android:layout_column="2" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button4" android:text="参数写入" android:layout_column="3" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> </GridLayout>将按键在水平方向上适当间隔
最新发布
12-25
<GridLayout android:layout_width="match_parent" android:layout_height="match_parent" android:columnCount="4" android:rowCount="30"> <TextView android:id="@+id/text2" android:text="工作模式:" android:layout_column="0" android:layout_row="0" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp"/> <Button android:id="@+id/button1" android:text="参数写入" android:layout_column="0" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button2" android:text="参数写入" android:layout_column="1" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button3" android:text="参数写入" android:layout_column="2" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> <Button android:id="@+id/button4" android:text="参数写入" android:layout_column="3" android:layout_row="1" android:layout_columnWeight="1" android:layout_rowWeight="1" android:layout_gravity="center_vertical" android:padding="10dp" android:layout_width="0dp" android:backgroundTint="#C8142D"/> </GridLayout>四个按键左右加一点间隔
12-25
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值