当前位置: 首页 > news >正文

expo + react native项目隐藏状态栏踩坑

我的app.tsx文件内容如下:

import MainPage from "./screens/Main/index";export default function App() {return (<MainPage />);
}

需求:当屏幕方向旋转90度后,状态栏所在位置是处于顶部安全区域所在位置。需要忽略顶部安全区区域,这样才不会显得非常突兀。

在使用expo的eas模块打包完毕后,手机端下载打开该APP,发现整个APP都被包裹在安全区域内显示了,这就非常奇怪了,我们明明没有使用安全区域的组件,为何APP会被置于安全区域内显示?

在网上找了很久原因,感觉这个是相对可靠的:Expo 默认会在 Android 上启用 SafeAreaView。即使你在代码中没有使用 SafeAreaView,Expo 也可以在预留时自动添加。

然后就是推荐我们使用这个第三方包来管理安全区域:react-native-safe-area-context

修改后的代码如下:

import { SafeAreaProvider, initialWindowMetrics } from 'react-native-safe-area-context';
import { SafeAreaView } from 'react-native-safe-area-context';
import MainPage from "./screens/Main/index";export default function App() {return (<SafeAreaProvider><SafeAreaView style={{ flex: 1 }} edges={["bottom"]} ><MainPage /></SafeAreaView></SafeAreaProvider>);
}

SafeAreaView的edges参数官方解释为:

Array of top, right, bottom, and left. Defaults to all.Sets the edges to apply the safe area insets to.

大致意思就是:设置要应用安全区域插入的边缘,默认值是[“left”,“right”,“top”,“bottom”]

我的理解就是哪边需要安全区,就将该方向放入数组中然后给edges参数即可。

打包后依旧不行,后来忘了在哪篇文章看到这样一段话了,大致意思说:状态栏的高度是由状态栏的背景颜色决定的,把StatusBar设置为透明,React Native将无法获取状态栏的安全区域。

修改代码如下:

import { SafeAreaProvider, initialWindowMetrics } from 'react-native-safe-area-context';
import { SafeAreaView } from 'react-native-safe-area-context';
import MainPage from "./screens/Main/index";
import { StatusBar } from "react-native";export default function App() {return (<SafeAreaProvider initialMetrics={initialWindowMetrics}><SafeAreaView style={{ flex: 1 }} edges={["bottom"]} ><StatusBar translucent={true} backgroundColor="rgba(0, 0, 0, 0)" /><MainPage /></SafeAreaView></SafeAreaProvider>);
}

打包apk后成功解决。

相关文章:

expo + react native项目隐藏状态栏踩坑

我的app.tsx文件内容如下&#xff1a; import MainPage from "./screens/Main/index";export default function App() {return (<MainPage />); }需求&#xff1a;当屏幕方向旋转90度后&#xff0c;状态栏所在位置是处于顶部安全区域所在位置。需要忽略顶部安…...

若依:用sqlite3随便掰饬掰饬

“若依”这个开源项目&#xff0c;感觉是外包公司标配了啊&#xff0c;都在用。从README感觉像是某位阿里员工的工作之余的小整理。对于SprintBoot&#xff0c;个人感觉太重型&#xff0c;不过人家生态起来了&#xff0c;不是那么容易玩完。但是随着VMware被博通收购&#xff0…...

刚安装的MySQL使用Navicat操作数据库遇到的问题

刚安装的MySQL使用Navicat操作数据库遇到的问题 一、编辑连接保存报错二、打开数据表很慢三、MySQL的进程出现大量“sleep”状态的进程四、执行sql脚本报错&#xff0c;部分表导不进去五、当前MySQL配置文件 一、编辑连接保存报错 连接上了数据库&#xff0c;编辑连接保存报错…...

物奇平台耳机宕机恢复功能实现

是否需要申请加入数字音频系统研究开发交流答疑群(课题组)&#xff1f;可加我微信hezkz17, 本群提供音频技术答疑服务&#xff0c;群赠送语音信号处理降噪算法&#xff0c;蓝牙音频&#xff0c;DSP音频项目核心开发资料, 物奇平台耳机宕机恢复功能实现 一 需求与场景 1 使…...

前端学习地址_备忘录(随时更新)

前端基础&&体系: MDN:MDN Web Docs 菜鸟教程:菜鸟教程 - 学的不仅是技术&#xff0c;更是梦想&#xff01; 印记中文:印记中文 - 深入挖掘国外前端新领域&#xff0c;为中国 Web 前端开发人员提供优质文档 w3cschool:w3cschool官网 - 1000多本编程教程免费学 vue系…...

安卓数据恢复工具哪个强? 10 个最佳 Android 数据恢复应用程序

