跳到主要內容

TweenMax MosaicPlugin

Flash製作Mosaic效果還滿常見的
但要給設計師們使用這樣的類別,好像不是那麼容易
就想到TweenMax有Plugin的概念, 讀了一下原理,就自己寫一個
這樣只要會使用TweenMax就可以使用這樣的效果。

線上Demo
需要再下載gs.TweenMax類別才能使用喔
完整程式碼

/**
/**
 * @author milkmidi
 * @see http://milkmidi.blogspot.com
 * @version 1.0.0
 * @date created 2010/04/16/
 */
package milkmidi.tweenmax.plugins {
 import flash.display.*; 
 import flash.geom.*; 
 import gs.plugins.TweenPlugin; 
 import gs.TweenLite;
 public class MosaicPlugin extends TweenPlugin {  
  public static const VERSION :Number = 1.0; 
  public static const API  :Number = 1.0; 
  private var _target  :Sprite;  
  private var _bitmap  :Bitmap;  
  private var _targetWidth:int;
  private var _targetHeight:int;
  private var _startValue :int = 0;
  private var _endValue :int = 20;
  private var _autoDestroy:Boolean = true;
  public function MosaicPlugin() {
   super();
   this.propName = "mosaic";
   this.overwriteProps = ["mosaic"];
   this.onComplete = onCompleteTween;
  }
  override public function onInitTween(pTarget:Object, pValue:*, $tween:TweenLite):Boolean {   
   if (!(pTarget is Sprite)) {
    trace("motionBlur tweens only work for DisplayObjects");
    return false;
   }
   _target = pTarget as Sprite;   
   _bitmap = _target.getChildByName("_mosaic_bitmap") as Bitmap;
   if (_bitmap == null) {    
    _bitmap = new Bitmap();
    _bitmap.name = "_mosaic_bitmap";
   }  
   if (typeof(pValue) != "object") {
    trace("parameter must be object");
    return false;
   }   
   _startValue = pValue.start;
   _endValue = pValue.end;   
   _autoDestroy = (pValue.autoDestroy == undefined) ? true: pValue.autoDestroy ;
   _target.addChild(_bitmap);   
   _targetWidth = _target.width;
   _targetHeight = _target.height;
   return true;
  }  
  public function onCompleteTween():void { 
   if (_autoDestroy==false) 
    return;   
   if(_target.contains(_bitmap))
    _target.removeChild(_bitmap);
   try {
    _bitmap.bitmapData.dispose();
   }catch (err:Error){}   
   _bitmap = null;   
  }
  override public function killProps($lookup:Object):void {
   super.killProps($lookup);
   _autoDestroy = true;
   onCompleteTween();
  }
  override public function get changeFactor():Number { return super.changeFactor; }  
  override public function set changeFactor(value:Number):void {
   super.changeFactor = value;   
   var _pixelSize:Number;      
   if (_startValue < _endValue) 
    _pixelSize = (value * _endValue) + 1 + _startValue;    
   else
    _pixelSize = ((1 - value) * _startValue) + 1 + _endValue;    
   _bitmap.bitmapData = new BitmapData(_targetWidth / _pixelSize, _targetHeight / _pixelSize, false);          
   var _matrix:Matrix = new Matrix();    
   _matrix.scale(1 / _pixelSize, 1 / _pixelSize); 
   _bitmap.visible = false;
   _bitmap.bitmapData.draw(_target, _matrix);    
   _bitmap.visible = true;
   _bitmap.width = _targetWidth;
   _bitmap.height = _targetHeight;
  } 
 }
 
}
測試用程式
/**
* @author milkmidi
* @see http://milkmidi.blogspot
* @version 1.0.1
* @date created 2010/04/15/
*/
package {
import flash.display.*; 
import flash.events.MouseEvent;
import gs.*
import gs.plugins.*;
import gs.easing.*; 
import milkmidi.tweenmax.plugins.MosaicPlugin;
public class MotionBlurPluginDemo extends Sprite {
[Embed(source='demo300x300.jpg')]
public static const Texture:Class;
public function MotionBlurPluginDemo() {
stage.scaleMode = StageScaleMode.NO_SCALE;
stage.align = StageAlign.TOP_LEFT;

var mc:Sprite = addChild(new Sprite()) as Sprite;
mc.addChild(  new Texture() );
addChild(mc);

TweenPlugin.activate([MosaicPlugin]);
//啟動 MosaicPlugin 
//之後就可以使用 mosaic 屬性
//mosaic 屬性現別必需要是Object, 
//可以使用的參數有 
/*
* start: 開啟的mosaic效果,  
* end:結束的mosaic效果, 
* autoDestroy: 當TweenMax完成時, 是否自動摧毀該效果, 預設值是true
*/ 

mc.addEventListener(MouseEvent.ROLL_OVER , function ():void {
TweenMax.to(mc, .8,
{ 
mosaic: { start:0, end:20 , autoDestroy:false }    
} ); 
});
mc.addEventListener(MouseEvent.ROLL_OUT , function ():void {
TweenMax.to(mc, .8,
{ 
mosaic: { start:20, end:0 }    
} ); 
});
}
}
}

