Android SDK 设置onesignal

日期: 栏目:文章分享 浏览:142 评论:0

有关使用 Android Studio 将 OneSignal Android 移动应用程序 SDK 添加到您的 Android 或 Amazon Kindle Fire 应用程序的说明。

要求

设置

1.添加SDK

打开您的应用程序文件,将以下内容添加到您的部分。build.gradle (Module: app)dependencies

Gradle 构建定义了项目及其任务和依赖项。在这里,我们将 OneSignal SDK 声明为项目的外部依赖项。有关更多详细信息,请查看Gradle 的构建脚本文档

implementation 'com.onesignal:OneSignal:[5.0.0, 5.99.99]'

Android SDK 设置onesignal-第1张图片-Ceacer网络

同步Sync

请确保在保存后弹出的横幅上按“立即同步(Sync Now)”!

2. 初始化

重要的

将以下代码添加到类中的方法中如果您没有应用程序类,请遵循我们的创建应用程序类指南onCreateApplication

SDK 需要一个 Android Context 来监听应用程序的前台更改。Activity 也是一个 Context,因此 SDK 可以利用它,但是如果您仅在其中初始化 OneSignal,则可能无法覆盖应用程序的所有入口点。此外,还有一些边缘情况,例如应用程序冷启动但恢复到特定的活动,在该活动中它不会触发您的这就是为什么我们建议遵循创建应用程序类指南MainActivityonCreateMainActivity

您可以在仪表板 设置 >密钥和 ID中找到ONESIGNAL_APP_ID

Kotlin

import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch

import com.onesignal.OneSignal
import com.onesignal.debug.LogLevel

// NOTE: Replace the below with your own ONESIGNAL_APP_ID
const val ONESIGNAL_APP_ID = "########-####-####-####-############"
  
class ApplicationClass : Application() {
   override fun onCreate() {
      super.onCreate()
        
      // Verbose Logging set to help debug issues, remove before releasing your app.
      OneSignal.Debug.logLevel = LogLevel.VERBOSE

      // OneSignal Initialization
      OneSignal.initWithContext(this, ONESIGNAL_APP_ID)

      // requestPermission will show the native Android notification permission prompt.
      // NOTE: It's recommended to use a OneSignal In-App Message to prompt instead.
      CoroutineScope(Dispatchers.IO).launch {
         OneSignal.Notifications.requestPermission(true)
      }
   }
}


java

import com.onesignal.OneSignal;
import com.onesignal.debug.LogLevel;
import com.onesignal.Continue;

public class ApplicationClass extends Application {
  
    // NOTE: Replace the below with your own ONESIGNAL_APP_ID
    private static final String ONESIGNAL_APP_ID = "########-####-####-####-############";
  
    @Override
    public void onCreate() {
        super.onCreate();
        
        // Verbose Logging set to help debug issues, remove before releasing your app.
        OneSignal.getDebug().setLogLevel(LogLevel.VERBOSE);
        
        // OneSignal Initialization
        OneSignal.initWithContext(this, ONESIGNAL_APP_ID);
      
        // requestPermission will show the native Android notification permission prompt.
        // NOTE: It's recommended to use a OneSignal In-App Message to prompt instead.
        OneSignal.getNotifications().requestPermission(true, Continue.with(r -> {
            if (r.isSuccess()) {
              if (r.getData()) {
                // `requestPermission` completed successfully and the user has accepted permission
              }
              else {
                // `requestPermission` completed successfully but the user has rejected permission
              }
            }
            else {
              // `requestPermission` completed unsuccessfully, check `r.getThrowable()` for more info on the failure reason
            }
        }));
    }
}


评论留言

我要留言

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。发布前请先查看评论规则:点我查看