闪屏界面:
在一个App 中, 一个闪屏页面必然是必不可少的。在一些公司中,闪屏界面是为了介绍公司的简介,为了显示当前的公司的内容;但是,在更多的公司中,这个闪屏界面就是为了推广另外的广告,实现广告的盈利。
闪屏界面的实现
在一些app 中对于闪屏界面的实现非常的简单
1. 设置当前的界面全屏
2. 给布局文件中的layout的根布局添加背景
实现方法界面全屏的方法
1. 在闪屏界面所对应的theme 下设置
2. 在android 的 java 或者 kt 文件中进行设置
kt 的写法
//去除标题栏
requestWindowFeature(Window.FEATURE_NO_TITLE)
//去除状态栏
window.setFlags(
WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN)
java 的写法
//去除标题栏
requestWindowFeature(Window.FEATURE_NO_TITLE);
//去除状态栏
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
注意 : 这个方法需要写到 setContentView 方法上面
出现的问题 :
问题 1 :在页面启动的时候会出现一闪而逝的白/黑屏幕
出现的原因 :
想要了解白屏产生的根源,就不得不去跟踪Activity组件的窗口启动过程。Activity组件在启动的过程中,会调用ActivityStack类的成语函数startActivityLocked方法。注意,在调用ActivityStack类的成语函数startActivityLocked方法的时候,Activity组件还处于启动过程中,即它的窗口尚未显示出来,不过这时候ActivityManagerService服务会检查是否需要为正在启动的Activity组件显示一个启动窗口。如果需要的话,那么ActivityManagerService服务就会请求WindowManagerService服务为正在启动的Activity组件设置一个启动窗口(ps:而这个启动窗口就是白屏的由来)。
ActivityStack.startActivityLocked
public class ActivityStack {
// set to false to disable the preview that is shown while a new activity
// is being started.
static final boolean SHOW_APP_STARTING_PREVIEW = true;
private final void startActivityLocked(ActivityRecord r, boolean newTask, boolean doResume) {
final int NH = mHistory.size();
int addPos = -1;
// Place to new activity at top of stack, so it is next to interact
// with the user.
if (addPos < 0) {
addPos = NH;
}
// Slot the activity into the history stack and proceed
mHistory.add(addPos, r);
if (NH > 0) {
// We want to show the starting preview window if we are
// switching to a new task, or the next activity's process is
// not currently running.
boolean showStartingIcon = newTasks;
ProcessRecord proc = r.app;
if (proc == null) {
proc = mService.mProcessNames.get(r.processName, r.info.applicationInfo.uid);
}
if (proc == null || proc.thread == null) {
showStartingIcon = true;
}
}
}
}
这里的分析与解决的方参考自博客
解决 :
在theme 中 调用这句
会将白屏/黑屏去掉
问题2 : android 9.0 之上出现许多的异性屏幕,所以我们需要对于异性屏幕进行解决
解决方法 :
if (Build.VERSION_CODES.P <= Build.VERSION.SDK_INT){
setScreen()
}
@RequiresApi(Build.VERSION_CODES.P)
fun setScreen() {
// 延伸显示区域到刘海
val lp = window.attributes
lp.layoutInDisplayCutoutMode = WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES
window.attributes = lp
// 设置页面全屏显示
val decorView = window.decorView;
decorView.systemUiVisibility = View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN or View.SYSTEM_UI_FLAG_LAYOUT_STABLE
}