Android Activity как диалог


257

У меня есть активность, whereActityкоторая также имеет дочерние диалоги. Теперь я хочу отобразить это действие в качестве диалога для другого действия.

Как я могу это сделать?

введите описание изображения здесь


Если вы просто хотите загрузить диалог, вы можете использовать ProgressDialog
Daksh Agrawal

Ответы:


546

Чтобы начать деятельность как диалог, я определил это так AndroidManifest.xml:

<activity android:theme="@android:style/Theme.Dialog" />

Используйте это свойство внутри вашего activityтега, чтобы диалоговое окно не отображалось в списке недавно использованных приложений.

android:excludeFromRecents="true"

Если вы хотите предотвратить уничтожение вашего диалога / действия, когда пользователь щелкает за пределами диалогового окна:

После setContentView()в вашем Activityиспользовании:

this.setFinishOnTouchOutside(false);

Теперь, когда я звоню, startActivity()он отображается в виде диалога с предыдущим действием, отображаемым, когда пользователь нажимает кнопку «Назад».

Обратите внимание, что если вы используете ActionBarActivity(или тему AppCompat), вам нужно использовать @style/Theme.AppCompat.Dialogвместо этого.


186
Использование android: theme = "@ android: style / Theme.Dialog" - это путь, но не забудьте использовать excludeFromRecents = true, иначе ваш диалог появится в недавно использованных приложениях (удерживайте клавишу Home).
Эммануэль

7
у меня есть трудности, связанные с действием в качестве диалога ... я сделал действие в виде диалога, но проблема в том, что когда я щелкаю вне действия, оно автоматически закрывается .. ??? Есть ли какое-либо решение, связанное с этим .. ??????
Росомаха

7
@ Emmanuel, это должен быть android: excludeFromRecents = "true" обратите внимание на двойные кавычки
Sandeep

43
Обратите внимание, что если вы используете ActionBarActivity (или тему AppCompat), вам нужно будет использовать@style/Theme.AppCompat.Dialog
Quentin Klein

8
@Wolverine, добавьте метод this.setFinishOnTouchOutside(false);after, setContentView()чтобы предотвратить разрушение действия при щелчке вне диалогового окна, которое вы создали.
Anggrayudi H

43

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

this.setFinishOnTouchOutside(false);

требуется уровень API 11


1
Есть ли решение для API <11?
ПК Гупта

@pkgupta, если это приемлемо для вас, вы не должны беспокоиться, по крайней мере, API <15 для меня, так как в любом случае мало людей используют эти более ранние версии. Фактически, по состоянию на 2017 год, я думаю, что 19 или 20 - это новый minSDK.
Neon Warge

28

Вы можете определить этот стиль в values ​​/ styles.xml, чтобы выполнить более прежний Splash:

   <style name="Theme.UserDialog" parent="android:style/Theme.Dialog">
        <item name="android:windowFrame">@null</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowIsTranslucent">true</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:background">@android:color/transparent</item>
        <item name="android:windowBackground">@drawable/trans</item>
    </style>

И используйте его AndroidManifest.xml:

   <activity android:name=".SplashActivity"
          android:configChanges="orientation"
          android:screenOrientation="sensor"
          android:theme="@style/Theme.UserDialog">

2
Re @drawable/trans: вы должны быть в состоянии использовать то, @android:color/transparentчто создаст ColorDrawableдля использования в качестве фона.
TWiStErRob

1
<item name = "android: windowBackground"> ​​@ null </ item> - это еще одна альтернатива
TouchBoarder

Проблема в том, что действие заполняет весь экран, но не отображается как наложение диалога.
Shajeel Afzal

Это <item name="windowNoTitle">true</item> (без «андроида»). Смотрите здесь . Не уверен насчет других предметов.
Gary99

23

1 - Вы можете использовать те же действия, что и в диалоговом режиме, так и в полноэкранном режиме, динамически:

Звоните setTheme(android.R.style.Theme_Dialog)перед звонком setContentView(...)и super.oncreate()в своей Активности.

2 - Если вы не планируете менять стиль темы деятельности, вы можете использовать

<activity android:theme="@android:style/Theme.Dialog" />

(как упомянуто @faisal khan)


Замечание: когда я использую программный метод (первый метод), все, что находится за диалоговым окном, полностью затемняется; это не было проблемой в другом методе, хотя. Жаль ... Я действительно хотел сделать это программно .... Nexus 5, Android 6.0.1
Eric

@ Эрик, ты нашел решение для затемнения?
Ананд

