一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

PHP生成Flash動畫的實現代碼

其中有一組映射到 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 示例
使用 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 文件
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。

php技術PHP生成Flash動畫的實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 伊人2| 中文字幕美日韩在线高清 | 欧洲视频一区 | 精品久久久久久中文 | 久久网站视频 | 国产精品亚洲国产三区 | 亚洲精品私拍国产福利在线 | 久久久久久91香蕉国产 | 午夜视频在线观看www中文 | 激情五月婷婷小说 | 97色婷婷| 婷婷香蕉 | 一本久久精品一区二区 | 国产在线视频h | 中文字幕一区二区在线观看 | 国产一区二区精品久久凹凸 | 亚洲狠狠97婷婷综合久久久久 | 久久久久久亚洲精品中文字幕 | 97人人模人人爽视频一区二区 | 四虎永久免费网站免费观看 | 色多多网址 | 国内精品美女久久久久 | 国产精品久久久久久麻豆一区 | 国产精品视频1区 | 成人入口 | 亚洲人成图片欧美人成图片 | 日韩成人免费在线 | 国产熟睡乱子伦视频观看看 | 米奇777四色精品人人爽 | 免费韩国美女爽快一级毛片 | 91新网址 | 国产综合欧美日韩视频一区 | 国产精品麻豆一区二区三区v视界 | 狠狠综合久久综合88亚洲日本 | 98bb国产精品视频 | 国产在线视频一区 | 在线欧美成人 | 国产成人深夜福利短视频99 | 国产在线观看色 | 日本xxx在线观看 | 一级做a爰片性色毛片男 |