Обработка ошибок с помощью Glance

Функции API для улучшения обработки ошибок в Glance включены начиная с Android 15. На этой странице представлены некоторые рекомендации по использованию этих API.

Используйте блок try-catch вокруг некомпонуемых компонентов.

Compose не допускает блоков try-catch вокруг компонуемых объектов, но позволяет обернуть в эти блоки другую логику вашего приложения. Это позволит вам использовать Compose для представления ошибок, как показано в следующем примере:

provideContent {
       
var isError = false;
       
var data = null
       
try {
           
val repository = (context.applicationContext as MyApplication).myRepository
           data
= repository.loadData()
       
} catch (e: Exception) {
           isError
= true;
           
//handleError
       
}

       
if (isError) {
           
ErrorView()
       
} else {
           
Content(data)
       
}
   
}

Макет ошибок по умолчанию

Если есть неперехваченное исключение или ошибка Compose, Glance отображает макет ошибки по умолчанию:

Сообщение об ошибке, показывающее тип ошибки и рекомендации о том, где ее искать.
Рисунок 1. Схема ошибок Glance 1.0 по умолчанию
Поле с текстом «Невозможно показать контент».
Рис. 2. Схема ошибок Glance 1.1.0 по умолчанию

Glance позволяет разработчикам предоставлять макет XML в качестве запасного варианта в случае сбоя композиции. Это означает, что в коде Compose произошла ошибка. Этот пользовательский интерфейс ошибки также появляется, если в коде вашего приложения есть необнаруженная ошибка.

class UpgradeWidget : GlanceAppWidget(errorUiLayout = R.layout.error_layout)

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

Содержит заголовок и текстовое поле для отображения сообщения об ошибке.
Рисунок 3. Пример пользовательского макета ошибок

Добавьте действия в пользовательский интерфейс ошибок по умолчанию

Начиная с Glance 1.1.0, Glance позволяет переопределить код обработки ошибок по умолчанию. Таким образом, вы можете добавить обратные вызовы действий в случае неперехваченного исключения или ошибки в композиции.

Чтобы использовать эту функцию, переопределите функцию onCompositionError() :

GlanceAppWidget.onCompositionError(
    context
: Context,
    glanceId
: GlanceId,
   
AppWidgetId: Int,
    throwable
: Throwable
)

В этой функции Glance обращается к API RemoteViews для обработки ошибок. Это позволяет вам указывать макеты и обработчики действий с помощью XML.

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

  1. Запишите файл error_layout.xml.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   
style="@style/Widget.MyApplication.AppWidget.Error"
   
android:id="@android:id/background"
   
android:layout_width="match_parent"
   
android:textSize="24sp"
   
android:layout_height="match_parent"
   
android:orientation="vertical">


   
<TextView
       
android:id="@+id/error_title_view"
       
android:layout_width="match_parent"
       
android:textColor="@color/white"
       
android:textFontWeight="800"
       
android:layout_height="wrap_content"
       
android:text="Example Widget Error" />

   
<LinearLayout
       
android:layout_width="match_parent"
       
android:orientation="horizontal"
       
android:paddingTop="4dp"
       
android:layout_height="match_parent">

       
<ImageButton
           
android:layout_width="64dp"
           
android:layout_height="64dp"
           
android:layout_gravity="center"
           
android:tint="@color/white"
           
android:id="@+id/error_icon"
           
android:src="@drawable/heart_broken_fill0_wght400_grad0_opsz24"
       
/>
       
<TextView
           
android:id="@+id/error_text_view"
           
android:layout_width="wrap_content"
           
android:textColor="@color/white"
           
android:layout_height="wrap_content"
           
android:layout_gravity="center"
           
android:padding="8dp"
           
android:textSize="16sp"
           
android:layout_weight="1"
           
android:text="Useful Error Message!" />
   
</LinearLayout>

</LinearLayout>

  1. Переопределить функцию onCompositionError
