Merge "Revert "Fix Canvas memory leak"" into mnc-ub-dev
This commit is contained in:
@@ -45,10 +45,4 @@ public class AttachInfo_Accessor {
|
||||
public static void dispatchOnPreDraw(View view) {
|
||||
view.mAttachInfo.mTreeObserver.dispatchOnPreDraw();
|
||||
}
|
||||
|
||||
public static void detachFromWindow(View view) {
|
||||
if (view != null) {
|
||||
view.dispatchDetachedFromWindow();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,37 +0,0 @@
|
||||
/*
|
||||
* 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 com.android.tools.layoutlib.annotations.LayoutlibDelegate;
|
||||
|
||||
/**
|
||||
* Delegate used to provide new implementation of a select few methods of
|
||||
* {@link ViewRootImpl.RunQueue}
|
||||
*
|
||||
* Through the layoutlib_create tool, the original methods of ViewRootImpl.RunQueue have been
|
||||
* replaced by calls to methods of the same name in this delegate class.
|
||||
*
|
||||
*/
|
||||
public class ViewRootImpl_RunQueue_Delegate {
|
||||
|
||||
@LayoutlibDelegate
|
||||
/*package*/ static void postDelayed(ViewRootImpl.RunQueue thisQueue, Runnable action, long
|
||||
delayMillis) {
|
||||
// The actual RunQueue is never run and therefore never cleared. This method avoids
|
||||
// runnables to be added to the RunQueue so they do not leak resources.
|
||||
}
|
||||
}
|
||||
@@ -208,9 +208,6 @@ public class BridgeRenderSession extends RenderSession {
|
||||
|
||||
@Override
|
||||
public void dispose() {
|
||||
if (mSession != null) {
|
||||
mSession.dispose();
|
||||
}
|
||||
}
|
||||
|
||||
/*package*/ BridgeRenderSession(RenderSessionImpl scene, Result lastResult) {
|
||||
|
||||
@@ -1396,21 +1396,4 @@ public class RenderSessionImpl extends RenderAction<SessionParams> {
|
||||
public RenderSession getSession() {
|
||||
return mScene;
|
||||
}
|
||||
|
||||
public void dispose() {
|
||||
AttachInfo_Accessor.detachFromWindow(mViewRoot);
|
||||
if (mCanvas != null) {
|
||||
mCanvas.release();
|
||||
mCanvas = null;
|
||||
}
|
||||
if (mViewInfoList != null) {
|
||||
mViewInfoList.clear();
|
||||
}
|
||||
if (mSystemViewInfoList != null) {
|
||||
mSystemViewInfoList.clear();
|
||||
}
|
||||
mImage = null;
|
||||
mViewRoot = null;
|
||||
mContentRoot = null;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -291,6 +291,7 @@ public class Main {
|
||||
@Test
|
||||
public void testActivity() throws ClassNotFoundException {
|
||||
renderAndVerify("activity.xml", "activity.png");
|
||||
|
||||
}
|
||||
|
||||
/** Test allwidgets.xml */
|
||||
@@ -430,8 +431,6 @@ public class Main {
|
||||
ImageUtils.requireSimilar(goldenImagePath, session.getImage());
|
||||
} catch (IOException e) {
|
||||
getLogger().error(e, e.getMessage());
|
||||
} finally {
|
||||
session.dispose();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -185,7 +185,6 @@ public final class CreateInfo implements ICreateInfo {
|
||||
"android.view.View#getWindowToken",
|
||||
"android.view.View#isInEditMode",
|
||||
"android.view.ViewRootImpl#isInTouchMode",
|
||||
"android.view.ViewRootImpl$RunQueue#postDelayed",
|
||||
"android.view.WindowManagerGlobal#getWindowManagerService",
|
||||
"android.view.inputmethod.InputMethodManager#getInstance",
|
||||
"android.view.MenuInflater#registerMenu",
|
||||
|
||||
Reference in New Issue
Block a user