QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4762|回复: 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图片和声音文件合成的。

# t* Q9 d( f# H0 q- p

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

# t: J8 U& Z% Z; Y2 @3 p

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

6 f! y8 ?; ?. t$ M

* b. l3 G' s! M, ~: E   <html>, [; F* n3 y- Y9 i   <head> 6 m2 s5 H9 g g  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 4 k+ [+ |. X# M1 |; Q* {( c  </head>

/ H0 X8 p* J9 a* {3 @: p! l

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

/ ?" G9 a" F8 S* K5 {

  <SCRIPT LANGUAGE="JavaScript">

. \4 G; m0 l: d

  function ID1_DoFSCommand(command, args) { ( V) H6 {9 i6 J   h0 n! @" X7 |3 v   if(command=="window" && args=="closeResult close")

4 @3 e. r1 |4 L" s+ Z% n: F

  {3 X5 C, T6 {/ @3 J( ]9 Y/ Q    8 U! }* u; j2 G  document.getElementById('V1').innerHTML = ''; 0 E( O% Z8 k9 u) g* m" j4 x  2 [0 ] \/ c) O6 Y) P6 C   }

& x t7 w; S4 r+ W* m; W* z

  }

) D4 U4 k: x! {8 V5 G" M

  </SCRIPT>

/ |: Q% x0 ^) x L. d1 d

  <SCRIPT LANGUAGE="VBScript">

# L# ]6 T- x# @4 R' J

  On Error Resume Next 7 H% N! n4 q# k % z, v3 U1 x% q! i- F  Sub ID1_FSCommand(ByVal command, ByVal args)+ g! s5 m8 A( @7 }    . }& {3 }, o0 k6 X7 O6 A! s  Call ID1_DoFSCommand(command, args)/ v' F2 b( h7 q) V7 `8 c. B   End Sub

% [4 A% \" S" `6 t1 ]. r$ W0 Y

  </SCRIPT>

; s' M( d# T; P

  <DIV ID="V1">

9 P% F8 f$ G, Z: W

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

% q4 f! h2 \/ A3 S; m

  align="middle">6 u4 X# x/ Q9 z: B7 G5 W9 O3 G   <param name="movie" value="dh188.swf" /> # G, O. ~# I4 K: F5 Q. u* k  <param name="quality" value="high" /> & M. Q/ g( B0 ~9 `/ O( a: X  <param name="wmode" value="transparent" /> $ m8 f& w) P9 X! U( ~  <param name="bgcolor" value="#ffffff" />2 j6 v& D) f. K/ [- a5 w$ [   <param name="allowScriptAccess" value="sameDomain" />! U7 k. E7 U9 [1 F2 j   <param name="scale" value="showall" /> " T; @1 L& | H5 K2 X5 j" @% R$ l x  </object>9 {+ T: T9 f6 b# |% \, E, _. X; R   </DIV> ' B4 c x m7 g/ c, E8 m. f  </body>! T8 \- c- ~1 S, d$ \7 q   </html>8 ~( {; U7 ?- X8 ^2 d6 s

$ a( _6 z1 l5 ?% _# l; e# Y+ R

3 u% Y$ H( W7 H2 y- d4 J1 |! |   呵呵,上面的代码就是整个程序的核心,只要你的程序能查看网页,你就可以把这断代码用在你的网页上.当然条件是你必须先把當前的屏幕截取下來:

2 q4 e2 c' C* e8 y( K

4 q, I0 O: u4 Q; T1 @   <body background="mt4F.jpg" style="overflow:hidden" border= "0">

/ S6 }8 s0 u1 F7 W

K0 ~ D& `) b( d5 C& K  "mt4F.jpg"就是你截取下來的图片,用他来做背景,才能和你的屏幕一致,才能达到透明的效果,还要注意不要变动程序的位置,QQ就是这样做的。

8 h( o/ T6 B! i& I) }' W, M m

  以上这些都是经过我证实过了.代码也是MagicFlash.exe生成的,大家有兴趣可以研究一下,做出自己的"魔法表情"或其他更強大的程序,利用Flash的透明属性结合网页可以做到很多意想不到的效果.# r) [! }) X* e% w7 Q" C2 ~   呵呵,小弟才疏学浅,看不懂的地方还请不要见怪。

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-6-10 22:20 , Processed in 0.411159 second(s), 51 queries .

回顶部