Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1   Report Post  
Posted to microsoft.public.excel.programming,microsoft.public.win32.programmer.tapi
external usenet poster
 
Posts: 22
Default Using TAPI in Excel VBA

I wish to dial telephone numbers from an Excel VBA macro using my PC's
modem. A Google search came up with:
http://www.ozgrid.com/forum/showthread.php?t=16781
and
http://www.mrexcel.com/forum/showthread.php?t=70207
amongst others. Essentially they declare a function to access tapi32.dll:

Declare Function tapiRequestMakeCall Lib "TAPI32.DLL" (ByVal lpszDestAddress
As String, ByVal lpszAppName As String, ByVal lpszCalledParty As String,
ByVal lpszComment As String) As Long

And then use the function:

x = tapiRequestMakeCall(cPhone, "", cName, "")

where cPhone is a string containing the required number. e.g. "0123456789"

This works as expected. The Phone Dialer application pops up two windows at
the top left of the screen, once labelled "Preview" and the other "Phone
Call". However, I actually want to dial 'numbers' including the * and #
characters, for example, to cancel ringback on the BT network by dialling
"#37#" etc. If I enter a non-numeric number the second window has the title
"Internet Call" and the call fails with the message "Failed: wrong number or
the called device is out of service".

I can dial such numbers manually using Phone Dialer where I am able to
select whether I wish to dial as a Phone Call or as an Internet Call.

How can I dial # and * on the modem using TAPI32?


  #2   Report Post  
Posted to microsoft.public.excel.programming,microsoft.public.win32.programmer.tapi
external usenet poster
 
Posts: 3
Default Using TAPI in Excel VBA

"Andrew" schrieb im Newsbeitrag
...
x = tapiRequestMakeCall(cPhone, "", cName, "")

where cPhone is a string containing the required number. e.g. "0123456789"

This works as expected. The Phone Dialer application pops up two windows at
the top left of the screen, once labelled "Preview" and the other "Phone
Call". However, I actually want to dial 'numbers' including the * and #
characters, for example, to cancel ringback on the BT network by dialling
"#37#" etc. If I enter a non-numeric number the second window has the title
"Internet Call" and the call fails with the message "Failed: wrong number or
the called device is out of service".

I can dial such numbers manually using Phone Dialer where I am able to
select whether I wish to dial as a Phone Call or as an Internet Call.

How can I dial # and * on the modem using TAPI32?


Andrew,
the issue isn't caused by TAPI32.DLL but by MS Dialer.exe (Version from Active
Voice Corporation for W2k and XP).
This Phone Dialer interprets (by design) a non-numeric char within the
DestAddress as an internet-call request.

You can try to either use another TAPI app as MakeCall request recipient,
or develop a complete TAPI app yourself,
or use a some 3rd party component / control for this.

--
Best Regards
Andreas Marschall
Microsoft MVP for TAPI / Windows SDK / Visual C++
TAPI / TSP Developer and Tester
My TAPI and TSPI FAQ:
http://www.I-B-A-M.de/Andreas_Marschall's_TAPI_and_TSPI_FAQ.htm
My Toto® Tools (a collection of free, mostly TAPI related tools):
http://www.i-b-a-m.de/Andreas_Marschall's_Toto_Tools.htm
TAPI development around the world (Frappr! map):
http://www.frappr.com/TAPIaroundTheWorld
* Please post all messages and replies to the newsgroup so all may
* benefit from the discussion. Private mail is usually not replied to.
* This posting is provided "AS IS" with no warranties, and confers no rights.



  #3   Report Post  
Posted to microsoft.public.excel.programming,microsoft.public.win32.programmer.tapi
external usenet poster
 
Posts: 1
Default Using TAPI in Excel VBA

Andrew,

when you feed a phone number to the phone dialer
through tapiRequestMakeCall it must be in canonical
or plain number format.

If you want to have prefixes dialed you should configure
these in the location settings (Phone and Modem Options).

Best regards,

Matthias Moetje
-------------------------------------
TAPI WIKI: http://www.tapi.info
-------------------------------------
TERASENS GmbH
Augustenstraße 24
80333 Munich, GERMANY
-------------------------------------
e-mail: moetje at terasens dot com
www: www.terasens.com
-------------------------------------

"Andrew" wrote in message
...
I wish to dial telephone numbers from an Excel VBA macro using my PC's
modem. A Google search came up with:
http://www.ozgrid.com/forum/showthread.php?t=16781
and
http://www.mrexcel.com/forum/showthread.php?t=70207
amongst others. Essentially they declare a function to access tapi32.dll:

Declare Function tapiRequestMakeCall Lib "TAPI32.DLL" (ByVal
lpszDestAddress As String, ByVal lpszAppName As String, ByVal
lpszCalledParty As String, ByVal lpszComment As String) As Long

And then use the function:

x = tapiRequestMakeCall(cPhone, "", cName, "")

where cPhone is a string containing the required number. e.g. "0123456789"

This works as expected. The Phone Dialer application pops up two windows
at the top left of the screen, once labelled "Preview" and the other
"Phone Call". However, I actually want to dial 'numbers' including the *
and # characters, for example, to cancel ringback on the BT network by
dialling "#37#" etc. If I enter a non-numeric number the second window
has the title "Internet Call" and the call fails with the message "Failed:
wrong number or the called device is out of service".

I can dial such numbers manually using Phone Dialer where I am able to
select whether I wish to dial as a Phone Call or as an Internet Call.

How can I dial # and * on the modem using TAPI32?



Reply
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules

Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
Where can I find TAPI code/reference for VBA? John[_70_] Excel Programming 3 December 29th 03 10:57 AM


All times are GMT +1. The time now is 02:03 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Copyright ©2004-2025 ExcelBanter.
The comments are property of their posters.
 

About Us

"It's about Microsoft Excel"