Merge "Adding workaround to make voice button target area larger (Bug 5653332)"

This commit is contained in:
Winson Chung
2012-01-17 10:32:50 -08:00
committed by Android (Google) Code Review
3 changed files with 82 additions and 0 deletions
+9
View File
@@ -70,6 +70,15 @@
android:id="@+id/qsb_bar"
layout="@layout/qsb_bar" />
<com.android.launcher2.DrawableStateProxyView
android:id="@+id/voice_button_proxy"
android:layout_width="@dimen/qsb_bar_height"
android:layout_height="@dimen/qsb_bar_height"
android:layout_gravity="right"
android:clickable="true"
android:onClick="onClickVoiceButton"
launcher:sourceViewId="@+id/voice_button" />
<include layout="@layout/apps_customize_pane"
android:id="@+id/apps_customize_pane"
android:layout_width="match_parent"
+7
View File
@@ -27,6 +27,13 @@
<skip />
<!-- DrawableStateProxyView specific attributes. These attributes are used to customize
a DrawableStateProxyView view in XML files. -->
<declare-styleable name="DrawableStateProxyView">
<!-- The source view to delegate touch presses events to. -->
<attr name="sourceViewId" format="integer" />
</declare-styleable>
<!-- Cling specific attributes. These attributes are used to customize
the cling in XML files. -->
<declare-styleable name="Cling">
@@ -0,0 +1,66 @@
/*
* Copyright (C) 2012 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.launcher2;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.StateListDrawable;
import android.util.AttributeSet;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import com.android.launcher.R;
public class DrawableStateProxyView extends LinearLayout {
private View mView;
private int mViewId;
public DrawableStateProxyView(Context context) {
this(context, null);
}
public DrawableStateProxyView(Context context, AttributeSet attrs) {
this(context, attrs, 0);
}
public DrawableStateProxyView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.DrawableStateProxyView,
defStyle, 0);
mViewId = a.getResourceId(R.styleable.DrawableStateProxyView_sourceViewId, -1);
a.recycle();
setFocusable(false);
}
@Override
protected void drawableStateChanged() {
super.drawableStateChanged();
if (mView == null) {
View parent = (View) getParent();
mView = parent.findViewById(mViewId);
}
mView.setPressed(isPressed());
mView.setHovered(isHovered());
}
}