精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

鴻蒙OS開發實例:【應用事件打點】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-07 17:13 ? 次閱讀

簡介

傳統的日志系統里匯聚了整個設備上所有程序運行的過程流水日志,難以識別其中的關鍵信息。因此,應用開發者需要一種數據打點機制,用來評估如訪問數、日活、用戶操作習慣以及影響用戶使用的關鍵因素等關鍵信息。

HiAppEvent是在系統層面為應用開發者提供的一種事件打點機制,用于幫助應用記錄在運行過程中發生的故障信息、統計信息、安全信息、用戶行為信息,以支撐開發者分析應用的運行情況。

基本概念

  • 打點
    記錄由用戶操作引起的變化,提供業務數據信息,以供開發、產品、運維分析。

事件設計規范

  • 事件領域:用于標識事件的領域,建議設置為業務模塊名稱,以便于區分不同的業務模塊。
  • 事件名稱:用于指定事件的名稱,建議設置為具體的業務名稱,以便于描述實際的業務意義。
  • 事件類型:用于指定事件的類型,支持以下四種類型事件:
    • 行為事件:用于記錄用戶日常操作行為的事件,例如按鈕點擊、界面跳轉等行為。
    • 故障事件:用于定位和分析應用故障的事件,例如界面卡頓、掉網掉話等異常。
    • 統計事件:用于統計和度量應用關鍵行為的事件,例如對使用時長、訪問數等的統計。
    • 安全事件:用于記錄涉及應用安全行為的事件,例如密碼修改、用戶授權等行為。
  • 事件參數:用于指定事件的參數,每個事件可以包含一組參數,建議設置為事件屬性或事件發生上下文信息,以便于描述事件的詳細信息。

接口說明

應用事件打點接口由hiAppEvent模塊提供。

打點接口功能介紹:

接口名描述
write(AppEventInfo info, AsyncCallback callback): void應用事件異步打點方法,使用callback方式作為異步回調。
write(AppEventInfo info): Promise應用事件異步打點方法,使用Promise方式作為異步回調。

訂閱接口功能介紹:

接口名描述
addWatcher(Watcher watcher): AppEventPackageHolder添加應用事件觀察者,以添加對應用事件的訂閱。
removeWatcher(Watcher watcher): void移除應用事件觀察者,以移除對應用事件的訂閱。
鴻蒙OS開發更多內容↓點擊HarmonyOSOpenHarmony技術
鴻蒙技術文檔開發知識更新庫gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md在這。

開發步驟

搜狗高速瀏覽器截圖20240326151547.png

更多鴻蒙開發文檔mau123789是v添加后免費領取。

