• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "JankAnimatorReporterAdapter.h"
17 #include "hiview_logger.h"
18 
19 namespace OHOS {
20 namespace HiviewDFX {
21 DEFINE_LOG_LABEL(0xD002D66, "Hiview-XPerformance");;
22 
JankAnimatorReporterAdapter(IJankAnimatorReportInfrastructure * impl,IScrollJankEventPoster * eventPoster)23 JankAnimatorReporterAdapter::JankAnimatorReporterAdapter(
24     IJankAnimatorReportInfrastructure* impl, IScrollJankEventPoster* eventPoster)
25 {
26     this->reporter = impl;
27     this->eventPoster = eventPoster;
28 }
29 
ReportNormal(const JankAnimatorReportEvent & event)30 void JankAnimatorReporterAdapter::ReportNormal(const JankAnimatorReportEvent& event)
31 {
32     HIVIEW_LOGD("[JankAnimatorReporterAdapter::ReportNormal]");
33     try {
34         if (reporter != nullptr) {
35             JankAnimatorReportData data = ConvertReporterEventToData(event);
36             reporter->ReportNormal(data);
37         } else {
38             HIVIEW_LOGE("[JankAnimatorReporterAdapter ReportNormal] report is null");
39         }
40 
41         if ((eventPoster != nullptr) && IsScrollJankEvent(event)) {
42             ScrollJankEventInfo evt = ConvertReportEventToEventInfo(event);
43             HIVIEW_LOGD("[JankAnimatorReporterAdapter::ReportNormal] PostScrollJankEvent begin");
44             eventPoster->PostScrollJankEvent(evt);
45             HIVIEW_LOGD("[JankAnimatorReporterAdapter::ReportNormal] PostScrollJankEvent end");
46         }
47     }
48     catch (std::logic_error& ex) {
49         HIVIEW_LOGE("[JankAnimatorReporterAdapter ReportNormal] exception: %{public}s", ex.what());
50     }
51 }
52 
ReportCritical(const JankAnimatorReportEvent & event)53 void JankAnimatorReporterAdapter::ReportCritical(const JankAnimatorReportEvent& event)
54 {
55     HIVIEW_LOGD("[JankAnimatorReporterAdapter::ReportCritical]");
56     try {
57         JankAnimatorReportData data = ConvertReporterEventToData(event);
58         if (reporter != nullptr) {
59             reporter->ReportCritical(data);
60         } else {
61             HIVIEW_LOGE("[JankAnimatorReporterAdapter ReportCritical] report is null");
62         }
63     }
64     catch (std::logic_error& ex) {
65         HIVIEW_LOGE("[JankAnimatorReporterAdapter::ReportCritical] exception: %s", ex.what());
66     }
67 }
68 
ConvertReporterEventToData(const JankAnimatorReportEvent & event)69 JankAnimatorReportData JankAnimatorReporterAdapter::ConvertReporterEventToData(const JankAnimatorReportEvent& event)
70 {
71     JankAnimatorReportData data;
72     data.appPid = event.appPid;
73     data.versionCode = event.versionCode;
74     data.versionName = event.versionName;
75     data.bundleName = event.bundleName;
76     data.processName = event.processName;
77     data.abilityName = event.abilityName;
78     data.pageUrl = event.pageUrl;
79     data.sceneId = event.sceneId;
80     data.bundleNameEx = event.bundleNameEx;
81     data.isFocus = event.isFocus;
82     data.startTime = event.startTime;
83     data.durition = event.durition;
84     data.totalAppFrames = event.totalAppFrames;
85     data.totalAppMissedFrames = event.totalAppMissedFrames;
86     data.maxAppFrameTime = event.maxAppFrameTime;
87     data.maxAppSeqMissedFrames = event.maxAppSeqMissedFrames;
88     data.isDisplayAnimator = event.isDisplayAnimator;
89     data.totalRenderFrames = event.totalRenderFrames;
90     data.totalRenderMissedFrames = event.totalRenderMissedFrames;
91     data.maxRenderFrameTime = event.maxRenderFrameTime;
92     data.averageRenderFrameTime = event.averageRenderFrameTime;
93     data.maxRenderSeqMissedFrames = event.maxRenderSeqMissedFrames;
94     data.isFoldDisp = event.isFoldDisp;
95     /* only for critical */
96     data.traceFileName = event.traceFileName;
97     data.infoFileName = event.infoFileName;
98     data.happenTime = event.happenTime;
99     return data;
100 }
101 
ConvertReportEventToEventInfo(const JankAnimatorReportEvent & event)102 ScrollJankEventInfo JankAnimatorReporterAdapter::ConvertReportEventToEventInfo(const JankAnimatorReportEvent& event)
103 {
104     ScrollJankEventInfo info;
105     info.appPid = event.appPid;
106     info.versionCode = event.versionCode;
107     info.versionName = event.versionName;
108     info.bundleName = event.bundleName;
109     info.processName = event.processName;
110     info.abilityName = event.abilityName;
111     info.pageUrl = event.pageUrl;
112     info.sceneId = event.sceneId;
113     info.bundleNameEx = event.bundleNameEx;
114     info.isFocus = event.isFocus;
115     info.startTime = event.startTime;
116     info.duration = event.durition;
117     info.totalAppFrames = event.totalAppFrames;
118     info.totalAppMissedFrames = event.totalAppMissedFrames;
119     info.maxAppFrameTime = event.maxAppFrameTime;
120     info.maxAppSeqMissedFrames = event.maxAppSeqMissedFrames;
121     info.isDisplayAnimator = event.isDisplayAnimator;
122     info.totalRenderFrames = event.totalRenderFrames;
123     info.totalRenderMissedFrames = event.totalRenderMissedFrames;
124     info.maxRenderFrameTime = event.maxRenderFrameTime;
125     info.averageRenderFrameTime = event.averageRenderFrameTime;
126     info.maxRenderSeqMissedFrames = event.maxRenderSeqMissedFrames;
127     info.isFoldDisp = event.isFoldDisp;
128     /* only for critical */
129     info.traceFileName = event.traceFileName;
130     info.infoFileName = event.infoFileName;
131     info.happenTime = event.happenTime;
132     return info;
133 }
134 
IsScrollJankEvent(const JankAnimatorReportEvent & event)135 bool JankAnimatorReporterAdapter::IsScrollJankEvent(const JankAnimatorReportEvent& event)
136 {
137     const std::string sceneId = event.sceneId;
138     return ((sceneId == "APP_LIST_FLING") || (sceneId == "APP_SWIPER_SCROLL") || (sceneId == "APP_SWIPER_FLING"));
139 }
140 } // HiviewDFX
141 } // OHOS