末日编程者_第七十四章 再改豌豆射手 首页

字体:      护眼 关灯

上一页 目录 下一章

   第七十四章 再改豌豆射手 (第3/3页)

声音的组建,好在豌豆射手天生有听觉模型,并且在炮筒上也长着嘴巴,韩海只需要把这两样功能模块,进行取样和转发就可以了。

    到了这一步,韩海就必须使用钩子技术了,他一共编写了2个篡改函数,因为函数的原型韩海可以看到,所以篡改以后的函数可以无缝对接原来的功能,从而不影响以前的程序。

    第一个篡改的是豌豆射手收听声音的函数,他只不过是从中截取了每一帧声音的数据。

    第二个篡改的是豌豆射手发声的函数,这一次他需要在发出声音的队里中,加入自己从socket收到的声音数据。

    豌豆射手声音的样板是标准的PCM,也就是PulseCodeModulation,即为脉冲编码调制。

    在光纤通信系统中,光纤中传输的是二进制光脉冲“0”码和“1”码,它由二进制数字信号对光源进行通断调制而产生。而数字信号是对连续变化的模拟信号进行抽样、量化和编码产生的,称为PCM(Pulse-codemodulation),即脉冲编码调制。

    而这种样本数据一般数量级比较大,不利于传输,所以韩海使用了一个通用压缩标准AAC进行编码传输,AAC即是高级音频编码(AdvancedAudioCoding)。

    目前韩海可以粗略的实现AAC的编码步骤,这种压缩编码算法是有损失的算法,原理采样一段时间内的PCM数据,然后使用傅里叶变幻编解码,声音其实就是不同频域的振幅,叠加起来的正弦波,编码算法其实就是进行时域正弦波叠加成近方型的正弦波,而解码就是使用傅里叶反变换,把叠加正弦波解码成原来一段段的正弦波。(这里只是粗略的进行编解码)

    再之后的步骤,把压缩后的音频向服务器进行发送就可以了,再由服务器转发到另外的客户端,当客户端接收到音频消息的时候,再运行篡改后的发声函数,这样就达到了通讯的目的。

    当然客户端也必须建立一套身份标识,否则通讯就无从寻找联系人了,这一点韩海已经想到了,当建立模型的时候,韩海可以给每个豌豆射手设置一个数字号码,当有人想要通讯的时候,在豌豆射手上拨号就可以了,而且系统内部还建立的群组概念,其实就是聊天群,联系人可以在群里发信息与群组内的所有人通讯。

    之后韩海还编写了一套聊天界面,他把豌豆射手一侧绿色的表皮,变成动态的屏幕,这样用户就既可以发送声音也可以发送文字了。(参考QQIM)

    目前韩海并没有开发视频聊天的功能,因为视频的编码比起声音来说复杂了不止一点,这是他以前学习中所欠缺的内容,这需要他再学习下H264视频编码后才可以实现,所以这里他留下了一个扣子,只有等以后再改进了。

    做完这些,韩海把socket连接的函数写好,然后仔仔细细观察起写好的代码来,这是他许久以来养成的习惯,没有一个程序员,敢说自己写的程序没有BUG,如果有人说了,那么只是他没发现而已。

    没一会儿,韩海又修改了几处地方,然后仔仔细细再看了一遍,直到发现不了问题后,他才送了一口气。

    在这个时候,他才感觉到一股困意袭来,显然大量代码的编写,耗费了他大量的精力,这使得他心中一惊,因为明天还有事情做,想到这里他不敢怠慢,开始放空自己的脑袋,真正不去思想东西,这才沉沉的睡了过去。

加入书签 我的书架

上一页 目录 下一章