留言

HARDMOUSE寫道…
你真的很活用耶~~利害!!
milkmidi寫道…
謝謝啦,因為懶的每次都寫一次
而且大家都會用TweenMax,就掛進去就好了
匿名表示…
綠奶大大可以請問一下
super();
的作用嗎?
謝謝
milkmidi寫道…
super 是會出現在繼承的關系
分二部份來說明
在建構函式時
super是呼叫父系的建函含式
如:父.as
public function 父(參數一){}
子.as
public function 子{
//因為父類別有明確規定要帶一個參數
//所以子類別在建立時, 也要帶一個參數父類別
//此時就寫成
super(參數一)
}

另一個出現的時機點:
父.as
public function 喝奶茶():void{}

子.as
因為是繼承關系, 所以子類別也有 喝奶茶 方法
而子類別如果要呼叫該方法時
可以寫:
喝奶茶(); //呼叫自己的方法, 但因為自己的該方法並沒有被重新override掉, 所以就視同呼叫父的方法
或是
super.喝奶茶(); //呼叫父系的方法。

如果子.as
override public function 喝奶茶():void{}

那在子.as寫
喝奶茶();//呼叫自己override掉的喝奶茶
跟super.喝奶茶()//呼叫父系的喝奶茶
會有這樣的差別
匿名表示…
謝謝老師的用心解說
匿名表示…
不好意思在請問一下
可是我看老師的super()並沒有帶參數
milkmidi寫道…
是這樣的
super()如果沒帶參數
指的就是呼叫父系的建構函式
反正不寫也是會執行。
所以沒什麼差別,
如果要說有差的話,
在進階一點的類別寫法才會有差
匿名表示…
謝謝!
Jacky表示…
請教老師一個問題~
我在作 TweenMax 時,遇上一個動作不知道如何使用
TweenMax 才能達到這樣子的效果。

我的情形是~

有一個 mc 元件,想要以 Quad.easeInOut 的方式
本來是要移動到 y = 300 位置才作結束的,但是中間
可能會發生某些條件而必需以 Quad.easeInOut 的方式
提前在 y = 100 就完成,目前我想到的是用 killXXXX
之類的,但是這樣就無法讓提前在 y = 100 位置時,
能以Quad.easeInOut 的移動方式提前結束這次的 TweenMax
移動。

拜託老師一下。

感恩
milkmidi寫道…
這樣的羅輯怪怪的
因為你要中斷他,就不可能完整的跑完你要的 easing 效果

這個網誌中的熱門文章

超好用的無限免費網頁空間,無廣告,無流量限制

