计算机收发短信的OCX控件二次开发说明 |
chen在2011/4/13发表,被浏览4516次
|
下载地址:JDCellPhoneXC.ocx 控件是标准的ActiveX控件,适用于Windows平台下的所有开发编程工具,例如Delphi、VB、C#、C++、Java、PB等。控件封装了标准AT指令、手机与计算机的通信内容,提供了发送短信、接收短信、拨打电话、接听电话等函数和事件,非常方便二次开发。 控件需要的硬件设备是高深商公司研发的“手机盒”(见下面的名词解析)或能与计算机连接的手机(要求手机通过COM口通信)。 名词解析: 超长短信 --- 当短信超过68个字时,就是超长短信。手机自动把超长短信分成几条短信发送,接收时也分多条短信形式存储在SIM卡中,在读短信时,临时组装成超长短信。 手机盒 --- 与计算机连接的设备,插入SIM卡才能使用。该设备尺寸为100mm×58mm×24.5mm(长×宽×高,其中天线21mm),有一个标准的USB接口,通过标准的USB连接线,连接计算机。该设备不用电池,启动计算机后,就会自动开启。利用此设备,可以把计算机当成手机使用,在电脑上收发短信,拨打电话。一台计算机可以连接多个设备,并通过参数devid区分不同的手机盒。有关手机盒的更多详细信息,请拨打电话020-38259081咨询。 主要属性: BaudRate --- 与计算机连接的波特率,最好不要人工设置,而是采用设置函数SetupPort自动查找。 Port --- 与计算机连接的端口,同上不要人工设置。 JDConnected --- 与计算机是否已连接,即是否已经打开端口,布尔型。 QueryATSeconds --- 当执行AT查询指令时,最长等待反应时间,默认2秒,整数。 ReadLongSmsSeconds --- 读超长短信时,最长的延时时间,默认30秒,整数。 ReadSmsSeconds --- 读普通短信时,最长的延时时间,默认5秒,整数。 ReadLongSmsWay --- 读短信函数ReadSms的工作方式(针对超长短信),有0、1、2数值可选择: 0 一般用于收到短信事件OnSms中;在读超长短信时,只有当id为最后一条短信id,才完整地读超长短信; 1 常用的读短信方式;当遇到超长短信时,首先计算此超长短信第一条id,按顺序读,当不成功时,读所有短信; 2 只要是超长短信,首先把SIM卡内的所有短信都读出来,拼接成此条超长短信; 建议在OnSms事件中调用ReadSms时,ReadLongSmsWay设为0,其它时候设为1。 ReturnCompleteLongSms --- 布尔型,默认False;如果设为True,ReadSms读短信,当遇到超长短信时,只有当超长短信读完整,才返回短信内容,读超长短信异常,例如超长短信还没有完整接收时,就执行ReadSms,导致超长短信不能读完整,则ReadSms返回0。 ShowRxChar --- 布尔型,默认False;如果设为True,显示手机盒与计算机通讯的内容,方便调试。 ShowTip --- 布尔型,默认True,表示当执行ReadSMS、ReadAllSms、QueryAT等函数时,提示手机盒正在与计算机通讯。 ExecJDSmsEvent --- 布尔型,默认True,表示收到短信时自动执行OnJDSms事件;当为False时,不触发OnJDSms,即不执行OnJDSms。 OnlyCheckUSBtoSerialComport --- 布尔型,默认True,表示在查找端口时只找USB转COM的端口。 主要事件: OnAfterOpen ---- 打开连接端口时触发。 函数原型:procedure AfterOpenEvent(Sender: TObject); OnAfterClose ---- 关闭连接端口时触发。 函数原型:procedure AfterCloseEvent(Sender: TObject); OnRing --- 当有电话呼入时,手机响铃,触发此事件;有3个传递参数值: no为来电号码,字符串; index是本次来电的响铃次数,其值为1,2...; devid是手机盒连接标识号,整数,其值为0,1,2... 函数原型:RingEvent(Sender: TObject; no: String; index, devid: Smallint); OnEndRing --- 对方挂断手机,响铃结束,触发此事件;有1个传递参数值: devid是手机盒标识号,其值为0,1,2... 函数原型:EndRingEvent(Sender: TObject; devid: Smallint); OnNoCarrier --- 拨号失败、连接不成功等均触发此事件;有2个传递参数值: str为失败原因: NO CARRIER、NO ANSWER、BUSY; devid是手机盒标识号。 函数原型:NoCarrierEvent(Sender: TObject; str: String; devid: Smallint); OnJDSms --- 手机盒接收到短信,并完整读取短信时,触发此事件;事件在ExecJDSmsEvent=True时有效;有5个传递参数值: id为短信标识号,可根据此id删除SIM卡内的短信; no为发送短信号码; t为接收短信时间; s为短信内容; devid是手机盒标识号。 函数原型:JDSmsEvent(Sender: TObject; id, no, t, s: String; devid: Smallint); OnSms --- 手机盒接收到短信时,触发此事件;有2个传递参数值: id为短信标识号,可根据id值读短信; devid是手机盒连接序号; 函数原型:SmsEvent(Sender: TObject; id: String; devid: Smallint); 与OnJDSms事件的不同点: OnSms不读短信,只要接收到短信,就触发此事件; OnJDSms在接收到短信时,马上读取短信,并判断短信是完整的,才触发此事件; 推荐使用OnJDSms。 主要函数: SetupPort --- 设置手机盒与计算机连接的端口,可以自动查找端口,一般在第一次使用时调用;成功时保存连接参数,并返回True;有1个参数: ShowForm 是否显示查找端口,True表示显示查找端口界面,False表示不显示查找端口界面。 函数原型:function SetupPort(ShowForm: WordBool): WordBool; Open --- 打开连接,JDConnected设为True。 函数原型:procedure Open; Close --- 关闭连接,JDConnected设为False。 函数原型:procedure Close; InitSIM300 --- 对手机盒初始化,一般在第一次使用时调用,返回设置手机盒的参数。 函数原型:function InitSIM300: WideString; LoadComportParam --- 在程序启动时调用,读取手机盒与计算机的连接参数;这些参数是在 SetupPort时保存的。 函数原型:procedure LoadComportParam; GetComportCount --- 返回手机盒与计算机的连接数量。 函数原型:function GetComportCount: Smallint; ReadSms --- 读短信函数,返回短信数量;有5个参数: id 短信标识号,函数按id读短信;当是超长短信时,id返回超长短信的第一条短信id; no 发送短信号码,返回值; t 短信接收时间,返回值; msg 短信内容,返回值; devid 手机盒标识号,表示从哪个手机盒读短信;当只有一个手机盒与计算机连接时,赋0。 函数原型:ReadSms(var id, no, t, msg: WideString; devid: Smallint): Smallint; ReadAllSms --- 读取所有短信函数,返回短信数量;有2个参数: memo 所有短信内容,返回值; devid 手机盒标识号,表示从哪个手机盒读短信。 函数原型:ReadAllSms(var memo: WideString; devid: Smallint): Smallint; SendSms --- 发送短信函数,返回成功发送短信的号码;有3个参数: nos 要发送的手机号码,可群发,号码之间用;或空格分隔; msg 要发送的短信内容; devid 手机盒标识号,表示用哪个手机盒发短信。 函数原型:function SendSms(const nos, msg: WideString; devid: Smallint): WideString; DeleteSms --- 删除短信的函数;有2个参数: id 短信标识号,函数按id删除短信; devid 手机盒标识号,表示删除哪个手机盒的短信。 函数原型:DeleteSms(const id: WideString; devid: Smallint): WordBool; QueryAT --- 向手机盒发送AT指令,返回手机盒响应内容,主要用于测试;有3个参数: cmd --- AT指令; mlines --- 返回内容是否有多行; devid 手机盒标识号,表示向哪个手机盒发AT指令。 函数原型:QueryAT(const cmd: WideString; mlines: WordBool; devid: Smallint): WideString; SIM300Setup --- 设置手机盒音量等参数,成功返回True;有1个参数: devid 手机盒标识号,表示设置哪个手机盒的参数。 函数原型:SIM300Setup(devid: Smallint): WordBool; DoDial --- 拨号函数,成功返回True,失败可用GetEroroCode查询原因;有2个参数: no 拨出号码; devid 手机盒标识号,表示用哪个手机盒拨号。 函数原型:DoDial(const no: WideString; devid: Smallint): WordBool; DoAnswer --- 接听电话函数,摘机,有1个参数: devid 手机盒标识号,表示接听哪个手机盒电话。 函数原型:DoAnswer(devid: Smallint): WordBool; DoHold --- 挂断电话函数,挂机,有1个参数: devid 手机盒标识号,表示挂断哪个手机盒电话。 函数原型:DoHold(devid: Smallint): WordBool; AllowSendDTMF --- 检查是否处于通话中,返回True,表示在通话中,可以发送应答拨号音;有1个devid参数。 函数原型:function AllowSendDTMF(devid: Smallint): WordBool; SendDTMF --- 在通话过程中,按语音提示输入应答内容,例如提示选择数、密码、账号等;有2个参数: str 应答的字符串,按语音提示格式输入;只能使用字符:'0'..'9', '*', '#', 'A'..'D'; devid 手机盒标识号。 函数原型:SendDTMF(const str: WideString; devid: Smallint): WordBool; getCNUM --- 返回本机号码,当为空时,表示未设置本机号码;有1个devid参数。 函数原型:function getCNUM(devid: Smallint): WideString; setThisPhoneNo --- 设置本机号码,成功时返回True;有2个参数: no 要设置的本机号码,当为空时,表示清除本机号码; devid 手机盒标识号。 函数原型:setThisPhoneNo(const no: WideString; devid: Smallint): WordBool; getCSQValue --- 返回手机信号强度,整数值,0表示无信号,31表示信号最强,-1表示不能获取信号强度;有1个devid参数。 函数原型:function getCSQValue(devid: Smallint): SYSINT; ShowWaiting --- 显示提示窗口,有3个参数: Caption 窗口标题; Tip 提示内容; MilliSeconds 提示窗口显示时间长度,单位毫秒,到时自动关闭;或调用CloseWaiting提前关闭。 函数原型:ShowWaiting(const Caption, Tip: WideString; MilliSeconds: Integer); CloseWaiting --- 强行关闭提示窗口。 函数原型:procedure CloseWaiting; AboutBox --- 显示OCX控件版本。 函数原型:procedure AboutBox; ReadSimBooks --- 按索引号(存放位置)读取SIM卡中的电话号码和姓名,成功时返回True;有4个参数: index 电话号码在SIM卡中的存放位置,即索引号; no 电话号码,返回值; name 姓名,返回值; devid 手机盒标识号。 函数原型:ReadSimBooks(index: Smallint; var no, name: WideString; devid: Smallint): WordBool; ReadSimBooksAll --- 返回SIM卡中的所有电话号码,1行1个号码,即号码之间分隔符为回车和换行符;有1个devid参数;返回的内容可调用ExtractSimBooks提取电话号码和姓名。 函数原型:function ReadSimBooksAll(devid: Smallint): WideString; ExtractSimBooks --- 从返回的字符串中按行提取电话号码和姓名,提取成功时返回True;有4个参数: str 要分析的字符串,即ReadSimBooksAll返回的其中1行内容; index 电话号码在SIM卡中的存放位置(索引号),返回值; no 电话号码,返回值; name 姓名,返回值; 函数原型:ExtractSimBooks(const str: WideString; var index, no, name: WideString): WordBool; AddSimBooks --- 向SIM卡中添加电话号码,成功时返回True;有4个参数: no 电话号码; name 姓名; index 在SIM卡中的存放位置(索引号),一般采用0,即自动按顺序存放; devid 手机盒标识号。 函数原型:AddSimBooks(const no, name: WideString; index, devid: Smallint): WordBool; DeleteSimBooks --- 删除SIM卡中的电话号码,成功时返回True;有2个参数: index 要删除的号码在SIM卡中的存放位置(索引号); devid 手机盒标识号。 函数原型:function DeleteSimBooks(index, devid: Smallint): WordBool; 开发要点: (1)在程序启动时,调用LoadComportParam函数。 (2)在第一次使用程序时,请调用SetupPort函数,设置与计算机连接的参数;成功设置后,请调用InitSIM300初始化手机盒模块。 (3)程序启动后,请调用Open函数打开连接;如果在程序设计时,JDConnected=True,则此步骤忽略。 (4)调用DoAnswer、DoHold、DoDial函数,实现拨打、接听电话。 (5)在OnRing、OnEndRing、OnNoCarrier事件中编写处理代码,可实现来电显示。 (6)在OnJDSms中编写处理代码,可自动接收短信。 (7)调用SendSms函数,可发送短信。 (8)调用ReadSms、ReadAllSms、DeleteSms函数,可读取、删除SIM卡内的短信。
|
|
|
|