Merge "Don't build display lists for views with a layer."
This commit is contained in:
@@ -2909,6 +2909,7 @@ public class View implements Drawable.Callback, Drawable.Callback2, KeyEvent.Cal
|
||||
initializeScrollbars(a);
|
||||
}
|
||||
break;
|
||||
//noinspection deprecation
|
||||
case R.styleable.View_fadingEdge:
|
||||
if (context.getApplicationInfo().targetSdkVersion >= ICE_CREAM_SANDWICH) {
|
||||
// Ignore the attribute starting with ICS
|
||||
|
||||
@@ -34,7 +34,6 @@ import android.os.SystemClock;
|
||||
import android.util.AttributeSet;
|
||||
import android.util.Log;
|
||||
import android.util.SparseArray;
|
||||
import android.view.View.AccessibilityDelegate;
|
||||
import android.view.accessibility.AccessibilityEvent;
|
||||
import android.view.accessibility.AccessibilityNodeInfo;
|
||||
import android.view.animation.Animation;
|
||||
@@ -2561,7 +2560,8 @@ public abstract class ViewGroup extends View implements ViewParent, ViewManager
|
||||
final View[] children = mChildren;
|
||||
for (int i = 0; i < count; i++) {
|
||||
final View child = children[i];
|
||||
if ((child.mViewFlags & VISIBILITY_MASK) == VISIBLE || child.getAnimation() != null) {
|
||||
if (((child.mViewFlags & VISIBILITY_MASK) == VISIBLE ||
|
||||
child.getAnimation() != null) && child.getLayerType() == LAYER_TYPE_NONE) {
|
||||
child.mRecreateDisplayList = (child.mPrivateFlags & INVALIDATED) == INVALIDATED;
|
||||
child.mPrivateFlags &= ~INVALIDATED;
|
||||
child.getDisplayList();
|
||||
|
||||
@@ -30,6 +30,15 @@
|
||||
android:label="HwUi"
|
||||
android:hardwareAccelerated="true">
|
||||
|
||||
<activity
|
||||
android:name="DisplayListLayersActivity"
|
||||
android:label="__DisplayListLayers">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
<category android:name="android.intent.category.LAUNCHER" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
|
||||
<activity
|
||||
android:name="TextFadeActivity"
|
||||
android:label="_TextFade">
|
||||
|
||||
@@ -0,0 +1,125 @@
|
||||
/*
|
||||
* Copyright (C) 2011 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.content.Context;
|
||||
import android.graphics.Canvas;
|
||||
import android.graphics.Paint;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.Gravity;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.LinearLayout;
|
||||
|
||||
import static android.view.View.LAYER_TYPE_HARDWARE;
|
||||
import static android.view.View.LAYER_TYPE_SOFTWARE;
|
||||
import static android.view.ViewGroup.LayoutParams.WRAP_CONTENT;
|
||||
|
||||
@SuppressWarnings({"UnusedDeclaration"})
|
||||
public class DisplayListLayersActivity extends Activity {
|
||||
private static final int VERTICAL_MARGIN = 12;
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
|
||||
LinearLayout root = createContainer();
|
||||
addChild(root, new LayerView(this, 0xffff0000, LAYER_TYPE_HARDWARE, "hardware"),
|
||||
WRAP_CONTENT, WRAP_CONTENT);
|
||||
addChild(root, new LayerView(this, 0xff0000ff, LAYER_TYPE_SOFTWARE, "software"),
|
||||
WRAP_CONTENT, WRAP_CONTENT);
|
||||
addChild(root, createButton(root), WRAP_CONTENT, WRAP_CONTENT);
|
||||
|
||||
setContentView(root);
|
||||
}
|
||||
|
||||
private Button createButton(final LinearLayout root) {
|
||||
Button button = new Button(this);
|
||||
button.setText("Invalidate");
|
||||
button.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
for (int i = 0; i < root.getChildCount(); i++) {
|
||||
View child = root.getChildAt(i);
|
||||
if (child != v) {
|
||||
child.invalidate();
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
return button;
|
||||
}
|
||||
|
||||
private void addChild(LinearLayout root, View child, int width, int height) {
|
||||
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(width, height);
|
||||
params.gravity = Gravity.CENTER_HORIZONTAL;
|
||||
params.setMargins(0, dipToPx(VERTICAL_MARGIN), 0, 0);
|
||||
root.addView(child, params);
|
||||
}
|
||||
|
||||
private int dipToPx(int size) {
|
||||
return (int) (getResources().getDisplayMetrics().density * size + 0.5f);
|
||||
}
|
||||
|
||||
private LinearLayout createContainer() {
|
||||
LinearLayout layout = new LinearLayout(this);
|
||||
layout.setOrientation(LinearLayout.VERTICAL);
|
||||
return layout;
|
||||
}
|
||||
|
||||
private class LayerView extends View {
|
||||
private static final String LOG_TAG = "LayerView";
|
||||
private final Paint mPaint = new Paint();
|
||||
|
||||
private final String mTag;
|
||||
|
||||
LayerView(Context context, int color, int layerType, String tag) {
|
||||
super(context);
|
||||
|
||||
mTag = tag;
|
||||
|
||||
mPaint.setColor(color);
|
||||
setLayerType(layerType, null);
|
||||
}
|
||||
|
||||
private void log(String tag) {
|
||||
Log.d(LOG_TAG, mTag + ": " + tag);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void invalidate() {
|
||||
log("invalidate");
|
||||
super.invalidate();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onDraw(Canvas canvas) {
|
||||
log("draw");
|
||||
canvas.drawRect(0, 0, getWidth(), getHeight(), mPaint);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
|
||||
setMeasuredDimension(MeasureSpec.getSize(widthMeasureSpec) / 3,
|
||||
MeasureSpec.getSize(heightMeasureSpec) / 3);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user