William
William

Reputation: 15593

Android SMS Message delivery report intent

Android isn't firing the delivery intent when sending a text message. I'm testing this on Android 2.2 on the HTC EVO 4G.

This is the current code. I'm seeing "SMS sent intent received." in the logs, but not "SMS delivered intent received.".

// Constants
String SENT_ACTION = "SMS_SENT_ACTION";
String DELIVERED_ACTION = "SMS_DELIVERED_ACTION";
String CELL_NUMBER = "0000000000";
String MESSAGE = "Hello World!";

// SMS sent pending intent
PendingIntent sentIntent = PendingIntent.getBroadcast(this, 0,
        new Intent(SENT_ACTION), 0);

// SMS delivered pending intent
PendingIntent deliveredIntent = PendingIntent.getBroadcast(this, 0,
        new Intent(DELIVERED_ACTION), 0);

// SMS sent receiver
registerReceiver(new BroadcastReceiver(){
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d(TAG, "SMS sent intent received.");
    }
}, new IntentFilter(SENT_ACTION));

// SMS delivered receiver
registerReceiver(new BroadcastReceiver(){
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d(TAG, "SMS delivered intent received.");
    }
}, new IntentFilter(DELIVERED_ACTION));

// Send the SMS message
SmsManager sms = SmsManager.getDefault();
sms.sendTextMessage(CELL_NUMBER, null, MESSAGE, sentIntent, deliveredIntent);

Upvotes: 16

Views: 20387

Answers (1)

Silambarasan
Silambarasan

Reputation: 665

This is a very late answer. but, it may help someone.

that code which is in question works fine, but, only change required is change the delivery request code. both are not to be the same request codes.

Here it is... and run on a real device to see delivery report.

EditText edNumber = findViewById(R.id.edNumber);
EditText edMessage = findViewById(R.id.edMessage);

String number = edNumber.getText().toString().trim();
String message = edMessage.getText().toString().trim();

// set pendingIntent for sent & delivered

        PendingIntent sentIntent = PendingIntent.getBroadcast(this, 100, new 
Intent(SENT_ACTION), 0);

        PendingIntent deliveryIntent = PendingIntent.getBroadcast(this, 200, new 
Intent(DELIVERY_ACTION), 0);

        registerReceiver(new BroadcastReceiver() {
            @Override
            public void onReceive(Context context, Intent intent) {
                Log.d("SMS ", "sent");
            }
        }, new IntentFilter(SENT_ACTION));

        registerReceiver(new BroadcastReceiver() {
            @Override
            public void onReceive(Context context, Intent intent) {
                Log.d("SMS ", "delivered");
            }
        }, new IntentFilter(DELIVERY_ACTION));

        SmsManager smsManager = SmsManager.getDefault();
        smsManager.sendTextMessage(number, null, message, sentIntent, 
deliveryIntent);

Upvotes: 5

Related Questions