以實現對用戶點擊按鈕行為的事件打點及訂閱為例,說明開發步驟。

  1. 新建一個ArkTS應用工程,編輯工程中的“entry > src > main > ets > entryability > EntryAbility.ts” 文件,在onCreate函數中添加對用戶點擊按鈕事件的訂閱,完整示例代碼如下:
    import hilog from '@ohos.hilog';
    import UIAbility from '@ohos.app.ability.UIAbility';
    import Window from '@ohos.window'
    import hiAppEvent from '@ohos.hiviewdfx.hiAppEvent'
    
    export default class EntryAbility extends UIAbility {
        onCreate(want, launchParam) {
            hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO);
            hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
            hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? '');
            hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:' + JSON.stringify(launchParam) ?? '');
            hiAppEvent.addWatcher({
                // 開發者可以自定義觀察者名稱,系統會使用名稱來標識不同的觀察者
                name: "watcher1",
                // 開發者可以訂閱感興趣的應用事件,此處是訂閱了按鈕事件
                appEventFilters: [{ domain: "button" }],
                // 開發者可以設置訂閱回調觸發的條件,此處是設置為事件打點數量滿足1個
                triggerCondition: { row: 1 },
                // 開發者可以自行實現訂閱回調函數,以便對訂閱獲取到的事件打點數據進行自定義處理
                onTrigger: function (curRow, curSize, holder) {
                    // 返回的holder對象為null,表示訂閱過程發生異常,因此在記錄錯誤日志后直接返回
                    if (holder == null) {
                        hilog.error(0x0000, 'testTag', "HiAppEvent holder is null")
                        return
                    }
                    let eventPkg = null
                    // 根據設置閾值大小(默認為512KB)去獲取訂閱事件包,直到將訂閱數據全部取出
                    // 返回的事件包對象為null,表示當前訂閱數據已被全部取出,此次訂閱回調觸發結束
                    while ((eventPkg = holder.takeNext()) != null) {
                        // 開發者可以對事件包中的事件打點數據進行自定義處理,此處是將事件打點數據打印在日志中
                        hilog.info(0x0000, 'testTag', `HiAppEvent eventPkg.packageId=%{public}d`, eventPkg.packageId)
                        hilog.info(0x0000, 'testTag', `HiAppEvent eventPkg.row=%{public}d`, eventPkg.row)
                        hilog.info(0x0000, 'testTag', `HiAppEvent eventPkg.size=%{public}d`, eventPkg.size)
                        for (const eventInfo of eventPkg.data) {
                            hilog.info(0x0000, 'testTag', `HiAppEvent eventPkg.info=%{public}s`, eventInfo)
                        }
                    }
                }
            })
        }
    }
    
  2. 編輯工程中的“entry > src > main > ets > pages > Index.ets” 文件,添加一個按鈕并在其onClick函數中進行事件打點,以記錄按鈕點擊事件,完整示例代碼如下:
    import hiAppEvent from '@ohos.hiviewdfx.hiAppEvent'
    import hilog from '@ohos.hilog'
    
    @Entry
    @Component
    struct Index {
      @State message: string = 'Hello World'
      build() {
        Row() {
          Column() {
            Text(this.message)
              .fontSize(50)
              .fontWeight(FontWeight.Bold)
            Button("writeTest").onClick(()= >{
              // 在按鈕點擊函數中進行事件打點,以記錄按鈕點擊事件
              hiAppEvent.write({
                // 事件領域定義
                domain: "button",
                // 事件名稱定義
                name: "click",
                // 事件類型定義
                eventType: hiAppEvent.EventType.BEHAVIOR,
                // 事件參數定義
                params: { click_time: 100 }
              }).then(() = > {
                hilog.info(0x0000, 'testTag', `HiAppEvent success to write event`)
              }).catch((err) = > {
                hilog.error(0x0000, 'testTag', `HiAppEvent err.code: ${err.code}, err.message: ${err.message}`)
              })
            })
          }
          .width('100%')
        }
        .height('100%')
      }
    }
    
  3. 點擊IDE界面中的運行按鈕,運行應用工程,然后在應用界面中點擊按鈕“writeTest”,觸發一次按鈕點擊事件打點。
  4. 最終,可以在Log窗口看到按鈕點擊事件打點成功的日志,以及觸發訂閱回調后對打點事件數據的處理日志:
    HiAppEvent success to write event
    
    HiAppEvent eventPkg.packageId=0
    HiAppEvent eventPkg.row=1
    HiAppEvent eventPkg.size=124
    HiAppEvent eventPkg.info={"domain_":"button","name_":"click","type_":4,"time_":1670268234523,"tz_":"+0800","pid_":3295,"tid_":3309,"click_time":100}
    

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • HarmonyOS
    +關注

    關注

    79

    文章

    1967

    瀏覽量

    30025
  • OpenHarmony
    +關注

    關注

    25

    文章

    3661

    瀏覽量

    16159
  • 鴻蒙OS
    +關注

    關注

    0

    文章

    188

    瀏覽量

    4371