如果您是 Android 用户并且已经使用您的设备一段时间&#xff0c;那么您很可能遇到过与数据相关的问题。这可能是由于软件问题导致文件被意外删除或损坏。许多人不经常备份数据&#xff0c;从而丢失了重要的文档、图像、视频文件等。最糟糕的是&#xff0c;数据丢失可能随时发生…...

在IDEA中配置Web开发环境

一、idea配置Web开发环境 第一步&#xff1a;下载并安装Tomcat服务器&#xff08;建议放根目录&#xff0c;完整路径中不要出现中文&#xff09; 第二步&#xff1a;打开IDEA&#xff0c;新建java项目 第三步&#xff1a;为项目添加Web应用 在项目上右键➡️选择“Add Framew…...

Cesium 相机设置

1.setView 直接跳转到目的地 // 设置相机位置 const position Cesium.Cartesian3.fromDegrees(113, 31, 20000); // setView通过定义相机目的地&#xff08;方向&#xff09;,直接跳转到目的地 viewer.camera.setView({ destination: position, // 位置设置 orientation: { //…...

【虹科干货】TWAMP:什么是双向主动测量协议?

TWAMP&#xff08;双向主动测量协议&#xff09;是什么&#xff1f;它在网络性能测量中有什么作用&#xff1f;如果您对IP网络中设备之间的性能问题感兴趣&#xff0c;或者想了解TWAMP与OWAMP之间的区别&#xff0c;以及TWAMP测试的好处。 一、TWAMP是什么&#xff1f; TWAMP代…...

bool型的盲注

bool型的盲注...

聊聊logback的ShutdownHook

序 本文主要研究一下logback的ShutdownHook ShutdownHook ch/qos/logback/core/hook/ShutdownHook.java /*** Interface describing a logback shutdown hook implementation* * author Mike Reinhold*/ public interface ShutdownHook extends Runnable, ContextAware { }…...

【第2章 Node.js基础】2.4 Node.js 全局对象...持续更新

什么是Node.js 全局对象 对于浏览器引擎来说&#xff0c;JavaScript 脚本中的 window 是全局对象&#xff0c;而Node.js程序中的全局对象是 global&#xff0c;所有全局变量(除global本身外)都是global 对象的属性。全局变量和全局对象是所有模块都可以调用的。Node.is 的全局…...

大数据毕业设计选题推荐-河长制大数据监测平台-Hadoop-Spark-Hive

✨作者主页&#xff1a;IT研究室✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…...

Unity与java后端UDP通信

1. unity客户端代码&#xff1a; using System.Collections; using System.Collections.Generic; using UnityEngine; using System.Net.Sockets; using System.Net; using System.Threading; using System.Text; using System;public class Udp : MonoBehaviour {static Sock…...

vue3 - swiper插件 实现PC端的 视频滑动功能(仿抖音短视频)

swiper官网 ​​​​​​swiper属性/组件查询 vue中使用swiper 步骤&#xff1a; ① npm install swiper 安装 ② 基础模板&#xff1a; <div><swiper class"swiper-box" :direction"vertical":grabCursor"true" :mousewheel"tr…...

简述SVM

概述 SVM&#xff0c;即支持向量机&#xff08;Support Vector Machine&#xff09;&#xff0c;是一种常见的监督学习算法&#xff0c;用于分类和回归问题。它是一种基于统计学习理论和结构风险最小化原则的机器学习方法。 SVM的主要思想是在特征空间中找到一个最优的超平面…...

【DevOps】Rundeck以及Jenkins

Rundeck是一个DevOps常用的工具&#xff0c;是PagerDuty公司开发的产品&#xff0c;能够很好的和PagerDuty进行集成。 但是平常我们听得或用得更多的是Jenkins&#xff0c;一个非常流行的CI工具&#xff0c;具有很好的可扩展性。 可是为什么那家公司会用Rundeck而不是Jenkins呢…...

数字滤波器分析---零极点分析

数字滤波器分析---零极点分析 zplane 函数绘制线性系统的极点和零点。 例如&#xff0c;在 -1/2 处为零且在 0.9e−j2π0.3 和 0.9ej2π0.3 处有一对复极点的简单滤波器为 zer -0.5; pol 0.9*exp(j*2*pi*[-0.3 0.3]); 要查看该滤波器的零极点图&#xff0c;您可以使用 z…...

HarmonyOS应用开发-网络请求与web组件

前言 当今世界&#xff0c;移动应用已经成为人们日常生活中不可或缺的一部分。无论是社交媒体、新闻、购物还是娱乐&#xff0c;安卓应用的广泛使用已经改变了我们与数字世界互动的方式。然而&#xff0c;这些应用的实际功能远不止界面和用户体验。它们背后的精密技术和网络请…...