1
@anand да, объединение обоих решений устраняет проблему отключения: установите тему действия на тему диалога в android manifest ( <activity android:theme="@android:style/Theme.Dialog" />) и программно установите тему действия на диалог или действие в onCreate stackoverflow.com/a/35915764/2898715
Эрик

21

Если вам нужна версия Appcompat

style.xml

    <!-- Base application theme. -->
    <style name="AppDialogTheme" parent="Theme.AppCompat.Light.Dialog">
        <!-- Customize your theme here. -->
        <item name="windowActionBar">false</item>
        <item name="android:windowNoTitle">true</item>
    </style>

yourmanifest.xml

    <activity
          android:name=".MyActivity"
          android:label="@string/title"
          android:theme="@style/AppDialogTheme">
    </activity>

Это круто. Мне нужно было удалить панель действий. Мне пришлось немного изменить XML, хотя. Я должен был добавить, <item name="windowNoTitle">true</item>чтобы это работало на меня. Я также добавил <item name="android:windowActionBar">false</item>для хорошей меры.
Эрик

5
Также у меня <item name="android:windowNoTitle">true</item>не сработало (Android 5.0.1), и мне пришлось сменить на<item name="windowNoTitle">true</item>
noti

17

Если ваша деятельность отображается в виде диалога, просто добавьте кнопку в XML своей активности,

<Button
    android:id="@+id/close_button"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Dismiss" />

Затем присоедините прослушиватель щелчков к Java-коду вашей деятельности. В слушателе просто позвонитеfinish()

Button close_button = (Button) findViewById(R.id.close_button);
close_button.setOnClickListener(new OnClickListener() {
    @Override
    public void onClick(View v) {
        finish();
    }
});

Это должно закрыть ваш диалог, вернув вас к вызывающей деятельности.


8

Если вы хотите удалить заголовок действия и предоставить настраиваемое представление для диалогового окна, добавьте следующее в блок действия вашего манифеста

android:theme="@style/Base.Theme.AppCompat.Dialog"

и создайте свой Activity_layout с желаемым видом


2

Установите тему в своем файле манифеста Android.

<activity android:name=".LoginActivity"
            android:theme="@android:style/Theme.Dialog"/>

И установите состояние диалога на ощупь, чтобы закончить.

this.setFinishOnTouchOutside(false);

1

Создайте активность как диалог, вот полный пример

введите описание изображения здесь

  1. AndroidManife.xml

    <activity android:name=".appview.settings.view.DialogActivity" android:excludeFromRecents="true" android:theme="@style/Theme.AppCompat.Dialog"/>

  2. DialogActivity.kt

    class DialogActivity : AppCompatActivity() {
      override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_dialog)
        this.setFinishOnTouchOutside(true)
    
        btnOk.setOnClickListener {
          finish()
        }
      }
    }
  3. activity_dialog.xml

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#0072ff"
    android:gravity="center"
    android:orientation="vertical">
    
    <LinearLayout
        android:layout_width="@dimen/_300sdp"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:orientation="vertical">
    
        <TextView
            android:id="@+id/txtTitle"
            style="@style/normal16Style"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:paddingTop="20dp"
            android:paddingBottom="20dp"
            android:text="Download"
            android:textColorHint="#FFF" />
    
        <View
            android:id="@+id/viewDivider"
            android:layout_width="match_parent"
            android:layout_height="2dp"
            android:background="#fff"
            android:backgroundTint="@color/white_90"
            app:layout_constraintBottom_toBottomOf="@id/txtTitle" />
    
        <TextView
            style="@style/normal14Style"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:paddingTop="20dp"
            android:paddingBottom="20dp"
            android:text="Your file is download"
            android:textColorHint="#FFF" />
    
    
        <Button
            android:id="@+id/btnOk"
            style="@style/normal12Style"
            android:layout_width="100dp"
            android:layout_height="40dp"
            android:layout_marginBottom="20dp"
            android:background="@drawable/circle_corner_layout"
            android:text="Ok"
            android:textAllCaps="false" />
        </LinearLayout>
    
      </LinearLayout>

Пожалуйста, не используйте х-большие шрифты, чтобы ваш ответ выглядел странно.
CopsOnRoad

0

Несколько раз вы можете получить Исключение, которое дано ниже

Причина: java.lang.IllegalStateException: Вам нужно использовать тему Theme.AppCompat (или потомок) с этим действием.

Таким образом, для решения вы можете использовать простое решение

добавить тему вашей деятельности в манифесте в качестве диалога для appCompact.

android:theme="@style/Theme.AppCompat.Dialog"

Это может быть полезно для кого-то.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.