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