一 修改状态栏颜色

状态栏说的是黄框内部部门
- //设置Activity的状态栏颜色 注意是状态栏 public static void setStatusBarColor(Activity activity, int color) { // 5.0 以上 直接调用系统提供的方法 setStatusBarColor if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { activity.getWindow().setStatusBarColor(color); } // 4.4 - 5.0 之间 大抵思路 采取一个本领,首先把他弄玉成屏,在状态栏的部门加一个结构 else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { // 首先把他弄玉成屏(),在状态栏的部门加一个结构 // activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);//这个标记位完全全屏了 都没有状态栏了 // FLAG_TRANSLUCENT_STATUS标记位 电量 时间 网络状态 都还在 // 1 将Window设置为全屏 activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS); // 在状态栏的部门加一个结构 setContentView 源码分析,自己加一个结构 (高度是状态栏的高度) // 2 先准备一个高度与statusBar相等的view 并设置好颜色 View view = new View(activity); ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, getStatusBarHeight(activity)); view.setLayoutParams(params); view.setBackgroundColor(color); // DecorView是一个 FrameLayout 结构 , 会加载一个系统的结构(LinearLayout) , // 在系统结构中会有一个 id 为 android.R.id.content 这结构是(RelativeLayout) // http://www.jianshu.com/p/531d1168b3ee // 3 将第二步准备好的view添加到decor view ViewGroup decorView = (ViewGroup) activity.getWindow().getDecorView(); decorView.addView(view); // 4 获取activity中setContentView结构的根结构 contentView 并给他一个padding // 出现结构被view遮挡的情况 办理方案一 ViewGroup contentView = (ViewGroup) activity.findViewById(android.R.id.content); contentView.setPadding(0, getStatusBarHeight(activity), 0, 0); // 创建的view最好不要加在mainActivity的结构 而是加在DecorView // 出现结构被view遮挡的情况 办理方案二可以在xml中添加 android:fitsSystemWindows="true" 但是每个结构都要写 // 出现结构被view遮挡的情况 办理方案三 // View activityView = contentView.getChildAt(0); // activityView.setFitsSystemWindows(true); // 这样只要设置一次即可 // 出现结构被view遮挡的情况 办理方案四 // activityView.setPadding(0,getStatusBarHeight(activity),0,0); // 方案一和方案四类似 只不外一个padding加在content的上面 一个padding加在了content的第一个子view上 // 不外方案一更优 因为方案四会导致我们在自己的结构文件最外层容器设置padding无效 // 整体逻辑:由外到内的结构分别是 1 PhoneWindow 2 DecorView(FrameLayout) 3 系统结构(LinearLayout有个叫android.R.id.content的占位符的FrameLayout) 4 我们创建的结构加载在android.R.id.content的位置 // 好比R.layout.screen_simple.xml是一个系统结构 是一个LinearLayout // 1 将PhoneWindow 设置为全屏 // 2 将准备好的view放到DecorView(FrameLayout)的尾部 对于FrameLayout来说就是最上层 // 3 由于FrameLayout不会自动将其他view挤到正确的位置 因此我们需要给处于FrameLayout中的系统结构设置一个padding大概fitsSystemWindows 将之前添加的view暴露来 } } //获取状态栏的高度 private static int getStatusBarHeight(Activity activity) { // 插件式换肤有讲到:怎么获取资源的-->类似反射 先获取资源id,根据id获取资源高度 Resources resources = activity.getResources(); int statusBarHeightId = resources.getIdentifier("status_bar_height", "dimen", "android"); Log.e("TAG", statusBarHeightId + " -> " + resources.getDimensionPixelOffset(statusBarHeightId)); return resources.getDimensionPixelOffset(statusBarHeightId); }
复制代码 二 设置全屏
- //设置activity全屏(5.0以上调用该方法还需要将主题设置为NoActionBar) public static void setStatusBarTranslucent(Activity activity) { // 5.0 以上 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { View decorView = activity.getWindow().getDecorView(); decorView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN); activity.getWindow().setStatusBarColor(Color.TRANSPARENT); } // 用上面的方法中的第一步即可 else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS); } }
复制代码 三 title渐隐效果思路思路
根据ImageView的高度修改title alpha值
效果

xml
activity
- /** * 本节内容 * 状态栏渐隐效果 * 原理: 根据ImageView的高度修改状态栏alpha值 */public class MainActivity extends AppCompatActivity { ScrollView mScrollView; ImageView mImageView; int mImageViewHeight; int mHeaderViewHeight; View mHeader; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mScrollView = findViewById(R.id.scrollView); mImageView = findViewById(R.id.imageView); mHeader = findViewById(R.id.header); mHeader.post(new Runnable() { @Override public void run() { mHeaderViewHeight = mHeader.getMeasuredHeight(); } }); mHeader.getBackground().setAlpha(0); mImageView.post(new Runnable() { @Override public void run() { mImageViewHeight = mImageView.getMeasuredHeight(); } }); mScrollView.setOnScrollChangeListener(new View.OnScrollChangeListener() { @Override public void onScrollChange(View v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) { if (mImageViewHeight == 0) { return; } float alpha = (float) scrollY / (mImageViewHeight - mHeaderViewHeight); alpha = alpha * 255; if (alpha > 255) { alpha = 255; } if (alpha < 0) { alpha = 0; } Log.d("TAG", "onScrollChange: alpha " + alpha); //background setAlpha和view setAlpha的取值范围差别 这里要*255 mHeader.getBackground().setAlpha((int) alpha); } }); }}
复制代码 代码
https://github.com/caihuijian/learn_darren_android.git
来源:https://blog.csdn.net/u011109881/article/details/112040835
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |