其中有一组映射到 SWF 动画中的数据类型的对象:子图形、图形、文本、位图等等。在本文中,我使用了预编译的扩展 php_ming.dll 库用于 Windows 版本的 PHP。
清单 2 显示了使用 Ming 库实现的 HelloWorld 示例。
清单 2. Hello.php
<?php $f = new SWFFont( '_sans' );
$t = new SWFTextField(); $t->setFont( $f ); $t->setColor( 0, 0, 0 ); $t->setHeight( 400 ); $t->addString( 'Hello World' );
$m = new SWFMovie(); $m->setDimension( 2500, 800 ); $m->add( $t );
$m->save( 'hello.swf' ); ?>
|
在命令行中运行这段代码将生成文件 hello.swf。当我在 Web 浏览器中打开该文件时,看到了图 1 所示的结果。
图 1. 使用 Ming 的 HelloWorld 示例
回过头来查看这段代码,我做的第一件事是创建指向一个内置字体(_sans)的指针,然后创建文本字段,设定字体、颜色和大小,最后为其提供 一些文本内容(“Hello World”)。再接下来创建了一个 SWFMovie 对象并设定其尺寸。最后,向动画中添加了文本元素并将动画保存到文件中。
作为直接构建文件的替代性方法,也可以使用下面的代码,使 SWF 动画像页面那样输出,而无需使用 save 方法:
header( 'Content-type: application/x-shockwave-flash' ); $m->output( );
|
此过程类似于使用 PHP 中的 ImageMagick 库来构建位图。对于所有 Ming 示例,我都将使用 save 方法,但您可以根据喜好来选择是否使用 save 方法。
让文本动起来
只是将一些文本放入 Flash 动画中是没有多大意义的,除非您能让它动起来。因此我整合了清单 2 中的示例,它包括两段文本:一部分开始很小后来变得越来越大,而另一部分保持静态。
清单 3. Text.php
<?php $f = new SWFFont( '_sans' );
$pt = new SWFTextField(); $pt->setFont( $f ); $pt->setColor( 0, 0, 0 ); $pt->setHeight( 400 ); $pt->addString( '1000' );
$tt = new SWFTextField(); $tt->setFont( $f ); $tt->setColor( 192, 192, 192, 90 ); $tt->setHeight( 350 ); $tt->addString( 'Points' );
$m = new SWFMovie(); $m->setDimension( 2500, 800 );
$pts = $m->add( $pt ); $pts->moveTo( 0, 0 );
$tts = $m->add( $tt ); $tts->moveTo( 1300, 200 );
for( $i = 0; $i < 10; $i++ ) { $m->nextframe(); $pts->scaleTo( 1.0 + ( $i / 10.0 ), 1.0 + ( $i / 10.0 ) ); }
$m->save( 'text.swf' ); ?>
|
在命令行中执行这段代码时,它将生成 text.swf。在 Web 浏览器中打开该文件时,我看到了图 2 所示的图片。
图 2. text.swf 文件
文本 “1000” 开始时很小,大小为 350 个点。然后使用 scaleTo() 方法使其增大为 750 个点,方法是对动画对象使用 nextframe() 方法。
要理解其工作原理,需要了解一点 Flash 制作动画的方法。Flash 中的动画就像电影中的动画一样运行:按帧运行。子图形将按帧在动画框架中移动。一个主要差别是 Flash 不获取每帧的快照。它存储子图形对象在每帧的状态。
您可能会注意到,我有一个名为 $pt 的变量,该变量具有文本 “1000”。随后当我把 $pt 添加到动画中时,获得了通过 add() 方法返回的名为 $pts 的新对象。该对象是 SWFDisplayItem, 表示子图形的实例。然后我可以围绕动画框架的表面逐帧移动实例。 这有点儿混乱,但我可以拥有同时移动的多个版本的 “1000” 文本子图形或 “points” 文本子图形。
绘制一些图形
接下来要处理的是矢量图形。首先仅绘制一条简单的直线,它从框架的左侧顶部到右侧底部。
清单 4. Line.php
<?php $m = new SWFMovie(); $m->setDimension( 300, 300 );
$s = new SWFShape(); $s->setLine( 10, 0, 0, 0 ); $s->movePenTo( 10, 10 ); $s->drawLineTo( 290, 290 ); $m->add( $s );
$m->save( 'line.swf' ); ?>
|
在命令行中运行此脚本,然后查看输出的 .swf 文件,效果如图 3 所示。
图 3. 绘制简单的直线
好的 —— 这十分简单,也不怎么令人激动。那么我做了什么?创建了一个新的 SWFShape 对象,然后向其中添加了一些笔触移动和直线。然后我将其作为子图形添加到了动画中。
为了让它变得更有趣,我使用了与刚才文本中使用的相同的帧式动画。但在本例中,我用下面所示的代码使这条直线围绕动画的中心旋转。
清单 5. 旋转直线
<?php $m = new SWFMovie(); $m->setDimension( 300, 300 );
$s = new SWFShape(); $s->setLine( 5, 0, 0, 0 ); $s->movePenTo( -100, -100 ); $s->drawLineTo( 100, 100 ); $ts = $m->add( $s );
$ts->moveTo( 150, 150 );
for( $i = 0; $i < 100; $i++ ) { $ts->rotate( 10 ); $m->nextframe(); }
$m->save( 'rotate.swf' ); ?>
|
在本例中,我从 -100, -100 到 100, 100 画了一条直线。这将把直线的中心放在坐标 0,0 处。这样,当我在旋转图形时,直线的中心将发生旋转。
当我向动画中添加图形时,将移动返回到框架中心的 SWFDisplayItem。然后用 rotate() 方法使它旋转并每旋转一周就增大其框架。
使用图片
文本和诸如直线、圆、弧、曲线和矩形之类的简单矢量图形都是十分优秀的,但在理想的情况下,您必须能访问这些 Flash 动画中的图片。值得庆幸的是,Ming 库使您可以轻松的使用图片,如下所示。
清单 6. 使用图片
<?php $img = new SWFBitmap( file_get_contents( 'megan.jpg' ) );
$s = new SWFShape(); $imgf = $s->addFill( $img ); $s->setRightFill( $imgf ); $s->movePenTo( 0, 0 ); $s->drawLineTo( $img->getWidth(), 0 ); $s->drawLineTo( $img->getWidth(), $img->getHeight() ); $s->drawLineTo( 0, $img->getHeight() ); $s->drawLineTo( 0, 0 );
$m = new SWFMovie(); $m->setDimension( $img->getWidth() * 2, $img->getHeight() * 2 ); $is = $m->add( $s ); $is->moveTo( $img->getWidth() / 2, $img->getHeight() / 2 );
for( $i = 0; $i < 10; $i++ ) { $is->skewx( 0.02 ); $is->skewy( -0.03 ); $m->nextframe(); }
$m->save( 'image.swf' ); ?>
|
在命令行中运行此脚本并在浏览器中查看 image.swf,结果如图 4 所示。
图 4. 生成的图片动画
此脚本在开始时读取了本地的 .jpeg 文件(在本例中,是我女儿 Megan 的照片)。然后创建一个矩形,并在其中填充图片。在那之后,它在10 帧处使用了位移效果使图片稍微移动。
继续移动
我只是触及了 Ming 库可为您提供的操作的表面。在这里我没有展示交互部分,在交互部分您可以将简单的脚本与元素连接起来。(但是,如果换成是交互操作,如果您有一个十分复杂 的 Flash 动画,则可能需要考虑使用 Flash 开发工具来构建 Web 应用程序内与 Web 服务对话的 Flash 动画。)
构建更加复杂的 Flash 动画的另外一种选择是使用诸如 Adobe Flex 或 Laszlo 之类的制作工具,这两种工具都提供了用于为 Flash 动画的用户界面布局的 XML 语法以及一个更轻松地例程,可用于开发为界面提供互动操作的 JavaScript。
相关推荐:
Debian VPS邮件服务器搭建全攻略,轻松部署与管理邮件服务
为什么选择SEO会员服务,让您的网站流量飞速增长,seo网站首荐火星产品
seo是什么文章,seo指的什么 ,ai创意标识
seo工作的核心是什么,seo工作的内涵 推广证书模板下载网站
VPS微信支付宝一体化高效解决方案,便捷、安全,一站式满足您的需求
SEO就业前景如何?打造数字时代的职业新风口,金华seo优化图片
空调怎么样算库存机房?
SEO舆情:如何通过有效的舆情管理提升企业品牌形象,怎样优化网站小学
无机房家用电梯怎么样?
VPS竖型封口机,高效精准,封口首选之选
seo有什么瞄准方法,seo有什么瞄准方法和技巧 ,门口监控ai
seo稿件是什么意思,seo文章写作要求 ,ai胡涂涂
SEO要素:优化网站排名的关键因素全解析,seo项目案例分享
金马家具机房怎么样?
学校机房安装软件怎么样?
VPS公网带宽升级至3m,网速飙升新境界!
华为云VPS火灾事件揭秘,紧急关注,危机之下探寻真相!
SEO查:如何通过精准优化让网站流量飞速增长,淘宝新建网站推广
SEO北京:数字时代,企业成功的关键,高端网站建设seo优化
seo是什么云南,seo yun ,ai画画搞钱
seo能转什么岗位,seo可以转行做什么 C 建设个人网站
seo文本链接工具是什么,seo 链接 ,AI里剪辑
seo汉语是什么,seo什么意思 seo电脑关键词
seo智能优化是什么,seo自动优化工具 ,ai描边的形状
什么是seo及作用,简述什么是seo 谷歌seo信息是2
免费VPS半小时体验,速度与稳定性全面测试!
seo根据什么规则,seo包括哪些手段 ,AI触角
URL站长的崛起:打造高效网站运营的秘密武器,别墅营销策划推广方案
SEO埋词技巧,如何提升网站排名?,茶油营销推广策略
哪里有seo排名优化,seo排名优化的网站 好搜seo信息
《权重参谋:让您的网站轻松登顶搜索引擎的秘密武器》,潍坊在线网站建设
VPS 1T存储空间是否满足需求?详解存储空间需求分析
全球顶级***网站推荐,选择最佳国外VPS服务全攻略
如何做seo排名,seo的排名规则和计算方式 seo检测网站
机房墙板质量怎么样?
seo排名点击 seo查询,seo排行 ,ai纺配
SEO组织:让您的网站流量倍增的秘密武器,福田seo方法
SEO站外优化策略:提升网站排名的关键因素,嗨淘网站建设素材视频
seo线索收集是什么,seo线索收集是什么意思 ,志明ai
seo相关知识是什么,seo相关技术 ,富兰克林ai
专业SEO方案助力企业网站流量暴增,精准引流不再是难题,乌海网站网络推广联系人
seo属于什么职能类别,seo属于什么职能类别的 天门网站推广哪里好做
虚拟机能取代VPS吗?全面解析替代性与优势对比!
SEO地位:如何提升你的网站排名与曝光度,抢占市场先机,太仓网站建设制作费用
SEO站群:打造强大网络营销引擎,助力企业快速提升排名与流量,强大广告文案网站推广
江山机房精密空调怎么样?
什么叫seo技术,seo 技术 威海网站建设招聘
在美国机房工作怎么样?
SEO立刻:快速提升网站排名,带你走在搜索引擎前沿,青岛seo工资标准
seo能干什么工作,做seo工作真的可以吗 社区营销推广