OpenHarmony开发者论坛

标题: OpenHarmony原生开发手记:04-一个完整元服务案例 [打印本页]

作者: zacksleo    时间: 5 天前
标题: OpenHarmony原生开发手记:04-一个完整元服务案例
[md]# 影院热映

> 分享一个完整的元服务案例,这个案例高仿了豆瓣的小程序。

## 简介

整个元服务分为 4-5 个页面,首页为列表页,展示了当前影院热门的电影,点开是一个详情介绍页,里面有影片详情,演职表,相关影片推荐等,热门海报。打开海报是一个完整的海报展示页,点开可以产看大图。
另外,还有一个关于我们的介绍页。

## 设计

元服务没有使用底部页签,而是把关于我们放置在了页面底部,以较为委婉的方式进行展示。

## 代码

1. 查看 `entry/src/main/etc/pages/` 目录,整个应用分为了四个页面。
   其路由在 `entry/src/main/resources/base/profile/main_pages.json` 中配置,路由名与文件名一一对应。
   在 `main_pages.json` 所在地目录中,可以看到一个 `form_config.json`文件,这个用来配置服务卡片,在此按下不表。

页面中多使用行列布局,各种间距优先使用 `Blank()` 来指定。

在 Album 页面中,使用了网格布局,点击其中一张图片时,会播放幻灯片,这里使用了 `@lyb/media-preview` 三方库,以下是核心代码:

```ets
Grid() {
    ForEach(this.items, (item: Photo, index: number) => {
      GridItem() {
        Image(item.image.normal.url)
          .width('100%')
          .height(140)
          .objectFit(ImageFit.Cover)
          .clickEffect({ level: ClickEffectLevel.MIDDLE, scale: 1.1 })
          .visibility(index == this.index ? Visibility.Hidden : Visibility.Visible)
          .onClick((event) => {
            this.options
              .setInitIndex(index)
              .setMedias(this.getPreviewResources())
              .setIndicator(false)
            MediaPreview.open(this.getUIContext(), this.options)
          })
      }
    })
  }
  .columnsTemplate('1fr 1fr 1fr')
  .columnsGap(2)
  .rowsGap(2)
  .scrollBar(BarState.Off)

```

2. `common` 目录存放一些全局变量,如 `Constants.ets` 文件,这里使用静态变量。另外还有请求类的简单封装,同样使用静态类作为单例。

为了让导入代码更简洁,同时也 “高内聚低耦合”,使用了 index 文件来导出这个目录下得类和方法。

`Request` 中的方法使用了泛型,这样可以根据传人类型自动反序列化,减少了样板代码量。
3. `components` 组件目录。这里存放各封装的小组件。本案例中包含了演职表、版权声明,海报列表,以及相关推荐共 4 个小组件。

`Copyright` 是一个简单的小组件,显示在页脚。

```ets
@Component
export struct Copyright {
  build() {
    Row() {
      Image($r('app.media.nutpi')).width(32)
      Blank().width(8)
      Text('坚果派出品').fontWeight(FontWeight.Bold).fontColor(Color.Gray)
    }.justifyContent(FlexAlign.Center)
    .width('100%')
    .onClick((event) => {
      router.pushUrl({ url: 'pages/About' })
    })
  }
}```

```

4. `quickactions/pages/QuickActionCard.ets` 为服务卡片的页面,这里描述了卡片的 UI,通过 Formlink 监听和触发点击事件

```ets
FormLink({
      action: this.ACTION_TYPE,
      abilityName: this.ABILITY_NAME,
      params: {
        action: this.MESSAGE
      }
    }) {
      Row() {
        Text('影院热映').fontSize(14)
          .fontColor($r('app.color.card_label'))
        Image($r('app.media.icon'))
          .width(32)
      }
      .justifyContent(FlexAlign.SpaceBetween)
      .height(this.FULL_HEIGHT_PERCENT)
      .width('100%')
      .padding({
        top: 10,
        left: 12,
        right: 12,
        bottom: 10
      })
      .backgroundColor($r('app.color.background_color'))
    }
```

在上面的代码中,描述了一个行布局,左侧为图标,右侧为应用名称。

5.`viewmodels` 为视图数据模型。本案例共 5 个模型,分别是 `AppInfo`,`Celebrities`, `Movie`, `Photos`, `Relative`.

```ets
export class AppInfo {
  logo: string = '';
  appName: string = '';
  appLinking: string = '';
  appId: string = '';
  desc: string = '';
  type: string = '';
}
```

`AppInfo` 是一个简单的应用信息类,包含 logo,应用名称,applink,描述和应用类型等信息。

## 应用截图

| 首页                                                                                                                                       | 我的                                                                                                                                       | 帮助                                                                                                                                       |
| ------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------ |
| ![1.jpeg](https://dl-harmonyos.51cto.com/i ... rocess=image/resize,w_820,h_2720)  | ![img2.jpg](https://dl-harmonyos.51cto.com/i ... rocess=image/resize,w_820,h_2720) | ![img3.jpg](https://dl-harmonyos.51cto.com/i ... rocess=image/resize,w_820,h_2720) |
| ![img4.jpg](https://dl-harmonyos.51cto.com/i ... rocess=image/resize,w_820,h_2720) | ![img5.jpg](https://dl-harmonyos.51cto.com/i ... rocess=image/resize,w_820,h_2720) |                                                                                                                                            |

## 注意事项

1. 打开元服务豁免管控:系统-开发者选项-开发中元服务豁免管控

## 其他

关于应用创建、服务卡片、打包签名、上架审核等,可以查看往期文章,或下方的参考资料。

## 完整代码

完整的代码见代码仓库
https://gitee.com/zacks/arkts-ohos-demo

## 参考资料

- [OpenHarmony原生开发手记:01-元服务开发](https://gitee.com/zacks/awesome- ... 5%BC%80%E5%8F%91.md)
- [OpenHarmony原生开发手记:02-服务卡片开发](https://gitee.com/zacks/awesome- ... 5%BC%80%E5%8F%91.md)
- [OpenHarmony原生开发手记:03-元服务开发全流程](https://gitee.com/zacks/awesome- ... 6%B5%81%E7%A8%8B.md)
- [OpenHarmony应用打包上架流程](https://gitee.com/zacks/awesome- ... 6%B5%81%E7%A8%8B.md)
[/md]




欢迎光临 OpenHarmony开发者论坛 (https://forums.openharmony.cn/) Powered by Discuz! X3.5