Introduction
...
Info | |||||||
---|---|---|---|---|---|---|---|
| |||||||
If you choose to use Google Play Services, you need to know the following :
|
...
If prompted with an error, add this "Import" command to enable Appoxee SDK usage:
Code Block language java linenumbers true import com.appoxee.Appoxee;
AndroidManifest.xml Updates - Make the following changes to your app's AndroidManifest.xml file:
GCM requires Android 2.2 or later. If your app cannot work without GCM, add the following line, where "xx" is the latest target SDK version:
sdkCode Block language xml linenumbers true <uses-
sdk android:minSdkVersion="8"
android:targetSdkVersion="xx"
/>
Note If your application is intended for android version 4.1 or above (that is, minSdkVersion 16), the next step (2.b.) is not required.
In this case, please skip the next step and proceed to step 2.c.Declare and use a custom permission, so only this application can receive GCM messages:
<permissionCode Block language xml linenumbers true <permission android:name="com.appoxee.example.permission.C2D_MESSAGE" android:protectionLevel="signature"
/>
permission<uses-
permission android:name="com.appoxee.example.permission.C2D_MESSAGE"
/>
Note You must replace "com.appoxee.example" with your app's package name, as defined by the manifest tag, otherwise it will not work.
To allow your app to use Google's Push Notification Service (GCM), add the following permissions:
Code Block language xml linenumbers true <!-- This app has permission to register and receive message -->
<!-- App receives GCM messages. -->
permission<uses-
/>permission android:name="com.google.android.c2dm.permission.RECEIVE"
/> <!-- GCM connects to Google Services. -->
<uses-permission
android:name="android.permission.INTERNET"
/>
<!-- GCM requires a Google account. -->
permission<uses-
permission android:name="android.permission.GET_ACCOUNTS"
/>
<!-- Keeps the processor from sleeping when a message is received. -->
<uses-permission
android:name="android.permission.WAKE_LOCK"
/>
In the manifest file's Application element, make sure your app has the name it has in your class file:
<applicationCode Block language xml linenumbers true <application android:label="@string/app_name"
android:icon="@drawable/ic_launcher"
android:allowClearUserData="true"
android:enabled="true"
>android:name="MyApplication"/
>
The class that extends "Application" that is the name that needs to be in the "MyApplication".Example:If the package name is "com.david.coolapps" and the class that extends Application is named "MyApp"
then in the Application tag the "name" value is : "com.david.coolapps.MyApp" .
<application
android:name="com.david.coolapps.MyApp"
..... >Add the following child element to your Application element (remember you must replace "com.appoxee.example" with your app's package name, as defined by the manifest tag):
Code Block language xml linenumbers true <service
android:name="com.appoxee.gcm.GCMIntentService"/>
<receiver<receiver android:name="com.appoxee.gcm.GCMBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND">
<!-- Receive the actual message -->
<intent-filter>
<action
android:name="com.google.android.c2dm.intent.RECEIVE"
/>
<category<category android:name="com.appoxee.example"
/>
</intent-filter>
<!-- Receive the registration id -->
<intent-filter>
<action
android:name="com.google.android.c2dm.intent.REGISTRATION"
/>
<category
android:name="com.appoxee.example"
/>
</intent-filter>
receiver></
> <activityreceiver> <!-- Must have for Push Support by Appoxee --
> <activity android:name
="com.appoxee.InboxMessage"/>
Note If you are using Appoxee's SDK as a "Push Only" solution (without using the Inbox that enables Rich Messages), this completes the integration procedure within the AndroidManifest.xml file.
Please continue to step 5 to complete the rest of the integration by adding your java codeTo enable Appoxee's in-app inbox, and other advanced features, add the following code inside your Application element:
<activityCode Block language xml linenumbers true <activity android:name="com.appoxee.activities.Inbox"/>
<activity<activity android:name="com.appoxee.activities.MoreApps"/>
<activity
><activity android:name="com.appoxee.activities.Feedback"/
> <!-- Add if missing from Push Integration -->
<activity<activity android:name
="com.appoxee.activities.InboxMessage"/>
Note The Inbox feature guarantees your ability to engage the user with rich messages (note that the Inbox cannot be disabled by users, as opposed to Push Notifications) and gives you the option to access features such as Feedback and More Apps . The Inbox must be used in your application's code in order to show it and utilize its features. The InboxMessage activity needs to be added in order to support Push Notifications by Appoxee. Check your Manifest.xml and see that it is added below the Receiver declaration.
This is the AndroidManifest.xml Code Block for GCM :Code Block language xml title AndroidManifest.xml - GCM Integration linenumbers true <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.appoxee.example" android:versionCode="25" android:versionName="2.2" > <uses-sdk android:minSdkVersion="8" android:targetSdkVersion="23" /> <!-- REQUIRED --> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.VIBRATE" /> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <!-- REQUIRED for C2DM --> <!-- Only this application can receive the messages and registration result --> <permission android:name="com.appoxee.example.permission.C2D_MESSAGE" android:protectionLevel="signature" /> <uses-permission android:name="com.appoxee.example.permission.C2D_MESSAGE" /> <!-- This app has permission to register and receive message --> <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> <uses-permission android:name="android.permission.GET_ACCOUNTS" /> <uses-permission android:name="android.permission.WAKE_LOCK" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <application android:name="com.appoxee.example.AppoxeeExample" android:allowBackup="true" android:allowClearUserData="true" android:enabled="true" android:hardwareAccelerated="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:launchMode="singleTask" > <activity android:name="com.appoxee.example.AppoxeeExampleActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <!-- REQUIRED for C2DM --> <service android:name="com.appoxee.gcm.GCMIntentService"> </service> <receiver android:name="com.appoxee.gcm.GCMBroadcastReceiver" android:permission="com.google.android.c2dm.permission.SEND" > <!-- Receive the actual message --> <intent-filter> <action android:name="com.google.android.c2dm.intent.RECEIVE" /> <category android:name="com.appoxee.example" /> </intent-filter> <!-- Receive the registration id --> <intent-filter> <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> <category android:name="com.appoxee.example" /> </intent-filter> </receiver> <!-- OPTIONAL, if you want to receive push, push opened and registration completed intents --> <activity android:name="com.appoxee.activities.Inbox" > </activity> <activity android:name="com.appoxee.activities.SplashScreen" > </activity> <activity android:name="com.appoxee.activities.MoreApps" > </activity> <activity android:name="com.appoxee.activities.Feedback" > </activity> <activity android:name="com.appoxee.activities.InboxMessage" > </activity> </application> </manifest>
This is the AndroidManifest.xml Code Block for Google Play Services :Code Block theme Eclipse language xml title AndroidManifest - PlayServices Integration linenumbers true <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.appoxee.example" android:versionCode="25" android:versionName="2.2" > <uses-sdk android:minSdkVersion="9" android:targetSdkVersion="23" /> <!-- REQUIRED --> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.VIBRATE" /> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <!-- REQUIRED for C2DM --> <!-- Only this application can receive the messages and registration result --> <permission android:name="com.appoxee.example.permission.C2D_MESSAGE" android:protectionLevel="signature" /> <uses-permission android:name="com.appoxee.example.permission.C2D_MESSAGE" /> <!-- This app has permission to register and receive message --> <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> <uses-permission android:name="android.permission.GET_ACCOUNTS" /> <uses-permission android:name="android.permission.WAKE_LOCK" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <application android:name="com.appoxee.example.AppoxeeExample" android:allowBackup="true" android:allowClearUserData="true" android:enabled="true" android:hardwareAccelerated="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:launchMode="singleTask" > <!-- This app uses GooglePlayServices.jar --> <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" /> <activity android:name="com.appoxee.example.AppoxeeExampleActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <!-- REQUIRED for C2DM --> <service android:name="com.appoxee.gcm.PlayIntentService" > </service> <receiver android:name="com.appoxee.listeners.OnCoppaReciever" /> <receiver android:name="com.appoxee.gcm.PlayBroadcastReceiver" android:permission="com.google.android.c2dm.permission.SEND" > <!-- Receive the actual message --> <intent-filter> <action android:name="com.google.android.c2dm.intent.RECEIVE" /> <category android:name="com.appoxee.example" /> </intent-filter> <!-- Receive the registration id --> <intent-filter> <action android:name="com.google.android.c2dm.intent.REGISTRATION" /> <category android:name="com.appoxee.example" /> </intent-filter> </receiver> <!-- OPTIONAL, if you want to receive push, push opened and registration completed intents --> <activity android:name="com.appoxee.activities.Inbox" > </activity> <activity android:name="com.appoxee.activities.SplashScreen" > </activity> <activity android:name="com.appoxee.activities.MoreApps" > </activity> <activity android:name="com.appoxee.activities.Feedback" > </activity> <activity android:name="com.appoxee.activities.InboxMessage" > </activity> </application> </manifest>
This completes the AndroidManifest.xml file updates. The remaining updates are made in your app code.
Inbox integration - after enabling the Inbox in your Appoxee account (by going to the app's Application Information page and checking Allow Inbox + Rich messages), add the Inbox to your code as follows:
Add code that opens the Inbox - the Inbox can be opened from any activity. In the example code below, the Inbox is opened from the main activity layout, using the "openInbox():" function:
public void openInbox(View view){Intent intent = new Intent(this, Inbox.class);}
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
this.startActivity(intent);Add a button that opens the Inbox - it is recommended to add a button to open the Inbox. This button is added in the activity layout as follows:
<Button
android:id="@+id/open_inbox"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="openInbox"
android:text="Open Appoxee Inbox" />Show the number of unread messages - to show the user the number of unread messages, fetch this number using the following command:
Appoxee.getUnreadMessages();
Depp Link / URL Scheme in Appoxee&Android
Add to your AndroidManifest.xml
<activity android:name="com.appoxee.example.DeepLinkActivity" >
<!-- Add the Intent Filter for activity needed to be URLScheme compatible -->
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="example" />
</intent-filter>
</activity>
Create DeepLinkActivity.java
//This sample extends AppoxeeBaseActivity, for onStart() & onStop() integration and analytics
public class DeepLinkActivity extends AppoxeeBaseActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Intent intent = getIntent();
if (intent == null || intent.getData() == null) {
finish();
}
openDeepLink(intent.getData());
// Finish this activity
finish();
}
public void openDeepLink(Uri deepLink) {
String path = deepLink.getPath();
Utils.Debug("Base path: " + path);
//Implement your Code here
path = path.replace("/", "");
Intent intent = new Intent();
intent.setClassName(this, path);
this.startActivity(intent);
} .....
...