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
|
/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.view;
import android.annotation.NonNull;
import android.annotation.UnsupportedAppUsage;
import android.os.Looper;
import android.os.MessageQueue;
import com.android.internal.util.VirtualRefBasePtr;
import java.lang.ref.WeakReference;
/**
* Provides streaming access to frame stats information from the rendering
* subsystem to apps.
*
* @hide
*/
public class FrameMetricsObserver {
@UnsupportedAppUsage
private MessageQueue mMessageQueue;
private WeakReference<Window> mWindow;
@UnsupportedAppUsage
private FrameMetrics mFrameMetrics;
/* pacage */ Window.OnFrameMetricsAvailableListener mListener;
/** @hide */
public VirtualRefBasePtr mNative;
/**
* Creates a FrameMetricsObserver
*
* @param looper the looper to use when invoking callbacks
*/
FrameMetricsObserver(@NonNull Window window, @NonNull Looper looper,
@NonNull Window.OnFrameMetricsAvailableListener listener) {
if (looper == null) {
throw new NullPointerException("looper cannot be null");
}
mMessageQueue = looper.getQueue();
if (mMessageQueue == null) {
throw new IllegalStateException("invalid looper, null message queue\n");
}
mFrameMetrics = new FrameMetrics();
mWindow = new WeakReference<>(window);
mListener = listener;
}
// Called by native on the provided Handler
@SuppressWarnings("unused")
@UnsupportedAppUsage
private void notifyDataAvailable(int dropCount) {
final Window window = mWindow.get();
if (window != null) {
mListener.onFrameMetricsAvailable(window, mFrameMetrics, dropCount);
}
}
}
|