override fun onCompositionError(
   context
: Context,
   glanceId
: GlanceId,
   
AppWidgetId: Int,
   throwable
: Throwable
) {
   
val rv = RemoteViews(context.packageName, R.layout.error_layout)
   rv
.setTextViewText(
       R
.id.error_text_view,
       
"Error was thrown. \nThis is a custom view \nError Message: `${throwable.message}`"
   
)
   rv
.setOnClickPendingIntent(R.id.error_icon, getErrorIntent(context, throwable))
   
AppWidgetManager.getInstance(context).updateAppWidget(AppWidgetId, rv)
}

  1. Создайте ожидающее намерение, которое ссылается на ваш GlanceAppWidgetReceiver
private fun getErrorIntent(context: Context, throwable: Throwable): PendingIntent {
   
val intent = Intent(context, UpgradeToHelloWorldPro::class.java)
    intent
.setAction("widgetError")
   
return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)
}

  1. Обработайте намерение в своем GlanceAppWidgetReceiver
override fun onReceive(context: Context, intent: Intent) {
   
super.onReceive(context, intent)
   
Log.e("ErrorOnClick", "Button was clicked.");
}

,

Функции API для улучшения обработки ошибок в Glance включены начиная с Android 15. На этой странице представлены некоторые рекомендации по использованию этих API.

Используйте блок try-catch вокруг некомпонуемых компонентов.

Compose не допускает блоков try-catch вокруг компонуемых объектов, но позволяет обернуть в эти блоки другую логику вашего приложения. Это позволит вам использовать Compose для просмотра ошибок, как показано в следующем примере:

provideContent {
       
var isError = false;
       
var data = null
       
try {
           
val repository = (context.applicationContext as MyApplication).myRepository
           data
= repository.loadData()
       
} catch (e: Exception) {
           isError
= true;
           
//handleError
       
}

       
if (isError) {
           
ErrorView()
       
} else {
           
Content(data)
       
}
   
}

Макет ошибок по умолчанию

Если есть неперехваченное исключение или ошибка Compose, Glance отображает макет ошибки по умолчанию:

Сообщение об ошибке, показывающее тип ошибки и рекомендации о том, где ее искать.
Рисунок 1. Схема ошибок Glance 1.0 по умолчанию
Поле с текстом «Невозможно показать контент».
Рис. 2. Схема ошибок Glance 1.1.0 по умолчанию

Glance позволяет разработчикам предоставлять макет XML в качестве запасного варианта в случае сбоя композиции. Это означает, что в коде Compose произошла ошибка. Этот пользовательский интерфейс ошибки также появляется, если в коде вашего приложения есть необнаруженная ошибка.

class UpgradeWidget : GlanceAppWidget(errorUiLayout = R.layout.error_layout)

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

Содержит заголовок и текстовое поле для отображения сообщения об ошибке.
Рисунок 3. Пример пользовательского макета ошибок

Добавьте действия в пользовательский интерфейс ошибок по умолчанию

Начиная с Glance 1.1.0, Glance позволяет переопределить код обработки ошибок по умолчанию. Таким образом, вы можете добавить обратные вызовы действий в случае неперехваченного исключения или ошибки в композиции.

Чтобы использовать эту функцию, переопределите функцию onCompositionError() :

GlanceAppWidget.onCompositionError(
    context
: Context,
    glanceId
: GlanceId,
   
AppWidgetId: Int,
    throwable
: Throwable
)

В этой функции Glance обращается к API RemoteViews для обработки ошибок. Это позволяет указывать макеты и обработчики действий с помощью XML.

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

  1. Запишите файл error_layout.xml.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   
style="@style/Widget.MyApplication.AppWidget.Error"
   
android:id="@android:id/background"
   
android:layout_width="match_parent"
   
android:textSize="24sp"
   
android:layout_height="match_parent"
   
android:orientation="vertical">


   
<TextView
       
android:id="@+id/error_title_view"
       
android:layout_width="match_parent"
       
android:textColor="@color/white"
       
android:textFontWeight="800"
       
android:layout_height="wrap_content"
       
android:text="Example Widget Error" />

   
<LinearLayout
       
android:layout_width="match_parent"
       
