mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
95 lines
3.3 KiB
Java
95 lines
3.3 KiB
Java
|
package com.airbnb.lottie;
|
||
|
|
||
|
import android.util.Log;
|
||
|
import androidx.collection.ArraySet;
|
||
|
import androidx.core.util.Pair;
|
||
|
import com.airbnb.lottie.utils.MeanCalculator;
|
||
|
import java.util.ArrayList;
|
||
|
import java.util.Collections;
|
||
|
import java.util.Comparator;
|
||
|
import java.util.HashMap;
|
||
|
import java.util.Iterator;
|
||
|
import java.util.List;
|
||
|
import java.util.Map;
|
||
|
import java.util.Set;
|
||
|
|
||
|
/* loaded from: classes2.dex */
|
||
|
public class PerformanceTracker {
|
||
|
private boolean enabled = false;
|
||
|
private final Set<FrameListener> frameListeners = new ArraySet();
|
||
|
private final Map<String, MeanCalculator> layerRenderTimes = new HashMap();
|
||
|
private final Comparator<Pair<String, Float>> floatComparator = new Comparator<Pair<String, Float>>() { // from class: com.airbnb.lottie.PerformanceTracker.1
|
||
|
@Override // java.util.Comparator
|
||
|
public int compare(Pair<String, Float> pair, Pair<String, Float> pair2) {
|
||
|
float floatValue = pair.second.floatValue();
|
||
|
float floatValue2 = pair2.second.floatValue();
|
||
|
if (floatValue2 > floatValue) {
|
||
|
return 1;
|
||
|
}
|
||
|
return floatValue > floatValue2 ? -1 : 0;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
/* loaded from: classes2.dex */
|
||
|
public interface FrameListener {
|
||
|
void onFrameRendered(float f);
|
||
|
}
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: package-private */
|
||
|
public void setEnabled(boolean z) {
|
||
|
this.enabled = z;
|
||
|
}
|
||
|
|
||
|
public void recordRenderTime(String str, float f) {
|
||
|
if (this.enabled) {
|
||
|
MeanCalculator meanCalculator = this.layerRenderTimes.get(str);
|
||
|
if (meanCalculator == null) {
|
||
|
meanCalculator = new MeanCalculator();
|
||
|
this.layerRenderTimes.put(str, meanCalculator);
|
||
|
}
|
||
|
meanCalculator.add(f);
|
||
|
if (str.equals("__container")) {
|
||
|
Iterator<FrameListener> it = this.frameListeners.iterator();
|
||
|
while (it.hasNext()) {
|
||
|
it.next().onFrameRendered(f);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addFrameListener(FrameListener frameListener) {
|
||
|
this.frameListeners.add(frameListener);
|
||
|
}
|
||
|
|
||
|
public void removeFrameListener(FrameListener frameListener) {
|
||
|
this.frameListeners.remove(frameListener);
|
||
|
}
|
||
|
|
||
|
public void clearRenderTimes() {
|
||
|
this.layerRenderTimes.clear();
|
||
|
}
|
||
|
|
||
|
public void logRenderTimes() {
|
||
|
if (this.enabled) {
|
||
|
List<Pair<String, Float>> sortedRenderTimes = getSortedRenderTimes();
|
||
|
Log.d(L.TAG, "Render times:");
|
||
|
for (int i = 0; i < sortedRenderTimes.size(); i++) {
|
||
|
Pair<String, Float> pair = sortedRenderTimes.get(i);
|
||
|
Log.d(L.TAG, String.format("\t\t%30s:%.2f", pair.first, pair.second));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public List<Pair<String, Float>> getSortedRenderTimes() {
|
||
|
if (!this.enabled) {
|
||
|
return Collections.emptyList();
|
||
|
}
|
||
|
ArrayList arrayList = new ArrayList(this.layerRenderTimes.size());
|
||
|
for (Map.Entry<String, MeanCalculator> entry : this.layerRenderTimes.entrySet()) {
|
||
|
arrayList.add(new Pair(entry.getKey(), Float.valueOf(entry.getValue().getMean())));
|
||
|
}
|
||
|
Collections.sort(arrayList, this.floatComparator);
|
||
|
return arrayList;
|
||
|
}
|
||
|
}
|