HarmonyOS 鸿蒙Next 类似于控制中心顶部的实时模糊实现方案

发布于 1周前 作者 wuwangju 最后一次编辑是 5天前 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 类似于控制中心顶部的实时模糊实现方案

cke_167.png

我实现了一个类似于控制中心顶部的实时模糊页面,但是感觉应该不是最佳的方案(因为需要将导航栏定义在最后面),请问是否有更好的实现方式?

我采用了stack组件,将导航栏定义在最上层,然后下层定义scroll用于设置可滚动的组件,并将导航栏和滚动组件扩展到了安全区。
 

@Component
export struct Page {
  @BuilderParam @Require column:()=>void=emptyBuilderFunction;
  @BuilderParam @Require navBar:()=>void=emptyBuilderFunction;
  build() {
    Stack() {
      Scroll() {
        Column({ space: 8 }) {
          this.column()
        }
        .padding({
          top: 60,
          left: 16,
          right: 16,
          bottom: 0
        })

      }
      .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP,SafeAreaEdge.BOTTOM])
      .edgeEffect(EdgeEffect.Spring)

      // 导航栏
      Row(){
        Text('测试')
          .fontSize(24)
          .fontColor(Color.Black)
          .fontWeight(FontWeight.Bold)
          .width("100%")
          .textAlign(TextAlign.Center)
          .padding(14)
          .height(52)
      }
      .width('100%')
      .backdropBlur(64)
      .expandSafeArea([SafeAreaType.SYSTEM], [SafeAreaEdge.TOP])
    }
    .width('100%')
    .alignContent(Alignment.TopStart)
  }
}

更多关于HarmonyOS 鸿蒙Next 类似于控制中心顶部的实时模糊实现方案的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

更多关于HarmonyOS 鸿蒙Next 类似于控制中心顶部的实时模糊实现方案的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


针对HarmonyOS鸿蒙Next实现类似于控制中心顶部的实时模糊效果,可以采用以下方案:

在鸿蒙Next中,可以使用backdropBlur属性为组件添加背景模糊效果。首先,通过布局组件(如StackColumn等)搭建页面结构,确保导航栏和滚动区域正确布局。然后,在需要模糊效果的组件上应用backdropBlur属性,并设置合适的模糊值。例如,在Stack组件中,可以为包含滚动内容的Column组件或其子组件添加backdropBlur属性,以实现背景模糊效果。

此外,还可以通过调整布局容器的对齐方式、边距、填充等属性,进一步优化页面布局和模糊效果。需要注意的是,模糊效果的实现可能受到设备性能、屏幕分辨率等因素的影响,因此在实际开发中需要进行充分的测试和调优。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部