android:orientation="horizontal"
       
android:paddingTop="4dp"
       
android:layout_height="match_parent">

       
<ImageButton
           
android:layout_width="64dp"
           
android:layout_height="64dp"
           
android:layout_gravity="center"
           
android:tint="@color/white"
           
android:id="@+id/error_icon"
           
android:src="@drawable/heart_broken_fill0_wght400_grad0_opsz24"
       
/>
       
<TextView
           
android:id="@+id/error_text_view"
           
android:layout_width="wrap_content"
           
android:textColor="@color/white"
           
android:layout_height="wrap_content"
           
android:layout_gravity="center"
           
android:padding="8dp"
           
android:textSize="16sp"
           
android:layout_weight="1"
           
android:text="Useful Error Message!" />
   
</LinearLayout>

</LinearLayout>

  1. Переопределить функцию onCompositionError
override fun onCompositionError(
   context
: Context,
   glanceId
: GlanceId,
   
AppWidgetId: Int,
   throwable
: Throwable
) {
   
val rv = RemoteViews(context.packageName, R.layout.error_layout)
   rv
.setTextViewText(
       R
.id.error_text_view,
       
"Error was thrown. \nThis is a custom view \nError Message: `${throwable.message}`"
   
)
   rv
.setOnClickPendingIntent(R.id.error_icon, getErrorIntent(context, throwable))
   
AppWidgetManager.getInstance(context).updateAppWidget(AppWidgetId, rv)
}

  1. Создайте ожидающее намерение, которое ссылается на ваш GlanceAppWidgetReceiver
private fun getErrorIntent(context: Context, throwable: Throwable): PendingIntent {
   
val intent = Intent(context, UpgradeToHelloWorldPro::class.java)
    intent
.setAction("widgetError")
   
return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)
}

  1. Обработайте намерение в своем GlanceAppWidgetReceiver
override fun onReceive(context: Context, intent: Intent) {
   
super.onReceive(context, intent)
   
Log.e("ErrorOnClick", "Button was clicked.");
}

,

Функции API для улучшения обработки ошибок в Glance включены начиная с Android 15. На этой странице представлены некоторые рекомендации по использованию этих API.

Используйте блок try-catch вокруг некомпонуемых компонентов.

Compose не допускает блоков try-catch вокруг компонуемых объектов, но позволяет обернуть в эти блоки другую логику вашего приложения. Это позволит вам использовать Compose для просмотра ошибок, как показано в следующем примере:

provideContent {
       
var isError = false;
       
var data = null
       
try {
           
val repository = (context.applicationContext as MyApplication).myRepository
           data
= repository.loadData()
       
} catch (e: Exception) {
           isError
= true;
           
//handleError
       
}

       
if (isError) {
           
ErrorView()
       
} else {
           
Content(data)
       
}
   
}

Макет ошибок по умолчанию

Если есть неперехваченное исключение или ошибка Compose, Glance отображает макет ошибки по умолчанию:

Сообщение об ошибке, показывающее тип ошибки и рекомендации о том, где ее искать.
Рисунок 1. Схема ошибок Glance 1.0 по умолчанию
Поле с текстом «Невозможно показать контент».
Рис. 2. Схема ошибок Glance 1.1.0 по умолчанию

Glance позволяет разработчикам предоставлять макет XML в качестве запасного варианта в случае сбоя композиции. Это означает, что в коде Compose произошла ошибка. Этот интерфейс ошибки также появляется, если в коде вашего приложения есть необнаруженная ошибка.

class UpgradeWidget : GlanceAppWidget(errorUiLayout = R.layout.error_layout)

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

Содержит заголовок и текстовое поле для отображения сообщения об ошибке.
Рисунок 3. Пример пользовательского макета ошибок

Добавьте действия в пользовательский интерфейс ошибок по умолчанию

Начиная с Glance 1.1.0, Glance позволяет переопределить код обработки ошибок по умолчанию. Таким образом, вы можете добавить обратные вызовы действий в случае неперехваченного исключения или ошибки в композиции.

