mirror of
https://gitlab.futo.org/keyboard/latinime.git
synced 2024-09-28 14:54:30 +01:00
Launch AOSP Keyboard Settings on the same display am: d762841494
am: d6c56279b3
Change-Id: Iee16bafc93cd5550cdb8da83b1bf2b93f3b2a83e
This commit is contained in:
commit
9dd8853932
@ -21,6 +21,7 @@ import static com.android.inputmethod.latin.common.Constants.ImeOption.NO_MICROP
|
|||||||
import static com.android.inputmethod.latin.common.Constants.ImeOption.NO_MICROPHONE_COMPAT;
|
import static com.android.inputmethod.latin.common.Constants.ImeOption.NO_MICROPHONE_COMPAT;
|
||||||
|
|
||||||
import android.Manifest.permission;
|
import android.Manifest.permission;
|
||||||
|
import android.app.ActivityOptions;
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@ -1781,6 +1782,22 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Starts {@link android.app.Activity} on the same display where the IME is shown.
|
||||||
|
*
|
||||||
|
* @param intent {@link Intent} to be used to start {@link android.app.Activity}.
|
||||||
|
*/
|
||||||
|
private void startActivityOnTheSameDisplay(Intent intent) {
|
||||||
|
// Note that WindowManager#getDefaultDisplay() returns the display ID associated with the
|
||||||
|
// Context from which the WindowManager instance was obtained. Therefore the following code
|
||||||
|
// returns the display ID for the window where the IME is shown.
|
||||||
|
final int currentDisplayId = ((WindowManager) getSystemService(Context.WINDOW_SERVICE))
|
||||||
|
.getDefaultDisplay().getDisplayId();
|
||||||
|
|
||||||
|
startActivity(intent,
|
||||||
|
ActivityOptions.makeBasic().setLaunchDisplayId(currentDisplayId).toBundle());
|
||||||
|
}
|
||||||
|
|
||||||
void launchSettings(final String extraEntryValue) {
|
void launchSettings(final String extraEntryValue) {
|
||||||
mInputLogic.commitTyped(mSettings.getCurrent(), LastComposedWord.NOT_A_SEPARATOR);
|
mInputLogic.commitTyped(mSettings.getCurrent(), LastComposedWord.NOT_A_SEPARATOR);
|
||||||
requestHideSelf(0);
|
requestHideSelf(0);
|
||||||
@ -1795,7 +1812,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||||||
| Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
| Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
||||||
intent.putExtra(SettingsActivity.EXTRA_SHOW_HOME_AS_UP, false);
|
intent.putExtra(SettingsActivity.EXTRA_SHOW_HOME_AS_UP, false);
|
||||||
intent.putExtra(SettingsActivity.EXTRA_ENTRY_KEY, extraEntryValue);
|
intent.putExtra(SettingsActivity.EXTRA_ENTRY_KEY, extraEntryValue);
|
||||||
startActivity(intent);
|
startActivityOnTheSameDisplay(intent);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void showSubtypeSelectorAndSettings() {
|
private void showSubtypeSelectorAndSettings() {
|
||||||
@ -1819,7 +1836,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
|||||||
| Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED
|
| Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED
|
||||||
| Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
| Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
||||||
intent.putExtra(Intent.EXTRA_TITLE, languageSelectionTitle);
|
intent.putExtra(Intent.EXTRA_TITLE, languageSelectionTitle);
|
||||||
startActivity(intent);
|
startActivityOnTheSameDisplay(intent);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
launchSettings(SettingsActivity.EXTRA_ENTRY_VALUE_LONG_PRESS_COMMA);
|
launchSettings(SettingsActivity.EXTRA_ENTRY_VALUE_LONG_PRESS_COMMA);
|
||||||
|
Loading…
Reference in New Issue
Block a user