QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4736|回复: 0
打印 上一主题 下一主题

紧跟潮流:剖折QQ魔法表情实现原理

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2004-11-19 10:35 |只看该作者 |倒序浏览
|招呼Ta 关注Ta

这几天.QQ刚推出了2004II beta2,新的功能挺不錯,最吸引人的就是魔法表情,在MSN中叫WINKS,但QQ实现的不同MSN,QQ用的是FLASH做为原素材,而MSN的WINKS用的是GFI图片和声音文件合成的。

9 Y: [& }& g, J1 Q

[被屏蔽广告]  大家都知道,在QQ魔法表情启动时,内存会多一个MagicFlash.exe的进程,他就是一个简单的FLASH播放器,其实也不是什么播放器,原理就是一个网页.在QQ的安装目录下面可以找到这个MagicFlash.exe文件,你可以试着拖一幅FLASH文件(SWF)到MagicFlash.exe图标上,看看这就是所谓的魔法表情,呵呵.是不是很简单呢。

3 q3 l& E$ Y$ @- m7 I

  说到实现的原理,也是非常简单的,我仔细研究过,其实MagicFlash.exe就是一个网页查看程序(MFC写的,我也不知道是什么控件,反正就是能看网页就是了,如WebBrowser控件).当运行MagicFlash.exe时,程序把当前屏幕的固定区域截取下來,做这网页的背景,然后插入一个ActiveX小插件(当然是FLASH了),用来播放你给的Flash,同时把Flash的背景设为透明,这样就神不知鬼不觉地呈现了透明的FLASH播放在你的屏幕当中.其实并不是透明的,而是把当前的固定屏幕区域截取下来做为网页的背景,呵呵..是不是很简单呢.你也可以用任何语言写一个和MagicFlash.exe一样的程序呢.下面贴出来播放Flash的代码:

* {3 @+ l& k( p' T4 J

& f3 g/ R; O: D" D1 |   <html> 9 p+ @( W* Q1 z  <head> / A5 u' S* ~$ n. ?# q3 T; I  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />: c. a# e5 Q# o# q   </head>

- u0 h6 G! o8 u2 C

  <body background="mt4F.jpg" style="overflow:hidden" border= "0">

" l: v/ q4 a& P/ o( G

  <SCRIPT LANGUAGE="JavaScript">

3 i! X/ h% h) g; d; ]

  function ID1_DoFSCommand(command, args) {% q# ?7 V! T1 Y, i$ S    % k4 J5 J4 f. E8 Q4 g3 b- j  if(command=="window" && args=="closeResult close")

+ V `1 r8 j, n3 |

  { ' E5 d' i/ U! u   4 i/ q D% ~# R+ ~* C  document.getElementById('V1').innerHTML = ''; ]4 N G) }/ {, m! ]$ r( U# q    : Y/ H" m3 U% ~6 V' }9 C  }

: z( N) W. X+ s. _. f6 }0 A3 ]4 O

  }

6 T" O4 ~2 e+ g& w3 A% z. o

  </SCRIPT>

0 ^5 J4 \8 w8 H! l8 w( v/ U5 V

  <SCRIPT LANGUAGE="VBScript">

/ \% n! p2 e5 w/ y1 g

  On Error Resume Next3 A8 |: d, {8 G8 R2 d ) u. p0 e' Y& o! i   Sub ID1_FSCommand(ByVal command, ByVal args) ( g( }* J. P1 ?2 _0 a3 {% |* s   " J3 \/ G& O( v+ s6 g  Call ID1_DoFSCommand(command, args)) d& X2 M2 Y5 O4 H/ R6 Z! R   End Sub

, d7 ^3 v e. |+ E: i" v

  </SCRIPT>

2 \. w' G( `2 K: @0 B L

  <DIV ID="V1">

+ q# V3 b4 p3 |# x1 a: h( J5 a- x) h* }

  <object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" id="ID1" width="400" height="400"

! w' F8 I9 C6 I% r- I

  align="middle"> . W# N' Q8 [, J- j8 E2 ^  <param name="movie" value="dh188.swf" />9 \& ?2 @. S8 N5 b W' f   <param name="quality" value="high" />$ l: Q7 z- U2 p4 w) t! s5 x   <param name="wmode" value="transparent" /> $ d( b1 ?8 H& W- b6 H) \- W  <param name="bgcolor" value="#ffffff" /> C. [# q6 K" ]; x  <param name="allowScriptAccess" value="sameDomain" /> 8 g4 h& S" k A/ D% m( G H/ t  <param name="scale" value="showall" /> 6 ` t7 @3 [) T% h$ _  </object>/ D0 ~) C& ~. h) y. b/ R. m2 b* Q5 y- S: k   </DIV>& ^( g% S8 _& X' {% {# K- U   </body> 8 v6 `) a. c. i' b4 E4 V5 \  </html> ) R; h& Z: B8 r! } `

. g5 }- |# E: |* {9 x/ s

5 X) A& |) h0 a$ ~+ M   呵呵,上面的代码就是整个程序的核心,只要你的程序能查看网页,你就可以把这断代码用在你的网页上.当然条件是你必须先把當前的屏幕截取下來:

" B6 |4 I' q. j5 X/ T& J' X# G5 P

; C; L9 x+ _" ~   <body background="mt4F.jpg" style="overflow:hidden" border= "0">

3 L+ i6 z! J) h

4 q) ~1 |4 ?3 J2 E   "mt4F.jpg"就是你截取下來的图片,用他来做背景,才能和你的屏幕一致,才能达到透明的效果,还要注意不要变动程序的位置,QQ就是这样做的。

- U! h5 H4 t; N6 R# H

  以上这些都是经过我证实过了.代码也是MagicFlash.exe生成的,大家有兴趣可以研究一下,做出自己的"魔法表情"或其他更強大的程序,利用Flash的透明属性结合网页可以做到很多意想不到的效果. 3 N/ C. j4 e5 O) m/ R5 f  呵呵,小弟才疏学浅,看不懂的地方还请不要见怪。

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-19 12:21 , Processed in 0.410330 second(s), 52 queries .

回顶部