Чтобы использовать эту функцию, переопределите функцию onCompositionError() :

GlanceAppWidget.onCompositionError(
    context
: Context,
    glanceId
: GlanceId,
   
AppWidgetId: Int,
    throwable
: Throwable
)

В этой функции Glance обращается к API RemoteViews для обработки ошибок. Это позволяет вам указывать макеты и обработчики действий с помощью XML.

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

  1. Запишите файл error_layout.xml.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   
style="@style/Widget.MyApplication.AppWidget.Error"
   
android:id="@android:id/background"
   
android:layout_width="match_parent"
   
android:textSize="24sp"
   
android:layout_height="match_parent"
   
android:orientation="vertical">


   
<TextView
       
android:id="@+id/error_title_view"
       
android:layout_width="match_parent"
       
android:textColor="@color/white"
       
android:textFontWeight="800"
       
android:layout_height="wrap_content"
       
android:text="Example Widget Error" />

   
<LinearLayout
       
android:layout_width="match_parent"
       
android:orientation="horizontal"
       
android:paddingTop="4dp"
       
android:layout_height="match_parent">

       
<ImageButton
           
android:layout_width="64dp"
           
android:layout_height="64dp"
           
android:layout_gravity="center"
           
android:tint="@color/white"
           
android:id="@+id/error_icon"
           
android:src="@drawable/heart_broken_fill0_wght400_grad0_opsz24"
       
/>
       
<TextView
           
android:id="@+id/error_text_view"
           
android:layout_width="wrap_content"
           
android:textColor="@color/white"
           
android:layout_height="wrap_content"
           
android:layout_gravity="center"
           
android:padding="8dp"
           
android:textSize="16sp"
           
android:layout_weight="1"
           
android:text="Useful Error Message!" />
   
</LinearLayout>

</LinearLayout>

  1. Переопределить функцию onCompositionError
override fun onCompositionError(
   context
: Context,
   glanceId
: GlanceId,
   
AppWidgetId: Int,
   throwable
: Throwable
) {
   
val rv = RemoteViews(context.packageName, R.layout.error_layout)
   rv
.setTextViewText(
       R
.id.error_text_view,
       
"Error was thrown. \nThis is a custom view \nError Message: `${throwable.message}`"
   
)
   rv
.setOnClickPendingIntent(R.id.error_icon, getErrorIntent(context, throwable))
   
AppWidgetManager.getInstance(context).updateAppWidget(AppWidgetId, rv)
}

  1. Создайте ожидающее намерение, которое ссылается на ваш GlanceAppWidgetReceiver
private fun getErrorIntent(context: Context, throwable: Throwable): PendingIntent {
   
val intent = Intent(context, UpgradeToHelloWorldPro::class.java)
    intent
.setAction("widgetError")
   
return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)
}

  1. Обработайте намерение в своем GlanceAppWidgetReceiver
override fun onReceive(context: Context, intent: Intent) {
   
super.onReceive(context, intent)
   
Log.e("ErrorOnClick", "Button was clicked.");
}

,

Функции API для улучшения обработки ошибок в Glance включены начиная с Android 15. На этой странице представлены некоторые рекомендации по использованию этих API.

Используйте блок try-catch вокруг некомпонуемых компонентов.

Compose не допускает блоков try-catch вокруг компонуемых объектов, но позволяет обернуть в эти блоки другую логику вашего приложения. Это позволит вам использовать Compose для просмотра ошибок, как показано в следующем примере:

provideContent {
       
var isError = false;
       
var data = null
       
try {
           
val repository = (context.applicationContext as MyApplication).myRepository
           data
= repository.loadData()
       
} catch (e: Exception) {
           isError
= true;
           
//handleError
       
}

       
if (isError) {
           
ErrorView()
       
} else {
           
Content(data)
       
}
   
}

Макет ошибок по умолчанию

Если есть неперехваченное исключение или ошибка Compose, Glance отображает макет ошибки по умолчанию:

