In a similar vein to Sending Pause and DTMF input in android, I'm trying to send the pause character "," to the dialer. This works on HTC Sense phones and even on the Xoom, but not on "stock experience" phones like the Nexus One or T-Mobile G2 (and I suspect the Motorola Droid).
These phones seem to have a dialer that tries to pretty-format the number (ie adding dashes) and stop upon hitting a comma character. Interestingly, it doesn't choke on a "p" character, though it will strip out "p"s and keep adding numbers.
Here is what the ActivityManager sees:
I/ActivityManager( 92): Starting activity: Intent { act=android.intent.action.DIAL dat=tel:8883333,444 cmp=com.android.contacts/.DialtactsActivity }
I've also tried the encoded form, "tel:8883333%2C444" with no difference in behavior on these phones. I've tried "p", as mentioned, but these characters are dropped resulting in the dialers having 888-333-3444 incorrectly populated, and I'm not sure that "p" is correct anyway.
So, the question: Is there a way to specify a pause that works across most or all android dialers?
dialing pause has been comma for 30 years
If the android phone is compatible with ITUT V.250 ATS8=2 should set the delay caused by comma to 2 seconds. (it's possible that it has somehow been set to 0s)
ITUT is a great standards orgnisation, you can download their standards for free.
',' is the standard but HTC used 'p' in rogers magic,, have you tried with 'p'? HTC Magic is using p
From the android's latin ime source code:
I am not 100% sure if it's public, but you might be able to use:
Short answer: Doesn't look like it's possible using the native dialer.
Long answer:
The native dialer in Android uses the following code to extract the number you pass in to the dialer using an Intent
Within the
setFormattedDigits
method the number gets transformed thusly:Looking at the docs for
extractNetworkPortion
you'll notice that it, "Extracts the network address portion [where the] Network address portion is everything up to DTMF control digit separators (pause or wait).So the code is intentionally striping out the pause character and anything that comes after it. The only alternative I can think of is to replace the dialer or use the
ACTION_CALL
action instead ofACTION_DIAL
. That'll bypass the dialer, so it should be used with caution.For future reference RFC-2806 specifies storing telephone numbers in the format:
Where
number
can start with+
for intentional dialling and can include-
or.
as a visual separator andpost-dial
can include numbers, upper case letters A-D,#
,*
,p
for pause andw
for wait.This is horrible and dangerous. Business people getting conference call emails on their phone have to constantly switch back and forth to get the number.
Just make it work like it should:
Should dial the
877
number pause then dial in the participant conference code and 'enter' (#) when selected anywhere on the phone.It's that simple. The fact this doesn't work in Android is a iPhone sales pitch.