Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(572)

Unified Diff: content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java

Issue 236193013: Android: Consolidate and simplify VSync logic (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java
diff --git a/content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java b/content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java
index d18c7f2bb2c6bbf24abb0efc19cbd631310ad275..94912581a3bb03e7e0b475bc8208fa7d47fc8bc1 100644
--- a/content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java
+++ b/content/public/android/java/src/org/chromium/content/browser/ContentViewRenderView.java
@@ -9,7 +9,6 @@ import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.PixelFormat;
-import android.os.Build;
import android.os.Handler;
import android.view.Surface;
import android.view.SurfaceHolder;
@@ -18,8 +17,6 @@ import android.widget.FrameLayout;
import org.chromium.base.CalledByNative;
import org.chromium.base.JNINamespace;
-import org.chromium.base.ObserverList;
-import org.chromium.base.ObserverList.RewindableIterator;
import org.chromium.base.TraceEvent;
import org.chromium.ui.base.WindowAndroid;
@@ -30,7 +27,7 @@ import org.chromium.ui.base.WindowAndroid;
* Note that only one ContentViewCore can be shown at a time.
*/
@JNINamespace("content")
-public class ContentViewRenderView extends FrameLayout {
+public class ContentViewRenderView extends FrameLayout implements WindowAndroid.VSyncClient {
private static final int MAX_SWAP_BUFFER_COUNT = 2;
// The native side of this object.
@@ -38,7 +35,7 @@ public class ContentViewRenderView extends FrameLayout {
private final SurfaceHolder.Callback mSurfaceCallback;
private final SurfaceView mSurfaceView;
- private final VSyncAdapter mVSyncAdapter;
+ private final WindowAndroid mRootWindow;
private int mPendingRenders;
private int mPendingSwapBuffers;
@@ -64,6 +61,8 @@ public class ContentViewRenderView extends FrameLayout {
mNativeContentViewRenderView = nativeInit(rootWindow.getNativePointer());
assert mNativeContentViewRenderView != 0;
+ mRootWindow = rootWindow;
+ rootWindow.setVSyncClient(this);
mSurfaceView = createSurfaceView(getContext());
mSurfaceView.setZOrderMediaOverlay(true);
mSurfaceCallback = new SurfaceHolder.Callback() {
@@ -99,86 +98,23 @@ public class ContentViewRenderView extends FrameLayout {
};
mSurfaceView.getHolder().addCallback(mSurfaceCallback);
- mVSyncAdapter = new VSyncAdapter(getContext());
addView(mSurfaceView,
new FrameLayout.LayoutParams(
FrameLayout.LayoutParams.MATCH_PARENT,
FrameLayout.LayoutParams.MATCH_PARENT));
}
- private class VSyncAdapter implements VSyncManager.Provider, VSyncMonitor.Listener {
- private final VSyncMonitor mVSyncMonitor;
- private boolean mVSyncNotificationEnabled;
- private VSyncManager.Listener mVSyncListener;
- private final ObserverList<VSyncManager.Listener> mCurrentVSyncListeners;
- private final RewindableIterator<VSyncManager.Listener> mCurrentVSyncListenersIterator;
-
- // The VSyncMonitor gives the timebase for the actual vsync, but we don't want render until
- // we have had a chance for input events to propagate to the compositor thread. This takes
- // 3 ms typically, so we adjust the vsync timestamps forward by a bit to give input events a
- // chance to arrive.
- private static final long INPUT_EVENT_LAG_FROM_VSYNC_MICROSECONDS = 3200;
-
- VSyncAdapter(Context context) {
- mVSyncMonitor = new VSyncMonitor(context, this);
- mCurrentVSyncListeners = new ObserverList<VSyncManager.Listener>();
- mCurrentVSyncListenersIterator = mCurrentVSyncListeners.rewindableIterator();
- }
-
- @Override
- public void onVSync(VSyncMonitor monitor, long vsyncTimeMicros) {
- if (mNeedToRender) {
- if (mPendingSwapBuffers + mPendingRenders <= MAX_SWAP_BUFFER_COUNT) {
- mNeedToRender = false;
- mPendingRenders++;
- render();
- } else {
- TraceEvent.instant("ContentViewRenderView:bail");
- }
- }
-
- if (mVSyncListener != null) {
- if (mVSyncNotificationEnabled) {
- for (mCurrentVSyncListenersIterator.rewind();
- mCurrentVSyncListenersIterator.hasNext();) {
- mCurrentVSyncListenersIterator.next().onVSync(vsyncTimeMicros);
- }
- mVSyncMonitor.requestUpdate();
- } else {
- // Compensate for input event lag. Input events are delivered immediately on
- // pre-JB releases, so this adjustment is only done for later versions.
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
- vsyncTimeMicros += INPUT_EVENT_LAG_FROM_VSYNC_MICROSECONDS;
- }
- mVSyncListener.updateVSync(vsyncTimeMicros,
- mVSyncMonitor.getVSyncPeriodInMicroseconds());
- }
- }
- }
-
- @Override
- public void registerVSyncListener(VSyncManager.Listener listener) {
- if (!mVSyncNotificationEnabled) mVSyncMonitor.requestUpdate();
- mCurrentVSyncListeners.addObserver(listener);
- mVSyncNotificationEnabled = true;
- }
-
- @Override
- public void unregisterVSyncListener(VSyncManager.Listener listener) {
- mCurrentVSyncListeners.removeObserver(listener);
- if (mCurrentVSyncListeners.isEmpty()) {
- mVSyncNotificationEnabled = false;
+ @Override
+ public void onVSync(long vsyncTimeMicros) {
+ if (mNeedToRender) {
+ if (mPendingSwapBuffers + mPendingRenders <= MAX_SWAP_BUFFER_COUNT) {
+ mNeedToRender = false;
+ mPendingRenders++;
+ render();
+ } else {
+ TraceEvent.instant("ContentViewRenderView:bail");
}
}
-
- void setVSyncListener(VSyncManager.Listener listener) {
- mVSyncListener = listener;
- if (mVSyncListener != null) mVSyncMonitor.requestUpdate();
- }
-
- void requestUpdate() {
- mVSyncMonitor.requestUpdate();
- }
}
/**
@@ -198,6 +134,7 @@ public class ContentViewRenderView extends FrameLayout {
* native resource can be freed.
*/
public void destroy() {
+ mRootWindow.setVSyncClient(null);
mSurfaceView.getHolder().removeCallback(mSurfaceCallback);
nativeDestroy(mNativeContentViewRenderView);
mNativeContentViewRenderView = 0;
@@ -209,7 +146,6 @@ public class ContentViewRenderView extends FrameLayout {
if (mContentViewCore != null) {
mContentViewCore.onPhysicalBackingSizeChanged(getWidth(), getHeight());
- mVSyncAdapter.setVSyncListener(mContentViewCore.getVSyncListener(mVSyncAdapter));
nativeSetCurrentContentViewCore(mNativeContentViewRenderView,
mContentViewCore.getNativeContentViewCore());
} else {
@@ -281,12 +217,11 @@ public class ContentViewRenderView extends FrameLayout {
} else {
post(mRenderRunnable);
}
- mVSyncAdapter.requestUpdate();
} else if (mPendingRenders <= 0) {
assert mPendingRenders == 0;
TraceEvent.instant("requestRender:later");
mNeedToRender = true;
- mVSyncAdapter.requestUpdate();
+ mRootWindow.requestVSyncUpdate();
}
}

Powered by Google App Engine
This is Rietveld 408576698