it-swarm.com.ru

Как Android кнопки диалогового окна в стиле Holo Theme

Я создаю диалоговое окно для Holo Theme и хочу следовать стандартному способу отображения кнопок в ОС. До сих пор я создал диалоговое окно, но кнопки отображаются не так, как в приложениях, выполненных в Holo для ICS. Как я могу это сделать? Мой предполагаемый внешний вид No. 3rd in this image и я могу добраться до здесь Notice the Signup and Login buttons

52
kishu27

немного поздно, но, возможно, кто-то все еще заинтересован в этом.

это работает довольно хорошо для меня.

...
<!--
EDIT: be carefull, "?android:attr/dividerHorizontal" is only supported since API 11
      just avoid it in prior OSs.
-->
<View
    Android:layout_width="fill_parent"
    Android:layout_height="1dip"
    Android:background="?android:attr/dividerHorizontal" />
<LinearLayout 
    style="?android:attr/buttonBarStyle"
    Android:layout_width="fill_parent"
    Android:layout_height="wrap_content"
    Android:orientation="horizontal"
    Android:paddingTop="0dip"
    Android:paddingLeft="2dip"
    Android:paddingRight="2dip"
    Android:measureWithLargestChild="true">

    <Button 
        Android:id="@+id/cancel"
        style="?android:attr/buttonBarButtonStyle"
        Android:layout_width="0dip"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:text="@Android:string/cancel"/>
    <Button 
        Android:id="@+id/ok"
        style="?android:attr/buttonBarButtonStyle"
        Android:layout_width="0dip"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:text="@Android:string/ok"/>
</LinearLayout>
...

активность, которая загружает этот макет, нуждается в теме Holo.Dialog.

Android:theme="@Android:style/Theme.Holo.Dialog"
85
SimonSays

Вот что работает:

<LinearLayout
    Android:id="@+id/buttonHolder"
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content" 
    Android:orientation="horizontal"
    >

    <Button
        Android:id="@+id/cmdSignup"
        style="@Android:style/Widget.Holo.Light.Button.Borderless.Small"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:text="@string/Signup" />

    <Button
        Android:id="@+id/cmdLogin"
        style="@Android:style/Widget.Holo.Light.Button.Borderless.Small"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:layout_weight="1"
        Android:text="@string/Login" />
</LinearLayout>

Свойство style="@Android:style/Widget.Holo.Light.Button.Borderless.Small" дает плоский внешний вид, а 50-процентное распределение веса происходит из-за сочетания 100-процентного определения размера LinearLayout с Android:layout_width="match_parent" andAndroid: layout_weight = "1" `для кнопок

22
kishu27

Вы можете установить тему с помощью Android Manifest xml или внутри onCreate Действия с помощью setTheme(Android.R.style.Theme_Holo);

Размер кнопок не связан с самой темой. Размер соответствует вашим определениям xml. На изображении, которое вы отправили, кажется, что кнопки получили тему Holo, так что в этом нет ничего плохого ...

Вот макет XML, который будет растягивать кнопки, чтобы заполнить всю ширину диалога:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
        Android:orientation="vertical"
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        >
    <LinearLayout
                Android:orientation="horizontal"
                Android:layout_width="fill_parent"
                Android:layout_height="wrap_content"
                Android:layout_marginTop="5dip"
                >
                <Button
                    Android:id="@+id/okButton"
                    Android:layout_width="fill_parent"
                    Android:layout_height="wrap_content"
                    Android:layout_weight="1"
                    Android:text="OK"
                />
                <Button
                    Android:id="@+id/cancelButton"
                    Android:layout_width="fill_parent"
                    Android:layout_height="wrap_content"
                    Android:layout_weight="1"
                    Android:text="Cancel"
                />          
        </LinearLayout>
</LinearLayout>
2
Lior Iluz