Skip to main content

[Flex] Pixel Bender Filter 動畫應用



雖然 Pixel Bender 已經出現了好一段時間,但是一直都沒很認真的看過,周遭朋友也鮮少討論它...直到最近工作需求才有開始使用。以下是集合各家長處能簡單應用 Pixel Bender Filters 到 AS3 的作法。
  1. 先到 Adobe Pixel Bender Exchange 挑選想要的特效 (這邊是選擇 Crystallize ) ,下載後解壓出 Crystallize.pbj
  2. 曾經從 CJ Cat 那邊聽到 pbj 可以整個轉換到 AS 內,經過 google 大神指點,找到了一個超級無敵好用的 PBJ to AS converter... 感謝作者 Marek Burn 的好心分享!!!! 利用 converter 轉換 pbj to AS, 存成 CrystallizeShader.as 放到工作目錄內。Pbj 內可設定參數可以參考轉出來的 as 檔內說明。
  3. 編寫 mxml: 使用 mx 包內建的 Tween

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
applicationComplete="init()"
layout="horizontal" >
<mx:Script>
<![CDATA[
import mx.effects.Tween;

private var shader:CrystallizeShader;

private function init():void{
var initNum:Number = 50;
shader = CrystallizeShader.getInstance();
shader.size = initNum;
var tween:Tween = new Tween(this, initNum, 1, 6000, -1, onUpdate, onEnd );
w1.filters = [ new ShaderFilter(shader)];
}
private function onUpdate(num:Number):void{
shader.size = num;
w1.filters = [ new ShaderFilter(shader)];
}
private function onEnd(num:Number):void{
w1.filters = [];
}
]]>
</mx:Script>
<mx:Panel width="250" height="200" layout="absolute" title="Pixel Bender Test"
backgroundColor="#F8F8F8" id="w1" />
</mx:Application>



完工!!
Ps. Pixel Bender 需要 Flash Player10 喔! Flash 寫法大同小異,請自行轉換...=P

References :
Pixel Bender Exchange
goAndLearn(): Animating Pixel Bender Filters
Marek Burn's PBJ to AS converter
Edit 04/21/2009 : Marek Burn's blog 連結已經失效...我手上也沒有檔案,很抱歉~~
Edit 10/02/2009 : Marek Burn's blog PBJ to AS 連結又復活囉!!不過他 blog 還是掛的...

Comments

  1. 求 PBJ to AS converter !!
    該作者的blog的域名已經賣掉了
    也google不出該作者的新blog

    T_T Shader Rookie,,,

    ReplyDelete
  2. 啊...我並沒有抓他的swf....因為想說不太可能會不見...= = ,一樣還是可以用 ShaderFilter 的方法去載入 pbj, 然後做成 custom effect...所以唯一的影響就是寫法麻煩一些...

    ReplyDelete
  3. 恩恩也只能這樣用了
    也可以使用cj cat的wrap class
    any way 謝謝啦!

    ReplyDelete
  4. This one?? http://blog.brun.pl/PBJtoAS/

    ReplyDelete
  5. 妳好, 剛學習flex一小段時間, 看到範例中flex也可以使用tween, 想請問, 用tween和用effect有什麼差別? 或者用哪一種較好? 若問題很笨, 請見諒.^^

    ReplyDelete
  6. Effect = 特效集合, Tween = 基本特效元件,沒有用哪一種比較好...因為都是由 Tween 發展的...

    ReplyDelete

Post a Comment

Popular posts from this blog

PureMVC 我也會 [6]

Mediator ViewComponents 與 pureMVC 架構的中介 監聽並反應 View Component 發出的 Event 可以發送與接收 Notification 儘量少操作 Proxy 公開方法,多用 sendNotification... Mediator design pattern 要多認識這個 Mediator 設計模式的話,請自行看連結說明啊! 簡單來講,假使有一個 View 裡面有好幾個 MovieClip 組成,而這些 MovieClip 會互相影響對方...這個情況在 Flash 中,通常都會變成下圖: MovieClip 直接控制其他 MovieClip 搞到整個關係很複雜...換一個元件簡直是災難。 加入 Mediator 後,示意圖就會變成: 這樣,所有的 MovieClip 都透過 Mediator 來跟其他 MovieClip 溝通,當某一個 MovieClip 替換成別的元件,這時候也只需要修改 Mediator 中的引用即可,是不是變得很乾淨?如果同一組 MovieClip 有另外一個操作模式,也只需要替換掉 Mediator 即可!天下太平啊~~~ 而 PureMVC 中就是利用 Mediator class 為與前端 ViewComponent 的中介,這樣可以切開 ViewComponent 與 PureMVC framework 的關係,不管你前端介面使用 Flash or Flex 製作都跟程式核心無關。 所以 ViewComponent 製作時只需要兩個原則,一把所有的請求都以 Event 送出由 Mediator 處理,二提供公開方法, Mediator 只需要監聽 View 的 Event,將收到的資訊透過公開方法喂進 ViewComponent 即可。 如在 ViewComponent 中: public function setList( result:Object ):void{ list.dataProvider = result as ArrayCollection; } //然後在按下取得資料的按鈕 Click action 寫上: dispatchEvent( new Event( "GET_LIST" )); 新建 Mediator 的時候一樣有幾個重點方...