Сообщение об ошибке, показывающее тип ошибки и рекомендации о том, где ее искать.
Рисунок 1. Схема ошибок Glance 1.0 по умолчанию
Поле с текстом «Невозможно показать контент».
Рис. 2. Схема ошибок Glance 1.1.0 по умолчанию

Glance позволяет разработчикам предоставлять макет XML в качестве запасного варианта в случае сбоя композиции. Это означает, что в коде Compose произошла ошибка. Этот пользовательский интерфейс ошибки также появляется, если в коде вашего приложения есть необнаруженная ошибка.

class UpgradeWidget : GlanceAppWidget(errorUiLayout = R.layout.error_layout)

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

Содержит заголовок и текстовое поле для отображения сообщения об ошибке.
Рисунок 3. Пример пользовательского макета ошибок

Добавьте действия в пользовательский интерфейс ошибок по умолчанию

Начиная с Glance 1.1.0, Glance позволяет переопределить код обработки ошибок по умолчанию. Таким образом, вы можете добавить обратные вызовы действий в случае неперехваченного исключения или ошибки в композиции.

Чтобы использовать эту функцию, переопределите функцию onCompositionError() :

GlanceAppWidget.onCompositionError(
    context
: Context,
    glanceId
: GlanceId,
   
AppWidgetId: Int,
    throwable
: Throwable
)

В этой функции Glance обращается к API RemoteViews для обработки ошибок. Это позволяет вам указывать макеты и обработчики действий с помощью XML.

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

  1. Запишите файл error_layout.xml.
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   
style="@style/Widget.MyApplication.AppWidget.Error"
   
android:id="@android:id/background"
   
android:layout_width="match_parent"
   
android:textSize="24sp"
   
android:layout_height="match_parent"
   
android:orientation="vertical">


   
<TextView
       
android:id="@+id/error_title_view"
       
android:layout_width="match_parent"
       
android:textColor="@color/white"
       
android:textFontWeight="800"
       
android:layout_height="wrap_content"
       
android:text="Example Widget Error" />

   
<LinearLayout
       
android:layout_width="match_parent"
       
android:orientation="horizontal"
       
android:paddingTop="4dp"
       
android:layout_height="match_parent">

       
<ImageButton
           
android:layout_width="64dp"
           
android:layout_height="64dp"
           
android:layout_gravity="center"
           
android:tint="@color/white"
           
android:id="@+id/error_icon"
           
android:src="@drawable/heart_broken_fill0_wght400_grad0_opsz24"
       
/>
       
<TextView
           
android:id="@+id/error_text_view"
           
android:layout_width="wrap_content"
           
android:textColor="@color/white"
           
android:layout_height="wrap_content"
           
android:layout_gravity="center"
           
android:padding="8dp"
           
android:textSize="16sp"
           
android:layout_weight="1"
           
android:text="Useful Error Message!" />
   
</LinearLayout>

</LinearLayout>

  1. Переопределить функцию onCompositionError
override fun onCompositionError(
   context
: Context,
   glanceId
: GlanceId,
   
AppWidgetId: Int,
   throwable
: Throwable
) {
   
val rv = RemoteViews(context.packageName, R.layout.error_layout)
   rv
.setTextViewText(
       R
.id.error_text_view,
       
"Error was thrown. \nThis is a custom view \nError Message: `${throwable.message}`"
   
)
   rv
.setOnClickPendingIntent(R.id.error_icon, getErrorIntent(context, throwable))
   
AppWidgetManager.getInstance(context).updateAppWidget(AppWidgetId, rv)
}

  1. Создайте ожидающее намерение, которое ссылается на ваш GlanceAppWidgetReceiver
private fun getErrorIntent(context: Context, throwable: Throwable): PendingIntent {
   
val intent = Intent(context, UpgradeToHelloWorldPro::class.java)
    intent
.setAction("widgetError")
   
return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)
}

  1. Обработайте намерение в своем GlanceAppWidgetReceiver
override fun onReceive(context: Context, intent: Intent) {
   
super.onReceive(context, intent)
   
Log.e("ErrorOnClick", "Button was clicked.");
}