Introduction
This document explains how to add the Appoxee code to your application code (step 3 of the Appoxee Android SDK integration process).
Info | |||||||
---|---|---|---|---|---|---|---|
| |||||||
If you choose to use Appoxee SDK uses Google Play Services, you need to know the following : To test your app whenwhich is supported on devices using the Google Play services SDK, you must use either:A compatible Android device that runsstore, and are running Android 2.3 or higher and includes Google Play Store.To make the Google Play services APIs available to your app:
<project_directory>/proguard-project.txt file:
|
We now have 2 options of Integration : Explicit & Implicit.
Explicit integration enables (through inheritance and interface implementation) an automated process of sending analytics data to Appoxee and to control API Calls (Tags, Alias etc.) through an Observer (Callback Methods implementation in your code which are declared in AppoxeeObserver) that will indicate if the SDK is done loading and ready to process the API Calls. This will save the trouble of checking if the SDK is ready through a separate thread or any other means.
Explicit Integration is the preferred way.
Implicit Integration is a form of Integration that can be done if your code doesn't allow you to inherit from Appoxee and to implement it's Observer Interface. Both Integrations are explained below.
and above. For more info / troubleshooting see Google Play Services documentation: https://developers.google.com/android/guides/setup |
The code sections below use the following typographic conventions:
- Regular text - existing code: You should already have this code in your project by default. No changes are required.
- Bold text - new code: Make sure you add this Appoxee code to your app code.
- Green text - comments: A comment describes the code that follows it and notes special issues you should pay attention to. Please read the comments carefully.
- Blue text - AndroidManifest.xml updates: The changes you should make in the app's AndroidManifest.xml file.
Integration Instructions
The integration has two parts:
- Source code integration - Integration into the source code which can be done in two ways:
- Explicit - Explicit integration enables (through inheritance and interface implementation) an automated process of sending analytics data to Appoxee and to control API Calls (Tags, Alias etc.) through an Observer (Callback Methods implementation in your code which are declared in AppoxeeObserver) that will indicate if the SDK is done loading and ready to process the API Calls. This will save the trouble of checking if the SDK is ready through a separate thread or any other means. Explicit Integration is the preferred way.
- Implicit - Implicit Integration is a form of Integration that can be done if your code doesn't allow you to inherit from Appoxee and to implement it's Observer Interface. Both Integrations are explained below.
- Manifest Integration and Advanced Options (Inbox / DeepLink (URLScheme) ) - Needed in either case of Code Integration (Explicit/Implicit)
Note | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
Note | ||||||||||
If you are using Eclipse and ProGuard, enter the following lines into the file "proguard-project.txt"
In order to avoid these additions in each activity, you can simply extend AppoxeeBaseActivity instead of Activity. (AppoxeeBaseActivity extends Android’s FragmentActivity and contains the onStart() & onStop() calls) |
Source code integration
Option A: Explicit Integration (with Observer) :
...
On your main activity class add the following code to Activity life-cycle callback methods:
...
Code Block | |||
---|---|---|---|
|
...
| |
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); ... new initAsync(getApplicationContext(),"APP_KEY", "SECRET_KEY", true, "com.package.MainActivity" |
...
).execute(); AppoxeeManager.setDebug(true); |
...
Make sure that the following methods are implemented and contain Appoxee's method calls :
Code Block | ||||
---|---|---|---|---|
| ||||
@Override
protected void onResume()
{
super.onResume();
// If Inbox implemented and you have a method for updating your inbox's
// Badge
updateMsgBadge();
}
@Override
public void onRegistrationCompleted() {
// TODO Auto-generated method stub
Utils.Debug("Can perform all API Calls");
}
@Override
public void onMessagesUpdateCompleted()
{
// If Inbox implemented and you have a method for updating your inbox's
// Badge
Utils.Debug("Can update Badge");
updateMsgBadge();
}
|
...
To fully use Appoxee’s Analytics , all of your activities should implement onStart() & onStop in the actvities code :
...
language | java |
---|---|
linenumbers | true |
...
//set 'false' to get less debug logs ... } @Override protected void onStart() { |
...
super.onStart(); |
...
Appoxee.onStart(); ... } |
...
@Override
protected void onStop() {
|
...
Appoxee.onStop(); |
...
super.onStop(); ... } |
...
|
In order to avoid these additions in each activity, you can simply extend AppoxeeBaseActivity instead of Activity. (AppoxeeBaseActivity extends Android’s FragmentActivity and contains the onStart() & onStop() calls)
Option B: Implicit Integration (without using Observer)
...
In your main activity class onCreate() method enter the following code :
Code Block | ||||
---|---|---|---|---|
| ||||
...
new initAsync(getApplicationContext(),"APP_KEY",
"SECRET_KEY", true, "com.package.MainActivity").execute();
AppoxeeManager.setDebug(true);
Appoxee.parseExtraFields(getIntent().getExtras());
setContentView(R.layout.main);
...
|
Code Block | ||||
---|---|---|---|---|
| ||||
@Override
protected void onStart()
{
super.onStart();
Appoxee.onStart();
}
@Override
protected void onStop()
{
super.onStop();
Appoxee.onStop();
}
@Override
protected void onNewIntent(Intent intent)
{
super.onNewIntent(intent);
Bundle bundle = intent.getExtras();
Appoxee.parseExtraFields(bundle);
}
@Override
protected void onResume()
{
super.onResume();
// If Inbox implemented and you have a method for updating your inbox's
// Badge
updateMsgBadge();
}
|
...
You may want to add observer to Appoxee callbacks.
To do so, you'll have to implement the AppoxeeObserver interface and implement callbacks.
Example:
Code Block |
---|
public class AppoxeeExampleActivity extends Activity implements AppoxeeObserver{
...
@Override
public void onRegistrationCompleted() {
//from this point on, Appoxee API is avaliable
}
@Override
public void onMessagesUpdateCompleted() {
//callback for getting inbox messages
}
@Override
public void onRegistrationFailure() {
//Huston, we have a problem...
}
@Override
public void onGeoRegistrationFailure() {
//This is for future support ;)
}
...
} |
Note |
---|
All Appoxee API calls will fail until Appoxee has finished initialization. When Integrating Appoxee and choosing not to use an Observer |
...
(and sometimes when do), you may consider checking if
|
...
before doing such operations. |
Note | |||||||
---|---|---|---|---|---|---|---|
To fully use Appoxee’s Analytics , all of your activities should implement onStart() & onStop in the actvities code :
|
...
|
...
|
...
|
...
|
...
|
...
|
...
|
...
|
...
|
...
Advanced Options (Inbox / DeepLink (URLScheme) ) :
If prompted with an error, add this "Import" command to enable Appoxee SDK usage:
Code Block language java linenumbers true import com.appoxee.Appoxee;
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:
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.
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:
Code Block language java linenumbers true 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:
Code Block language xml linenumbers true <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:
Code Block language java linenumbers true Appoxee.getUnreadMessages();
Deep Link / URL Scheme in Appoxee & Android
Add to your AndroidManifest.xml
Code Block language xml linenumbers true <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" android:host="pushnotification" /> </intent-filter> </activity>
Create DeepLinkActivity.java
Code Block language java title DeepLink Activity Sample linenumbers true //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); } .....
NEXT STEP: Step 4 of the Appoxee Android SDK IntegrationYou are now done integrating the Appoxee SDK! Congrats!
1. If you wish to use the SDK Sync API's - press here
2. If you wish to use the SDK Async API's - press here
3. If you wish to use the Custom Push Notification Builder - press here
As mentioned earlier, our Test Application contains a full code sample. it can be downloaded from here.