ответ Оливьерга работал для меня и является лучшим решением, если создание пользовательского класса диалога - это путь, по которому вы хотите идти. Однако меня беспокоило, что я не могу использовать класс AlertDialog. Я хотел использовать системный стиль AlertDialog по умолчанию. Создание пользовательского диалогового класса не будет иметь этот стиль.
Итак, я нашел решение (взломать), которое будет работать без создания пользовательского класса, вы можете использовать существующие компоновщики.
AlertDialog помещает представление над представлением содержимого в качестве заполнителя для заголовка. Если вы найдете вид и установите высоту 0, пробел исчезнет.
До сих пор я проверял это на 2.3 и 3.0, возможно, это работает не на всех версиях.
Вот два вспомогательных метода для этого:
/**
* Show a Dialog with the extra title/top padding collapsed.
*
* @param customView The custom view that you added to the dialog
* @param dialog The dialog to display without top spacing
* @param show Whether or not to call dialog.show() at the end.
*/
public static void showDialogWithNoTopSpace(final View customView, final Dialog dialog, boolean show) {
// Now we setup a listener to detect as soon as the dialog has shown.
customView.getViewTreeObserver().addOnGlobalLayoutListener(new OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
// Check if your view has been laid out yet
if (customView.getHeight() > 0) {
// If it has been, we will search the view hierarchy for the view that is responsible for the extra space.
LinearLayout dialogLayout = findDialogLinearLayout(customView);
if (dialogLayout == null) {
// Could find it. Unexpected.
} else {
// Found it, now remove the height of the title area
View child = dialogLayout.getChildAt(0);
if (child != customView) {
// remove height
LinearLayout.LayoutParams lp = (LinearLayout.LayoutParams) child.getLayoutParams();
lp.height = 0;
child.setLayoutParams(lp);
} else {
// Could find it. Unexpected.
}
}
// Done with the listener
customView.getViewTreeObserver().removeGlobalOnLayoutListener(this);
}
}
});
// Show the dialog
if (show)
dialog.show();
}
/**
* Searches parents for a LinearLayout
*
* @param view to search the search from
* @return the first parent view that is a LinearLayout or null if none was found
*/
public static LinearLayout findDialogLinearLayout(View view) {
ViewParent parent = (ViewParent) view.getParent();
if (parent != null) {
if (parent instanceof LinearLayout) {
// Found it
return (LinearLayout) parent;
} else if (parent instanceof View) {
// Keep looking
return findDialogLinearLayout((View) parent);
}
}
// Couldn't find it
return null;
}
Вот пример того, как он используется:
Dialog dialog = new AlertDialog.Builder(this)
.setView(yourCustomView)
.create();
showDialogWithNoTopSpace(yourCustomView, dialog, true);
Если вы используете это с DialogFragment, переопределите метод onCreateDialog
DialogFragment. Затем создайте и верните диалог, как в первом примере выше. Единственное изменение заключается в том, что вы должны передать false в качестве третьего параметра (show), чтобы он не вызывал show () в диалоговом окне. DialogFragment будет обрабатывать это позже.
Пример:
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
Dialog dialog = new AlertDialog.Builder(getContext())
.setView(yourCustomView)
.create();
showDialogWithNoTopSpace(yourCustomView, dialog, false);
return dialog;
}
По мере дальнейшего тестирования я обязательно обновлюсь с необходимыми дополнительными настройками.