组件导航 (Navigation)+flutter项目搭建-混合开发+分栏

组件导航 (Navigation)+flutter项目搭建

接上一章flutter项目的环境变量配置并运行flutter

上一章面熟了搭建flutter并用编辑器运行了ohos项目,这章主要是对项目的工程化改造

先创建flutter项目,再配置Navigation

1.在开发视图的resources/base/profile下面定义配置文件,文件名可以自定义,例如:router_map.json。

复制代码
{
  "routerMap": [
    {
      "name": "PageFlutter",
      "pageSourceFile": "src/main/ets/pages/home/PageFlutter.ets",
      "buildFunction": "PageFlutterBuilder",
      "data": {
        "description": "this is PageOne"
      }
    },
    {
      "name": "PageTwo",
      "pageSourceFile": "src/main/ets/pages/home/PageTwo.ets",
      "buildFunction": "PageTwoBuilder",
      "data": {
        "description": "this is PageTwo"
      }
    },
    {
      "name": "PageThree",
      "pageSourceFile": "src/main/ets/pages/home/PageThree.ets",
      "buildFunction": "PageThreeBuilder",
      "data": {
        "description": "this is PageThree"
      }
    }
  ]
}

2.在module.json5配置的module下面配置

复制代码
{
  "module": {
	  ...
	  "routerMap": "$profile:router_map",
	  }
}

项目文件如下

在入口 "pages/Index"文件配置

需要注意的是flutter只会一次,把栈移到顶部,不能一直push

Index.ets

复制代码
import { PageFlutterBuilder } from "./home/PageFlutter";
import { PageThreeBuilder } from "./home/PageThree";
import { PageTwoBuilder } from "./home/PageTwo";

let storage = LocalStorage.getShared()

@Entry(storage)
@Component
struct Index {
  @Provide('pageInfos') pageInfos: NavPathStack = new NavPathStack()
  private arr: string[] = ['PageFlutter', 'PageTwo', 'PageThree'];

  build() {
    Column() {
      Navigation(this.pageInfos) {
        List({ space: 12 }) {
          ForEach(this.arr, (item: string) => {
            ListItem() {
              Text("Page" + item)
                .width("100%")
                .height(72)
                .backgroundColor('#FFFFFF')
                .borderRadius(24)
                .fontSize(16)
                .fontWeight(500)
                .textAlign(TextAlign.Center)
                .onClick(() => {
                  if(item==='PageFlutter'&&this.pageInfos.getAllPathName().includes('PageFlutter')){
                    // flutter只会一次,把栈移到顶部
                    this.pageInfos.moveToTop(item)
                  }else {
                    this.pageInfos.pushPath({ name: item});
                  }

                })
            }
          }, (item: number) => item.toString())
        }
        .width("90%")
        .margin({ top: 12 })
      }
      .mode(NavigationMode.Auto)
      .hideTitleBar(true)
    }
    .height('100%')
    .width('100%')
    .backgroundColor('#F1F3F5')
  }
}

PageFlutter.ets

复制代码
import { FlutterPage } from "@ohos/flutter_ohos";
import { common } from "@kit.AbilityKit";

// 跳转页面入口函数
@Builder
export function PageFlutterBuilder() {
  PageFlutter();
}
const EVENT_BACK_PRESS = 'EVENT_BACK_PRESS'


@Component
struct PageFlutter {
  pathStack: NavPathStack = new NavPathStack();
  @LocalStorageLink('viewId') viewId: string = "";
  private context = getContext(this) as common.UIAbilityContext

  build() {
    NavDestination() {
      Text('hellppp')
      if(this.viewId){
        FlutterPage({ viewId: this.viewId })
      }
    }
    .onReady((context: NavDestinationContext) => {
      this.pathStack = context.pathStack;
    })
    .onBackPressed(() => {
      this.context.eventHub.emit(EVENT_BACK_PRESS)
      return true;
    })
    .hideTitleBar(true)
  }
}

其他PageThree.ets,PageTwo.ets随便写

效果如下

相关推荐
大师兄66682 分钟前
HarmonyOS 卡片 UI 三种玩法:普通卡片、动效卡片、Canvas 卡片
harmonyos·arkts·formkit·动效卡片·canvas卡片
JXNL@3 小时前
电源适配器的拓扑结构探索
电脑
特立独行的猫a5 小时前
鸿蒙 PC 命令行工具迁移实战 · 直播PPT
android·华为·harmonyos·vcpkg·三方库移植·鸿蒙pc
qwert10375 小时前
相机视图矩阵的由来:从空间感知到图形渲染的核心桥梁
数码相机·矩阵·图形渲染
想你依然心痛5 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与Face AR & Body AR的“灵犀智投“——PC端沉浸式AR量化交易分析工作台
华为·ar·harmonyos·悬浮导航·沉浸光感
特立独行的猫a5 小时前
鸿蒙 PC 三方库移植实战 · 直播课件(详细教案)
华为·harmonyos·移植·鸿蒙pc·opendesk
西西学代码5 小时前
Flutter---侧边栏
flutter
xmdy58667 小时前
Flutter+开源鸿蒙实战|企业级工具APP Day2 全局网络封装与 Dio 拦截器实战(鸿蒙兼容版)
flutter·开源·harmonyos
xmdy58667 小时前
Flutter+开源鸿蒙实战:企业级工具类APP开发教程(含第三方库适配)
flutter·开源·harmonyos
richard_yuu8 小时前
鸿蒙Stage模型实战|心晴驿站分层架构与隐私安全设计
安全·架构·harmonyos