Fix possible divided by zeror error
Bug: 9534022 Change-Id: I5ab575c724fd7a9e80c76a93d83949e81b2970bb
This commit is contained in:
parent
940cca4fa9
commit
bafe4b8a4e
1 changed files with 7 additions and 13 deletions
|
@ -279,8 +279,14 @@ public final class MoreKeysKeyboard extends Keyboard {
|
|||
mParentKey = parentKey;
|
||||
|
||||
final int width, height;
|
||||
// {@link KeyPreviewDrawParams#mPreviewVisibleWidth} should have been set at
|
||||
// {@link MainKeyboardView#showKeyPreview(PointerTracker}, though there may be
|
||||
// some chances that the value is zero. <code>width == 0</code> will cause
|
||||
// zero-division error at
|
||||
// {@link MoreKeysKeyboardParams#setParameters(int,int,int,int,int,int,boolean,int)}.
|
||||
final boolean singleMoreKeyWithPreview = parentKeyboardView.isKeyPreviewPopupEnabled()
|
||||
&& !parentKey.noKeyPreview() && parentKey.mMoreKeys.length == 1;
|
||||
&& !parentKey.noKeyPreview() && parentKey.mMoreKeys.length == 1
|
||||
&& keyPreviewDrawParams.mPreviewVisibleWidth > 0;
|
||||
if (singleMoreKeyWithPreview) {
|
||||
// Use pre-computed width and height if this more keys keyboard has only one key to
|
||||
// mitigate visual flicker between key preview and more keys keyboard.
|
||||
|
@ -291,22 +297,10 @@ public final class MoreKeysKeyboard extends Keyboard {
|
|||
// adjusted with their bottom paddings deducted.
|
||||
width = keyPreviewDrawParams.mPreviewVisibleWidth;
|
||||
height = keyPreviewDrawParams.mPreviewVisibleHeight + mParams.mVerticalGap;
|
||||
// TODO: Remove this check.
|
||||
if (width == 0) {
|
||||
throw new IllegalArgumentException(
|
||||
"Zero width key detected: " + parentKey + " in " + parentKeyboard.mId);
|
||||
}
|
||||
} else {
|
||||
width = getMaxKeyWidth(parentKeyboardView, parentKey, mParams.mDefaultKeyWidth,
|
||||
context.getResources());
|
||||
height = parentKeyboard.mMostCommonKeyHeight;
|
||||
// TODO: Remove this check.
|
||||
if (width == 0) {
|
||||
throw new IllegalArgumentException(
|
||||
"Zero width calculated: " + parentKey
|
||||
+ " moreKeys=" + java.util.Arrays.toString(parentKey.mMoreKeys)
|
||||
+ " in " + parentKeyboard.mId);
|
||||
}
|
||||
}
|
||||
final int dividerWidth;
|
||||
if (parentKey.needsDividersInMoreKeys()) {
|
||||
|
|
Loading…
Reference in a new issue