大家好,我是奶綠茶 今天來教大家如何申請一個無限免費速度又快的網頁空間 1 首先到  https://github.com/ 申請帳號(一直下一步,下一步,下一步) 2 到你的個人頁,切換上方的 tab 到 Repositories, 按下右鍵的 new 3 Repository name 一定要是這樣的格式 username.github.io 我的 github 網址是 github.com/milkmidi 那就要輸入 milkmidi.github.io 選擇 public, 這樣別人才看的到 private 有其他用途, 而且要付費才能使用 完成後按下 Create repository 5 安裝 SourceTree github 並不支援 FTP 或是網頁上傳,一定要透過指令碼 在這我們選用有圖型介面的軟體,方便大家學習 https://www.sourcetreeapp.com/ 下載並安裝 啟動後登入你的 github 帳號 6 clone 你的 github io 專案 右上角有個 Clone or download 點選後 複製 https 連結(不要選到 ssh ) 7 將 https 的連結貼到 SourceTree 8 上傳 html 到本機 github.io 資料夾,放一個 index.html 切換到 SourceTree, 這時會看到 Unstaged files 的欄位 選擇 Stage All 9 git 要求每次的 Commit, 都一定要打說明文字(好習慣) 輸入完成後,按下右邊的 Commit 10 發佈(Push),這樣就完成啦 可以到你的 http://milkmidi.github.io/ 去查看檔案有沒有出來 其他 Commit 可以想像是做一個記錄,你可以很多的 Commit 最後再一次 Push 上去 github 原本是給程式設計師用的版本控管服務 免費版提供無限空間讓你放檔案,但一定要是 public 想要有私有的 Project ,就只能付費 github.io 只能放靜態檔案,php, aspx 服務並不支援。 祝大家學習愉快 轉載請註明出處 奶綠的 gi...

奶綠茶新書上市_密技公怖_程式碼下載

奶綠茶第一本 Flash 書籍上市啦 博客來書籍館 Flash 3D 特效宅急便 - 商業範例隨學隨 把我對 Flash 的研究與熱愛, 全寫在其中 本書的前幾章, 特別安排 ActionScript3.0 的許多範例 好讓你一步步瞭解 as2 和 as3 的差別 再安排製作動畫不可缺少的 Tweener 類別和一些常用的數學動畫公式 最後當然就來到本書的重點 PV3D 啦 從 PV3D 的原理, 基本架構一點一點的介紹 再透過許多實用的範例, 從中瞭解 PV3D 製作的小技巧 有任何書籍相關的問題, 也請不吝指教 感謝一路走來, 幫助過我的前輩們, 邦邦、Ticore、神魂、Maso、Erin 旗標出版社 小編 Bready 米蘭數位所有夥伴 米蘭數位ActionScript Team:Jason,Ash,Mark 本書大鋼: 1.ActionScript3.0概論 分析AS3的概念與語法, 從基本的滑鼠事件、外部載入、氣泡事件介紹起 適合熟悉AS2, 想轉戰AS3的人員。 2.程式碼製作動畫 使用簡單的數學公式, 套用到程式裡, 脫離死版的影格動畫。 3.製作動畫的好夥伴:Tweener 除了套用數學公式外, Tweener類別也能加速我們開發出更多的動畫效果, 不需辛辛苦苦的找公式。 4.自定類別 AS3的精神, 是在於強大的物件導向, 當然也要熟悉類別的寫法與使用。 5.Flash3D - Papervison3D 如果在Flash玩轉3D效果, PV3D是最好學, 最快上手的3D Flash Engine, 從簡單的3D概念, PV3D類別, 事件等。 6 漫天飛舞的Paper3DWorld效果 7 迷你旋轉木馬式秀圖效果 8 最經典! CoverFlow 圖像展示效果 9 天旋地轉 TiltViewer效果 10 FlatWall3D電視牆效果 11 經典旋轉木馬 Carousel3D 秀圖效果 12 光源材質展示與簡易型的方塊彈跳效果 13 載入外部3D模型與動畫 14 超立體旋轉九宮格 Box3DWorld 15 空間感與透明感兼具的 SpaceGallery 16 螺旋式 SpiralCarouse 影像展示 17 Flash10 3D功能 18 Flash效...

奶綠茶photoGalleryV3.5

奶小茶的photoGalleryV3.5原始檔 2007/12/30 更新小Bug,請重新下載 線上Demo: http://milkmidi.com/photogallery/galleryv3.html 1.支援SWFAddress,讓FLASH可以有上一頁下一頁和每張獨立網址的功能 2.圖片路徑圖說經由XML來設定 3.背景依據顯示圖片,自動變化成最接近的顏色 4.非商業用途,歡迎使用並修改(如果覺得我製作的好,也煩請加入我的logo) 5.可結合後端伺服器 00.art 相本集資料夾 com 奶綠茶的Class檔 swfaddress SWFAddress資料夾 swfobject swfobject資料夾 XML galleryV3.fla 原始檔 index.html 主檔html SWFAddress.as SWFaddressEvent.as Source Code Download 解壓密碼:回覆文章,即可看見Password