Utilize StateListDrawable for key preview background
Change-Id: I268550a185701caecefc27ebaec40fb2c940d883
This commit is contained in:
parent
2a2b5edc21
commit
e8c6d5a480
11 changed files with 127 additions and 127 deletions
|
@ -14,9 +14,11 @@
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
<selector
|
||||||
<item android:state_long_pressable="true"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:latin="http://schemas.android.com/apk/res/com.android.inputmethod.latin"
|
||||||
|
>
|
||||||
|
<item latin:state_has_morekeys="true"
|
||||||
android:drawable="@drawable/keyboard_key_feedback_more_background" />
|
android:drawable="@drawable/keyboard_key_feedback_more_background" />
|
||||||
|
|
||||||
<item android:drawable="@drawable/keyboard_key_feedback_background" />
|
<item android:drawable="@drawable/keyboard_key_feedback_background" />
|
||||||
</selector>
|
</selector>
|
||||||
|
|
|
@ -14,8 +14,23 @@
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
<selector
|
||||||
<item android:state_long_pressable="true"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:latin="http://schemas.android.com/apk/res/com.android.inputmethod.latin"
|
||||||
|
>
|
||||||
|
<!-- Left edge -->
|
||||||
|
<item latin:state_left_edge="true" latin:state_has_morekeys="true"
|
||||||
|
android:drawable="@drawable/keyboard_key_feedback_left_more_background_holo" />
|
||||||
|
<item latin:state_left_edge="true"
|
||||||
|
android:drawable="@drawable/keyboard_key_feedback_left_background_holo" />
|
||||||
|
|
||||||
|
<!-- Right edge -->
|
||||||
|
<item latin:state_right_edge="true" latin:state_has_morekeys="true"
|
||||||
|
android:drawable="@drawable/keyboard_key_feedback_right_more_background_holo" />
|
||||||
|
<item latin:state_right_edge="true"
|
||||||
|
android:drawable="@drawable/keyboard_key_feedback_right_background_holo" />
|
||||||
|
|
||||||
|
<item latin:state_has_morekeys="true"
|
||||||
android:drawable="@drawable/keyboard_key_feedback_more_background_holo" />
|
android:drawable="@drawable/keyboard_key_feedback_more_background_holo" />
|
||||||
<item android:drawable="@drawable/keyboard_key_feedback_background_holo" />
|
<item android:drawable="@drawable/keyboard_key_feedback_background_holo" />
|
||||||
</selector>
|
</selector>
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:state_long_pressable="true"
|
|
||||||
android:drawable="@drawable/keyboard_key_feedback_left_more_background_holo" />
|
|
||||||
<item android:drawable="@drawable/keyboard_key_feedback_left_background_holo" />
|
|
||||||
</selector>
|
|
|
@ -1,21 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:state_long_pressable="true"
|
|
||||||
android:drawable="@drawable/keyboard_key_feedback_right_more_background_holo" />
|
|
||||||
<item android:drawable="@drawable/keyboard_key_feedback_right_background_holo" />
|
|
||||||
</selector>
|
|
|
@ -20,8 +20,8 @@
|
||||||
|
|
||||||
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
|
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="80dp"
|
android:layout_height="wrap_content"
|
||||||
android:textSize="40dp"
|
android:background="@drawable/keyboard_key_feedback"
|
||||||
android:minWidth="32dp"
|
android:minWidth="32dp"
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
/>
|
/>
|
||||||
|
|
27
java/res/layout/key_preview_ics.xml
Normal file
27
java/res/layout/key_preview_ics.xml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
/*
|
||||||
|
**
|
||||||
|
** Copyright 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.
|
||||||
|
*/
|
||||||
|
-->
|
||||||
|
|
||||||
|
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:background="@drawable/keyboard_key_feedback_ics"
|
||||||
|
android:minWidth="32dp"
|
||||||
|
android:gravity="center"
|
||||||
|
/>
|
|
@ -54,12 +54,10 @@
|
||||||
|
|
||||||
<!-- Layout resource for key press feedback.-->
|
<!-- Layout resource for key press feedback.-->
|
||||||
<attr name="keyPreviewLayout" format="reference" />
|
<attr name="keyPreviewLayout" format="reference" />
|
||||||
<!-- The background for key press feedback. -->
|
<!-- Key preview background states -->
|
||||||
<attr name="keyPreviewBackground" format="reference" />
|
<attr name="state_left_edge" format="boolean" />
|
||||||
<!-- The background for the left edge key press feedback. -->
|
<attr name="state_right_edge" format="boolean" />
|
||||||
<attr name="keyPreviewLeftBackground" format="reference" />
|
<attr name="state_has_morekeys" format="boolean" />
|
||||||
<!-- The background for the right edge key press feedback. -->
|
|
||||||
<attr name="keyPreviewRightBackground" format="reference" />
|
|
||||||
<!-- Vertical offset of the key press feedback from the key. -->
|
<!-- Vertical offset of the key press feedback from the key. -->
|
||||||
<attr name="keyPreviewOffset" format="dimension" />
|
<attr name="keyPreviewOffset" format="dimension" />
|
||||||
<!-- Height of the key press feedback popup. -->
|
<!-- Height of the key press feedback popup. -->
|
||||||
|
|
|
@ -54,9 +54,6 @@
|
||||||
<item name="keyPopupHintLetterPadding">@dimen/key_popup_hint_letter_padding</item>
|
<item name="keyPopupHintLetterPadding">@dimen/key_popup_hint_letter_padding</item>
|
||||||
<item name="keyShiftedLetterHintPadding">@dimen/key_uppercase_letter_padding</item>
|
<item name="keyShiftedLetterHintPadding">@dimen/key_uppercase_letter_padding</item>
|
||||||
<item name="keyPreviewLayout">@layout/key_preview</item>
|
<item name="keyPreviewLayout">@layout/key_preview</item>
|
||||||
<item name="keyPreviewBackground">@drawable/keyboard_key_feedback</item>
|
|
||||||
<item name="keyPreviewLeftBackground">@null</item>
|
|
||||||
<item name="keyPreviewRightBackground">@null</item>
|
|
||||||
<item name="keyPreviewTextColor">#FFFFFFFF</item>
|
<item name="keyPreviewTextColor">#FFFFFFFF</item>
|
||||||
<item name="keyPreviewOffset">@dimen/key_preview_offset</item>
|
<item name="keyPreviewOffset">@dimen/key_preview_offset</item>
|
||||||
<item name="keyPreviewHeight">@dimen/key_preview_height</item>
|
<item name="keyPreviewHeight">@dimen/key_preview_height</item>
|
||||||
|
@ -323,9 +320,7 @@
|
||||||
<item name="keyHintLabelColor">#A0FFFFFF</item>
|
<item name="keyHintLabelColor">#A0FFFFFF</item>
|
||||||
<item name="keyShiftedLetterHintInactivatedColor">#66E0E4E5</item>
|
<item name="keyShiftedLetterHintInactivatedColor">#66E0E4E5</item>
|
||||||
<item name="keyShiftedLetterHintActivatedColor">#FFFFFFFF</item>
|
<item name="keyShiftedLetterHintActivatedColor">#FFFFFFFF</item>
|
||||||
<item name="keyPreviewBackground">@drawable/keyboard_key_feedback_ics</item>
|
<item name="keyPreviewLayout">@layout/key_preview_ics</item>
|
||||||
<item name="keyPreviewLeftBackground">@drawable/keyboard_key_feedback_left_ics</item>
|
|
||||||
<item name="keyPreviewRightBackground">@drawable/keyboard_key_feedback_right_ics</item>
|
|
||||||
<item name="keyPreviewTextColor">#FFFFFFFF</item>
|
<item name="keyPreviewTextColor">#FFFFFFFF</item>
|
||||||
<item name="keyPreviewOffset">@dimen/key_preview_offset_ics</item>
|
<item name="keyPreviewOffset">@dimen/key_preview_offset_ics</item>
|
||||||
<item name="keyTextShadowColor">#00000000</item>
|
<item name="keyTextShadowColor">#00000000</item>
|
||||||
|
|
|
@ -59,9 +59,6 @@ import java.util.HashSet;
|
||||||
* @attr ref R.styleable#KeyboardView_keyBackground
|
* @attr ref R.styleable#KeyboardView_keyBackground
|
||||||
* @attr ref R.styleable#KeyboardView_moreKeysLayout
|
* @attr ref R.styleable#KeyboardView_moreKeysLayout
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewLayout
|
* @attr ref R.styleable#KeyboardView_keyPreviewLayout
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewBackground
|
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewLeftBackground
|
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewRightBackground
|
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewOffset
|
* @attr ref R.styleable#KeyboardView_keyPreviewOffset
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewHeight
|
* @attr ref R.styleable#KeyboardView_keyPreviewHeight
|
||||||
* @attr ref R.styleable#KeyboardView_keyPreviewLingerTimeout
|
* @attr ref R.styleable#KeyboardView_keyPreviewLingerTimeout
|
||||||
|
@ -108,9 +105,6 @@ import java.util.HashSet;
|
||||||
public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
private static final String TAG = KeyboardView.class.getSimpleName();
|
private static final String TAG = KeyboardView.class.getSimpleName();
|
||||||
|
|
||||||
// Miscellaneous constants
|
|
||||||
private static final int[] LONG_PRESSABLE_STATE_SET = { android.R.attr.state_long_pressable };
|
|
||||||
|
|
||||||
// XML attributes
|
// XML attributes
|
||||||
private final KeyVisualAttributes mKeyVisualAttributes;
|
private final KeyVisualAttributes mKeyVisualAttributes;
|
||||||
private final int mKeyLabelHorizontalPadding;
|
private final int mKeyLabelHorizontalPadding;
|
||||||
|
@ -139,12 +133,13 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
private Keyboard mKeyboard;
|
private Keyboard mKeyboard;
|
||||||
protected final KeyDrawParams mKeyDrawParams = new KeyDrawParams();
|
protected final KeyDrawParams mKeyDrawParams = new KeyDrawParams();
|
||||||
|
|
||||||
|
// Preview placer view
|
||||||
|
private final PreviewPlacerView mPreviewPlacerView;
|
||||||
|
private final int[] mCoordinates = new int[2];
|
||||||
|
|
||||||
// Key preview
|
// Key preview
|
||||||
private static final int PREVIEW_ALPHA = 240;
|
private static final int PREVIEW_ALPHA = 240;
|
||||||
private final int mKeyPreviewLayoutId;
|
private final int mKeyPreviewLayoutId;
|
||||||
private final Drawable mPreviewBackground;
|
|
||||||
private final Drawable mPreviewLeftBackground;
|
|
||||||
private final Drawable mPreviewRightBackground;
|
|
||||||
private final int mPreviewOffset;
|
private final int mPreviewOffset;
|
||||||
private final int mPreviewHeight;
|
private final int mPreviewHeight;
|
||||||
private final int mPreviewLingerTimeout;
|
private final int mPreviewLingerTimeout;
|
||||||
|
@ -152,7 +147,28 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
protected final KeyPreviewDrawParams mKeyPreviewDrawParams = new KeyPreviewDrawParams();
|
protected final KeyPreviewDrawParams mKeyPreviewDrawParams = new KeyPreviewDrawParams();
|
||||||
private boolean mShowKeyPreviewPopup = true;
|
private boolean mShowKeyPreviewPopup = true;
|
||||||
private int mDelayAfterPreview;
|
private int mDelayAfterPreview;
|
||||||
private final PreviewPlacerView mPreviewPlacerView;
|
// Background state set
|
||||||
|
private static final int[][][] KEY_PREVIEW_BACKGROUND_STATE_TABLE = {
|
||||||
|
{ // STATE_MIDDLE
|
||||||
|
EMPTY_STATE_SET,
|
||||||
|
{ R.attr.state_has_morekeys }
|
||||||
|
},
|
||||||
|
{ // STATE_LEFT
|
||||||
|
{ R.attr.state_left_edge },
|
||||||
|
{ R.attr.state_left_edge, R.attr.state_has_morekeys }
|
||||||
|
},
|
||||||
|
{ // STATE_RIGHT
|
||||||
|
{ R.attr.state_right_edge },
|
||||||
|
{ R.attr.state_right_edge, R.attr.state_has_morekeys }
|
||||||
|
}
|
||||||
|
};
|
||||||
|
private static final int STATE_MIDDLE = 0;
|
||||||
|
private static final int STATE_LEFT = 1;
|
||||||
|
private static final int STATE_RIGHT = 2;
|
||||||
|
private static final int STATE_NORMAL = 0;
|
||||||
|
private static final int STATE_HAS_MOREKEYS = 1;
|
||||||
|
private static final int[] KEY_PREVIEW_BACKGROUND_DEFAULT_STATE =
|
||||||
|
KEY_PREVIEW_BACKGROUND_STATE_TABLE[STATE_MIDDLE][STATE_NORMAL];
|
||||||
|
|
||||||
// Drawing
|
// Drawing
|
||||||
/** True if the entire keyboard needs to be dimmed. */
|
/** True if the entire keyboard needs to be dimmed. */
|
||||||
|
@ -230,15 +246,6 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
R.styleable.KeyboardView, defStyle, R.style.KeyboardView);
|
R.styleable.KeyboardView, defStyle, R.style.KeyboardView);
|
||||||
mKeyBackground = keyboardViewAttr.getDrawable(R.styleable.KeyboardView_keyBackground);
|
mKeyBackground = keyboardViewAttr.getDrawable(R.styleable.KeyboardView_keyBackground);
|
||||||
mKeyBackground.getPadding(mKeyBackgroundPadding);
|
mKeyBackground.getPadding(mKeyBackgroundPadding);
|
||||||
mPreviewBackground = keyboardViewAttr.getDrawable(
|
|
||||||
R.styleable.KeyboardView_keyPreviewBackground);
|
|
||||||
mPreviewLeftBackground = keyboardViewAttr.getDrawable(
|
|
||||||
R.styleable.KeyboardView_keyPreviewLeftBackground);
|
|
||||||
mPreviewRightBackground = keyboardViewAttr.getDrawable(
|
|
||||||
R.styleable.KeyboardView_keyPreviewRightBackground);
|
|
||||||
setAlpha(mPreviewBackground, PREVIEW_ALPHA);
|
|
||||||
setAlpha(mPreviewLeftBackground, PREVIEW_ALPHA);
|
|
||||||
setAlpha(mPreviewRightBackground, PREVIEW_ALPHA);
|
|
||||||
mPreviewOffset = keyboardViewAttr.getDimensionPixelOffset(
|
mPreviewOffset = keyboardViewAttr.getDimensionPixelOffset(
|
||||||
R.styleable.KeyboardView_keyPreviewOffset, 0);
|
R.styleable.KeyboardView_keyPreviewOffset, 0);
|
||||||
mPreviewHeight = keyboardViewAttr.getDimensionPixelSize(
|
mPreviewHeight = keyboardViewAttr.getDimensionPixelSize(
|
||||||
|
@ -278,11 +285,6 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
mPaint.setAntiAlias(true);
|
mPaint.setAntiAlias(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void setAlpha(final Drawable drawable, final int alpha) {
|
|
||||||
if (drawable == null) return;
|
|
||||||
drawable.setAlpha(alpha);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void blendAlpha(final Paint paint, final int alpha) {
|
private static void blendAlpha(final Paint paint, final int alpha) {
|
||||||
final int color = paint.getColor();
|
final int color = paint.getColor();
|
||||||
paint.setARGB((paint.getAlpha() * alpha) / Constants.Color.ALPHA_OPAQUE,
|
paint.setARGB((paint.getAlpha() * alpha) / Constants.Color.ALPHA_OPAQUE,
|
||||||
|
@ -498,7 +500,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw key background.
|
// Draw key background.
|
||||||
protected void onDrawKeyBackground(Key key, Canvas canvas) {
|
protected void onDrawKeyBackground(final Key key, final Canvas canvas) {
|
||||||
final Rect padding = mKeyBackgroundPadding;
|
final Rect padding = mKeyBackgroundPadding;
|
||||||
final int bgWidth = key.getDrawWidth() + padding.left + padding.right;
|
final int bgWidth = key.getDrawWidth() + padding.left + padding.right;
|
||||||
final int bgHeight = key.mHeight + padding.top + padding.bottom;
|
final int bgHeight = key.mHeight + padding.top + padding.bottom;
|
||||||
|
@ -520,7 +522,8 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw key top visuals.
|
// Draw key top visuals.
|
||||||
protected void onDrawKeyTopVisuals(Key key, Canvas canvas, Paint paint, KeyDrawParams params) {
|
protected void onDrawKeyTopVisuals(final Key key, final Canvas canvas, final Paint paint,
|
||||||
|
final KeyDrawParams params) {
|
||||||
final int keyWidth = key.getDrawWidth();
|
final int keyWidth = key.getDrawWidth();
|
||||||
final int keyHeight = key.mHeight;
|
final int keyHeight = key.mHeight;
|
||||||
final float centerX = keyWidth * 0.5f;
|
final float centerX = keyWidth * 0.5f;
|
||||||
|
@ -676,7 +679,8 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw popup hint "..." at the bottom right corner of the key.
|
// Draw popup hint "..." at the bottom right corner of the key.
|
||||||
protected void drawKeyPopupHint(Key key, Canvas canvas, Paint paint, KeyDrawParams params) {
|
protected void drawKeyPopupHint(final Key key, final Canvas canvas, final Paint paint,
|
||||||
|
final KeyDrawParams params) {
|
||||||
final int keyWidth = key.getDrawWidth();
|
final int keyWidth = key.getDrawWidth();
|
||||||
final int keyHeight = key.mHeight;
|
final int keyHeight = key.mHeight;
|
||||||
|
|
||||||
|
@ -696,7 +700,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int getCharGeometryCacheKey(char referenceChar, Paint paint) {
|
private static int getCharGeometryCacheKey(final char referenceChar, final Paint paint) {
|
||||||
final int labelSize = (int)paint.getTextSize();
|
final int labelSize = (int)paint.getTextSize();
|
||||||
final Typeface face = paint.getTypeface();
|
final Typeface face = paint.getTypeface();
|
||||||
final int codePointOffset = referenceChar << 15;
|
final int codePointOffset = referenceChar << 15;
|
||||||
|
@ -714,7 +718,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
// Working variable for the following methods.
|
// Working variable for the following methods.
|
||||||
private final Rect mTextBounds = new Rect();
|
private final Rect mTextBounds = new Rect();
|
||||||
|
|
||||||
private float getCharHeight(char[] referenceChar, Paint paint) {
|
private float getCharHeight(final char[] referenceChar, final Paint paint) {
|
||||||
final int key = getCharGeometryCacheKey(referenceChar[0], paint);
|
final int key = getCharGeometryCacheKey(referenceChar[0], paint);
|
||||||
final Float cachedValue = sTextHeightCache.get(key);
|
final Float cachedValue = sTextHeightCache.get(key);
|
||||||
if (cachedValue != null)
|
if (cachedValue != null)
|
||||||
|
@ -726,7 +730,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
return height;
|
return height;
|
||||||
}
|
}
|
||||||
|
|
||||||
private float getCharWidth(char[] referenceChar, Paint paint) {
|
private float getCharWidth(final char[] referenceChar, final Paint paint) {
|
||||||
final int key = getCharGeometryCacheKey(referenceChar[0], paint);
|
final int key = getCharGeometryCacheKey(referenceChar[0], paint);
|
||||||
final Float cachedValue = sTextWidthCache.get(key);
|
final Float cachedValue = sTextWidthCache.get(key);
|
||||||
if (cachedValue != null)
|
if (cachedValue != null)
|
||||||
|
@ -738,36 +742,37 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
return width;
|
return width;
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getLabelWidth(String label, Paint paint) {
|
public float getLabelWidth(final String label, final Paint paint) {
|
||||||
paint.getTextBounds(label.toString(), 0, label.length(), mTextBounds);
|
paint.getTextBounds(label, 0, label.length(), mTextBounds);
|
||||||
return mTextBounds.width();
|
return mTextBounds.width();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static void drawIcon(Canvas canvas, Drawable icon, int x, int y, int width,
|
protected static void drawIcon(final Canvas canvas, final Drawable icon, final int x,
|
||||||
int height) {
|
final int y, final int width, final int height) {
|
||||||
canvas.translate(x, y);
|
canvas.translate(x, y);
|
||||||
icon.setBounds(0, 0, width, height);
|
icon.setBounds(0, 0, width, height);
|
||||||
icon.draw(canvas);
|
icon.draw(canvas);
|
||||||
canvas.translate(-x, -y);
|
canvas.translate(-x, -y);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawHorizontalLine(Canvas canvas, float y, float w, int color,
|
private static void drawHorizontalLine(final Canvas canvas, final float y, final float w,
|
||||||
Paint paint) {
|
final int color, final Paint paint) {
|
||||||
paint.setStyle(Paint.Style.STROKE);
|
paint.setStyle(Paint.Style.STROKE);
|
||||||
paint.setStrokeWidth(1.0f);
|
paint.setStrokeWidth(1.0f);
|
||||||
paint.setColor(color);
|
paint.setColor(color);
|
||||||
canvas.drawLine(0, y, w, y, paint);
|
canvas.drawLine(0, y, w, y, paint);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawVerticalLine(Canvas canvas, float x, float h, int color, Paint paint) {
|
private static void drawVerticalLine(final Canvas canvas, final float x, final float h,
|
||||||
|
final int color, final Paint paint) {
|
||||||
paint.setStyle(Paint.Style.STROKE);
|
paint.setStyle(Paint.Style.STROKE);
|
||||||
paint.setStrokeWidth(1.0f);
|
paint.setStrokeWidth(1.0f);
|
||||||
paint.setColor(color);
|
paint.setColor(color);
|
||||||
canvas.drawLine(x, 0, x, h, paint);
|
canvas.drawLine(x, 0, x, h, paint);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void drawRectangle(Canvas canvas, float x, float y, float w, float h, int color,
|
private static void drawRectangle(final Canvas canvas, final float x, final float y,
|
||||||
Paint paint) {
|
final float w, final float h, final int color, final Paint paint) {
|
||||||
paint.setStyle(Paint.Style.STROKE);
|
paint.setStyle(Paint.Style.STROKE);
|
||||||
paint.setStrokeWidth(1.0f);
|
paint.setStrokeWidth(1.0f);
|
||||||
paint.setColor(color);
|
paint.setColor(color);
|
||||||
|
@ -849,7 +854,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void showGestureFloatingPreviewText(String gestureFloatingPreviewText) {
|
public void showGestureFloatingPreviewText(final String gestureFloatingPreviewText) {
|
||||||
locatePreviewPlacerView();
|
locatePreviewPlacerView();
|
||||||
mPreviewPlacerView.setGestureFloatingPreviewText(gestureFloatingPreviewText);
|
mPreviewPlacerView.setGestureFloatingPreviewText(gestureFloatingPreviewText);
|
||||||
}
|
}
|
||||||
|
@ -865,7 +870,6 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
mPreviewPlacerView.invalidatePointer(tracker);
|
mPreviewPlacerView.invalidatePointer(tracker);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation") // setBackgroundDrawable is replaced by setBackground in API16
|
|
||||||
@Override
|
@Override
|
||||||
public void showKeyPreview(final PointerTracker tracker) {
|
public void showKeyPreview(final PointerTracker tracker) {
|
||||||
final KeyPreviewDrawParams previewParams = mKeyPreviewDrawParams;
|
final KeyPreviewDrawParams previewParams = mKeyPreviewDrawParams;
|
||||||
|
@ -886,10 +890,17 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
// If key is invalid or IME is already closed, we must not show key preview.
|
// If key is invalid or IME is already closed, we must not show key preview.
|
||||||
// Trying to show key preview while root window is closed causes
|
// Trying to show key preview while root window is closed causes
|
||||||
// WindowManager.BadTokenException.
|
// WindowManager.BadTokenException.
|
||||||
if (key == null)
|
if (key == null) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
final KeyDrawParams drawParams = mKeyDrawParams;
|
final KeyDrawParams drawParams = mKeyDrawParams;
|
||||||
|
previewText.setTextColor(drawParams.mPreviewTextColor);
|
||||||
|
final Drawable background = previewText.getBackground();
|
||||||
|
if (background != null) {
|
||||||
|
background.setState(KEY_PREVIEW_BACKGROUND_DEFAULT_STATE);
|
||||||
|
background.setAlpha(PREVIEW_ALPHA);
|
||||||
|
}
|
||||||
final String label = key.isShiftedLetterActivated() ? key.mHintLabel : key.mLabel;
|
final String label = key.isShiftedLetterActivated() ? key.mHintLabel : key.mLabel;
|
||||||
// What we show as preview should match what we show on a key top in onDraw().
|
// What we show as preview should match what we show on a key top in onDraw().
|
||||||
if (label != null) {
|
if (label != null) {
|
||||||
|
@ -908,7 +919,6 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
key.getPreviewIcon(mKeyboard.mIconsSet));
|
key.getPreviewIcon(mKeyboard.mIconsSet));
|
||||||
previewText.setText(null);
|
previewText.setText(null);
|
||||||
}
|
}
|
||||||
previewText.setBackgroundDrawable(mPreviewBackground);
|
|
||||||
|
|
||||||
previewText.measure(
|
previewText.measure(
|
||||||
ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
|
ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
|
||||||
|
@ -924,32 +934,29 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
// The distance between the top edge of the parent key and the bottom of the visible part
|
// The distance between the top edge of the parent key and the bottom of the visible part
|
||||||
// of the key preview background.
|
// of the key preview background.
|
||||||
previewParams.mPreviewVisibleOffset = mPreviewOffset - previewText.getPaddingBottom();
|
previewParams.mPreviewVisibleOffset = mPreviewOffset - previewText.getPaddingBottom();
|
||||||
getLocationInWindow(previewParams.mCoordinates);
|
getLocationInWindow(mCoordinates);
|
||||||
// The key preview is horizontally aligned with the center of the visible part of the
|
// The key preview is horizontally aligned with the center of the visible part of the
|
||||||
// parent key. If it doesn't fit in this {@link KeyboardView}, it is moved inward to fit and
|
// parent key. If it doesn't fit in this {@link KeyboardView}, it is moved inward to fit and
|
||||||
// the left/right background is used if such background is specified.
|
// the left/right background is used if such background is specified.
|
||||||
int previewX = key.getDrawX() - (previewWidth - keyDrawWidth) / 2
|
final int statePosition;
|
||||||
+ previewParams.mCoordinates[0];
|
int previewX = key.getDrawX() - (previewWidth - keyDrawWidth) / 2 + mCoordinates[0];
|
||||||
if (previewX < 0) {
|
if (previewX < 0) {
|
||||||
previewX = 0;
|
previewX = 0;
|
||||||
if (mPreviewLeftBackground != null) {
|
statePosition = STATE_LEFT;
|
||||||
previewText.setBackgroundDrawable(mPreviewLeftBackground);
|
|
||||||
}
|
|
||||||
} else if (previewX > getWidth() - previewWidth) {
|
} else if (previewX > getWidth() - previewWidth) {
|
||||||
previewX = getWidth() - previewWidth;
|
previewX = getWidth() - previewWidth;
|
||||||
if (mPreviewRightBackground != null) {
|
statePosition = STATE_RIGHT;
|
||||||
previewText.setBackgroundDrawable(mPreviewRightBackground);
|
} else {
|
||||||
}
|
statePosition = STATE_MIDDLE;
|
||||||
}
|
}
|
||||||
// The key preview is placed vertically above the top edge of the parent key with an
|
// The key preview is placed vertically above the top edge of the parent key with an
|
||||||
// arbitrary offset.
|
// arbitrary offset.
|
||||||
final int previewY = key.mY - previewHeight + mPreviewOffset
|
final int previewY = key.mY - previewHeight + mPreviewOffset + mCoordinates[1];
|
||||||
+ previewParams.mCoordinates[1];
|
|
||||||
|
|
||||||
// Set the preview background state
|
if (background != null) {
|
||||||
previewText.getBackground().setState(
|
final int hasMoreKeys = (key.mMoreKeys != null) ? STATE_HAS_MOREKEYS : STATE_NORMAL;
|
||||||
key.mMoreKeys != null ? LONG_PRESSABLE_STATE_SET : EMPTY_STATE_SET);
|
background.setState(KEY_PREVIEW_BACKGROUND_STATE_TABLE[statePosition][hasMoreKeys]);
|
||||||
previewText.setTextColor(drawParams.mPreviewTextColor);
|
}
|
||||||
ViewLayoutUtils.placeViewAt(
|
ViewLayoutUtils.placeViewAt(
|
||||||
previewText, previewX, previewY, previewWidth, previewHeight);
|
previewText, previewX, previewY, previewWidth, previewHeight);
|
||||||
previewText.setVisibility(VISIBLE);
|
previewText.setVisibility(VISIBLE);
|
||||||
|
@ -975,7 +982,7 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
||||||
* @see #invalidateAllKeys
|
* @see #invalidateAllKeys
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void invalidateKey(Key key) {
|
public void invalidateKey(final Key key) {
|
||||||
if (mInvalidateAllKeys) return;
|
if (mInvalidateAllKeys) return;
|
||||||
if (key == null) return;
|
if (key == null) return;
|
||||||
mInvalidatedKeys.add(key);
|
mInvalidatedKeys.add(key);
|
||||||
|
|
|
@ -20,7 +20,7 @@ import android.graphics.Typeface;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.ResourceUtils;
|
import com.android.inputmethod.latin.ResourceUtils;
|
||||||
|
|
||||||
public class KeyDrawParams {
|
public final class KeyDrawParams {
|
||||||
public Typeface mTypeface;
|
public Typeface mTypeface;
|
||||||
|
|
||||||
public int mLetterSize;
|
public int mLetterSize;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
|
|
||||||
package com.android.inputmethod.keyboard.internal;
|
package com.android.inputmethod.keyboard.internal;
|
||||||
|
|
||||||
public class KeyPreviewDrawParams {
|
public final class KeyPreviewDrawParams {
|
||||||
// The graphical geometry of the key preview.
|
// The graphical geometry of the key preview.
|
||||||
// <-width->
|
// <-width->
|
||||||
// +-------+ ^
|
// +-------+ ^
|
||||||
|
@ -41,6 +41,4 @@ public class KeyPreviewDrawParams {
|
||||||
// offset between the top edge of parent key and the bottom of the visible part of key
|
// offset between the top edge of parent key and the bottom of the visible part of key
|
||||||
// preview background.
|
// preview background.
|
||||||
public int mPreviewVisibleOffset;
|
public int mPreviewVisibleOffset;
|
||||||
|
|
||||||
public final int[] mCoordinates = new int[2];
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue