浙江商城网站建设,合肥响应网站案例,免费ppt模板下载网站入口,seo推广品牌排行榜背景
在实际项目中#xff0c;为了软件使用整体色调看起来统一#xff0c;一般顶部和底部的颜色需要铺满整个手机屏幕。因此#xff0c;这篇帖子是介绍设置的方法#xff0c;也是应用沉浸式效果。如下图#xff1a;底部的绿色延伸到上面的状态栏和下面的导航栏 UI
在鸿蒙…背景
在实际项目中为了软件使用整体色调看起来统一一般顶部和底部的颜色需要铺满整个手机屏幕。因此这篇帖子是介绍设置的方法也是应用沉浸式效果。如下图底部的绿色延伸到上面的状态栏和下面的导航栏 UI
在鸿蒙应用中全屏UI元素分为状态栏、应用界面和导航栏。 一般实现应用沉浸式效果由两种方式
窗口全屏布局方案调整布局系统为全屏布局界面元素延伸到状态栏和导航条区域实现沉浸式效果。组件延伸方案组件布局在应用界面区域通过接口方法延伸到状态栏和导航栏。
窗口全屏布局方案
新建展示页面并使用StorageProp定义页面内容的顶部偏移和底部偏移属性
Entry
Component
struct Index {StorageProp(bottomRectHeight)bottomRectHeight: number 0;StorageProp(topRectHeight)topRectHeight: number 0;build() {Row() {Column() {Row() {Text(DEMO-ROW1).fontSize(40)}.backgroundColor(Color.Orange).padding(20)Row() {Text(DEMO-ROW2).fontSize(40)}.backgroundColor(Color.Orange).padding(20)Row() {Text(DEMO-ROW3).fontSize(40)}.backgroundColor(Color.Orange).padding(20)Row() {Text(DEMO-ROW4).fontSize(40)}.backgroundColor(Color.Orange).padding(20)Row() {Text(DEMO-ROW5).fontSize(40)}.backgroundColor(Color.Orange).padding(20)Row() {Text(DEMO-ROW6).fontSize(40)}.backgroundColor(Color.Orange).padding(20)}.width(100%).height(100%).alignItems(HorizontalAlign.Center).justifyContent(FlexAlign.SpaceBetween).backgroundColor(#008000)// top数值与状态栏区域高度保持一致bottom数值与导航条区域高度保持一致.padding({ top: px2vp(this.topRectHeight), bottom: px2vp(this.bottomRectHeight) })}}
}在EntryAbility的onWindowStageCreate方法中调用window.Window.setWindowLayoutFullScreen方法设置窗口全屏。
let windowClass: window.Window windowStage.getMainWindowSync();
let isLayoutFullScreen true;windowClass.setWindowLayoutFullScreen(isLayoutFullScreen).then(() {console.info(Succeeded in setting the window layout to full-screen mode.);}).catch((err: BusinessError) {console.error(Failed to set the window layout to full-screen mode. Cause: JSON.stringify(err));});为了避免构件被挡住根据导航条和状态栏的高度修改bottomRectHeight和topRectHeight的数值。 //获取导航栏高度let bottomRectHeight windowClass.getWindowAvoidArea(window.AvoidAreaType.TYPE_NAVIGATION_INDICATOR).bottomRect.height;AppStorage.setOrCreate(bottomRectHeight, bottomRectHeight);// 获取状态栏区域高度let topRectHeight windowClass.getWindowAvoidArea(window.AvoidAreaType.TYPE_SYSTEM).topRect.height;AppStorage.setOrCreate(topRectHeight, topRectHeight);再设置页面监听动态修改bottomRectHeight和topRectHeight的数值。
windowClass.on(avoidAreaChange, (data) {if (data.type window.AvoidAreaType.TYPE_SYSTEM) {let topRectHeight data.area.topRect.height;AppStorage.setOrCreate(topRectHeight, topRectHeight);} else if (data.type window.AvoidAreaType.TYPE_NAVIGATION_INDICATOR) {let bottomRectHeight data.area.bottomRect.height;AppStorage.setOrCreate(bottomRectHeight, bottomRectHeight);}});EntryAbility完整代码
仅需要修改onWindowStageCreate方法
onWindowStageCreate(windowStage: window.WindowStage): void {// Main window is created, set main page for this abilityhilog.info(0x0000, testTag, %{public}s, Ability onWindowStageCreate);windowStage.loadContent(pages/Index, (err) {if (err.code) {hilog.error(0x0000, testTag, Failed to load the content. Cause: %{public}s, JSON.stringify(err) ?? );return;}hilog.info(0x0000, testTag, Succeeded in loading the content.);});// 获取应用主窗口let windowClass: window.Window windowStage.getMainWindowSync();// 设置窗口全屏let isLayoutFullScreen true;windowClass.setWindowLayoutFullScreen(isLayoutFullScreen).then(() {console.info(Succeeded in setting the window layout to full-screen mode.);}).catch((err: BusinessError) {console.error(Failed to set the window layout to full-screen mode. Cause: JSON.stringify(err));});//获取导航栏高度let bottomRectHeight windowClass.getWindowAvoidArea(window.AvoidAreaType.TYPE_NAVIGATION_INDICATOR).bottomRect.height;AppStorage.setOrCreate(bottomRectHeight, bottomRectHeight);// 获取状态栏区域高度let topRectHeight windowClass.getWindowAvoidArea(window.AvoidAreaType.TYPE_SYSTEM).topRect.height;AppStorage.setOrCreate(topRectHeight, topRectHeight);// 注册监听函数动态获取避让区域数据windowClass.on(avoidAreaChange, (data) {if (data.type window.AvoidAreaType.TYPE_SYSTEM) {let topRectHeight data.area.topRect.height;AppStorage.setOrCreate(topRectHeight, topRectHeight);} else if (data.type window.AvoidAreaType.TYPE_NAVIGATION_INDICATOR) {let bottomRectHeight data.area.bottomRect.height;AppStorage.setOrCreate(bottomRectHeight, bottomRectHeight);}});}组件延伸方案
使用expandSafeArea方法来实现。
expandSafeArea(types?: ArraySafeAreaType, edges?: ArraySafeAreaEdge): T;types配置扩展安全区域的类型。SafeAreaType枚举类型SYSTEM是系统默认非安全区域包括状态栏、导航栏CUTOUT是设备的非安全区域例如刘海屏或挖孔屏区域KEYBOARD是软键盘区域组件不避让键盘。edges扩展安全区域的方向。
代码
通过颜色对比可以看出组件延伸效果。
column背景颜色设置为橘色从图片可以看出只能在安全区域内显示。list背景颜色设置为黄色从图片可以看出已经延伸至导航条和状态栏了。Text背景颜色设置成红色就可以看到整个组件的滑动过程. Entry
Component
struct ExamplePage {private arr: number[] [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]build() {Column() {List({ space: 20, initialIndex: 0 }) {ForEach(this.arr, (item: number) {ListItem() {Text( item).width(100%).height(100).fontSize(16).textAlign(TextAlign.Center).borderRadius(10).backgroundColor(Color.Red)}}, (item: number) item.toString())}.listDirection(Axis.Vertical) // 排列方向.scrollBar(BarState.Off).friction(0.6).divider({strokeWidth: 2,color: 0xFFFFFF,startMargin: 20,endMargin: 20}) // 每行之间的分界线.edgeEffect(EdgeEffect.Spring) // 边缘效果设置为Spring.width(90%).backgroundColor(Color.Yellow)// List组件的视窗范围扩展至导航条。.expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP, SafeAreaEdge.BOTTOM])}.width(100%).height(100%).backgroundColor(Color.Orange)}
}总结
如果不是全部界面都需要实现沉浸式布局时可以通过组件延伸方案去实现部分组件的沉浸式布局。