Beberapa hari ini saya berfikir bagaimana cara membuat sebuaah aplikasi yang memiliki notifikasi. Mulai dari situ saya mencari-cari beberapa situs yang menyediakan notifikasi. mulai dari pubnub.com, firebase.com, parse.com, dan google cloud message (gcm). Tepatnya mulai dari 2 hari kemarin (selasa, 15-Des-2015) satu persatu situs tersebut mulai saya jajal, alhasil malam ini saya baru berhasil mengimplementasikan push notifikasi dari situs parse.com, walaupun belum maksimal hasilnya, tetapi bisa memuaskan keingintahuan saya untuk membuat notifikasi di android ini. Hasil dari "tahap pencarian" saya, saya coba jabarkan di artikel ini.
referensi: http://www.androidhive.info/2015/06/android-push-notifications-using-parse-com/
Langkah-Langkah:
1. Lakukan Sign up pada parse.com
2. Membuat projek baru
5. Download Parse-1.9.1.jar
6. Set depedency di build.gradle(Module:app)
6. Buatlah struktur folder seperti gambar dibawah ini
7. activity_login.xml
8. activity_main.xml
9. list_row.xml
10. toolbar.xml
11. LoginActivity.java
12. MainActivity.java
13. AppConfig.java
Ganti <Change With Your Code> dengan code hasil generate dari projek di parse.com
14. MyApplication.java
15. NotificationUtils.java
16. ParseUtils.java
17. PrefManager.java
18. Message.java
19. CustomPushReceiver.java
22. Set permission in AndroidManifest.xml
26. klik send now
27. tunggu hingga notifikasi muncul pada HP
28. JIka aplikasi dalam keadaan terbuka, maka notifikasi akan masuk kedalam listview
28. Jika aplikasi dalam keadaan tertutup, maka akan ada notifikasi di screen utama
Source : https://github.com/ardhimaarik/parse
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Sekian ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Sekian tutorial yang saya buat, semoga bermanfaat :)
referensi: http://www.androidhive.info/2015/06/android-push-notifications-using-parse-com/
Langkah-Langkah:
1. Lakukan Sign up pada parse.com
2. Membuat projek baru
beri nama. misal <parse>
3. Akses Application ID dan Client Key projek yang sudah di buat
4. Membuat project baru di android Studio. source code bisa di ambil disini -> https://github.com/ardhimaarik/parse
File - > New -> New Project...
atau
Start a new Android Studio Project
5. Download Parse-1.9.1.jar
6. Set depedency di build.gradle(Module:app)
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.1.1'
compile 'com.parse.bolts:bolts-android:1.+'
compile fileTree(dir: 'libs', include: 'Parse-*.jar')
}
Klik
6. Buatlah struktur folder seperti gambar dibawah ini
================================ LayOut=================================
7. activity_login.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ffffff"
tools:context="info.androidhive.parsenotifications.activity.LoginActivity">
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:gravity="center"
android:orientation="vertical"
android:paddingBottom="10dp"
android:paddingTop="10dp">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:fontFamily="sans-serif-light"
android:gravity="center_horizontal"
android:text="Parse Notifications"
android:textColor="#218eed"
android:textSize="24dp" />
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="20dp"
android:fontFamily="sans-serif-light"
android:gravity="center_horizontal"
android:paddingLeft="20dp"
android:paddingRight="20dp"
android:text="Enter your email address to subscribe to parse channel!"
android:textColor="#9d9d9d"
android:textSize="16dp" />
<EditText
android:id="@+id/email"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="40dp"
android:layout_marginRight="40dp"
android:background="@android:color/white"
android:hint="Your email address"
android:gravity="center_horizontal"
android:inputType="textEmailAddress"
android:padding="10dp"
android:textColor="#444444"
android:textColorHint="#888888"
android:textSize="18dp" />
<View
android:layout_width="fill_parent"
android:layout_height="1dp"
android:layout_marginLeft="40dp"
android:layout_marginRight="40dp"
android:background="#dedede"/>
<Button
android:id="@+id/btnLogin"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="40dp"
android:layout_marginRight="40dp"
android:layout_marginTop="20dp"
android:background="#218eed"
android:text="Login"
android:textColor="@android:color/white" />
</LinearLayout>
</RelativeLayout>
8. activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<include
android:id="@+id/toolbar"
layout="@layout/toolbar" />
</LinearLayout>
<ListView
android:id="@+id/list_view"
android:layout_width="fill_parent"
android:layout_height="wrap_content"></ListView>
</LinearLayout>
9. list_row.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/message"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="5dp"
android:paddingLeft="10dp"
android:paddingRight="10dp"
android:paddingTop="10dp"
android:textSize="16dp" />
<TextView
android:id="@+id/timestamp"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="15dp"
android:paddingLeft="10dp"
android:paddingRight="10dp"
android:textColor="#666666" />
</LinearLayout>
10. toolbar.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:local="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
android:minHeight="?attr/actionBarSize"
local:popupTheme="@style/ThemeOverlay.AppCompat.Light"
local:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" />
===============================Java Class================================11. LoginActivity.java
package com.example.erdearik.parse.activity;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.text.TextUtils;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.example.erdearik.parse.R;
import com.example.erdearik.parse.helper.ParseUtils;
import com.example.erdearik.parse.helper.PrefManager;
/**
* Created by erdearik on 12/16/15.
*/
public class LoginActivity extends ActionBarActivity implements View.OnClickListener {
private EditText inputEmail;
private Button btnLogin;
private PrefManager pref;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Verifying parse configuration. This is method is for developers only.
ParseUtils.verifyParseConfiguration(this);
pref = new PrefManager(getApplicationContext());
if (pref.isLoggedIn()) {
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
startActivity(intent);
finish();
}
setContentView(R.layout.activity_login);
inputEmail = (EditText) findViewById(R.id.email);
btnLogin = (Button) findViewById(R.id.btnLogin);
btnLogin.setOnClickListener(this);
}
private void login() {
String email = inputEmail.getText().toString();
if (isValidEmail(email)) {
pref.createLoginSession(email);
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
startActivity(intent);
finish();
} else {
Toast.makeText(getApplicationContext(), "Please enter valid email address!", Toast.LENGTH_LONG).show();
}
}
public final static boolean isValidEmail(CharSequence target) {
return !TextUtils.isEmpty(target) && android.util.Patterns.EMAIL_ADDRESS.matcher(target).matches();
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btnLogin:
login();
break;
default:
}
}
}
12. MainActivity.java
package com.example.erdearik.parse.activity;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.Toolbar;
import android.text.format.DateUtils;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import com.example.erdearik.parse.R;
import com.example.erdearik.parse.helper.ParseUtils;
import com.example.erdearik.parse.helper.PrefManager;
import com.example.erdearik.parse.model.Message;
import com.parse.Parse;
import com.parse.ParseInstallation;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private static String TAG = MainActivity.class.getSimpleName();
private Toolbar mToolbar;
private ListView listView;
private List<Message> listMessages = new ArrayList<>();
private MessageAdapter adapter;
private PrefManager pref;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (ListView) findViewById(R.id.list_view);
mToolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(mToolbar);
getSupportActionBar().setDisplayShowHomeEnabled(true);
adapter = new MessageAdapter(this);
pref = new PrefManager(getApplicationContext());
listView.setAdapter(adapter);
Intent intent = getIntent();
String email = intent.getStringExtra("email");
if (email != null) {
ParseUtils.subscribeWithEmail(pref.getEmail());
}
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
String message = intent.getStringExtra("message");
Message m = new Message(message, System.currentTimeMillis());
listMessages.add(0, m);
adapter.notifyDataSetChanged();
}
private class MessageAdapter extends BaseAdapter {
LayoutInflater inflater;
public MessageAdapter(Activity activity) {
inflater = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
public int getCount() {
return listMessages.size();
}
@Override
public Object getItem(int position) {
return listMessages.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
view = inflater.inflate(R.layout.list_row, null);
}
TextView txtMessage = (TextView) view.findViewById(R.id.message);
TextView txtTimestamp = (TextView) view.findViewById(R.id.timestamp);
Message message = listMessages.get(position);
txtMessage.setText(message.getMessage());
CharSequence ago = DateUtils.getRelativeTimeSpanString(message.getTimestamp(), System.currentTimeMillis(),
0L, DateUtils.FORMAT_ABBREV_ALL);
txtTimestamp.setText(String.valueOf(ago));
return view;
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_logout) {
pref.logout();
Intent intent = new Intent(MainActivity.this, LoginActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
startActivity(intent);
finish();
return true;
}
return super.onOptionsItemSelected(item);
}
}
13. AppConfig.java
Ganti <Change With Your Code> dengan code hasil generate dari projek di parse.com
package com.example.erdearik.parse.app; /** * Created by erdearik on 12/16/15. */ public class AppConfig { public static final String PARSE_CHANNEL = "parse"; public static final String PARSE_APPLICATION_ID = "<Change With Your Code>"; public static final String PARSE_CLIENT_KEY = "<Change With Your Code>"; public static final int NOTIFICATION_ID = 100; }
14. MyApplication.java
package com.example.erdearik.parse.app;
import android.app.Application;
import com.example.erdearik.parse.helper.ParseUtils;
/**
* Created by erdearik on 12/16/15.
*/
public class MyApplication extends Application {
private static MyApplication mInstance;
@Override
public void onCreate() {
super.onCreate();
mInstance = this;
// register with parse
ParseUtils.registerParse(this);
}
public static synchronized MyApplication getInstance() {
return mInstance;
}
}
15. NotificationUtils.java
package com.example.erdearik.parse.helper;
import android.app.ActivityManager;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.graphics.BitmapFactory;
import android.media.RingtoneManager;
import android.os.Build;
import android.support.v4.app.NotificationCompat;
import android.text.TextUtils;
import com.example.erdearik.parse.R;
import com.example.erdearik.parse.app.AppConfig;
import java.util.List;
/**
* Created by erdearik on 12/16/15.
*/
public class NotificationUtils {
private String TAG = NotificationUtils.class.getSimpleName();
private Context mContext;
public NotificationUtils() {
}
public NotificationUtils(Context mContext) {
this.mContext = mContext;
}
public void showNotificationMessage(String title, String message, Intent intent) {
// Check for empty push message
if (TextUtils.isEmpty(message))
return;
if (isAppIsInBackground(mContext)) {
// notification icon
int icon = R.mipmap.ic_launcher;
int mNotificationId = AppConfig.NOTIFICATION_ID;
PendingIntent resultPendingIntent =
PendingIntent.getActivity(
mContext,
0,
intent,
PendingIntent.FLAG_CANCEL_CURRENT
);
NotificationCompat.InboxStyle inboxStyle = new NotificationCompat.InboxStyle();
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(
mContext);
Notification notification = mBuilder.setSmallIcon(icon).setTicker(title).setWhen(0)
.setAutoCancel(true)
.setContentTitle(title)
.setStyle(inboxStyle)
.setContentIntent(resultPendingIntent)
.setSound(RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION))
.setLargeIcon(BitmapFactory.decodeResource(mContext.getResources(), icon))
.setContentText(message)
.build();
NotificationManager notificationManager = (NotificationManager) mContext.getSystemService(Context.NOTIFICATION_SERVICE);
notificationManager.notify(mNotificationId, notification);
} else {
intent.putExtra("title", title);
intent.putExtra("message", message);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_SINGLE_TOP);
mContext.startActivity(intent);
}
}
/**
* Method checks if the app is in background or not
*
* @param context
* @return
*/
public static boolean isAppIsInBackground(Context context) {
boolean isInBackground = true;
ActivityManager am = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
if (Build.VERSION.SDK_INT > Build.VERSION_CODES.KITKAT_WATCH) {
List<ActivityManager.RunningAppProcessInfo> runningProcesses = am.getRunningAppProcesses();
for (ActivityManager.RunningAppProcessInfo processInfo : runningProcesses) {
if (processInfo.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
for (String activeProcess : processInfo.pkgList) {
if (activeProcess.equals(context.getPackageName())) {
isInBackground = false;
}
}
}
}
} else {
List<ActivityManager.RunningTaskInfo> taskInfo = am.getRunningTasks(1);
ComponentName componentInfo = taskInfo.get(0).topActivity;
if (componentInfo.getPackageName().equals(context.getPackageName())) {
isInBackground = false;
}
}
return isInBackground;
}
}
16. ParseUtils.java
package com.example.erdearik.parse.helper;
import android.app.Activity;
import android.content.Context;
import android.text.TextUtils;
import android.util.Log;
import android.widget.Toast;
import com.example.erdearik.parse.app.AppConfig;
import com.parse.Parse;
import com.parse.ParseException;
import com.parse.ParseInstallation;
import com.parse.ParsePush;
import com.parse.SaveCallback;
/**
* Created by erdearik on 12/16/15.
*/
public class ParseUtils {
private static String TAG = ParseUtils.class.getSimpleName();
public static void verifyParseConfiguration(Context context) {
if (TextUtils.isEmpty(AppConfig.PARSE_APPLICATION_ID) || TextUtils.isEmpty(AppConfig.PARSE_CLIENT_KEY)) {
Toast.makeText(context, "Please configure your Parse Application ID and Client Key in AppConfig.java", Toast.LENGTH_LONG).show();
((Activity) context).finish();
}
}
public static void registerParse(Context context) {
// initializing parse library
Parse.initialize(context, AppConfig.PARSE_APPLICATION_ID, AppConfig.PARSE_CLIENT_KEY);
ParseInstallation.getCurrentInstallation().saveInBackground();
ParsePush.subscribeInBackground(AppConfig.PARSE_CHANNEL, new SaveCallback() {
@Override
public void done(ParseException e) {
Log.e(TAG, "Successfully subscribed to Parse!");
}
});
}
public static void subscribeWithEmail(String email) {
ParseInstallation installation = ParseInstallation.getCurrentInstallation();
installation.put("email", email);
installation.saveInBackground();
}
}
17. PrefManager.java
package com.example.erdearik.parse.helper;
import android.content.Context;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
/**
* Created by erdearik on 12/16/15.
*/
public class PrefManager {
// Shared Preferences
SharedPreferences pref;
// Editor for Shared preferences
SharedPreferences.Editor editor;
// Context
Context _context;
// Shared pref mode
int PRIVATE_MODE = 0;
// Shared pref file name
private static final String PREF_NAME = "AndroidHive";
// All Shared Preferences Keys
private static final String IS_LOGIN = "IsLoggedIn";
// Email address
private static final String KEY_EMAIL = "email";
// Constructor
public PrefManager(Context context) {
this._context = context;
pref = _context.getSharedPreferences(PREF_NAME, PRIVATE_MODE);
editor = pref.edit();
}
/**
* Create login session
*/
public void createLoginSession(String email) {
// Storing login value as TRUE
editor.putBoolean(IS_LOGIN, true);
// Storing email in pref
editor.putString(KEY_EMAIL, email);
// commit changes
editor.commit();
}
public String getEmail() {
return pref.getString(KEY_EMAIL, null);
}
public boolean isLoggedIn() {
return pref.getBoolean(IS_LOGIN, false);
}
public void logout() {
editor.clear();
editor.commit();
}
}
18. Message.java
package com.example.erdearik.parse.model;
/**
* Created by erdearik on 12/16/15.
*/
public class Message {
private String message;
private long timestamp;
public Message() {
}
public Message(String message, long timestamp) {
this.message = message;
this.timestamp = timestamp;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public long getTimestamp() {
return timestamp;
}
public void setTimestamp(long timestamp) {
this.timestamp = timestamp;
}
}
19. CustomPushReceiver.java
package com.example.erdearik.parse.receiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;
import com.example.erdearik.parse.activity.MainActivity;
import com.example.erdearik.parse.helper.NotificationUtils;
import com.parse.ParsePushBroadcastReceiver;
import org.json.JSONException;
import org.json.JSONObject;
/**
* Created by erdearik on 12/16/15.
*/
public class CustomPushReceiver extends ParsePushBroadcastReceiver {
private final String TAG = CustomPushReceiver.class.getSimpleName();
private NotificationUtils notificationUtils;
private Intent parseIntent;
public CustomPushReceiver() {
super();
}
@Override
protected void onPushReceive(Context context, Intent intent) {
super.onPushReceive(context, intent);
if (intent == null)
return;
try {
JSONObject json = new JSONObject(intent.getExtras().getString("com.parse.Data"));
Log.e(TAG, "Push received: " + json);
parseIntent = intent;
parsePushJson(context, json);
} catch (JSONException e) {
Log.e(TAG, "Push message json exception: " + e.getMessage());
}
}
@Override
protected void onPushDismiss(Context context, Intent intent) {
super.onPushDismiss(context, intent);
}
@Override
protected void onPushOpen(Context context, Intent intent) {
super.onPushOpen(context, intent);
}
/**
* Parses the push notification json
*
* @param context
* @param json
*/
private void parsePushJson(Context context, JSONObject json) {
try {
boolean isBackground = json.getBoolean("is_background");
JSONObject data = json.getJSONObject("data");
String title = data.getString("title");
String message = data.getString("message");
if (!isBackground) {
Intent resultIntent = new Intent(context, MainActivity.class);
showNotificationMessage(context, title, message, resultIntent);
}
} catch (JSONException e) {
Log.e(TAG, "Push message json exception: " + e.getMessage());
}
}
/**
* Shows the notification message in the notification bar
* If the app is in background, launches the app
*
* @param context
* @param title
* @param message
* @param intent
*/
private void showNotificationMessage(Context context, String title, String message, Intent intent) {
notificationUtils = new NotificationUtils(context);
intent.putExtras(parseIntent.getExtras());
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
notificationUtils.showNotificationMessage(title, message, intent);
}
}
====================================== menu ===========================
20. menu_main.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".MainActivity">
<item
android:id="@+id/action_logout"
android:orderInCategory="100"
android:title="@string/action_logout"
app:showAsAction="never" />
</menu>
21. styles.xml (res -> value ->styles.xml)
<resources>
<style name="MyMaterialTheme" parent="MyMaterialTheme.Base">
</style>
<style name="MyMaterialTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
</resources>
<!-- IMPORTANT: Change "com.example.erdearik.parse" to match your app's package name. -->
<!-- IMPORTANT: Change "com.example.erdearik.parse" to match your app's package name. -->
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.erdearik.parse">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="android.permission.GET_TASKS" />
<!--
IMPORTANT: Change "com.example.erdearik.parse.permission.C2D_MESSAGE" in the lines below
to match your app's package name + ".permission.C2D_MESSAGE".
-->
<permission android:protectionLevel="signature"
android:name="com.example.erdearik.parse.permission.C2D_MESSAGE" />
<uses-permission android:name="com.example.erdearik.parse.permission.C2D_MESSAGE" />
<application
android:name=".app.MyApplication"
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/MyMaterialTheme">
<activity
android:name=".activity.LoginActivity"
android:label="@string/app_name"
android:windowSoftInputMode="stateHidden|adjustResize">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".activity.MainActivity"
android:label="@string/app_name" />
<!-- Added for Parse push notifications -->
<service android:name="com.parse.PushService" />
<receiver
android:name=".receiver.CustomPushReceiver"
android:exported="false">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<action android:name="android.intent.action.USER_PRESENT" />
<action android:name="com.parse.push.intent.RECEIVE" />
<action android:name="com.parse.push.intent.DELETE" />
<action android:name="com.parse.push.intent.OPEN" />
</intent-filter>
</receiver>
<receiver
android:name="com.parse.GcmBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND">
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<!-- IMPORTANT: Change "com.example.erdearik.parse" to match your app's package name. -->
<category android:name="com.example.erdearik.parse" />
</intent-filter>
</receiver>
<!-- /Added for Parse push notifications -->
</application>
</manifest>
23. Build Your Apps
24. Isikan alamat email anda, jika sudah anda akan masuk ke page berikut ->
25. kirimkan notifikasi melalui https://www.parse.com/apps
{"data":{"message":"Hello! Welcome to parse notifications.","title":"AndroidHive"},"is_background":false}
27. tunggu hingga notifikasi muncul pada HP
28. JIka aplikasi dalam keadaan terbuka, maka notifikasi akan masuk kedalam listview
Source : https://github.com/ardhimaarik/parse
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Sekian ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Sekian tutorial yang saya buat, semoga bermanfaat :)
No comments:
Post a Comment