Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Android Manifest XML Changes

Introduction

...

Info
titleUsing Google Play Services

If you choose to use Google Play Services, you need to know the following :

  1. To test your app when using the Google Play services SDK, you must use either:

    • A compatible Android device that runs Android 2.3 or higher and includes Google Play Store.
    • The Android emulator with an AVD that runs the Google APIs platform based on Android 4.2.2 or higher.
  2. To make the Google Play services APIs available to your app:

    1. Copy the library project at <android-sdk>/extras/google/google_play_services/libproject/google-play-services_lib/ to the location where you maintain your Android app projects.
    2. Import the library project into your Eclipse workspace (if you use Eclipse) : Click File > Import, select Android > Existing Android Code into Workspace, and browse to the copy of the library project to import it.
    3. In your app project, reference Google Play services library project.

      Note: You should be referencing a copy of the library that you copied to your development workspace—you should not reference the library directly from the Android SDK directory.

  3. To prevent ProGuard from stripping away required classes, add the following lines in the<project_directory>/proguard-project.txt file:

     

    Code Block
    languagetext
    titleProGuard
    -keep class * extends java.util.ListResourceBundle {
        protected Object[][] getContents();
    }
    
    -keep public class com.google.android.gms.common.internal.safeparcel.SafeParcelable {
        public static final *** NULL;
    }
    
    -keepnames @com.google.android.gms.common.annotation.KeepName class *
    -keepclassmembernames class * {
        @com.google.android.gms.common.annotation.KeepName *;
    }
    
    -keepnames class * implements android.os.Parcelable {
        public static final ** CREATOR;
    }



 

...

  1. Your MainActivity needs to exted AppoxeeBaseActivity and implement AppoxeeObserver
  2. Your MainActivity onCreate() method should contain : 

     

    new initAsync(getApplicationContext(),"APP_KEY",

                         "SECRET_KEY", "com.package.MainActivity" , true, this).execute();

    AppoxeeManager.setDebug(true);

    Appoxee.parseExtraFields(getIntent().getExtras());

    setContentView(R.layout.main);

    .....



  3. Make sure that the following methods are implemented and contain Appoxee's method calls :

    @Override

       protected void onResume()

          {

        super.onResume();

     // If Inbox implemented and you have a method for updating your inbox’s

     // Badge

          updateMsgBadge();

          }

     

    d. @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();

     

     }




    Note

    To fully use Appoxee’s Analytics , all of your activities should implement onStart() & onStop in the actvities code :

     

    @Override

    protected void onStart()

                  {

       super.onStart();

       Appoxee.onStart();

                 }

       

    @Override

                 protected void onStop()

                 {

       super.onStop();

       Appoxee.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)

    1. In your main activity class onCreate() method enter the following code :

      new initAsync(getApplicationContext(),"APP_KEY",

                           "SECRET_KEY", true, "com.package.MainActivity").execute();

      AppoxeeManager.setDebug(true);

      Appoxee.parseExtraFields(getIntent().getExtras());

      setContentView(R.layout.main);

      .....



    2. Make sure that the following methods are implemented and contain Appoxee's method calls :

       

      @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();

       

       }

       

      Note

      When Integrating Appoxee and choosing not to use an Observer, All Appoxee API Calls will fail unless implementing a thread that will sample the flag

      Appoxee.isReady()==true. Only then will the API Calls will execute (Tags,Alias... )


  4. If prompted with an error, add this "Import" command to enable Appoxee SDK usage:

    import com.appoxee.Appoxee
  5. AndroidManifest.xml Updates - Make the following changes to your app's AndroidManifest.xml file:
    1. GCM requires Android 2.2 or later. If your app cannot work without GCM, add the following line, where "xx" is the
      Note

      To fully use Appoxee’s Analytics , all of your activities should implement onStart() & onStop in the actvities code :

      Code Block
      languagejava
      linenumberstrue
      @Override 
      protected void onStart()
        {
         super.onStart();
         Appoxee.onStart();
        }
          
      @Override
      protected void onStop()
        {
         super.onStop();
         Appoxee.onStop();
        }
      
      
      

       

      @Override

      protected void onStart()

                    {

         super.onStart();

         Appoxee.onStart();

                   }

         

      @Override

                   protected void onStop()

                   {

         super.onStop();

         Appoxee.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)

     

Manifest Integration and Advanced Options (Inbox / DeepLink (URLScheme) ) :

    1. 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)

     

