| 前述 本控件是专门为高深商公司的"记得"系电脑来电管理器而设计,它适用JD-2000全系列的设备包括
 来电显示产品 JD-2000U  JD-2000C   JD-2002U  JD-2002C  JD-2004U  JD-2004C
 电话回拨产品 JD-2100U  JD-2100C   JD-2102U  JD-2102C  JD-2104U  JD-2104C
 电话录音产品 JD-2300U  JD-2300C   JD-2302U  JD-2304U
 录音回拨产品 JD-2500U  JD-2500C   JD-2502U  JD-2504U
 电话语音产品 JD-2600U  JD-2600C   JD-2602U  JD-2604U
 
 使用本控件你可以避免与硬件设备打交道,在你的应用系统中只要寥寥数行的代码即可将有关来电弹屏、自动拨号、电话录音、自动语音应答、黑名单的功能集成到你的系统里。
 
 
 控件的名称
 JDComPort.ocx
 需要的文件 qtintf.dll
 
 下载控件包: JDComPort.rar
 
 注册控件
 
 在Win7 和Win8,win10中 注册OCX控件的关键是要以管理员身份进行操作,具体的方法如下:
 
 1、将OCX文件存复制到Windows目录
 在64位系统下是:C:\Windows\Syswow64
 在32位系统下是:C:\Windows\System32
 
 2、注册:“运行”对话框中输入引号内命令: RegSvr32 XXX.OCX
 
 3、卸载:“运行”对话框中输入引号内命令:RegSvr32 XXX.OCX /U"
 
 4、如果注册时出现对DllRegisterServer的调用失败,则选择开始菜单->附件->“命令提示符”->右键,选择“以管理员身份运行”,然后在打开的窗口中,执行RegSvr32 XXX.OCX命令即可。
 
 例如注册 我们的来电管理控件 JDComport.OCX 时可以用以下的手工方法实现
 
 第一步:
 将文件 JDComport.OCX 和 qtintf.dll (会被JDComport.OCX 用到) 复制到文件夹
 c:\windows\System32 或者64位系统的C:\Windows\Syswow64 目录
 
 第二步:
 win7:    开始->所有程序->附件->CMD 命令
 win8:    鼠标移到桌面右上角->搜索->CMD 命令->屏幕左上方提示"命令提示符"->鼠标右
 键->以管理员身份运行
 
 第三步:
 在DOS命令窗口 进入 c:\windows\System32目录
 在提示符c:\windows\System32> RegSvr32 JDComport.ocx
 或
 c:\windows\System32> RegSvr32 C:\Windows\Syswow64\JDComport.ocx
 即可完成注册
 
 使用前的准备
 如果是USB接口的设备请确保驱动程序已经安装,如果你没有驱动程序,可以用以下链接下载:
 绿色指示灯设备驱动USB_To_COM32_DRIVER.zip
 红色指示灯设备驱动USBDRIVE.rar
 
 使用方法
 
 一、OCX控件的GUID:
 GUID={C4751F74-C039-4272-8532-11F7ACBAD184}
 
 二、控件的属性
 1、    port:  widestring
 
 来电设备与电脑连接的端口 字符串型 如"COM1"、"COM2"、"COM3"、"COM4"、"COM5" ....
 3、    baudrate:
 
 波特率只3种选择 br9600, br115200, br460800
 
 以上2个属性一般不用设定,在我们的控件里有一个方法查找设备(SetupPorts),可以把连接到电脑的设备找到,而且可以把找到的参数自动保存下来,以后再调用时会自动装入
 
 3、    connected: Boolean
 
 设备是否打开 如果打开返回 True  否则 False
 本属性是只读的
 
 
 三、函数与方法:
 1、 procedure Open
 
 作用:打开设备
 说明:此函数是其他函数与方法调用的前提,用来打开与电脑连接的设备,只有在设备被打开后才可以进行其他的操作。
 参数:无
 
 其它关联事项:判断一个设备是否打开可以用属性 connected 如果为TRUE则已经打开;多次打开不影响设备的相关操作。
 
 
 2、procedure Close
 
 作用:关闭设备
 说明:用来断开电脑与设备的连接。在退出程序前应关闭设备
 参数:无。
 
 3、function SetupPorts: WideString;
 
 说明:查找设备,查找与电脑连接的设备
 参数:无
 返回值:取消查找或找不到设备返回空串。找到设备"Ports=AAAA    BaudRate=BBBB"
 其中AAAA是串口的列表 如COM2,COM4 它们之间用逗号分开
 BBBB是串口的波特率代号 如7,13,它们之间用逗号分开(7=br9600  13=br115200 0=不如60800)
 
 注:找到设备时 AAAA 与 BBBB会被自动保存到与应用程序同名的ini文件中,在下次被调用时自动调入。
 
 4、procedure SetSate;
 
 说明:用来设定系统状态字
 参数:无
 返回值:无
 注:状态字被自动保存到与应用程序同名的ini文件中,在下次被调用时自动调入。
 
 
 5、function StartWaveIn(chanl: Integer; const WaveFile: WideString): WideString;
 
 说明:强制录音开始
 参数:chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 WaveFile:录音文件的文件名,如果文件名是个空字符串,则系统会自动生成文件名,如果是合法的文件名,则系统会以给出的文件名生产录音文件
 
 返回值:实际的录音文件名。如果文件名是空的则表示不能进行录音。如果已经开始录音了则返回实际的录音文件名。
 注:在一般情况下,不用调用本函数。在默认的情况下,控件会进行自动录音如果是打进的电话,摘机后1秒开始自动录音。打出的电话在播出3个电话号码后的6秒开始录音,在录音开始时会有事件发生。
 在未摘机的情况下,本函数失效。
 本函数适用 JD-230X JD-250X JD-260X 系列产品
 
 
 6、procedure StopWaveIn(chanl: Integer);
 
 说明:停止通道chanl的录音
 参数:chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 
 7、procedure SetHandUp(isHandup: Integer; chanl: Integer);
 
 说明:设定通道chanl摘机或挂机
 参数:isHandup: 摘机或挂机 1--摘机   0--挂机
 chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 注:本过程只适用于JD-250X和JD-260X系列的产品
 
 8、procedure PlayWaveFile(WaveFile: WideString; chanl: Integer);
 
 说明:在指定通道按文件播放语音
 参数:WaveFile: 录音文件 数据格式为 8位数据 1通道 采样率4800/秒
 chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 注:本过程只JD-260X系列的产品
 
 
 9、procedure PlayWaveByte(wavebyte: Smallint; chanl: Integer);
 
 说明:在指定通道按字节播放语音
 参数:wavebyte: 语音的采样值 数据格式为 8位数据 1通道 采样率4800/秒
 chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 注:本过程只JD-260X系列的产品
 
 10、procedure PlayWaveData(WData: OleVariant; chanl: Integer);
 
 说明:在指定通道按字节流播放语音
 参数:WData: 语音的采样流 数据格式为 8位数据 1通道 采样率4800/秒
 chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 注:本过程只JD-260X系列的产品
 
 11、procedure playWaveabort(chanl: Integer);
 
 说明:在指定通道停止播放语音数据
 参数:chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 注:本过程只JD-260X系列的产品
 
 12、function ReadFactryID: WideString;
 
 说明:  读取设备生产厂商的ID
 返回值:厂商的ID
 
 13、function ReadDevID: Integer;
 
 说明:  读取来电管理设备的设备号
 返回值:设备号
 
 14、function ReadDevVer: WideString;
 
 说明:  读取来电管理设备的型号和软件版本
 返回值:设备的型号和软件版本
 
 15、function LineStatus(chanl: Integer): Integer;
 
 说明:  通道的线路状态
 参数:chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于双口设备chanl的值有    0 、1、2、3
 返回值:线路状态  0--摘机  255--挂机
 
 
 16、function DialupChanl(const TeleNo: WideString; chanl: Integer): Integer;
 
 说明:回拨电话
 参数:TeleNo:电话号码
 chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于四口设备chanl的值有    0 、1、2、3
 返回值:没有意义
 注:电话号码的长度不要超过16个字节,超过16字节的建议一个一个地拨号,2个号码之间的延时要大于200ms
 
 对于要拨“0” 或 “9”才能拨外线的用户,可以先调用本命令拨“0” 等待一段时间后再拨后面要拨出的号码。
 如在通道0 拨 0,38259081 可以使用以下过程
 1、 DialupChanl('0',0)
 2、 延时 (不能超过10秒,否则在此期间要发出摘机命令)
 3、 DialupChanl('38259081',0)
 
 17、function WavePath: WideString;
 
 说明:保存录音文件的路径
 参数:无
 要设定本参数可以在SetSate中设定 或在JD2000OCX.INI中直接修改
 
 
 18、function SelectDev(const Devid: WideString): Integer;
 
 说明:选择当前设备
 参数:Devid:设备所在的端口 如"COM1"  "COM2" ..."COM8"
 返回值: -1 指定端口的设备不存在。
 0  指定端口的设备存在,并将当前设备设为指定端口的设备,对设备的操作为对这个设备的操作。
 本函数用于一台电脑接有多个来电管理器的情形。
 
 
 19、function CurDev: WideString;
 
 说明:返回当前设备
 参数:无
 返回值: 当前设备的端口 如 COM1 或 COM5等
 
 20、function PlayingWave(chanl: Integer): WordBool;
 
 说明:指定通道是否正在播音
 参数:chanl:通道号 通道1-4 的chanl值为0-3,
 对于单口设备chanl的值永远是0
 对于双口设备chanl的值只有  0 、1
 对于四口设备chanl的值有    0 、1、2、3
 返回值: 当前通道是否正在播音 TRUE--正在播音 FALSE--不播音
 
 四、事件与消息
 
 
 1、 procedure OnRead(const s: WideString; t: Double; const devid: WideString; const WaveFile: WideString)
 
 说明:当有来电显示或开始录音时,会产生这个事件。
 参数:   s: 来电或拨出的电话号码
 t: 发送来电或开始录音的时间 实际是个Date数据类型
 devid:设备号每一条线路对应一个设备号如"2-1"和"1-1"分别表示COM2口的第1条线和COM1口的第1条线
 WaveFile:录音文件的文件名,如果你不进行录音或你的设备没有录音功能的,可以忽略本参数
 
 2、 procedure OnKeyPress(const key: WideString; const devid: WideString);
 
 说明:当检测到有DTMF按键(电话按键)、电话振铃、摘机或挂机时,会产生这个事件。
 参数:   key: 电话按键或电话振铃、摘机或挂机
 key="R"、"T"、"H" 分表代表电话振铃、摘机和挂机
 key="0"、"1"、"2"、"3"...."9"、"*"、"#" 分表代表电话机的对应按键被按下
 devid:设备号每一条线路对应一个设备号如"2-1"和"1-1"分别表示COM2口的第1条线和COM1口的第1条线
 
 3、 procedure OnOpen;
 
 一次成功的Open过程会触发一次OnOpen事件
 
 4、 procedure OnClose;
 
 一次成功的Close过程会触发一次OnClose事件
 
 
 5、 procedure OnWaveIn(wavestring: OleVariant; Count: Integer; const devid: WideString);
 
 说明:当有录音数据被获取时,会产生这个事件。
 参数:wavestring:
 录音数据,是Byte数组;8位数据 1通道 采样率4800/秒
 Count: 数据的长度以Byte计
 devid:设备号每一条线路对应一个设备号如"2-1"和"1-1"分别表示COM2口的第1条线和COM1口的第1条线
 注:事件主要用于实时监听和用作语音网关
 
 6、 procedure OnStartRecord(const devid, FileNam
 |