频次最高的38道selenium面试题及答案

1、selenium的原理是什么&#xff1f; selenium的原理涉及到3个部分&#xff0c;分别是&#xff1a; 浏览器driver&#xff1a;一般我们都会下载driverclient&#xff1a;也就是我们写的代码 client其实并不知道浏览器是怎么工作的&#xff0c;但是driver知道&#xff0c;在…...

紧急!生产环境MCP网关偶发120ms毛刺?用perf + flame graph 15分钟定位C++虚函数调用链引发的L3缓存抖动——附热补丁patch与回归测试用例

第一章&#xff1a;紧急&#xff01;生产环境MCP网关偶发120ms毛刺&#xff1f;用perf flame graph 15分钟定位C虚函数调用链引发的L3缓存抖动——附热补丁patch与回归测试用例凌晨三点&#xff0c;MCP网关监控告警突现周期性120ms P99延迟毛刺&#xff0c;仅影响约0.3%请求&a…...

别再让RC522模块烧了!用STC89C51单片机驱动Mifare卡,3.3V供电避坑全记录

STC89C51驱动RC522模块实战指南&#xff1a;从硬件防护到稳定读卡 第一次接触RC522模块时&#xff0c;我犯了一个几乎所有初学者都会犯的错误——直接用5V供电。随着一缕青烟升起&#xff0c;价值60元的模块瞬间报废。这个惨痛教训让我意识到&#xff0c;RFID开发不仅仅是写代码…...

从AE到MAE:图解自监督学习中的生成式方法,为什么说它正在“复兴”?

从AE到MAE&#xff1a;生成式自监督学习的复兴之路 当ChatGPT用海量无标注文本训练出通用对话能力时&#xff0c;一个被忽视的技术细节是&#xff1a;支撑其成功的核心预训练方法——掩码语言建模&#xff08;MLM&#xff09;&#xff0c;本质上是一种生成式自监督学习。这不禁…...

从YUV序列到码流分析:一次完整的H.266/VVC编码实验与问题排查实录

从YUV序列到码流分析&#xff1a;一次完整的H.266/VVC编码实验与问题排查实录 在视频编码技术快速迭代的今天&#xff0c;H.266/VVC作为新一代标准&#xff0c;其压缩效率相比前代提升显著&#xff0c;但随之而来的复杂度也令许多开发者望而生畏。本文将带您深入实战&#xff0…...

一念成仙 攻略 核心地图移动与高级传送技巧完全指南

在众多文字修仙爱好者寻找优质玩法体验时&#xff0c;一念成仙凭借其庞大且真实的地图交互系统脱颖而出。为了帮助新手与进阶玩家在广袤的修仙世界中高效跑图&#xff0c;本篇一念成仙 攻略将结合深度的实际游玩经验&#xff0c;为您提供最专业、最可靠的地图移动与传送系统解析…...

重庆数据备份公司排行榜单

数据备份行业&#xff1a;技术挑战与本地化解决方案的崛起行业痛点分析当前&#xff0c;数据备份领域正面临前所未有的技术挑战。随着数据量呈指数级增长&#xff0c;传统备份方案在效率、成本和安全性上的短板日益凸显。首先&#xff0c;海量非结构化数据的涌现使得备份窗口被…...

如何专业配置游戏优化工具:DLSS Swapper终极性能提升指南

如何专业配置游戏优化工具&#xff1a;DLSS Swapper终极性能提升指南 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper DLSS Swapper是一款专为游戏玩家设计的显卡性能优化工具&#xff0c;通过智能管理DLSS、FSR和XeSS超…...

不只是安装:用moltemplate + LAMMPS在Ubuntu 20.04上跑通你的第一个分子动力学案例

不只是安装&#xff1a;用moltemplate LAMMPS在Ubuntu 20.04上跑通你的第一个分子动力学案例 当你第一次在Ubuntu上成功安装moltemplate时&#xff0c;那种成就感可能很快会被"接下来该做什么"的迷茫取代。本文将从实际科研需求出发&#xff0c;带你完成从软件安装到…...

思源宋体TTF:为什么这款免费字体能彻底改变你的中文排版体验

思源宋体TTF&#xff1a;为什么这款免费字体能彻底改变你的中文排版体验 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还记得那些年为中文字体版权发愁的日子吗&#xff1f;当我第一…...

基准测试实践指南:从原理到技术选型与性能优化

1. 基准测试的价值与意义在技术领域工作多年&#xff0c;我越来越意识到基准测试&#xff08;Baseline Results&#xff09;的重要性。就像盖房子需要打地基一样&#xff0c;任何性能优化、系统改进或算法评估都需要一个可靠的参照点。基准测试结果就是这个参照点&#xff0c;它…...