Manifest Integration and Advanced Options (Inbox / DeepLink (URLScheme) ) :

  1. If prompted with an error, add this "Import" command to enable Appoxee SDK usage:

    import com.appoxee.Appoxee
  2. AndroidManifest.xml Updates - Make the following changes to your app's AndroidManifest.xml file:

    1. 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:

      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.
    2. Declare and use a custom permission, so only this application can receive GCM messages:

      <permission android:name="com.appoxee.example.permission.C2D_MESSAGE" android:protectionLevel="signature" /> 
      <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.

    3. To allow your app to use Google's Push Notification Service (GCM), add the following permissions: 

      <!-- This app has permission to register and receive message -->
      <!-- App receives GCM messages. -->
      <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. -->
      <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" />

       

    4. In the manifest file's Application element, make sure your app has the name it has in your class file:

      <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"
      ..... >

       

    5.  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):

      <service android:name="com.appoxee.gcm.GCMIntentService"/>
      <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> <!-- 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 code


    6. To enable Appoxee's in-app inbox, and other advanced features, add the following code inside your Application element:

      <activity android:name="com.appoxee.activities.Inbox"/>
      <activity android:name="com.appoxee.activities.MoreApps"/>
      <activity android:name="com.appoxee.activities.Feedback"/> <!-- Add if missing from Push Integration -->
      <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.

      Your updated AndroidManifest.xml file should be similar to the following example XML: <?xml version="1.0" encoding="utf-8"?>
      <manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.demo"
      android:versionCode="1"
      android:versionName="1.0" > 
      <uses-sdk android:minSdkVersion="8" /> 
      <!-- REQUIRED -->
      <uses-permission android:name="android.permission.INTERNET" /> 
      <uses-permission android:name="android.permission.VIBRATE" /> 
      <!-- REQUIRED for GCM -->
      <!-- 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 -->
      <!-- App receives GCM messages. -->
      <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> 
      <!-- GCM connects to Google Services. -->
      <uses-permission 

      it is added below the Receiver declaration.

       

      This is the AndroidManifest.xml Code Block for GCM  :
      Code Block
      languagexml
      titleAndroidManifest.xml - GCM Integration
      linenumberstrue
      <?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
      themeEclipse
      languagexml
      titleAndroidManifest - PlayServices Integration
      linenumberstrue
      <?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.
      INTERNET" /> 
      <!-- GCM requires a Google account. -->
      <uses-permission 
      ACCESS_NETWORK_STATE" />
          
          <application
              android:name="
      android
      com.appoxee.
      permission.GET_ACCOUNTS" />
      <!-- Keeps the processor from sleeping when a message is received. -->
      <uses-permission android:name="android.permission.WAKE_LOCK" />
      <!—The name of MyApplication Needs to be replaced with the name of the class of your application -->
      <application android:label="@string/app_name"
      android:icon="@drawable/ic_launcher"
      android:allowClearUserData="true"
      android:enabled="true" android:name="MyApplication"/>
      <activity android:name="DemoActivity" 
      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 
       >
                  <intent-filter>
                      <action android:name="android.intent.action.MAIN"
       />
      <category 
       />
                      <category android:name="android.intent.category.LAUNCHER"
       
       />
      
                  </intent-filter>
      
              </activity>

      
      
              <!-- REQUIRED for
      GCM
       C2DM -->

      <service 
      
              <service android:name="com.appoxee.gcm.PlayIntentService" >
              </service>
      
              <receiver android:name="com.appoxee.
      gcm
      listeners.
      GCMIntentService
      OnCoppaReciever"
      />
      <receiver 
       />
              <receiver
                  android:name="com.appoxee.gcm.
      GCMBroadcastReceiver"
      PlayBroadcastReceiver"
                  android:permission="com.google.android.c2dm.permission.SEND"
      >
       >
      
                  <!-- Receive the actual
      message -->
      <intent-filter><action 
       message -->
                  <intent-filter>
                      <action android:name="com.google.android.c2dm.intent.RECEIVE"
       />
      <category 
       />
                      <category android:name="com.appoxee.example"
       
       />
      
                  </intent-
      filter>
      filter>
      
                  <!-- Receive the registration id -->

      
                  <intent-filter>
      <action 
      
                      <action android:name="com.google.android.c2dm.intent.REGISTRATION"
       
       />

      <category 
      
                      <category android:name="com.appoxee.example"
       />
       />
                  </intent-filter>
      
              </receiver>

      
      
              <!--
      Add the following intents to your application if Inbox and other advanced features are enabled -->
      <activity 
       OPTIONAL, if you want to receive push, push opened and registration completed intents -->
              <activity android:name="com.appoxee.activities.Inbox" >
              </
      >
      <activity 
      activity>
              <activity android:name="com.appoxee.activities.SplashScreen" >
              </activity>
              <activity android:name="com.appoxee
      .activities.MoreApps"/>
      <activity 
      .activities.MoreApps" >
              </activity>
              <activity android:name="com.appoxee.activities.Feedback"
      />
      <activity 
       >
              </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.

       

       


  3. 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: 

    1. 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);
      }
    2. 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:

    3. Show the number of unread messages - to show the user the number of unread messages, fetch this number using the following command:

      Appoxee.getUnreadMessages();

       

       

       

  4. Depp Link / URL Scheme in Appoxee&Android

    1. 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>

    2. 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);

                

         } .....




...