android fitsystemwindows简单使用

fitsystemwindows :
设置应用布局时是否考虑系统窗口布局;如果为true,将调整系统窗口布局以适应你自定义的布局。比如系统有状态栏,应用也有状态栏时。看你这个布局代码,恰恰是在定义标题栏样式,所以用到这个属性了。

下面详细说一下它在自定义标题栏的时候使用:

这里写图片描述

通常我们的带有自定义标题栏的app界面如上图:1为状态栏 2为标题栏 3为内容 4为导航栏
在4.4(KITKAT)之后google加了一个特效 就是状态栏和导航栏半透明并且当前布局可以全屏显示 如下图
这里写图片描述
实现上图这一效果需要加上

        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){
            //半透明头部状态栏,底部导航栏   布局在状态栏,导航栏下方
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
        }

Build.VERSION.SDK_INT:当前系统版本
Build.VERSION_CODES.KITKAT:4.4版本
Build.VERSION_CODES.LOLLIPOP:5.0版本

发现设置完之后标题栏跑到statusbar下方了 达不到我们的效果
这就切入正题了 fitsystemwindows的使用
在标题栏加上此属性之后
这里写图片描述
文字内容挤下去了~~
发现了一个问题状态栏是半透明的
这个是版本决定的 5.0以上是半透明 4.4~5.0是全透明 4.4一下无效果
全透明状态栏 将在我的下一篇博客介绍
全部代码:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){
            //半透明头部状态栏,底部导航栏   布局在状态栏,导航栏下方
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
        }

    }
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.yqy.yqy_test.MainActivity">


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#ffe0a0"
        android:fitsSystemWindows="true"
        android:clipToPadding="true"
        android:gravity="center"
        android:orientation="horizontal">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="我是标题"/>
    </LinearLayout>

    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="我是内容"
        android:gravity="center"
        android:background="#e0ffa0"/>



</LinearLayout>
Android R 中,全屏手势识别可以通过使用新的 GestureNavigation API 来实现。下面是一个简单的实现示例: 1. 在你的 Activity 中,设置 Window 的属性以启用全屏手势识别: ```java if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { getWindow().setDecorFitsSystemWindows(false); getWindow().setInsetsController(new WindowInsetsController.Builder(getWindow(), getWindow().getDecorView()) .setSystemBarsBehavior(WindowInsetsController.BEHAVIOR_SHOW_TRANSIENT_BARS_BY_SWIPE) .build()); } ``` 2. 在你的布局文件中,将根布局的 fitSystemWindows 属性设置为 false: ```xml <androidx.constraintlayout.widget.ConstraintLayout android:layout_width="match_parent" android:layout_height="match_parent" android:fitsSystemWindows="false"> ... </androidx.constraintlayout.widget.ConstraintLayout> ``` 3. 在你的 Activity 中,实现 OnSwipeGestureListener 接口来处理手势事件: ```java public class MyActivity extends AppCompatActivity implements OnSwipeGestureListener { private final GestureNavigationController gestureNavigationController = new GestureNavigationController(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // ... gestureNavigationController.setSwipeGestureListener(this); } @Override public void onSwipeLeft() { // 处理向左滑动手势 } @Override public void onSwipeRight() { // 处理向右滑动手势 } @Override public void onSwipeUp() { // 处理向上滑动手势 } @Override public void onSwipeDown() { // 处理向下滑动手势 } } ``` 以上就是 Android R 中实现全屏手势识别的简单示例。当然,具体实现还需要根据你的需求进行调整和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Android翻山之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值