am c58ab5f6: Merge "Allow all loopers to be RT-accelerated"
* commit 'c58ab5f60e5fcc845ceb1e146372a1dbf99cbb82': Allow all loopers to be RT-accelerated
This commit is contained in:
@@ -710,12 +710,15 @@ public final class ViewRootImpl implements ViewParent,
|
||||
|
||||
if (!HardwareRenderer.sRendererDisabled || (HardwareRenderer.sSystemRendererDisabled
|
||||
&& forceHwAccelerated)) {
|
||||
// Don't enable hardware acceleration when we're not on the main thread
|
||||
if (!HardwareRenderer.sSystemRendererDisabled &&
|
||||
Looper.getMainLooper() != Looper.myLooper()) {
|
||||
Log.w(HardwareRenderer.LOG_TAG, "Attempting to initialize hardware "
|
||||
+ "acceleration outside of the main thread, aborting");
|
||||
return;
|
||||
if (!HardwareRenderer.sUseRenderThread) {
|
||||
// TODO: Delete
|
||||
// Don't enable hardware acceleration when we're not on the main thread
|
||||
if (!HardwareRenderer.sSystemRendererDisabled &&
|
||||
Looper.getMainLooper() != Looper.myLooper()) {
|
||||
Log.w(HardwareRenderer.LOG_TAG, "Attempting to initialize hardware "
|
||||
+ "acceleration outside of the main thread, aborting");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (mAttachInfo.mHardwareRenderer != null) {
|
||||
|
||||
@@ -232,6 +232,15 @@
|
||||
<category android:name="com.android.test.hwui.TEST" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
|
||||
<activity
|
||||
android:name="LooperAcceleration"
|
||||
android:label="Misc/LooperAcceleration">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
<category android:name="com.android.test.hwui.TEST" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
|
||||
<activity
|
||||
android:name="TextFadeActivity"
|
||||
|
||||
@@ -0,0 +1,96 @@
|
||||
/*
|
||||
* Copyright (C) 2014 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 com.android.test.hwui;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.Dialog;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
import android.graphics.Canvas;
|
||||
import android.os.Bundle;
|
||||
import android.os.Looper;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup.LayoutParams;
|
||||
import android.webkit.WebChromeClient;
|
||||
import android.webkit.WebView;
|
||||
import android.webkit.WebViewClient;
|
||||
import android.widget.LinearLayout;
|
||||
|
||||
public class LooperAcceleration extends Activity {
|
||||
|
||||
static final boolean INCLUDE_WEBVIEW = false;
|
||||
|
||||
static class IsAcceleratedView extends View {
|
||||
|
||||
public IsAcceleratedView(Context context) {
|
||||
super(context);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onDraw(Canvas canvas) {
|
||||
super.onDraw(canvas);
|
||||
if (canvas.isHardwareAccelerated()) {
|
||||
canvas.drawARGB(0xFF, 0x00, 0xFF, 0x00);
|
||||
} else {
|
||||
canvas.drawARGB(0xFF, 0xFF, 0x00, 0x00);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private View makeView() {
|
||||
LinearLayout layout = new LinearLayout(this);
|
||||
layout.addView(new IsAcceleratedView(this), LayoutParams.MATCH_PARENT, 60);
|
||||
|
||||
if (INCLUDE_WEBVIEW) {
|
||||
WebView wv = new WebView(this);
|
||||
wv.setWebViewClient(new WebViewClient());
|
||||
wv.setWebChromeClient(new WebChromeClient());
|
||||
wv.loadUrl("http://www.webkit.org/blog-files/3d-transforms/poster-circle.html");
|
||||
layout.addView(wv, LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
|
||||
}
|
||||
return layout;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
|
||||
setContentView(makeView());
|
||||
|
||||
new Thread() {
|
||||
@Override
|
||||
public void run() {
|
||||
Looper.prepare();
|
||||
final Context context = LooperAcceleration.this;
|
||||
Dialog dlg = new Dialog(context);
|
||||
dlg.addContentView(makeView(), new LayoutParams(300, 400));
|
||||
dlg.setCancelable(true);
|
||||
dlg.setCanceledOnTouchOutside(true);
|
||||
dlg.setOnDismissListener(new DialogInterface.OnDismissListener() {
|
||||
@Override
|
||||
public void onDismiss(DialogInterface dialog) {
|
||||
Looper.myLooper().quit();
|
||||
}
|
||||
});
|
||||
dlg.setTitle("Not Looper.getMainLooper() check");
|
||||
dlg.show();
|
||||
Looper.loop();
|
||||
}
|
||||
}.start();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user