Ответ 1
Собственно, хотя решение выше работает отлично, есть более простой способ.
picker.setDescendantFocusability(NumberPicker.FOCUS_BLOCK_DESCENDANTS);
Это все, что нужно. В любом случае, спасибо за ответы!!!!: -)
Всем,
Я пытаюсь заставить простой NumberPicker работать в AlertDialog. Проблема в том, что всякий раз, когда я увеличиваю/уменьшаю значение в цифровом пиктограмме, клавиатура активируется.
Есть много сообщений, описывающих эту проблему, но ни одно из предложений не работает. Я пробовал:
android:configChanges="keyboard|keyboardHidden"
и
inputManager.hideSoftInputFromWindow(currentView.getWindowToken(), 0);
И
getWindow().setSoftInputMode(
WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
Я пробовал вызывать эти функции до и после инициализации (dialog.show()), при событиях нажатия клавиш (очевидно, используя прослушиватели) и т.д., но пока не повезло.
Полный код:
popup.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content" >
<NumberPicker
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/myNumber"
android:configChanges="keyboard|keyboardHidden"
/>
</RelativeLayout>
И вызывающая функция:
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
return;
} });
builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
return;
} });
View view = getLayoutInflater().inflate(R.layout.popup, null);
builder.setView (view);
final AlertDialog dialog = builder.create ();
NumberPicker picker = (NumberPicker) view.findViewById(R.id.myNumber);
picker.setMinValue(0);
picker.setMaxValue(999);
dialog.getWindow().
setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
dialog.show();
Любая помощь оценена
Barry
Собственно, хотя решение выше работает отлично, есть более простой способ.
picker.setDescendantFocusability(NumberPicker.FOCUS_BLOCK_DESCENDANTS);
Это все, что нужно. В любом случае, спасибо за ответы!!!!: -)
Поскольку нет доступа к кнопкам NumberPicker, это невозможно сделать.
Я сделал быстрый грязный хак, чтобы справиться с этим.
Сначала добавьте фокус eater к макету, в этом случае Button с 0 размером:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content" >
<NumberPicker
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/myNumber"
android:configChanges="keyboard|keyboardHidden"
/>
<Button
android:id="@+id/myBtn"
android:layout_width="0dp"
android:layout_height="0dp"
/>
</RelativeLayout>
Нам нужно поймать событие щелчка по кнопкам ввода/уменьшения, я выбрал OnValueChangedListener, не смог найти что-то лучше.
EditText edit = null;
try {
final Field[] fields = picker.getClass().getDeclaredFields();
for (Field f : fields) {
if (EditText.class.equals(f.getType())) {
f.setAccessible(true);
edit = (EditText) f.get(picker);
}
}
} catch (IllegalAccessException e) {
e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
}
if (edit != null) {
final EditText finalEdit = edit;
final InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
picker.setOnValueChangedListener(new NumberPicker.OnValueChangeListener() {
@Override
public void onValueChange(NumberPicker numberPicker, int i, int i1) {
dialog.findViewById(R.id.myBtn).requestFocusFromTouch();
imm.hideSoftInputFromWindow(finalEdit.getWindowToken(), 0);
}
});
}
Это не рекомендуется. Надеюсь, кто-то найдет что-то лучше. Используйте только в образовательных целях; -)
Атрибут android:configChanges
принадлежит вашему файлу Manifest.xml
, а не макету. Но если вы скрываете клавиатуру оттуда, вы, вероятно, лучше всего используете
android:windowSoftInputMode="stateAlwaysHidden"
Вы также должны попытаться использовать getWindow()
на Activity
, а не только Dialog
и посмотреть, помогает ли это. Это, пожалуй, лучшее решение, так как первое (скрытое от манифеста) удерживает клавиатуру в течение всей активности.
XML:
<NumberPicker
...
android:descendantFocusability="blocksDescendants" />