am 46e17983
: [IL125] Remove arg to onPickSuggestionManually
* commit '46e17983c69650415c6469a80c46154cb4299f9d': [IL125] Remove arg to onPickSuggestionManually
This commit is contained in:
commit
d90a8ab0d1
3 changed files with 84 additions and 30 deletions
|
@ -17,6 +17,7 @@
|
|||
package com.android.inputmethod.event;
|
||||
|
||||
import com.android.inputmethod.latin.Constants;
|
||||
import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
|
||||
|
||||
/**
|
||||
* Class representing a generic input event as handled by Latin IME.
|
||||
|
@ -49,6 +50,8 @@ public class Event {
|
|||
final public static int EVENT_MODE_KEY = 3;
|
||||
// An event corresponding to a gesture.
|
||||
final public static int EVENT_GESTURE = 4;
|
||||
// An event corresponding to the manual pick of a suggestion.
|
||||
final public static int EVENT_SUGGESTION_PICKED = 5;
|
||||
|
||||
// 0 is a valid code point, so we use -1 here.
|
||||
final public static int NOT_A_CODE_POINT = -1;
|
||||
|
@ -85,31 +88,50 @@ public class Event {
|
|||
// Some flags that can't go into the key code. It's a bit field of FLAG_*
|
||||
final private int mFlags;
|
||||
|
||||
// If this is of type EVENT_SUGGESTION_PICKED, this must not be null (and must be null in
|
||||
// other cases).
|
||||
final public SuggestedWordInfo mSuggestedWordInfo;
|
||||
|
||||
// The next event, if any. Null if there is no next event yet.
|
||||
final public Event mNextEvent;
|
||||
|
||||
// This method is private - to create a new event, use one of the create* utility methods.
|
||||
private Event(final int type, final int codePoint, final int keyCode, final int x, final int y,
|
||||
final int flags, final Event next) {
|
||||
final SuggestedWordInfo suggestedWordInfo, final int flags, final Event next) {
|
||||
mType = type;
|
||||
mCodePoint = codePoint;
|
||||
mKeyCode = keyCode;
|
||||
mX = x;
|
||||
mY = y;
|
||||
mSuggestedWordInfo = suggestedWordInfo;
|
||||
mFlags = flags;
|
||||
mNextEvent = next;
|
||||
// Sanity checks
|
||||
// mSuggestedWordInfo is non-null if and only if the type is SUGGESTION_PICKED
|
||||
if (EVENT_SUGGESTION_PICKED == mType) {
|
||||
if (null == mSuggestedWordInfo) {
|
||||
throw new RuntimeException("Wrong event: SUGGESTION_PICKED event must have a "
|
||||
+ "non-null SuggestedWordInfo");
|
||||
}
|
||||
} else {
|
||||
if (null != mSuggestedWordInfo) {
|
||||
throw new RuntimeException("Wrong event: only SUGGESTION_PICKED events may have " +
|
||||
"a non-null SuggestedWordInfo");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static Event createSoftwareKeypressEvent(final int codePoint, final int keyCode,
|
||||
final int x, final int y) {
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, keyCode, x, y, FLAG_NONE, null);
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, keyCode, x, y,
|
||||
null /* suggestedWordInfo */, FLAG_NONE, null);
|
||||
}
|
||||
|
||||
public static Event createHardwareKeypressEvent(final int codePoint, final int keyCode,
|
||||
final Event next) {
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, keyCode,
|
||||
Constants.EXTERNAL_KEYBOARD_COORDINATE, Constants.EXTERNAL_KEYBOARD_COORDINATE,
|
||||
FLAG_NONE, next);
|
||||
null /* suggestedWordInfo */, FLAG_NONE, next);
|
||||
}
|
||||
|
||||
// This creates an input event for a dead character. @see {@link #FLAG_DEAD}
|
||||
|
@ -117,7 +139,7 @@ public class Event {
|
|||
// TODO: add an argument or something if we ever create a software layout with dead keys.
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, keyCode,
|
||||
Constants.EXTERNAL_KEYBOARD_COORDINATE, Constants.EXTERNAL_KEYBOARD_COORDINATE,
|
||||
FLAG_DEAD, next);
|
||||
null /* suggestedWordInfo */, FLAG_DEAD, next);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -130,7 +152,8 @@ public class Event {
|
|||
public static Event createEventForCodePointFromUnknownSource(final int codePoint) {
|
||||
// TODO: should we have a different type of event for this? After all, it's not a key press.
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, NOT_A_KEY_CODE,
|
||||
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE, FLAG_NONE, null /* next */);
|
||||
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE,
|
||||
null /* suggestedWordInfo */, FLAG_NONE, null /* next */);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -144,13 +167,24 @@ public class Event {
|
|||
public static Event createEventForCodePointFromAlreadyTypedText(final int codePoint,
|
||||
final int x, final int y) {
|
||||
// TODO: should we have a different type of event for this? After all, it's not a key press.
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, NOT_A_KEY_CODE, x, y, FLAG_NONE,
|
||||
null /* next */);
|
||||
return new Event(EVENT_INPUT_KEYPRESS, codePoint, NOT_A_KEY_CODE, x, y,
|
||||
null /* suggestedWordInfo */, FLAG_NONE, null /* next */);
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates an input event representing the manual pick of a suggestion.
|
||||
* @return an event for this suggestion pick.
|
||||
*/
|
||||
public static Event createSuggestionPickedEvent(final SuggestedWordInfo suggestedWordInfo) {
|
||||
return new Event(EVENT_SUGGESTION_PICKED, NOT_A_CODE_POINT, NOT_A_KEY_CODE,
|
||||
Constants.SUGGESTION_STRIP_COORDINATE, Constants.SUGGESTION_STRIP_COORDINATE,
|
||||
suggestedWordInfo, FLAG_NONE, null);
|
||||
}
|
||||
|
||||
public static Event createNotHandledEvent() {
|
||||
return new Event(EVENT_NOT_HANDLED, NOT_A_CODE_POINT, NOT_A_KEY_CODE,
|
||||
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE, FLAG_NONE, null);
|
||||
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE,
|
||||
null /* suggestedWordInfo */, FLAG_NONE, null);
|
||||
}
|
||||
|
||||
// Returns whether this event is for a dead character. @see {@link #FLAG_DEAD}
|
||||
|
|
|
@ -1276,15 +1276,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||
final InputTransaction completeInputTransaction =
|
||||
mInputLogic.onCodeInput(mSettings.getCurrent(), event,
|
||||
mKeyboardSwitcher.getKeyboardShiftMode(), mHandler);
|
||||
switch (completeInputTransaction.getRequiredShiftUpdate()) {
|
||||
case InputTransaction.SHIFT_UPDATE_LATER:
|
||||
mHandler.postUpdateShiftState();
|
||||
break;
|
||||
case InputTransaction.SHIFT_UPDATE_NOW:
|
||||
mKeyboardSwitcher.updateShiftState();
|
||||
break;
|
||||
default: // SHIFT_NO_UPDATE
|
||||
}
|
||||
updateShiftModeAfterInputTransaction(completeInputTransaction.getRequiredShiftUpdate());
|
||||
mKeyboardSwitcher.onCodeInput(codePoint);
|
||||
}
|
||||
|
||||
|
@ -1500,8 +1492,10 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||
// interface
|
||||
@Override
|
||||
public void pickSuggestionManually(final int index, final SuggestedWordInfo suggestionInfo) {
|
||||
mInputLogic.onPickSuggestionManually(mSettings.getCurrent(), index, suggestionInfo,
|
||||
mHandler, mKeyboardSwitcher);
|
||||
final InputTransaction completeInputTransaction = mInputLogic.onPickSuggestionManually(
|
||||
mSettings.getCurrent(), index, suggestionInfo,
|
||||
mKeyboardSwitcher.getKeyboardShiftMode(), mHandler);
|
||||
updateShiftModeAfterInputTransaction(completeInputTransaction.getRequiredShiftUpdate());
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -1539,6 +1533,18 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||
}
|
||||
}
|
||||
|
||||
private void updateShiftModeAfterInputTransaction(final int requiredShiftUpdate) {
|
||||
switch (requiredShiftUpdate) {
|
||||
case InputTransaction.SHIFT_UPDATE_LATER:
|
||||
mHandler.postUpdateShiftState();
|
||||
break;
|
||||
case InputTransaction.SHIFT_UPDATE_NOW:
|
||||
mKeyboardSwitcher.updateShiftState();
|
||||
break;
|
||||
default: // SHIFT_NO_UPDATE
|
||||
}
|
||||
}
|
||||
|
||||
private void hapticAndAudioFeedback(final int code, final int repeatCount) {
|
||||
final MainKeyboardView keyboardView = mKeyboardSwitcher.getMainKeyboardView();
|
||||
if (keyboardView != null && keyboardView.isInDraggingFinger()) {
|
||||
|
|
|
@ -196,13 +196,16 @@ public final class InputLogic {
|
|||
* @param settingsValues the current values of the settings.
|
||||
* @param index the index of the suggestion.
|
||||
* @param suggestionInfo the suggestion info.
|
||||
* @param keyboardShiftState the shift state of the keyboard, as returned by
|
||||
* {@link com.android.inputmethod.keyboard.KeyboardSwitcher#getKeyboardShiftMode()}
|
||||
* @return the complete transaction object
|
||||
*/
|
||||
// Called from {@link SuggestionStripView} through the {@link SuggestionStripView#Listener}
|
||||
// interface
|
||||
public void onPickSuggestionManually(final SettingsValues settingsValues,
|
||||
final int index, final SuggestedWordInfo suggestionInfo,
|
||||
// TODO: remove these two arguments
|
||||
final LatinIME.UIHandler handler, final KeyboardSwitcher keyboardSwitcher) {
|
||||
public InputTransaction onPickSuggestionManually(final SettingsValues settingsValues,
|
||||
final int index, final SuggestedWordInfo suggestionInfo, final int keyboardShiftState,
|
||||
// TODO: remove this argument
|
||||
final LatinIME.UIHandler handler) {
|
||||
final SuggestedWords suggestedWords = mSuggestedWords;
|
||||
final String suggestion = suggestionInfo.mWord;
|
||||
// If this is a punctuation picked from the suggestion strip, pass it to onCodeInput
|
||||
|
@ -212,16 +215,26 @@ public final class InputLogic {
|
|||
LatinImeLogger.logOnManualSuggestion("", suggestion, index, suggestedWords);
|
||||
// Rely on onCodeInput to do the complicated swapping/stripping logic consistently.
|
||||
final int primaryCode = suggestion.charAt(0);
|
||||
final Event event = Event.createSoftwareKeypressEvent(primaryCode, Event.NOT_A_KEY_CODE,
|
||||
Constants.SUGGESTION_STRIP_COORDINATE, Constants.SUGGESTION_STRIP_COORDINATE);
|
||||
onCodeInput(settingsValues, event, keyboardSwitcher.getKeyboardShiftMode(), handler);
|
||||
// TODO: we should be using createSuggestionPickedEvent here, but for legacy reasons,
|
||||
// onCodeInput is expected a software keypress event for a suggested punctuation
|
||||
// because the current code is descended from a time where this information used not
|
||||
// to be available. Fix this.
|
||||
final Event event = Event.createSoftwareKeypressEvent(primaryCode,
|
||||
Event.NOT_A_KEY_CODE /* keyCode*/,
|
||||
Constants.SUGGESTION_STRIP_COORDINATE /* x */,
|
||||
Constants.SUGGESTION_STRIP_COORDINATE /* y */);
|
||||
final InputTransaction completeTransaction = onCodeInput(settingsValues, event,
|
||||
keyboardShiftState, handler);
|
||||
if (ProductionFlag.USES_DEVELOPMENT_ONLY_DIAGNOSTICS) {
|
||||
ResearchLogger.latinIME_punctuationSuggestion(index, suggestion,
|
||||
false /* isBatchMode */, suggestedWords.mIsPrediction);
|
||||
}
|
||||
return;
|
||||
return completeTransaction;
|
||||
}
|
||||
|
||||
final Event event = Event.createSuggestionPickedEvent(suggestionInfo);
|
||||
final InputTransaction inputTransaction = new InputTransaction(settingsValues,
|
||||
event, SystemClock.uptimeMillis(), mSpaceState, keyboardShiftState);
|
||||
mConnection.beginBatchEdit();
|
||||
if (SpaceState.PHANTOM == mSpaceState && suggestion.length() > 0
|
||||
// In the batch input mode, a manually picked suggested word should just replace
|
||||
|
@ -241,11 +254,11 @@ public final class InputLogic {
|
|||
if (SuggestedWordInfo.KIND_APP_DEFINED == suggestionInfo.mKind) {
|
||||
mSuggestedWords = SuggestedWords.EMPTY;
|
||||
mSuggestionStripViewAccessor.setNeutralSuggestionStrip();
|
||||
keyboardSwitcher.updateShiftState();
|
||||
inputTransaction.requireShiftUpdate(InputTransaction.SHIFT_UPDATE_NOW);
|
||||
resetComposingState(true /* alsoResetLastComposedWord */);
|
||||
mConnection.commitCompletion(suggestionInfo.mApplicationSpecifiedCompletionInfo);
|
||||
mConnection.endBatchEdit();
|
||||
return;
|
||||
return inputTransaction;
|
||||
}
|
||||
|
||||
// We need to log before we commit, because the word composer will store away the user
|
||||
|
@ -264,7 +277,7 @@ public final class InputLogic {
|
|||
mLastComposedWord.deactivate();
|
||||
// Space state must be updated before calling updateShiftState
|
||||
mSpaceState = SpaceState.PHANTOM;
|
||||
keyboardSwitcher.updateShiftState();
|
||||
inputTransaction.requireShiftUpdate(InputTransaction.SHIFT_UPDATE_NOW);
|
||||
|
||||
// We should show the "Touch again to save" hint if the user pressed the first entry
|
||||
// AND it's in none of our current dictionaries (main, user or otherwise).
|
||||
|
@ -290,6 +303,7 @@ public final class InputLogic {
|
|||
// If we're not showing the "Touch again to save", then update the suggestion strip.
|
||||
handler.postUpdateSuggestionStrip();
|
||||
}
|
||||
return inputTransaction;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in a new issue