Before Sending Message
After Sending Message
Create new Android Project
Project Name: TextMessage
Build Target: Android 2.3.3 //or greater than that
Application Name: TextMessage
Package Name: com.shaikhhamadali.blogspot.textmessage
Create layout file: activity_messege_sender
Min SDK: 10 // or greater than that
1. create main layout:
Project Name: TextMessage
Build Target: Android 2.3.3 //or greater than that
Application Name: TextMessage
Package Name: com.shaikhhamadali.blogspot.textmessage
Create layout file: activity_messege_sender
Min SDK: 10 // or greater than that
- Two Edit Text (receiver number and Message)
- one Button (send message)
<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:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MessageSender" > <!-- Reciever Number edit text --> <EditText android:id="@+id/eTReceiverNo" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_marginTop="16dp" android:hint="@string/enterReceiverNumber" android:ems="10" android:inputType="number" > <requestFocus /> </EditText> <!-- Message multiline edit text --> <EditText android:id="@+id/eTMessage" android:layout_width="match_parent" android:layout_height="250dp" android:layout_marginTop="60dp" android:ems="10" android:hint="@string/enterMessageHere" android:gravity="top" android:inputType="textMultiLine" /> <!-- Send message Edit text --> <Button android:id="@+id/btnSend" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_marginBottom="50dp" android:text="@string/send" /> </RelativeLayout>
2. code of string:
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="app_name">TextMessage</string> <string name="action_settings">Settings</string> <string name="enterMessageHere">enter message here</string> <string name="enterReceiverNumber">enter receiver number</string> <string name="send">Send</string> </resources>
3. code of manifest:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.shaikhhamadali.blogspot.textmessage" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="9" android:targetSdkVersion="16" /> <uses-permission android:name="android.permission.SEND_SMS"/> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.shaikhhamadali.blogspot.textmessage.MessageSender" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
6. code of main activity:
package com.shaikhhamadali.blogspot.textmessage; import java.util.Set; import android.os.Bundle; import android.app.Activity; import android.app.PendingIntent; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.telephony.SmsManager; import android.util.Log; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class MessageSender extends Activity { private final static String TAG = "MessageSenderActivity"; private final static String INTENT_ACTION_SENT = "com.shaikhhamadali.blogspot.textmessage.INTENT_ACTION_SENT"; private final static String INTENT_ACTION_DELIVERY = "com.shaikhhamadali.blogspot.textmessage.INTENT_ACTION_DELIVERY"; private final static int REQUEST_CODE_ACTION_SENT = 1; private static final int REQUEST_CODE_ACTION_DELIVERY = 2; private BroadcastReceiver smsSentDeliveredReceiver; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_message_sender); //Receiver edit text final EditText eTReceiverNumebr = (EditText) findViewById(R.id.eTReceiverNo); //Sender edit text final EditText eTMessage = (EditText) findViewById(R.id.eTMessage); //Send Message Button Button btnSend = (Button) findViewById(R.id.btnSend); btnSend.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //get receiver number String number = eTReceiverNumebr.getText().toString(); //get message to send String message = eTMessage.getText().toString(); //call send sms message method to send the sms sendSMS(number, message); } }); //initialize broadcast receiver for message delivery initializeReceivers(); } private void sendSMS(String number, String message) { /*create intent instance and pass INTENT_ACTION_SENT * INTENT_ACTION_SENT is used to send an sms on GSM * */ Intent sentIntent = new Intent(INTENT_ACTION_SENT); /*create pendingintent instance and pass this as context instance,REQUEST_CODE_ACTION_SENT and FLAG_UPDATE_CURRENT * REQUEST_CODE_ACTION_SENT=1 defined at top * FLAG_UPDATE_CURRENT: Flag for use with getActivity(Context, int, Intent, int), * getBroadcast(Context, int, Intent, int), and getService(Context, int, Intent, int): * if the described PendingIntent already exists, then keep it but its replace * its extra data with what is in this new Intent. This can be used if you are * creating intents where only the extras change, and don't care that any * entities that received your previous PendingIntent will be able to launch * it with your new extras even if they are not explicitly given to it. * */ PendingIntent pendingSentIntent = PendingIntent.getBroadcast(this, REQUEST_CODE_ACTION_SENT, sentIntent, PendingIntent.FLAG_UPDATE_CURRENT); /*create intent instance and pass INTENT_ACTION_DELIVERY * INTENT_ACTION_DELIVERY is used to receive an sms delivery on GSM * */ Intent deliveryIntent = new Intent(INTENT_ACTION_DELIVERY); /*create pendingintent instance and pass this as context instance,REQUEST_CODE_ACTION_DELIVERY and FLAG_UPDATE_CURRENT * REQUEST_CODE_ACTION_DELIVERY=2 defined at top * FLAG_UPDATE_CURRENT:Flag for use with getActivity(Context, int, Intent, int), * getBroadcast(Context, int, Intent, int), and getService(Context, int, Intent, int): * if the described PendingIntent already exists, then keep it but its replace its * extra data with what is in this new Intent. This can be used if you are creating * intents where only the extras change, and don't care that any entities that received * your previous PendingIntent will be able to launch it with your new extras even if * they are not explicitly given to it. * */ PendingIntent pendingDeliveryIntent = PendingIntent.getBroadcast(this, REQUEST_CODE_ACTION_DELIVERY, deliveryIntent, PendingIntent.FLAG_UPDATE_CURRENT); //Create instance of SmsManager and get the default instance of the Sms manager SmsManager smsManager = SmsManager.getDefault(); /* Second parameter is the service center number. Use null if you want *to use the default number */ smsManager.sendTextMessage(number, null, message, pendingSentIntent, pendingDeliveryIntent); } @Override protected void onPause() { super.onPause(); unregisterReceiver(smsSentDeliveredReceiver); } @Override protected void onResume() { super.onResume(); //Create instance of intent filter and add actions we defined IntentFilter filter = new IntentFilter(INTENT_ACTION_SENT); filter.addAction(INTENT_ACTION_DELIVERY); //register receiver for our defined actions registerReceiver(smsSentDeliveredReceiver, filter); } private void initializeReceivers() { //sent sms delivery receiver smsSentDeliveredReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { //call process broadcasts method processBroadcasts(intent); } }; } private void processBroadcasts(Intent intent) { //get action String action = intent.getAction(); //log as info in logcat the received action Log.i(TAG, "Received: " + action); if (action.equals(INTENT_ACTION_SENT)) { Bundle bundle = intent.getExtras(); // can check for error messages //log as info in logcat that message sent Log.i(TAG, "Message: Sent"); //show toast that message sent Toast.makeText(this, "Message sent", Toast.LENGTH_LONG).show(); } else if (action.equals(INTENT_ACTION_DELIVERY)) { Bundle bundle = intent.getExtras(); Set<String> keys = bundle.keySet(); // can check for error messages //log as info in logcat that message Delivered Log.i(TAG, "Message: Delivered"); //show toast that message Delivered Toast.makeText(this, "Message delivered", Toast.LENGTH_LONG).show(); } } }
7. note that:
- code help taken from tech droid.
- donot forget to provide permission in manifest file either you can not send the message or will get the exception.
- The logic behind this is, send message through SmsManager and use broad cast receivers for deliveries.
8. conclusion:
- Some information about SmsManager,Broad Cast Receivers and permissions.
- Know how to send an sms.
- Know how to get notification of sms delivered.
9. about the post:
- Coming posts could be Receive Message,types of Intent,types of Toast ets
- The code seems to explain itself due to comments, and is very easy to understand.
- Don’t mind to write a comment whatever you like to ask, to know,to suggest or recommend.
- Hope you enjoy it!
10. Source Code:
you can download the source code here
Cheers,
you can download the source code here
Hamad Ali Shaikh