Примеры использования методов
- Инициализация библиотеки с расширенной конфигурацией
- Отправка статистики на дополнительный API key
- Отправка местоположения устройства библиотекой
- Установка местоположения вручную
- Отправка собственного события
- Отправка собственного события с вложенными параметрами
- Отправка собственного сообщения об ошибке
- Отправка событий из буфера
- Отслеживание жизненного цикла приложения вручную
- Отслеживание аварийных остановок приложения
- Отслеживание аварийных остановок приложения вручную
- Отправка ProfileId
- Отправка атрибутов профиля
- Отправка ECommerce-событий
- Отправка In-App покупок
- Отправка Ad Revenue
- Отслеживание открытий приложения с помощью deeplink
- Установка длительности тайм-аута сессии
- Установка версии приложения
- Определение уровня API библиотеки (Android)
- Определение версии библиотеки
- Запрос отложенного deeplink
- Запрос параметров отложенного deeplink
- Учет новых пользователей
- Отключение и включение отправки статистики
- Получение различных идентификаторов AppMetrica SDK
Инициализация библиотеки с расширенной конфигурацией
Чтобы инициализировать библиотеку с расширенной стартовой конфигурацией, передайте объект типа AppMetricaConfig
с необходимыми настройками и активируйте библиотеку с помощью метода AppMetrica.activate(AppMetricaConfig config)
. С помощью расширенной конфигурации можно, например, включить или отключить логирование, установить тайм-аут сессии, передать параметры для отслеживания предустановленных приложений.
Настройки расширенной конфигурации применяются с момента инициализации библиотеки.
AppMetrica.activate(
AppMetricaConfig(API_KEY, logs: true
// ...
));
Отправка статистики на дополнительный API key
Отправка данных на дополнительный API key позволяет собирать для каждого API key свою статистику. Это можно использовать для управления доступом к информации. Например, чтобы предоставить доступ к статистике для аналитиков, можно продублировать отправку маркетинговых данных на дополнительный API key и предоставить им доступ к этой статистике. Так у них будет доступ только к той информации, которая им необходима.
Для отправки данных на дополнительный API key необходимо использовать репортеры. С помощью них можно отправлять события, сообщения об ошибках, профили и информацию о покупках в приложении. Репортеры могут работать без инициализации AppMetrica SDK.
Шаг 1. (Опционально) Инициализируйте репортер с расширенной конфигурацией
Чтобы инициализировать репортер с расширенной конфигурацией, создайте объект класса AppMetricaReporterConfig
с необходимыми настройками и активируйте репортер с помощью метода AppMetrica.activateReporter(AppMetricaReporterConfig reporterConfig)
. Конфигурация применяется для репортера с указанным API key. Для каждого дополнительного API key можно настроить свою конфигурацию.
Внимание
Инициализацию репортера с расширенной конфигурацией необходимо проводить до первого обращения к репортеру. Иначе репортер будет инициализирован без конфигурации.
// Creating extended configuration of the reporter.
// To create it, pass a ANOTHER_API_KEY that is different from the app's API_KEY.
AppMetricaReporterConfig reporterConfig = AppMetricaReporterConfig("ANOTHER_API_KEY",
// Setting up the configuration. For example, to enable logging.
logs: true);
// Initializing a reporter.
AppMetrica.activateReporter(reporterConfig);
Шаг 2. Настройте отправку данных с помощью репортера
Для отправки данных с помощью репортера, необходимо получить объект, который реализует абстрактный класс AppMetricaReporter
с помощью метода AppMetrica.getReporter(String apiKey)
, и использовать методы интерфейса для отправки отчетов. Если репортер не был инициализирован с расширенной конфигурацией, то вызов данного метода произведет инициализацию репортера для указанного API key.
Пример отправки события:
AppMetrica.getReporter("ANOTHER_API_KEY").reportEvent("Updates installed");
Для корректного отслеживания сессий взаимодействия пользователя с приложением настройте отправку событий о начале и приостановке сессии для каждого репортера. Для этого используйте методы resumeSession()
и pauseSession()
:
AppMetricaReporter reporter = AppMetrica.getReporter("ANOTHER_API_KEY");
reporter.resumeSession();
reporter.reportEvent("Updates installed");
reporter.pauseSession();
Отправка местоположения устройства библиотекой
Для Android отправка местоположения устройства по умолчанию отключена. Чтобы включить отправку, инициализируйте библиотеку с конфигурацией, в которой отправка информации о местоположении устройства включена. Для этого при создании расширенной конфигурации библиотеки укажите свойство locationTracking
равным true
:
AppMetrica.activate(AppMetricaConfig(API_KEY,
locationTracking: true));
Чтобы включить отправку в процессе работы приложения, используйте метод AppMetrica.setLocationTracking(bool enabled)
:
AppMetrica.setLocationTracking(true);
Для более точного определения местоположения добавьте в файл AndroidManifest.xml одно из следующих разрешений:
android.permission.ACCESS_COARSE_LOCATION
— для приблизительного определения;android.permission.ACCESS_FINE_LOCATION
— для точного определения.
Установка местоположения вручную
Перед отправкой собственной информации о местоположении устройства убедитесь, что отправка отчетов включена.
Библиотека определяет местоположение устройства самостоятельно. Чтобы отправить собственную информацию о местоположении устройства, передайте AppMetricaLocation
в метод AppMetrica.setLocation(AppMetricaLocation? location)
:
// Determining the location.
AppMetricaLocation location = AppMetricaLocation(latitude, longitude);
// Setting your own location information of the device.
AppMetrica.setLocation(location);
Чтобы отправить собственную информацию о местоположении устройства с помощью расширенной конфигурации, при создании расширенной конфигурации библиотеки передайте объект типа AppMetricaLocation
в свойство location
:
AppMetricaLocation location = AppMetricaLocation(latitude, longitude);
AppMetrica.activate(AppMetricaConfig(API_KEY,
location: location));
Отправка собственного события
Чтобы отправить собственное событие без вложенных параметров, передайте короткое название или описание события в метод AppMetrica.reportEvent(String eventName)
:
AppMetrica.reportEvent("eventName");
Отправка собственного события с вложенными параметрами
Чтобы передать параметры в формате JSON:
String jsonAttributes = '{"item":"book","price":9.99}';
AppMetrica.reportEventWithJson("Purchase", jsonAttributes);
Чтобы передать параметры в формате Map:
Map<String, dynamic> attributesMap = {"item": "book", "price": 9.99};
AppMetrica.reportEventWithMap("Purchase", attributesMap);
Отправка собственного сообщения об ошибке
Чтобы отправить собственное сообщение об ошибке, используйте метод:
AppMetrica.reportError(
message: "Error occurred",
errorDescription: AppMetricaErrorDescription(StackTrace.current),
);
Для отправки сообщения об ошибке с идентификатором группы:
AppMetrica.reportErrorWithGroup(
"IDENTIFIER",
message: "MESSAGE",
errorDescription: AppMetricaErrorDescription(StackTrace.current),
);
Отправка событий из буфера
AppMetrica SDK не отправляет событие сразу после того, как оно произошло. Библиотека хранит данные о событиях в буфере. Метод sendEventsBuffer
отправляет данные из буфера и очищает его. Используйте этот метод для принудительной отправки сохраненных событий после прохождения важных сценариев пользователя.
AppMetrica.sendEventsBuffer();
Частое использование метода может привести к повышению энергопотребления и расходу интернет-трафика.
Отслеживание жизненного цикла приложения вручную
AppMetrica отслеживает границы сессии автоматически. При необходимости можно отключить автоматический трекинг сессий, передавая false
в свойство sessionsAutoTrackingEnabled
в расширенной конфигурации библиотеки.
AppMetrica.activate(
AppMetricaConfig(API_KEY, sessionsAutoTrackingEnabled: false));
Для отслеживания жизненного цикла вручную используйте методы:
-
Приостановка сессии:
AppMetrica.pauseSession();
-
Возобновление или начало новой сессии:
AppMetrica.resumeSession();
Отслеживание аварийных остановок приложения
Отчеты об аварийных остановках приложения отправляются по умолчанию.
Чтобы отключить автоматическое отслеживание, инициализируйте библиотеку с конфигурацией, в которой отправка информации об аварийных остановках приложения отключена. Для этого передайте значение false
в свойства crashReporting
и flutterCrashReporting
при создании расширенной конфигурации.
AppMetrica.activate(AppMetricaConfig("daa46e63-d4a6-46d1-bbf9-0dcf4b482b83",
// Disabling the data sending about the native android/ios crashes.
crashReporting: false,
// Disabling the data sending about the Flutter crashes.
flutterCrashReporting: false));
Отслеживание аварийных остановок приложения вручную
Отчеты об аварийных остановках приложения отправляются по умолчанию. Чтобы избежать дублирования событий при ручной отправке, необходимо отключить автоматическое отслеживание аварийных остановок.
Чтобы отправлять информацию об аварийных остановках приложения вручную, используйте метод AppMetrica.reportUnhandledException(AppMetricaErrorDescription errorDescription)
:
AppMetrica.reportUnhandledException(
AppMetricaErrorDescription.fromCurrentStackTrace(
message: 'Error message', type: 'Error type'),
);
Отправка ProfileId
Если идентификатор пользовательского профиля известен до инициализации AppMetrica SDK, передавайте его до инициализации (setUserProfileID
) или во время инициализации с расширенной конфигурацией (withUserProfileID
).
В противном случае будет создан технический профиль с идентификатором appmetrica_device_id
.
В любой момент можно обновить ProfileId
с помощью вызова setUserProfileID
:
AppMetrica.setUserProfileID("id");
Отправка атрибутов профиля
Чтобы отправить атрибуты профиля, передайте в метод AppMetrica.reportUserProfile(UserProfile)
объект класса UserProfile
.
AppMetricaUserProfile userProfile = AppMetricaUserProfile([
// Updating predefined attributes.
AppMetricaNameAttribute.withValue("John"),
AppMetricaGenderAttribute.withValue(AppMetricaGender.male),
AppMetricaBirthDateAttribute.withAge(24),
AppMetricaNotificationEnabledAttribute.withValue(false),
// Updating custom attributes.
AppMetricaStringAttribute.withValue("string_attribute", "string"),
AppMetricaNumberAttribute.withValue("number_attribute", 55),
AppMetricaCounterAttribute.withDelta("counter_attribute", 1)
]);
// Setting the ProfileID using the method of the YandexMetrica class.
AppMetrica.setUserProfileID("id");
// Sending the UserProfile instance.
AppMetrica.reportUserProfile(userProfile);
Отправка ECommerce-событий
В AppMetrica нет возможности сегментировать ECommerce-события на «тестовые» и «не тестовые». Если для отладки покупок вы используете основной API key, то тестовые события будут попадать в общую статистику. Поэтому чтобы отладить отправку ECommerce-событий, используйте отправку статистики на дополнительный API key с помощью репортера.
Шаг 1. Создайте тестовое приложение в AppMetrica
Заполните параметры приложения: ссылка в магазине приложений (если приложение еще не опубликовано — оставьте поле пустым), название, категория, часовой пояс для построения отчетов.
Чтобы добавить еще одно приложение, нажмите кнопку Добавить приложение в выпадающем списке в интерфейсе AppMetrica.
Шаг 2. Настройте отправку ECommerce-событий на тестовый API key
Для различных действий пользователя есть соответствующие типы ECommerce-событий. Чтобы создать конкретный тип события, используйте нужный метод класса AppMetricaECommerce.
Ниже приведены примеры отправки конкретных типов событий.
Открытие страницы
Map<String, String> payload = {
"configuration": "landscape",
"full_screen": "true",
};
// Creating a screen object.
AppMetricaECommerceScreen screen = AppMetricaECommerceScreen(
name: "ProductCardActivity", // Optional.
searchQuery: "даниссимо кленовый сироп", // Optional.
payload: payload, // Optional.
categoriesPath: ["Акции", "Красная цена"] // Optional.
);
AppMetricaECommerceEvent showScreenEvent = AppMetricaECommerce.showScreenEvent(screen);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key").reportECommerce(showScreenEvent);
Просмотр карточки товара
Map<String, String> payload = {
"configuration": "landscape",
"full_screen": "true"
};
// Creating a screen object.
AppMetricaECommerceScreen screen = AppMetricaECommerceScreen(
name: "ProductCardActivity", // Optional.
searchQuery: "даниссимо кленовый сироп", // Optional.
payload: payload, // Optional.
categoriesPath: ["Акции", "Красная цена"] // Optional.
);
AppMetricaECommerceAmount amount =
AppMetricaECommerceAmount(amount: Decimal.parse('4.53'), currency: "USD");
// Creating an actualPrice object.
AppMetricaECommercePrice actualPrice =
AppMetricaECommercePrice(fiat: amount, internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30_570_000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating an originalPrice object.
AppMetricaECommercePrice originalPrice = AppMetricaECommercePrice(
fiat: AppMetricaECommerceAmount(amount: Decimal.parse('5.78'), currency: "USD"),
internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating a product object.
AppMetricaECommerceProduct product = AppMetricaECommerceProduct(
sku: "779213",
name: "Продукт творожный «Даниссимо» 5.9%, 130 г.", // Optional.
actualPrice: actualPrice, // Optional.
originalPrice: originalPrice, // Optional.
promocodes: ["BT79IYX", "UT5412EP"], // Optional.
payload: payload, // Optional.
categoriesPath: [
"Продукты",
"Молочные продукты",
"Йогурты"
] // Optional.
);
AppMetricaECommerceEvent showProductCardEvent =
AppMetricaECommerce.showProductCardEvent(product, screen);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key")
.reportECommerce(showProductCardEvent);
Просмотр страницы товара
Map<String, String> payload = {
"configuration": "landscape",
"full_screen": "true"
};
// Creating a screen object.
AppMetricaECommerceScreen screen = AppMetricaECommerceScreen(
name: "ProductCardActivity", // Optional.
searchQuery: "даниссимо кленовый сироп", // Optional.
payload: payload, // Optional.
categoriesPath: ["Акции", "Красная цена"] // Optional.
);
AppMetricaECommerceAmount amount =
AppMetricaECommerceAmount(amount: Decimal.parse('4.53'), currency: "USD");
// Creating an actualPrice object.
AppMetricaECommercePrice actualPrice =
AppMetricaECommercePrice(fiat: amount, internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30_570_000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating an originalPrice object.
AppMetricaECommercePrice originalPrice = AppMetricaECommercePrice(
fiat: AppMetricaECommerceAmount(amount: Decimal.parse('5.78'), currency: "USD"),
internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating a product object.
AppMetricaECommerceProduct product = AppMetricaECommerceProduct(
sku: "779213",
name: "Продукт творожный «Даниссимо» 5.9%, 130 г.", // Optional.
actualPrice: actualPrice, // Optional.
originalPrice: originalPrice, // Optional.
promocodes: ["BT79IYX", "UT5412EP"], // Optional.
payload: payload, // Optional.
categoriesPath: [
"Продукты",
"Молочные продукты",
"Йогурты"
] // Optional.
);
AppMetricaECommerceEvent showProductDetailsEvent =
AppMetricaECommerce.showProductDetailsEvent(product, screen);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key")
.reportECommerce(showProductDetailsEvent);
Добавление или удаление товара из корзины
Map<String, String> payload = {
"configuration": "landscape",
"full_screen": "true"
};
// Creating a screen object.
AppMetricaECommerceScreen screen = AppMetricaECommerceScreen(
name: "ProductCardActivity", // Optional.
searchQuery: "даниссимо кленовый сироп", // Optional.
payload: payload, // Optional.
categoriesPath: ["Акции", "Красная цена"] // Optional.
);
AppMetricaECommerceAmount amount =
AppMetricaECommerceAmount(amount: Decimal.parse('4.53'), currency: "USD");
// Creating an actualPrice object.
AppMetricaECommercePrice actualPrice =
AppMetricaECommercePrice(fiat: amount, internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating an originalPrice object.
AppMetricaECommercePrice originalPrice = AppMetricaECommercePrice(
fiat: AppMetricaECommerceAmount(amount: Decimal.parse('5.78'), currency: "USD"),
internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating a product object.
AppMetricaECommerceProduct product = AppMetricaECommerceProduct(
sku: "779213",
name: "Продукт творожный «Даниссимо» 5.9%, 130 г.", // Optional.
actualPrice: actualPrice, // Optional.
originalPrice: originalPrice, // Optional.
promocodes: ["BT79IYX", "UT5412EP"], // Optional.
payload: payload, // Optional.
categoriesPath: [
"Продукты",
"Молочные продукты",
"Йогурты"
] // Optional.
);
AppMetricaECommerceReferrer referrer = AppMetricaECommerceReferrer(
type: "button", // Optional.
identifier: "76890", // Optional.
screen: screen // Optional.
);
// Creating a cartItem object.
AppMetricaECommerceCartItem addedItems1 = AppMetricaECommerceCartItem(
product: product,
revenue: actualPrice,
quantity: Decimal.parse("1.0"),
referrer: referrer // Optional.
);
AppMetricaECommerceEvent addCartItemEvent = AppMetricaECommerce.addCartItemEvent(addedItems1);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key").reportECommerce(addCartItemEvent);
AppMetricaECommerceEvent removeCartItemEvent =
AppMetricaECommerce.removeCartItemEvent(addedItems1);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key")
.reportECommerce(removeCartItemEvent);
Начало оформления и завершение покупки
Map<String, String> payload = {
"configuration": "landscape",
"full_screen": "true"
};
// Creating a screen object.
AppMetricaECommerceScreen screen = AppMetricaECommerceScreen(
name: "ProductCardActivity", // Optional.
searchQuery: "даниссимо кленовый сироп", // Optional.
payload: payload, // Optional.
categoriesPath: ["Акции", "Красная цена"] // Optional.
);
AppMetricaECommerceAmount amount =
AppMetricaECommerceAmount(amount: Decimal.parse('4.53'), currency: "USD");
// Creating an actualPrice object.
AppMetricaECommercePrice actualPrice =
AppMetricaECommercePrice(fiat: amount, internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating an originalPrice object.
AppMetricaECommercePrice originalPrice = AppMetricaECommercePrice(
fiat: AppMetricaECommerceAmount(amount: Decimal.parse('5.78'), currency: "USD"),
internalComponents: [
// Optional.
AppMetricaECommerceAmount(amount: Decimal.parse('30570000'), currency: "wood"),
AppMetricaECommerceAmount(amount: Decimal.parse('26.89'), currency: "iron"),
AppMetricaECommerceAmount(amount: Decimal.parse('5.1'), currency: "gold"),
]);
// Creating a product object.
AppMetricaECommerceProduct product = AppMetricaECommerceProduct(
sku: "779213",
name: "Продукт творожный «Даниссимо» 5.9%, 130 г.", // Optional.
actualPrice: actualPrice, // Optional.
originalPrice: originalPrice, // Optional.
promocodes: ["BT79IYX", "UT5412EP"], // Optional.
payload: payload, // Optional.
categoriesPath: [
"Продукты",
"Молочные продукты",
"Йогурты"
] // Optional.
);
AppMetricaECommerceReferrer referrer = AppMetricaECommerceReferrer(
type: "button", // Optional.
identifier: "76890", // Optional.
screen: screen // Optional.
);
// Creating a cartItem object.
AppMetricaECommerceCartItem addedItems1 = AppMetricaECommerceCartItem(
product: product,
revenue: actualPrice,
quantity: Decimal.parse("1.0"),
referrer: referrer // Optional.
);
// Creating an order object.
AppMetricaECommerceOrder order = AppMetricaECommerceOrder(
identifier: "88528768",
items: [addedItems1],
payload: payload // Optional.
);
AppMetricaECommerceEvent beginCheckoutEvent = AppMetricaECommerce.beginCheckoutEvent(order);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key")
.reportECommerce(beginCheckoutEvent);
AppMetricaECommerceEvent purchaseEvent = AppMetricaECommerce.purchaseEvent(order);
// Sending an e-commerce event.
AppMetrica.getReporter("Testing API key").reportECommerce(purchaseEvent);
Шаг 3. Проверьте отчет тестового приложения
Совершите тестовые покупки в приложении. Через некоторое время в интерфейсе AppMetrica проверьте отчет «Ecommerce». Убедитесь, что ECommerce-события отображаются в отчете. Подробнее об отчете в разделе Ecommerce.
Шаг 4. Настройте отправку ECommerce на основной API Key
После успешного тестирования настройте отправку ECommerce-событий на основной API key.
Чтобы отправить объект AppMetricaECommerceEvent
на основной API key, используйте метод AppMetrica.reportECommerce(AppMetricaECommerceEvent event)
:
...
// Sending an e-commerce event.
AppMetrica.reportECommerce(ecommerceEvent);
Отправка In-App покупок
С валидацией
Чтобы покупки Android валидировались, настройте отправку объекта Revenue.Receipt
вместе с Revenue, а для iOS настройте отправку поля transactionID
.
- Создайте объект
AppMetricaReceipt
с информацией о покупке и подписью. - Создайте объект
AppMetricaRevenue
и передайте в негоAppMetricaReceipt
иtransactionID
. - Отправьте объект
AppMetricaRevenue
с помощью методаAppMetrica.reportRevenue(AppMetricaRevenue revenue)
.
AppMetricaReceipt receipt = AppMetricaReceipt(
data: billingClientPurchase.originalJson,
signature: billingClientPurchase.signature);
AppMetricaRevenue revenue = AppMetricaRevenue(
Decimal.parse("100.100"),
"USD",
quantity: 2,
productId: "com.yandex.service.299",
payload: "{\"source\":\"Google Play\"}",
receipt: receipt,
transactionId: transactionIdentifier);
AppMetrica.reportRevenue(revenue);
Без валидации
-
Создайте объект
AppMetricaRevenue
. -
(Опционально) Чтобы группировать покупки по
OrderID
, передайте его в свойствоpayload
.
Примечание
Если идентификатор OrderID
не указан, AppMetrica генерирует идентификатор автоматически.
- Отправьте объект
AppMetricaRevenue
с помощью методаAppMetrica.reportRevenue(AppMetricaRevenue revenue)
.
AppMetricaRevenue revenue = AppMetricaRevenue(Decimal.parse("100.100"), "USD",
quantity: 2,
productId: "com.yandex.service.299",
payload: """{"OrderID":"Identifier", "source":"Google Play"}""");
AppMetrica.reportRevenue(revenue);
Отправка Ad Revenue
В AppMetrica можно передавать данные о выручке от показов рекламы (Ad Revenue).
Шаг 1. Убедитесь, что SDK активирован
Пример активации:
AppMetricaConfig config = AppMetricaConfig("API_KEY");
AppMetrica.activate(config);
Шаг 2. Настройте отправку Ad Revenue
-
Создайте объект класса
AppMetricaAdRevenue
.Map<String, String> adRevenuePayload = { "payload_key_1": "payload_value_1", "payload_key_2": "payload_value_2" }; AppMetricaAdRevenue adRevenue = AppMetricaAdRevenue( adRevenue: Decimal.parse("100.100"), currency: "USD", adNetwork: "ad_network", // Optional adPlacementId: "ad_placement_id", // Optional adPlacementName: "ad_placement_name", // Optional adType: AdType.NATIVE, // Optional adUnitId: "ad_unit_id", // Optional adUnitName: "ad_unit_name", // Optional precision: "some precision", // Optional payload: adRevenuePayload // Optional );
-
Отправьте объект
AppMetricaAdRevenue
используя методreportAdRevenue(AppMetricaAdRevenue adRevenue)
.AppMetrica.reportAdRevenue(adRevenue);
Шаг 3. Убедитесь, что Ad Revenue отображается в отчетах
-
Совершите просмотры рекламы в приложении.
-
Убедитесь, что в отчете In-app и Ad Revenue количество событий Ad Revenue соответствует количеству просмотров рекламы.
Отслеживание открытий приложения с помощью deeplink
Отслеживание открытий осуществляется с помощью метода reportAppOpen(String deeplink)
:
AppMetrica.reportAppOpen(deeplink);
Установка длительности тайм-аута сессии
По умолчанию длительность тайм-аута сессии равна 10 секундам. Это минимально допустимое значение параметра sessionTimeout
.
Чтобы изменить длительность тайм-аута, передайте значение в секундах в свойство sessionTimeout
при создании расширенной конфигурации библиотеки.
AppMetrica.activate(
AppMetricaConfig(API_KEY, sessionTimeout: 15));
Установка версии приложения
Чтобы вручную указать версию приложения из кода, передайте версию приложения в свойство appVersion
при создании расширенной конфигурации библиотеки.
AppMetrica.activate(
AppMetricaConfig(API_KEY, appVersion: "1.13.2"));
где 1.13.2
— версия приложения.
Определение уровня API библиотеки (Android)
Чтобы определить уровень API библиотеки из кода приложения, используйте свойство libraryApiLevel
.
int apiLevel;
AppMetrica.libraryApiLevel.then((value) => {apiLevel = value});
Определение версии библиотеки
Чтобы определить версию библиотеки из кода приложения, используйте метод AppMetrica.GetLibraryVersion()
.
String version;
AppMetrica.libraryVersion.then((value) => {version = value});
Запрос отложенного deeplink
Чтобы запросить отложенный deeplink, вызывайте метод AppMetrica.requestDeferredDeeplink()
. Отложенный deeplink можно запросить только при первом запуске приложения после получения Google Play Install Referrer.
AppMetrica.requestDeferredDeeplink()
.then((value) => {
// Processing deferred deeplink.
})
.onError((error, stackTrace) => {
// Handling the error.
});
Подробнее об отложенных deeplinks в разделе Поддержка отложенных deeplinks.
Запрос параметров отложенного deeplink
Чтобы запросить параметры отложенного deeplink, вызовите метод AppMetrica.requestDeferredDeeplinkParameters()
. Параметры отложенного deeplink можно запросить только при первом запуске приложения после получения Google Play Install Referrer.
AppMetrica.requestDeferredDeeplinkParameters()
.then((value) => {
// Processing deeplink parameters.
})
.onError((error, stackTrace) => {
// Handling the error.
});
Подробнее об отложенных deeplinks в разделе Поддержка отложенных deeplinks.
Учет новых пользователей
По умолчанию в момент первого запуска приложения все пользователи определяются как новые. Если AppMetrica SDK подключается к приложению, у которого уже есть активные пользователи, то для корректного отслеживания статистики можно настроить учет новых и старых пользователей. Для этого необходимо инициализировать AppMetrica SDK, используя расширенную стартовую конфигурацию AppMetricaConfig
:
bool isFirstLaunch = false;
// Implement logic to detect whether the app is opening for the first time.
// For example, you can check for files (settings, databases, and so on),
// which the app creates on its first launch.
if (conditions) {
isFirstLaunch = true;
}
// Activating SDK with extended library configuration.
AppMetrica.activate(
AppMetricaConfig(API_KEY, firstActivationAsUpdate: !isFirstLaunch));
Отключение и включение отправки статистики
Если для отправки статистических данных требуется согласие пользователя, необходимо инициализировать библиотеку с отключенной опцией отправки статистики. Для этого передайте значение false
в свойство dataSendingEnabled
при создании расширенной конфигурации библиотеки.
AppMetrica.activate(
AppMetricaConfig(API_KEY, dataSendingEnabled: false));
После того как пользователь дал согласие на отправку статистики (например, в настройках приложения или в соглашении при первом открытии), включите отправку статистики с помощью метода AppMetrica.setDataSendingEnabled(bool enabled)
:
// Checking the status of the boolean variable. It shows the user confirmation.
if (flag) {
// Enabling sending data.
AppMetrica.setDataSendingEnabled(true);
}
Пример оповещения
Для информирования пользователей вы можете использовать любой текст. Например:
Это приложение использует сервис аналитики AppMetrica, предоставляемый компанией ООО «ЯНДЕКС», 119021, Россия,Москва, ул. Л. Толстого, 16 (далее — Яндекс) на Условиях использования сервиса.
AppMetrica анализирует данные об использовании приложения, в том числе об устройстве, на котором оно функционирует, источнике установки, составляет конверсию и статистику вашей активности в целях продуктовой аналитики, анализа и оптимизации рекламных кампаний, а также для устранения ошибок. Собранная таким образом информация не может идентифицировать вас.
Информация об использовании вами данного приложения, собранная при помощи инструментов AppMetrica, в обезличенном виде будет передаваться Яндексу и храниться на сервере Яндекса в ЕС и Российской Федерации. Яндекс будет обрабатывать эту информацию для предоставления статистики использования вами приложения, составления для нас отчетов о работе приложения и предоставления других услуг.
Получение различных идентификаторов AppMetrica SDK
Чтобы получить различные идентификаторы AppMetrica SDK (DeviceId
, DeviceIdHash
, UUID
) используйте метод requestStartupParams()
. Для получения appmetrica_device_id
нужно запрашивать DeviceIdHash
.
Future<AppMetricaStartupParams> params = AppMetrica.requestStartupParams([
AppMetricaStartupParams.deviceIdHashKey,
AppMetricaStartupParams.deviceIdKey,
AppMetricaStartupParams.uuidKey
]);
params.then((value) => {
print(value.result?.deviceIdHash),
print(value.result?.deviceId),
print(value.result?.uuid)
});
Если вы не нашли ответ на свой вопрос, то вы можете задать его через форму обратной связи. Пожалуйста, опишите возникшую проблему как можно подробнее. Если возможно, приложите скриншот.