收藏 人收藏

    評論

    相關推薦

    HarmonyOS應用事打點開發指導

    hiAppEvent 模塊提供,API 接口的具體使用說明(參數使用限制、具體取值范圍等)請參考應用事打點 API 文檔。 打點接口功能介紹: 訂閱接口功能介紹: 開發步驟 以
    發表于 12-21 11:02

    鴻蒙OS應用程序開發

    這份學習文檔主要是帶領大家在鴻蒙OS上學習開發一個應用程序,主要知識點如下:1、U-Boot引導文件燒寫方式;2、內核鏡像燒寫方式;3、鏡像運行。
    發表于 09-11 14:39

    鴻蒙OS適用的全場景到底什么意思?

    鴻蒙系統(HarmonyOS),第一款基于微內核的全場景分布式OS,是華為自主研發的操作系統。華為在開發者大會HDC.2019上正式發布了鴻蒙系統,該系統將率先部署在智慧屏、車載終端、
    發表于 09-25 09:25

    鴻蒙 OS 應用開發初體驗

    的操作系統平臺和開發框架。HarmonyOS 的目標是實現跨設備的無縫協同和高性能。 DevEco Studio 對標 Android Studio,開發鴻蒙 OS 應用的 IDE。
    發表于 11-02 19:38

    嵌入式系統設計與實例開發—ARM與uC/OS-Ⅱ

    嵌入式系統設計與實例開發 ——ARM與uC/OS-Ⅱ
    發表于 11-08 17:32 ?0次下載

    華為鴻蒙OS 2.0帶來哪些智慧體驗?

    華為已經定于12月16日在北京發布鴻蒙OS 2.0手機開發者Beta版本。這不僅是手機鴻蒙OS的首次亮相,同時也意味著手機
    的頭像 發表于 12-15 15:10 ?2048次閱讀

    鴻蒙OS 2.0手機開發者Beta版發布會在京舉辦

    三個月前,鴻蒙OS 2.0正式在華為開發者大會2020亮相。12月16日,鴻蒙OS 2.0手機開發
    的頭像 發表于 12-16 09:29 ?1.9w次閱讀

    華為正式推出鴻蒙OS的手機開發者Beta版

    12月16日上午消息,華為今日宣布正式推出鴻蒙OS的手機開發者Beta版,華為消費者業務軟件部總裁王成錄表示,今年已有美的、九陽、老板電器、海雀科技搭載鴻蒙
    的頭像 發表于 12-16 10:37 ?2588次閱讀

    鴻蒙OS2.0手機開發者Beta版登場

    12 月 16 日,華為宣布正式推出鴻蒙 OS 的手機開發者 Beta 版,并正式面向個人/企業開發者公測鴻蒙 2.0,
    的頭像 發表于 12-16 14:39 ?2190次閱讀

    華為發布鴻蒙OS Beta版

    昨天華為發布鴻蒙OS Beta版了?鴻蒙系統一直在按照既有步伐前進,現在華為發布鴻蒙OS Beta版,而且一些生態
    的頭像 發表于 12-17 08:41 ?2854次閱讀

    鴻蒙OS與Lite OS的區別是什么

    鴻蒙OS鴻蒙OS面向未來、面向全場景、分布式。在單設備系統能力基礎上,鴻蒙OS提出了基于同一套系
    的頭像 發表于 12-24 12:40 ?4922次閱讀

    鴻蒙os怎么升級

    6月2日,華為正式發布了鴻蒙armonyOS 2系統,那么鴻蒙os如何升級?現將鴻蒙os升級方式告知如下。
    的頭像 發表于 06-08 16:26 ?2712次閱讀

    華為開發者大會2021鴻蒙os在哪場

    華為開發者大會2021將在10月22日-24日舉辦,地點為東莞松山湖,鴻蒙os 3.0或將與我們見面,那么華為開發者大會2021鴻蒙
    的頭像 發表于 10-22 15:24 ?1877次閱讀

    鴻蒙開發系統基礎能力:ohos.hiAppEvent應用打點

    本模塊提供了應用事打點能力,包括對打點數據的落盤,以及對打點功能的管理配置。
    的頭像 發表于 06-24 11:09 ?444次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發</b>系統基礎能力:ohos.hiAppEvent應用<b class='flag-5'>打點</b>

    鴻蒙開發系統基礎能力:ohos.hiTraceMeter性能打點

    本模塊提供了追蹤進程軌跡,度量程序執行性能的打點能力。本模塊打點的數據供hiTraceMeter工具分析使用。
    的頭像 發表于 06-25 16:12 ?377次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發</b>系統基礎能力:ohos.hiTraceMeter性能<b class='flag-5'>打點</b>