HarmonyOS NEXT 实战之元服务:静态案例效果---电动车电池健康状况

背景:

前几篇学习了元服务,后面几期就让我们开发简单的元服务吧,里面丰富的内容大家自己加,本期案例 仅供参考

先上本期效果图 ,里面图片自行替换

效果图1完整代码案例如下:

复制代码
import { authentication } from '@kit.AccountKit';
import { BusinessError } from '@kit.BasicServicesKit';
import { hilog } from '@kit.PerformanceAnalysisKit';

@Entry
@Component
struct Index {
  @State message: string = 'Hello World';

  build() {
    Column() {
      Image($r('app.media.diandongche')).width('60%')
        .height(200)
      Row() {
        Column({ space: 5 }) {
          Row() {
            Image($r('app.media.dianchi')).width(50).height(50)
            Text('50%').fontColor(Color.White).fontSize(20).fontWeight(FontWeight.Bold)
          }

          Image($r('app.media.diandongche')).width(80)
            .height(80)
        }
        .width('40%')
        .backgroundColor('#9571E9')
        .borderWidth(1)
        .borderColor('#FF7F00')
        .borderRadius(10)
        .padding(6)


        Row() {
          Column({ space: 5 }) {
            Image($r('app.media.dizhi')).width(50).height(50)
            Text('庞各庄地铁C口').fontColor(Color.Black).fontSize(12)
          }

          Column({ space: 5 }) {
            Image($r('app.media.xiang')).width(50).height(50)
            Text('响铃找车').fontColor(Color.Black).fontSize(12)
          }

        }
        .justifyContent(FlexAlign.SpaceBetween)
        .width('100%')
        .height(146)
        .backgroundColor('#70E07B')
        .borderWidth(1)
        .borderColor('#FF7F00')
        .borderRadius(10)
        .width('55%')
        .padding(6)

      }
      .justifyContent(FlexAlign.SpaceBetween)
      .width('100%')
      .margin({ top: 12 })
      .backgroundColor('#D8D8FB')
      .borderWidth(1)
      .borderColor('#FF7F00')
      .borderRadius(10)
      .padding(6)


      Row() {
        Column({ space: 5 }) {
          Text('450km').fontColor('#FF7F00').fontSize(18)
          Text('累计骑行')

        }


        Column({ space: 5 }) {
          Text('50km').fontColor('#FF7F00').fontSize(18)
          Text('预计续航')

        }
        Column({ space: 5 }) {
          Image($r('app.media.diandongche')).width(50).height(50)
          Text('VIP解锁更多功能')
        }

      }
      .justifyContent(FlexAlign.SpaceBetween)
      .width('100%')
      .margin({ top: 12 })
      .backgroundColor('#D8D8FB')
      .borderWidth(1)
      .borderColor('#FF7F00')
      .borderRadius(10)
      .padding(6)

    }
    .height('100%')
    .width('100%')
    .margin({ top: 60 })
    .padding(16)
  }

  aboutToAppear() {
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
    this.loginWithHuaweiID();
  }

  /**
   * Sample code for using HUAWEI ID to log in to atomic service.
   * According to the Atomic Service Review Guide, when a atomic service has an account system,
   * the option to log in with a HUAWEI ID must be provided.
   * The following presets the atomic service to use the HUAWEI ID silent login function.
   * To enable the atomic service to log in successfully using the HUAWEI ID, please refer
   * to the HarmonyOS HUAWEI ID Access Guide to configure the client ID and fingerprint certificate.
   */
  private loginWithHuaweiID() {
    // Create a login request and set parameters
    let loginRequest = new authentication.HuaweiIDProvider().createLoginWithHuaweiIDRequest();
    // Whether to forcibly launch the HUAWEI ID login page when the user is not logged in with the HUAWEI ID
    loginRequest.forceLogin = false;
    // Execute login request
    let controller = new authentication.AuthenticationController();
    controller.executeRequest(loginRequest).then((data) => {
      let loginWithHuaweiIDResponse = data as authentication.LoginWithHuaweiIDResponse;
      let authCode = loginWithHuaweiIDResponse.data?.authorizationCode;
      // Send authCode to the backend in exchange for unionID, session

    }).catch((error: BusinessError) => {
      hilog.error(0x0000, 'testTag', 'error: %{public}s', JSON.stringify(error));
      if (error.code == authentication.AuthenticationErrorCode.ACCOUNT_NOT_LOGGED_IN) {
        // HUAWEI ID is not logged in, it is recommended to jump to the login guide page

      }
    });
  }
}
相关推荐
晚秋大魔王3 小时前
OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——nettle库
linux·开源·harmonyos
python算法(魔法师版)7 小时前
.NET 在鸿蒙系统上的适配现状
华为od·华为·华为云·.net·wpf·harmonyos
bestadc8 小时前
鸿蒙 UIAbility组件与UI的数据同步和窗口关闭
harmonyos
枫叶丹49 小时前
【HarmonyOS Next之旅】DevEco Studio使用指南(二十二)
华为·harmonyos·deveco studio·harmonyos next
ax一号街阿楠11 小时前
华为FAT AP配置 真机
网络·华为·智能路由器
吗喽对你问好11 小时前
华为5.7机考第一题充电桩问题Java代码实现
java·华为·排序
乱世刀疤13 小时前
深度 |国产操作系统“破茧而出”:鸿蒙电脑填补自主生态空白
华为·harmonyos
博睿谷IT99_18 小时前
华为HCIP-AI认证考试版本更新通知
人工智能·华为
连续讨伐18 小时前
ensp的华为小实验
华为
沙振宇19 小时前
【Web】使用Vue3开发鸿蒙的HelloWorld!
前端·华为·harmonyos