Android 学习笔记
安卓(Android)是一种基于Linux内核(不包含GNU组件)的自由及开放源代码的操作系统。主要使用于移动设备,如智能手机和平板电脑,由美国Google公司和开放手机联盟领导及开发。Android的系统架构和其操作系统一样,采用了分层的架构。分为四个层,从高层到低层分别是应用程序层、应用程序框架层、系统运行库层和Linux内核层。Android把所有能够显示的图形都抽象为Drawable类(可
一.Android入门
1.Android 概述
安卓(Android)是一种基于Linux内核(不包含GNU组件)的自由及开放源代码的操作系统。主要使用于移动设备,如智能手机和平板电脑,由美国Google公司和开放手机联盟领导及开发。
Android的系统架构和其操作系统一样,采用了分层的架构。分为四个层,从高层到低层分别是应用程序层、应用程序框架层、系统运行库层和Linux内核层。
2.Android Studio
Android Studio是Android运用的开发工具,由谷歌公司在2013年5月推出,是基于IDER演变而来的,比Eclipse更加好用
下载 Android Studio
官网地址:https://developer.android.google.cn/studio
详细安装步骤:https://blog.csdn.net/m0_65379736/article/details/126813964
3.创建模拟器
首选打开Android Studio,然后【点击】
点击【Create device】
然后,点击【Phone】
选择安卓版本
根据需求选择竖屏或横屏,然后点击【Finish】
启动模拟器
出现以下界面,表明安装成功,
若没有创建成功,请重新操作此步骤,创建模拟器。若实在不行,就使用外部模拟器
4.使用外部模拟器
下载夜神模拟器
直接下载,安装就直接下一步、下一步就可以了
连接夜神模拟器
先进入安装夜神模拟器中的bin目录
输入cmd,然后回车
然后输入在黑窗口中输入下面这行命令,回车
nox_adb.exe connect 127.0.0.1:62001
出现以下界面,表明连接成功
5.第一个app
直接运行即可,前提是创建了模拟器且已打开
二.app开发基础
1.开发语言
app开发主要有两大技术路线,分别是原生开发和混合开发
Android 的官方编程语言包括Java和Kotlin,但是要做Android开发必须学Java,没有Java基础是做不了的;因为这个源码是用Java写的,即使现在流行用Kotin开发,也要会Java才行
2.app工程目录结构
-
manifests子目录,下面有一个xml文件,即AndroidManifest.xml,是APP的运行配置文件。
-
java子目录,下面有3个com.example.,myapplication包,其中第一个包存放的是APP工程的java源代码,后面两个包存放的是测试用的java代码。
-
res子目录,存放的是APP工程的资源文件。
res子目录下面又有4个子目录:
-
drawable目录存放的是图形描述文件与用户图片
-
layout目录存放的是APP页面的布局文件
-
mipmap目录存放的是启动图标
-
values目录存放的是一些常量定义文件,字符串常量strings.xml、像素常量dimens.xml、颜色常量colors.xml、样式风格定义styles.xml等。
Gradle Scripts工程的编译配置文件:
-
build.gradle,该文件分别为项目及和模块级两种,用于描述APP工程的编译规则。
-
proguard-rules.pro,该文件用于描述java文件的代码混淆规则。
-
gradle.properties,该文件用于配置编译工程的命令行参数,一般无须改动。
-
settings.gradle,配置哪些模块一起编译。初始内容为include“app”,表示只编译APP模块。
-
local.properties,项目的本地配置,一般无须改动。该文件是在工程编译时自动生成的,用于描述开发本机的配置,比如SDK的本地路径、NDK的本地路径等。
AndroidManifest.xml配置文件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.myapplication">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.MyApplication">
<activity
android:name=".MainActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
- AndroidManifest.xml的根节点为manifest,它的packagel属性指定了该App的包名。manifest下面有个application节点,它的各属
性说明如下:
android:allowBackup,是否允许应用备份。允许用户备份系统应用和第三方应用的apk安装包和应用数据,以便在刷机或者数据丢失后恢复应用,用户即可通过adb backup和adb restore来进行对应用数据的格份和恢复。为true表示允许,为false则表示不允许。 - android:icon,指定App在手机屏幕上显示的图标。
- android:label,指定App在手机屏幕上显示的名称。
- android:roundIcon,指定App的圆角图标。
- android:supportsRtl,是否支持阿拉伯语/波斯语这种从右往左的文字排列顺序。为true表示支持,为false!则表示不支持。
- android:theme,指定App的显示风格。
注意到application下面还有个activity节点,它是活动页面的注册声明,只有在AndroidManifest…xml中正确配置了activity节点,才能在运行时访问对应的活动页面。初始配置的MainActivity正是App的默认主页,之所以说该页面是App主页,是因为它的activity节点内部还
配置了以下的过滤信息:
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
其中action节点设置的android.intent.action.MAIN表示该页面是App的入口页面,启动App时会最先打开该页面。而category节点设置的android.intent.category.LAUNCHER决定了是否在手机屏幕上显示App图标,如果同时有两个activity节点内部都设置了android.intent.category.LAUNCHER,那么桌面就会显示两个App图标。
3.文本控件TextView
(1)设置文本内容
在XML文件中通过属性 android:text 设置文本
<TextView
android:id="@+id/tv_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
/>
在Java代码中调用文本视图对象的 setText 方法设置文本
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.textView = (TextView) findViewById(R.id.tv_1);
textView.setText("你好,世界");
}
还可以引用字符串string文件
在XML文件中引用(@string/name名)
在Java代码中引用(R.string.name名)
(2)设置文本大小
在XML文件中通过属性 android:textSize 设置文本大小,单位sp,可以用px和dp
- px:它是手机屏幕的最小显示单位,与设备的显示屏像素有关。
- dp:它是与设备无关的显示单位,只与屏幕的尺寸有关。
- sp:专门设置字体的大小,在系统中可以调整字体的大小
android:textSize="30sp"
在Java代码中调用 setTextSize 方法设置文本大小
textView.setTextSize(30); //默认单位sp
(3)设置文本颜色
在XML文件中通过属性 android:textColor 设置文本颜色
android:textColor="#FF000000"
在Java代码中调用 setTextColor 方法设置文本颜色
textView.setTextColor(0xff000000); //设置字体为黑色
(4)设置背景颜色
在XML文件中通过属性 android:background 背景颜色,可以理解为填充整个控件的颜色,可以是图片
android:background="ff00ffff"
android:background="@drawable/iocm_1"
(5)设置视图宽高
android:layout_width 视图宽度属性
android:layout_height 视图高度属性 ,单位dp
- match_parent,跟父控件保持一致
- wrap_content,根据内容自动分配
(6)设置视图间距
外边距属性 android:layout_margin 设置当前视图与周围平级视图之间的距离,还有:
layout_marginLeft、layout_marginTop、layout_marginRight、layout_marginBottom
内边距属性 android:padding 设置当前视图与子视图之间的距离,还有:
paddingLeft、paddingTop、paddingRight、paddingBottom
(7)设置视图对齐方式
android:layout_gravity 设置当前视图与父控件的对齐方式
android:gravity 设置当前视图与子视图之间的对齐方式
- center_horizontal(水平居中)
- center_vertical(垂直居中)
- center(中央)
还包括:left、top、right、bottom,可以用竖线连接,如"left|top"表示朝左上角对齐
4.线性布局LinearLayout
通过属性android:orientation将内部的控件在线性方向上依次排列
- vertical(水平排列),水平方向从左往右排
- horizontal(垂直排列),垂直方向从上往下排
若不指定,默认水平排列
权重
线性布局的子视图各自拥有多大比例的宽高,通过在子视图中设置 android:layout_weight 属性,形成宽高比例
5.相对布局RelativeLayout
使子视图的位置由其它视图决定
属性 | 描述 |
---|---|
android:layout_centerHorizontal | 如果为true,将该控件的置于水平居中 |
android:layout_centerVertical | 如果为true,将该控件的置于垂直居中 |
android:layout_centerInParent | 如果为true,将该控件的置于父控件的中央 |
android:layout_alignParentTop | 如果为true,将该控件的顶部与其父控件的顶部对齐 |
android:layout_alignParentBottom | 如果为true,将该控件的底部与其父控件的底部对齐 |
android:layout_alignParentLeft | 如果为true,将该控件的左部与其父控件的左部对齐 |
android:layout_alignParentRight | 如果为true,将该控件的右部与其父控件的右部对齐 |
android:layout_below=“@id/view_1” | 将该控件置于"@id/view_1"控件下边 |
android:layout_above=“@id/view_1” | 将该控件置于"@id/view_1"控件上边 |
android:layout_toLeftOf=“@id/view_1” | 将该控件置于"@id/view_1"控件的左边 |
android:layout_toRightOf =“@id/view_1” | 将该控件置于"@id/view_1"控件的右边 |
android:layout_alignTop =“@id/view_1” | 将该控件的顶部边缘与"@id/view_1"顶部边缘对齐 |
android:layout_alignBottom =“@id/view_1” | 将该控件的底部边缘与"@id/view_1"底部边缘对齐 |
android:layout_alignLeft =“@id/view_1” | 将该控件的左边缘与"@id/view_1"的左边缘对齐 |
android:layout_alignRight =“@id/view_1” | 将该控件的右边缘与"@id/view_1"的右边缘对齐 |
6.网格布局GridLayout
支持多行多列的表格排列,默认从左往右、从上往下排列
- android:columnCount,网格的列数,每行能放多少个视图
- android:rowCount,网格的行数,每列能放多少个视图
7.滚动视图ScrollView
ScrollView 设置垂直方向的滚动视图
HorizontalScrollView 设置水平方向滚动视图
8.按钮控件Button
由TextView派生而来的,但是Button拥有默认的按钮背景,内部文本默认居中对齐,会将内部文本中的英文默认转换为大写
- android:textAllCaps,是否将英文字母转换为大写,默认为"ture"
在xml文件中通过属性 android:clickable 设置是否点击
onClick方法设置按钮的监听器,点击按钮调用对应的方法,方法格式 public void XXXX(View v)
这个监听目前已经淘汰,但是可以用
private Button mBtn3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_button);
mBtn3 = (Button) findViewById(R.id.btn_3);
mBtn3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(ButtonActivity.this, "btn3被点击了", Toast.LENGTH_SHORT).show();
}
});
}
使用drawableXXX属性,可以将图片与按钮结合,使用paddingXXX即可调整其位置
注意:
Button默认背景蓝紫色,若手动设置的颜色无效,可能是因为res/values/themes.xml
中的parent=“Theme.MaterialComponents.DayNight.DarkActionBar”,只需要将DarkActionBar改为Bridge
9.点击事件和长按事件
监听器,专门监听控件的动作行为。只有控件发生了指定的动作,监听器才会触发开关去执行对应的代码逻辑。
按钮控件有两种常用的监听器:
- 点击监听器,通过setOnClickListener方法设置。按钮被按住少于S00毫秒时,会触发点击事件。
- 长按监听器,通过setOnLongClickListener方法设置。按钮被按住超过500毫秒时,会触发长按
事件。
private Button mBtn3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_button);
mBtn3 = (Button) findViewById(R.id.btn_3);
mBtn3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(ButtonActivity.this, "btn3被点击了", Toast.LENGTH_SHORT).show();
}
});
}
10.禁用与恢复按钮
不可用按钮:按钮不允许点击,即使点击也没反应,同时按钮文字为灰色
可用按钮:按钮允许点击,点击按钮会触发点击事件,同时按钮文字为正常的黑色
在XML文件中通过android:enabled设置属性是否允许点击
android:enabled="true"
在Java代码中通过setEnabled方法设置属性是否允许点击
bn_t.setEnabled(false)
11.图像视图ImageView
在XML文件中通过属性 android:src 设置图片资源
android:src="@drawable/iocm_1"
在Java代码中通过setImageResource方法设置图片资源
imageView_1.setImageResource(R.drawable.iocm_1)
ImageView本身默认图片居中显示,若要改变图片的显示方式,可通过scaleType属性设定,
XML文件中 | ScaleType类中 | 描述 |
---|---|---|
fitXY | FIT_XY | 拉伸图片使其正好填满视图(图片可能被拉伸变形) |
fitStart | FIT_START | 保持宽高比例,拉伸图片使其位于视图上方或左侧 |
fitCenter | FIT_CENTER | 保持宽高比例,拉伸图片使其位于视图中间 |
fitEnd | FIT_END | 保持宽高比例,拉伸图片使其位于视图下方或右侧 |
center | CENTER | 保持图片原尺寸,并使其位于视图中间 |
centerCrop | CENTER_CROP | 拉伸图片使其充满视图,并位于视图中间 |
centerlnside | CENTER_INSIDE | 保持宽高比例,缩小图片使之位于视图中间(只缩小不放大) |
在XML文件中通过属性 android:scaleType 设置图片显示方式
android:scaleType="fitXY"
在Java代码中通过setScaleType方法设置图片显示方式
imageView_1.setImageResource(ImageView.ScaleType.FIT_XY)
12.图像按钮ImageButton
显示图片的图像按钮,继承自ImageView,ImageButton只能显示图片,且图片按比例自动缩放,可以设置两张图片,实现叠加效果
- android:foreground,设置前景图
- android:background,设置背景图
13.在文本中添加图像
属性 | 描述 |
---|---|
android:drawableTop | 在文本上边导入图片 |
android:drawableBottom | 在文本下边导入图片 |
android:drawableLight | 在文本左边导入图片 |
android:drawableRight | 在文本右边导入图片 |
android:drawablePadding | 设置图片与文字之间的距离 |
三.Activity
Android的四大组件之一
Activity整个生命周期中有四种状态:
-
运行状态:在用户界面中最上层,完全能被用户看到,能够与用户进行交互
-
暂停状态:Activity失去焦点,Activity界面被部分遮挡,该Activity不再处于用户界面的最上层,且不能够与用户进行交互
-
停止状态:Activity在界面上完全不能被用户看到,也就是说这个Activity被其他Activity全部遮挡,但它依然保持所有状态和成员信息,只是它不再可见,它的窗口被隐藏
-
终止状态:被系统清理出内存
1.启动和结束
从当前页面跳转到新页面
startActivity(源页面.this, 目标页面.class)
从当前页面回到上一个页面,相当于关闭当前页面
finish(); //结束当前的活动页面
2.生命周期
onCreate:创建活动。把页面布局加载进内存,进入了初始状态。
onStart:开始活动。把活动页面显示在屏幕上,进入了就绪状态。
onResume:恢复活动。活动页面进入活跃状态,能够与用户正常交互,例如允许响应用户的点击动作、允许用户输入文字等等。
onPause:暂停活动。页面进入暂停状态,无法与用户正常交互。
onStop:停止活动。页面将不在屏幕上显示。
onDestroy:销毁活动。回收活动占用的系统资源,把页面从内存中清除。
onRestart:重启活动。重新加载内存中的页面数据。
onNewlntent:重用已有的活动实例。
各状态之间的切换过程:
打开新页面的方法调用顺序
onCreate》onStart》onResume
关闭旧页面的方法调用顺序
onPause》onStop》onDestroy
3.启动模式
默认启动模式standard
该模式下,启动的Activity会依照启动顺序被依次压入Task栈中
栈顶复用模式singleTop
该模式下,如果栈顶Activity为我们要新建的Activity,那么就不会重复创建新的Activity
栈内复用模式singleTask
该模式下,如果task栈内存中存在目标Activity实例,则将task内的对应Activity实例之上的所有Activity弹出栈,并将对应Activity置于栈顶
全局唯一模式singleInstance
该模式下,我们会为目标Activity创建一个新的task栈,将目标Activity放入新的task,并让目标Activity获得焦点。新的task有且只有这一个Activity实例。如果已经创建过目标Activity实例,则不会创建新的task,而是将以前的创建过的Activity唤醒。
动态设置启动模式
setFlags方法值 | 说明 |
---|---|
Intent.FLAG_ACTIVITY_NEW_TASK | 开辟一个新的任务栈 |
Intent.FLAG_ACTIVITY_SINGLE_TOP | 当栈顶为待跳转的活动实例之时,则重用栈顶的实例 |
Intent.FLAG_ACTIVITY_CLEAR_TOP | 当栈中存在待跳转的活动实例时,则重新创建一个新实例,并清除原实例上方的所有实例 |
Intent.FLAG_ACTIVITY_NO_HISTORY | 栈中不保存新启动的活动实例 |
Intent.FLAG_ACTIVITY_CLEAR_TASK | 跳转到新页面时,栈中的原有实例都被清空 |
4.在活动之间传递消息
Intent是各个组件之间信息沟通的桥梁,用于各个组件之间的通信
元素名称 | 设置方法 | 说明 |
---|---|---|
Component | setComponent | 组件,指定意图的来源与目标 |
Action | setAction | 动作,指定意图的动作行为 |
Data | setData | Uri,指定动作要操作的数据路径 |
Category | addCategory | 类别,指定意图的操作类别 |
Type | setType | 数据类型,指定消息的数据类型 |
Extras | putExtras | 扩展信息,指定装载的包裹信息 |
Flags | setFlags | 标志位,指定活动的启动标志 |
显式Intent
直接指定来源活动与目标活动,属于精准匹配
-
在Intent的构造函数中指定
Intent intent = new Intent(this, ActNextActivity.class);
-
调用意图对象的setClass方法指定
Intent intent = new Intent(); intent.setClass(this, ActNextActivity.class);
-
调用意图对象的setComponent方法指定
Intent intent = new Intent(); ComponentName component = new ComponentName(this, ActNextActivity.class); intent.serComponent(component);
隐式Intent
没有明确指定要跳转的目标活动,只给出一个动作字符串让系统自动匹配,属于模糊匹配
Intent类的系统动作常量名 | 系统动作常量值 | 说明 |
---|---|---|
ACTION_MAIN | android.intent.action.MAIN | app启动时的入口 |
ACTION_VIEW | android.intent.action.VIEW | 向用户显示数据 |
ACTION_SEND | android.intent.action.SEND | 分享内容 |
ACTION_CALL | android.intent.action.CALL | 直接拨号 |
ACTION_DIAL | android.intent.action.DIAL | 准备拨号 |
ACTION_SENDTO | android.intent.action.SENDTO | 发送短信 |
ACTION_ANSWER | android.intent.action.ANSWER | 接听电话 |
动作名称既可以通过setAction方法指定,也可以通过构造函数Intent(String action)直接生成意图对象
发送数据
Intent使用Bundle对象存放待传递的数据信息
Bundle对象操作各类型数据的读写方法
数据类型 | 读方法 | 写方法 |
---|---|---|
整型 | getInt | putInt |
浮点 | getFloat | putFloat |
双精度 | getDouble | putDouble |
布尔值 | getBoolean | putBoolean |
字符串 | getString | putString |
字符串数组 | getStringArray | putStringArray |
字符串列表 | getStringArrayList | putSrtingArrayList |
可序列化结构 | getSerializable | putSerializable |
发送消息包裹,调用意图对象的putExtras方法
接收消息包裹,调用意图对象的getExtras方法
返回数据
处理下一个页面的应答数据
- 上一个页面打包好请求数据,调用registerForActivityResult方法执行跳转动作
- 下一个页面接收并解析请求数据,进行相应处理
- 下一个页面在返回上一个页面时,打包应答数据并调用setResult方法返回数据包裹
- 上一个页面重写方法onActivityResult,解析获得下一个页面的返回数据
四.控件
1.Drawable介绍
Android把所有能够显示的图形都抽象为Drawable类(可绘制的)。包括图片、色块、画板、背景等。
drawable目录一般保存描述性的XML文件,而图片文件一般放在具体分辨率的drawable目录下
- drawable-ldpi里面存放低分辨率的图片(如240×320),现在基本没有这样的智能手机了
- drawable-mdpi里面存放中等分辨率的图片(如320×480),这样的智能手机已经很少了
- drawable-hdpi里面存放高分辨率的图片(如480×800),一般对应4英寸~4.5英寸的手机(但不绝对,同尺寸手机有可能分辨率不同,手机分辨率就高不就低,因为分辨率低了屏幕会有模糊的感觉)
- drawable-xhdpi里面存放加高分辨率的图片(如720×1280),一般对应5英寸~5.5英寸的手机
- drawable-xxhdpi里面存放超高分辨率的图片(如1080×1920),一般对应6英寸~6.5英寸的手机
- drawable-xxxhdpi里面存放超超高分辨率的图片(如1440×2560),一般对应7英寸以上的平板电脑
分辨率每加大一级,宽度和高度就要增加二分之一或三分之一像素。在开发Ap时,为了兼容不同的手机屏幕,在各目录存放不同分辨率的图片(Android会根据手机的分辨率适配对应文件夹里的图片),从而提升视觉效果
2.Shape图形
形状图形的定义文件是以shape标签为根节点的XML描述文件,支持4种类型的形状:
形状 | 说明 |
---|---|
rectangle | 矩形,默认为矩形 |
oval | 椭圆。此时corners节点会失效 |
line | 直线。此时必须设置stroke节点,否则会报错 |
ring | 圆环 |
size(尺寸)
size是shapel的下级节点,用来描述形状图形的宽高尺寸。若无size节点,则表示宽高与宿主视图一样大小。
- height:图形高度
- width:图形宽度
stroke(描边)
stroke是shapel的下级节点,用来描述形状图形的描边规格。若无stroke节点,则表示不存在描边。
-
color:描边的颜色
-
dashGap:每段虚线之间的间隔
-
dashWidth:每段虚线的宽度。若dashGap和dashWidth有一个值为O,则描边为实线
-
width:描边的厚度
corners(圆角)
corners是shapef的下级节点,用来描述形状图形的圆角大小。若无corners-节点,则表示没有圆角。
- bottomLeftRadius:左下圆角的半径
- bottomRightRadius:右下圆角的半径
- topLeftRadius:左上圆角的半径
- topRightRadius:右上圆角的半径
- radius:4个圆角的半径
solid(填充)
solid是shapel的下级节点,用来描述形状图形的填充色彩。若无solid节点,则表示无填充颜色。
- coor:内部填充的颜色
padding(间隔)
padding是shapel的下级节点,用来描述形状图形与周围边界的间隔。若无padding节点,则表示四周不设间隔。
- top:与上方的间隔
- bottom:与下方的间隔
- left:与左边的间隔
- right:与右边的间隔
gradient(渐变)
gradient是shape的下级节点,用来描述形状图形的颜色渐变。若无gradient节点,则表示没有渐变效果。
- angle:渐变的起始角度。为0时表示时钟的9点位置,值增大表示往逆时针方向旋转。如:值为90表示6点位置,值为180表示3点位置,值为270表示0点/12点位置
- type:渐变类型,linear(线性渐变,默认)、radial(放射渐变)、sweep(滚动渐变)
- centerX:圆心的X坐标。当android:type="‘linear’"时不可用
- centerY::圆心的Y坐标。当android:type="linear’"时不可用
- gradientRadius:渐变的半径。当android:type="radial"时需要设置该属性
- centerColor:渐变的中间颜色
- startColor:渐变的起始颜色
- endColor:渐变的终止颜色
- useLevel:是否无渐变色,true为无渐变色、false为有渐变色
state_pressed(按压效果)
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
<shape>
<solid android:color="#cc7a00"/>
<corners android:radius="5dp"/>
</shape>
</item>
<item android:state_pressed="false">
<shape>
<solid android:color="#ff9900"/>
<corners android:radius="5dp"/>
</shape>
</item>
</selector>
属性 | 说明 | 适用控件 |
---|---|---|
state_pressed | 是否按下 | 按钮Button |
state_checked | 是否勾选 | 复选框CheckBox、单选按钮RadioButton |
state_focused | 是否获取焦点 | 文本编辑框EditText |
state_selected | 是否选中 | 各控件通用 |
3.复合按钮
CompoundButton在XML文件中主要属性:
- checked:指定按钮的勾选状态,true表示勾选,false则表示未勾选。默认为未勾选
- button=“@null” 表示取消自带的默认样式
- buto:指定左侧勾选图标的图形资源,如果不指定就使用系统的默认图标
CompoundButton在Java代码中主要方法:
- setChecked:设置按钮的勾选状态
- setButtonDrawable:设置左侧勾选图标的图形资源
- setOnCheckedChangeListener:设置勾选状态变化的监听器
- isChecked:判断按钮是否勾选
Switch开关按钮在XML文件新添加的属性:
- textOn:设置右侧开启时的文本
- textOff:设置左侧关闭时的文本
- track:设置开关轨道背景
- thumb:设置开关标识图标
RadioGroup单选组实质上是个布局,同一组RadioButton都要放在同一个RadioGroup节点下。RadioGroup提供了orientation属性指定下级控件的排列方向,该属性为horizontal时,单选按钮在水平方向排列;该属性为vertical时,单选按钮在垂直方向排列。
RadioGroup下面还可以挂载其他子控件(如TextView、ImageView等)。单选组相当于特殊的线性布局,它们的主要区别:
- 单选组多了管理单选按钮的功能,而线性布局不具备该功能
- 如果不指定orientation,属性,那么单选组默认垂直排列,而线性布局默认水平排列
RadioGroup在Java代码中常用方法:
- check:选中指定资源编号的单选按钮
- getCheckedRadioButtonld:获取已选中单选按钮的资源编号
- setOnCheckedChangeListener:设置单选按钮勾选变化的监听器
4.编辑框EditText
EditText在XML文件新添加的属性:
- int:设置文本提示内容
- textColorHint:设置文本提示内容的颜色
- macLength:设置文本输入的最大长度
- inputType:设置文本输入类型,如:textPassword(显示文本为*号) 、number(整数)、numberDecimal(小数)
5.下拉列表Spinner
Spinner在XML文件中的属性没什么特别的,主要是在Java文件中设置监听、适配器
// 定义下拉列表要显示的文本数组
private String[] heroNames = {"美美1号", "美美2号", "美美3号", "美美4号"};
private Spinner mSpinner;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mSpinner = (Spinner) findViewById(R.id.spinner);
// 声明一个下拉列表的数组适配器
ArrayAdapter mAdapter = new ArrayAdapter(this, androidx.appcompat.R.layout.support_simple_spinner_dropdown_item, heroNames);
mSpinner.setAdapter(mAdapter);
// 设置下拉框默认显示第一项
mSpinner.setSelection(0);
mSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
String strMsg = "您选择了\""+heroNames[i]+"\"!";
Toast.makeText(MainActivity.this, strMsg, Toast.LENGTH_LONG).show();
}
@Override
public void onNothingSelected(AdapterView<?> adapterView) {
}
});
}
6.列表视图ListView
ListView类的设置方法 | 说明 |
---|---|
getCount | 获取列表项的个数 |
getItem | 获取列表项的数据 |
getItemId | 获取列表项的编号 |
getView | 获取每项的展示视图,并对每项的内部控件进行业务处理 |
设置数组适配器
private ListView mListView;
private String[] names = {"美美1号", "美美2号", "美美3号", "美美4号"};
private List<HashMap> dataList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = findViewById(R.id.listview);
// 声明一个数组适配器
ArrayAdapter mAdapter = new ArrayAdapter(this, androidx.appcompat.R.layout.support_simple_spinner_dropdown_item, names);
mListView.setAdapter(mAdapter);
}
7.网格视图GridView
GridView新添加的属性:
XML中的属性 | GridView类的设置方法 | 说明 |
---|---|---|
horizontalSpacing | setHorizontalSpacing | 指定网格顶在水平方向的间距 |
verticalSpacing | setVerticalSpacing | 指定网格顶在垂直方向的间距 |
numColumns | setNumColumns | 指定列的数目 |
stretchMode | setStretchMode | 指定剩余空间的拉伸模式 |
columnWidth | setColumnWidth | 指定每列的宽度;拉伸模式为spacingWidth、spacingWidthUniform时,必须指定列宽 |
private String[] names = new String[] {"美美1号", "美美2号", "美美3号", "美美4号"};
List imagelist;
private GridView mGridView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mGridView=findViewById(R.id.gridview);
// 声明一个数组适配器
ArrayAdapter mAdapter = new ArrayAdapter(this, androidx.appcompat.R.layout.support_simple_spinner_dropdown_item, names);
mGridView.setAdapter(mGridView);
}
8.RecyclerView
RecyclerView能够灵活实现大数据集的展示,视图的复用管理比ListView更好,能够显示列表、网格、瀑布流等形式,且不同的ViewHolder能够实现item多元化的功能。简单来说,就是列表和网格的一个优化版
9.翻页视图ViewPager
翻页视图就是允许页面在水平方向左右滑动
-
setAdapter:设置页面项的适配器。适配器用的是PagerAdapter及其子类
-
setCurrentItem:设置当前页码,也就是要显示哪个页面
-
addOnPageChangeListener:添加翻页视图的页面变更监听器。该监听器需实现接
OnPageChangeListener下的3个方法,
- onPageScrollStateChanged:在页面滑动状态变化时触发
- onPageScrolled:在页面滑动过程中触发
- onPageSelected:在选中页面时,即滑动结束后触发
- getCount:获取页面项的个数
- isViewFromObject:判断当前视图是否来自指定对象,返回view == object即可
- instantiateItem:实例化指定位置的页面,并将其添加到容器中
- destroyItem:从容器中销毁指定位置的页面
- getPageTitle:获得指定页面的标题文本,有搭配翻页标签栏时才要实现该方法
五.数据存储
1.SharedPreferences
SharedPreferences是Android的一个轻量级存储工具,采用的存储结构Key-Vaue的键值对方式,存储在XML规范的配置文件中(路径:/data/data/应用包名/shared_perfs/文件名.xml)
运用场合:
- 简单且孤立的数据
- 文本形式的数据
- 需要持久化存储的数据
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
et_name = findViewById(R.id.et_name);
et_age = findViewById(R.id.et_age);
et_height = findViewById(R.id.et_age);
preferences = getPreferenceScreen("config", Context.MODE_PRIVATE);
reload();
findViewById(R.id.btn_save).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String name = et_name.getText().toString();
String age = et_age.getText().toString();
String height = et_height.getText().toString();
//储存数据
SharedPreferences.Editor editor = preferences.edit();
editor.putString("name", name);
editor.putInt("age", Integer.parseInt(age));
editor.putFloat("height", parseFloat(height));
editor.commit();
}
});
}
//获取数据
private void reload() {
String name = preferences.getString("name", null);
if (name != null) {
et_name.setText(name);
}
int age = preferences.getInt("age", 0);
if (age != 0) {
et_age.setText(String.valueOf(age));
}
float height = preferences.getFloat("height", 0f);
if (height != 0f) {
et_height.setText(String.valueOf(height));
}
}
}
2.SQLite
SQLiteDatabase
在Java代码中操作SQLite需要专门的工具类,SQLiteDatabase是Android提供的SQLite数据库管理器
管理类:
openOrCreateDatabase:打开指定路径的数据库,不存在则创建
deleteDatabase:删除指定路径的数据库
isOpen:判断数据库是否打开
close:关闭数据库
getVersion:获取数据库的版本号
setVersion:设置数据库的版本号
事务类:
beginTransaction:开始事务
setTransactionSuccessful:设置事务的成功标志
endTransaction:结束事务
数据处理类:
execSQL:执行拼接好的SQL控制语句
delete:删除符合条件的记录
update:更新符合条件的记录
insert:插入一条记录
query:执行查询操作,返回结果集的游标
rawQuery:执行拼接好的SQL查询语句,返回结果集的游标
SQLiteOpenHelper
SQLiteOpenHelper是Android提供的数据库辅助工具,用于指导开发者进行SQLite的合理使用
读写本地图片
Android的位图工具是Bitmap,app读写Bitmap可以使用性能更好的BufferedOutputStream和BufferedInputStream。
Android还提供了BitmapFactory工具用于读取各种来源图片方法:
decodeResource:该方法可从资源文件中读取图片信息
decodeFile:该方法可将指定路径的图片读取到Bitmap对象
decodeStream:该方法从输入流中读取位图数据
六.Application
Application是Android的一大组件,在app运行过程中有且仅有一个Application对象贯穿整个生命周期
Application类的方法 | 说明 |
---|---|
onCreate() | 在Application创建的时候调用,一般用于初始化,如全局的对象,环境的配置等 |
onConfigurationChanged(Configuration newConfig) | 重写此方法可以监听APP一些配置信息的改变事件 |
onLowMemory() | 重写此方法可以监听Android系统整体内存较低时候的事件 |
onTerminate() | 在程序结束的时候会调用。但这个方法在Android产品机是不会调用的 |
七.ContentProvider
ContentProvider是Android的一大组件,为app存取内部数据提供统一的外部接口,让不同的应用之间可以共享数据
动态申请权限:
-
检查App是否开启了指定权限
调用ContextCompat的checkSelfPermission方法
-
请求系统弹窗,以便用户选择是否开启权限
调用ActivityCompati的requestPermissions?方法,即可命令系统自动弹出权限申请窗口
-
判断用户的权限选择结果
重写活动页面的权限请求回调方法onRequestPermissionsResult,在该方法内部处理用户的权限选择结果
八.Fragment
传统的Activity并不能很好的处理大屏问题,所以就出现了Fragment,能够划分区域的展示内容,且有属于自己的独立可操作空间
静态注册在布局文件中直接指定Fragment,而动态注册直接在代码中才动态添加Fragment
方法 | 说明 |
---|---|
onAttach() | Fragment和Activity相关联时调用。可以通过该方法获取Activity引用,还可以通过getArguments()获取参数 |
onCreate() | Fragment被创建时调用 |
onCreateView() | 创建Fragment的布局 |
onActivityCreated() | 当Activity完成onCreate()时调用 |
onStart() | 当Fragment可见时调用 |
onResume() | 当Fragment可见且可交互时调用 |
onPause() | 当Fragment不可交互但可见时调用 |
onStop() | 当Fragment不可见时调用 |
onDestroyView() | 当Fragment的UI从视图结构中移除时调用 |
onDestroy() | 销毁Fragment时调用 |
onDetach() | 当Fragment和Activity解除关联时调用 |
这是我写的笔记,不是很全,还望谅解哈!!!
更多推荐
所有评论(0)