forked from dicallc/MyPerformance
-
Notifications
You must be signed in to change notification settings - Fork 5
/
ActivityHooker.java
84 lines (84 loc) · 2.79 KB
/
ActivityHooker.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
//package com.optimize.performance.aop;
//
//import android.content.Context;
//import android.os.Bundle;
//import android.os.Handler;
//import android.util.Log;
//
//import com.optimize.performance.utils.LogUtils;
//import com.optimize.performance.wakelock.WakeLockUtils;
//
//import me.ele.lancet.base.Origin;
//import me.ele.lancet.base.Scope;
//import me.ele.lancet.base.annotations.Insert;
//import me.ele.lancet.base.annotations.Proxy;
//import me.ele.lancet.base.annotations.TargetClass;
//
//public class ActivityHooker {
//
// public static ActivityRecord sActivityRecord;
//
// static {
// sActivityRecord = new ActivityRecord();
// }
//
// public static String trace;
//
// @Insert(value = "onCreate",mayCreateSuper = true)
// @TargetClass(value = "android.support.v7.app.AppCompatActivity",scope = Scope.ALL)
// protected void onCreate(Bundle savedInstanceState) {
// sActivityRecord.mOnCreateTime = System.currentTimeMillis();
// Origin.callVoid();
// }
//
// @Insert(value = "onWindowFocusChanged",mayCreateSuper = true)
// @TargetClass(value = "android.support.v7.app.AppCompatActivity",scope = Scope.ALL)
// public void onWindowFocusChanged(boolean hasFocus) {
// sActivityRecord.mOnWindowsFocusChangedTime = System.currentTimeMillis();
// LogUtils.i("onWindowFocusChanged cost "+(sActivityRecord.mOnWindowsFocusChangedTime - sActivityRecord.mOnCreateTime));
// Origin.callVoid();
// }
//
//
// public static long sStartTime = 0;
//
// @Insert(value = "acquire")
// @TargetClass(value = "com.optimize.performance.wakelock.WakeLockUtils",scope = Scope.SELF)
// public static void acquire(Context context){
// trace = Log.getStackTraceString(new Throwable());
// sStartTime = System.currentTimeMillis();
// Origin.callVoid();
// new Handler().postDelayed(new Runnable() {
// @Override
// public void run() {
// WakeLockUtils.release();
// }
// },1000);
// }
//
// @Insert(value = "release")
// @TargetClass(value = "com.optimize.performance.wakelock.WakeLockUtils",scope = Scope.SELF)
// public static void release(){
// LogUtils.i("PowerManager "+(System.currentTimeMillis() - sStartTime)+"/n"+trace);
// Origin.callVoid();
// }
//
//
// public static long runTime = 0;
//
// @Insert(value = "run")
// @TargetClass(value = "java.lang.Runnable",scope = Scope.ALL)
// public void run(){
// runTime = System.currentTimeMillis();
// Origin.callVoid();
// LogUtils.i("runTime "+(System.currentTimeMillis() - runTime));
// }
//
// @Proxy("i")
// @TargetClass("android.util.Log")
// public static int i(String tag, String msg) {
// msg = msg + "";
// return (int) Origin.call();
// }
//
//}