Merge "Fix stale key drawing" into jb-dev
This commit is contained in:
commit
a8b1563d08
2 changed files with 17 additions and 0 deletions
|
@ -197,6 +197,20 @@ public class Keyboard {
|
|||
return null;
|
||||
}
|
||||
|
||||
public boolean hasKey(Key aKey) {
|
||||
if (mKeyCache.containsKey(aKey)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
for (final Key key : mKeys) {
|
||||
if (key == aKey) {
|
||||
mKeyCache.put(key.mCode, key);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public static boolean isLetterCode(int code) {
|
||||
return code >= MINIMUM_LETTER_CODE;
|
||||
}
|
||||
|
|
|
@ -487,6 +487,9 @@ public class KeyboardView extends View implements PointerTracker.DrawingProxy {
|
|||
} else {
|
||||
// Draw invalidated keys.
|
||||
for (final Key key : mInvalidatedKeys) {
|
||||
if (!mKeyboard.hasKey(key)) {
|
||||
continue;
|
||||
}
|
||||
final int x = key.mX + getPaddingLeft();
|
||||
final int y = key.mY + getPaddingTop();
|
||||
mInvalidatedKeysRect.set(x, y, x + key.mWidth, y + key.mHeight);
|
||||
|
|
Loading…
Reference in a new issue