• 【Android】-- 关于文本和视图的基本操作(设置内容、大小、颜色、宽高、间距、对齐方式)


    下面介绍一下android如何设置文本内容、设置文本字体大小、文本颜色、视图宽高、视图间距、和视图的对齐方式,只简单说明一下如何操作,具体知识后续。

    目录文件说明

    mainifests子目录:下面的AndroidMainifest.xml文件是APP的运行配置文件。

    java子目录:下面有三个com.example.myapp包,第一个包存放当前模块的java源代码,后面两个包存放测试用的java代码。

    res子目录:存放当前模块的资源文件,有四个子目录:

    •                                 drawable目录存放图形描述文件与图片文件
    •                                 layout目录存放app页面的布局文件
    •                                 mipmap存放app的启动图标
    •                                 values存放一些常量定义文件,如字符串常量string.xml等。


     

    一、设置文本内容

    有两种方式:在XML文件中设置和在java类中调用settext方法。

    在XML文件中通过属性android:text设置

    1、在layout文件下新建一个xml文件

    新建后会有以下默认内容:

    1. "1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent">
    5. LinearLayout>

    2、配置XML文件,设置文本

    LinearLayout标签里添加以下内容;

    text标签里不写具体的内容是因为:

    情况:多个文件都用了相同的内容,但是需要修改此内容,那么就需要修改多个文件,而把内容写在string文件里,则只需要修改string文件的内容。

    1. <TextView
    2. android:id="@+id/tv_hello"
    3. android:layout_width="wrap_content"
    4. android:layout_height="wrap_content"
    5. android:text="@string/hello"/> //调用string文件里name为hello的文本

     3、string文件内容

    1. <resources>
    2. <string name="app_name">test</string>
    3. <string name="hello">你好</string>
    4. </resources>

     4、java类调用

    新建Java类,继承AppComatActivity类,并重写onCreate方法

    1. public class TextViewActivity extends AppCompatActivity {
    2. @Override
    3. protected void onCreate(@Nullable Bundle savedInstanceState) {
    4. super.onCreate(savedInstanceState);
    5. setContentView(R.layout.activity_text_view);
    6. }
    7. }

    在java代码中调用文本视图对象的setText方法设置文本

    与前面不同的是不需要在xml文件中写text标签,需要在java类中创建对象并调用setText方法。

    1. public class TextViewActivity extends AppCompatActivity {
    2. @Override
    3. protected void onCreate(@Nullable Bundle savedInstanceState) {
    4. super.onCreate(savedInstanceState);
    5. setContentView(R.layout.activity_text_view);
    6. TextView tv_hello = findViewById(R.id.tv_hello);
    7. tv_hello.setText(R.string.hello);// 调用setText方法设置文本
    8. }
    9. }

    二、设置文本的大小

    px:是手机屏幕的最小显示单位,与设备的显示屏有关。

    dp/dip:是与设备无关的显示单位,只与屏幕的尺寸有关,相同尺寸手机,即使分辨率不同,同dp组件占用屏幕比例也相同,如果屏幕尺寸差异过大,需要做dp适配。

    sp:专门用来设置字体大小,在系统设置中可以调整字体大小,跟随系统字体设置而变化。

    在java代码中调用setTextSize方法

    新建XML文件

    1. <?xml version="1.0" encoding="utf-8"?>
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. android:orientation="vertical">
    6. <TextView
    7. android:id="@+id/tv_hello"
    8. android:layout_width="wrap_content"
    9. android:layout_height="wrap_content"
    10. android:text="@string/hello" />
    11. </LinearLayout>

    新建java类

    1. public class TextSizeActivity extends AppCompatActivity {
    2. @Override
    3. protected void onCreate(@Nullable Bundle savedInstanceState) {
    4. super.onCreate(savedInstanceState);
    5. setContentView(R.layout.activity_text_size);
    6. TextView tv_px = findViewById(R.id.tv_hello);
    7. tv_px.setTextSize(30);//这里不用指定单位,默认为sp,所以官方推荐字体设置单位是sp
    8. }

    在XML文件中通过属性android:textSize指定

    XML文件

    1. android:textSize="30px"/>

    java类

    1. public class TextSizeActivity extends AppCompatActivity {
    2. @Override
    3. protected void onCreate(@Nullable Bundle savedInstanceState) {
    4. super.onCreate(savedInstanceState);
    5. setContentView(R.layout.activity_text_size);
    6. }
    7. }

    三、设置文本颜色

    在java代码中调用setTextColor方法设置文本颜色

    具体色值可从Color获取

    XML文件

    1. <TextView
    2. android:id="@+id/tv_code_system"
    3. android:layout_width="wrap_content"
    4. android:layout_height="wrap_content"
    5. android:text="设置系统自带颜色"
    6. android:textSize="17sp"/>

    java类

    1. public class TextColorActivity extends AppCompatActivity {
    2. @Override
    3. protected void onCreate(@Nullable Bundle savedInstanceState) {
    4. super.onCreate(savedInstanceState);
    5. setContentView(R.layout.activity_text_color);
    6. //布局文件中获取文本视图
    7. TextView tv_code_system = findViewById(R.id.tv_code_system);
    8. //设置文本颜色
    9. tv_code_system.setTextColor(Color.GREEN);
    10. }

    四、设置视图的宽高

    视图宽度通过属性android:layout_width表达,高度通过android:layout_height

    宽高的取值主要有下列三种:

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

    例:

    1. //上面的
    2. android:layout_width="wrap_content"
    3. android:layout_height="wrap_content"
    4. //下面的
    5. android:layout_width="match_parent"
    6. android:layout_height="wrap_content"

     五、设置视图的间距

    有两种方式:采用layout_margin属性、padding属性

    1、layout_margin

    指定了当前视图与周围平级视图之间的距离,即外边距,包括:layout_margin、layout_marginLeft、layout_marginTop、layout_marginRight、layout_marginBottom

    2、padding

    指定当前视图与内部下级视图之间的距离,即内边距,包括:padding、paddingLeft、paddingTop、paddingRight、paddingBottom

    例:

    View标签在LinearLayout内,所以为其下级视图

    1. <!-- 中间层的布局背景为黄色-->
    2. <LinearLayout
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. android:layout_margin="20dp"//外边距20dp
    6. android:background="#FFFF99"
    7. android:padding="60dp">//内边距60dp
    8. <!-- 最内层的视图背景为红色-->
    9. <View
    10. android:layout_width="match_parent"
    11. android:layout_height="match_parent"
    12. android:background="#FF0000"/>
    13. </LinearLayout>

     六、设置视图的对齐方式

    有两种方式:采用layout_gravity属性、采用gravity属性;

    取值包括:left、top、right、bottom,可以用竖线连接各取值,如:left|top表示朝左上角对齐。

    1、layout_gravity

    指定当前视图相对于上级视图的对齐方式。

    2、gravity

    指定下级视图相对于当前视图的对齐方式。

    例:

    1. <!--第一个子布局背景为红色,它在上级视图中朝下对齐,下级视图靠左对齐-->
    2. <LinearLayout
    3. android:layout_width="0dp"
    4. android:layout_height="200dp"
    5. android:layout_weight="1"
    6. android:layout_margin="10dp"
    7. android:padding="10dp"
    8. android:background="#ff0000"
    9. android:layout_gravity="bottom"
    10. android:gravity="left">
    11. <!-- 内部视图-->
    12. <View
    13. android:layout_width="100dp"
    14. android:layout_height="100dp"
    15. android:background="#00ffff"/>
    16. </LinearLayout>
    17. <!--第二个子布局背景为红色,它在上级视图中朝上对齐,下级视图靠右对齐-->
    18. <LinearLayout
    19. android:layout_width="0dp"
    20. android:layout_height="200dp"
    21. android:layout_weight="1"
    22. android:layout_margin="10dp"
    23. android:padding="10dp"
    24. android:background="#ff0000"
    25. android:layout_gravity="top">
    26. <View
    27. android:layout_width="100dp"
    28. android:layout_height="100dp"
    29. android:background="#00ffff"
    30. android:gravity="right"/>
    31. </LinearLayout>

     

     


  • 相关阅读:
    HALCON 22.11来了
    C Primer Plus(6) 中文版 第14章 结构和其他数据形式 14.10 联合简介
    VBA_MF系列技术资料1-207
    矩阵相乘
    [洛谷] P1141 01迷宫
    【.Net实用方法总结】 整理并总结System.IO中Directory类及其方法介绍
    2022亚太数学杯数学建模竞赛A题(思路分析......)
    Git目录不对,即当前文件夹不对应git仓库
    常见排序算法之冒泡排序
    JavaScript之事件
  • 原文地址:https://blog.csdn.net/Tir_zhang/article/details/126772429