QQ魔法表情实现原理

这几天.QQ刚推出了2004II Beta II,新的功能挺不錯,最吸引人的就是魔法表情,在MSN中叫WINKS,但QQ实现的不同MSN,QQ用的是FLASH做为原素材,而MSN的WINKS用的是GFI图片和声音文件合成的.
大家都知道,在QQ魔法表情启动时,内存会多一个MagicFlash.exe的进程,他就是一个简单的FLASH播放器,其实也不是什么播放器,原理就是一个网页.在QQ的安装目录下面可以找到这个MagicFlash.exe文件,你可以试着拖一幅FLASH文件(SWF)到MagicFlash.exe图标上,看看这就是所谓的魔法表情,呵呵.是不是很简单呢..
说到实现的原理,也是非常简单的,我仔细研究过,其实MagicFlash.exe就是一个网页查看程序(MFC写的,我也不知道是什么控件,反正就是能看网页就是了,如WebBrowser控件).当运行MagicFlash.exe时,程序把当前屏幕的固定区域截取下來,做这网页的背景,然后插入一个ActiveX小插件(当然是FLASH了),用来播放你给的Flash,同时把Flash的背景设为透明,这样就神不知鬼不觉地呈现了透明的FLASH播放在你的屏幕当中.其实并不是透明的,而是把当前的固定屏幕区域截取下来做为网页的背景,呵呵..是不是很简单呢.你也可以用任何语言写一个和MagicFlash.exe一样的程序呢.下面贴出来播放Flash的代码:

 1<html>
 2<head>
 3<meta content="text/html; charset=utf-8" http-equiv="Content-Type"/>
 4</head>
 5<body background="mt4F.jpg" border="0" style="overflow:hidden">
 6<script language="JavaScript">
 7
 8function ID1_DoFSCommand(command, args) {   
 9  
10if(command=="window" && args=="closeResult close") 
11
12{   
13  
14document.getElementById('V1').innerHTML = '';   
15  
16} 
17
18} 
19
20</script>
21<script language="VBScript">
22
23On Error Resume Next 
24
25  
26Sub ID1_FSCommand(ByVal command, ByVal args)   
27  
28Call ID1_DoFSCommand(command, args) 
29
30End Sub 
31
32</script>
33<div id="V1">
34<object align="middle" classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" height="400" id="ID1" width="400">
35<param name="movie" value="dh188.swf"/>
36<param name="quality" value="high"/>
37<param name="wmode" value="transparent"/>
38<param name="bgcolor" value="#ffffff"/>
39<param name="allowScriptAccess" value="sameDomain"/>
40<param name="scale" value="showall"/>
41</object>
42</div>
43</body>
44</html>

呵呵,上面的代码就是整个程序的核心,只要你的程序能查看网页,你就可以把这断代码用在你的网页上.当然条件是你必须先把當前的屏幕截取下來:

1<body background="mt4F.jpg" border="0" style="overflow:hidden">   
2"mt4F.jpg"就是你截取下來的图片,用他来做背景,才能和你的屏幕一致,才能达到透明的效果,还要注意不要变动程序的位置,QQ就是这样做的.   
3以上这些都是经过我证实过了.代码也是MagicFlash.exe生成的,大家有兴趣可以研究一下,做出自己的"魔法表情"或其他更強大的程序,利用Flash的透明属性结合网页可以做到很多意想不到的效果.   
4呵呵,小弟才疏学浅,看不懂的地方还请见怪.</body>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus