跳到主要內容

FlashPlayer10.2 StageVideo 試玩心得

FP10.2 正式發怖啦,
這次最主要的新功能, 就是 StageVideo 類別
Adobe 官網教學與介紹
線上Preview
StageVideo API Reference

說明一下使用方法:
一樣是使用 NetStream 連線
之前的版本是使用 Video 類別, attachNetStream( NetStream );
改成對 StageVideo attachNetStream, 其他的偵聽進度與播放停止等功能, 都和之前一樣。

想要嘗鮮的同學你需要

Flex 4.5 SDK – build 4.5.0.18623 available

解開後找到 xxxx\frameworks\libs\player
目前只有10.2的資料,copy一份,並命名為10.1, 這樣是為了讓目前的flashdevelop版本能夠發怖
開啟flashdevelop, 在 Properties 面版 Compiler Options裡的 Additional Compiler Options
加入 -swf-version=11
這樣就可以發怖成功了。




轉載請註明出處
package  {
package  {
 import flash.display.*;
 import flash.events.*;
 import flash.geom.*;
 import flash.media.*;
 import flash.net.*;
 //import net.hires.debug.*;
 /**
  * ...
  * @author milkmidi
  */
 public class StageVideoDemo extends Sprite {
  // youtube Iron Man2
  private static const VIDEO_URL:String = "http://v1.lscache7.c.youtube.com/videoplayback?" +
  "sparams=id%2Cexpire%2Cip%2Cipbits%2Citag%2Cratebypass%2Coc%3AU0dYTFNST19FSkNNOF9LTFNH&" +
  "fexp=908607&itag=37&ipbits=0&signature=53BA5F94D1C8D46E51D5C571F5A7F5D4BFF56844" +
  ".BEC86A8A482EC4B39B068AD5359A6F1C8D487566&sver=3&ratebypass=yes&expire" +
  "=1297371600&key=yt1&ip=0.0.0.0&id=b224200fda8e851b&begin=112292";
  private var sv:StageVideo;
  public function StageVideoDemo() {      
   if (stage) init();
   else  addEventListener(Event.ADDED_TO_STAGE , init);   
  }  
  private function init(e:Event = null):void {   
   removeEventListener(Event.ADDED_TO_STAGE, init);   
   stage.addEventListener(StageVideoAvailabilityEvent.STAGE_VIDEO_AVAILABILITY, onStageVideoState)  
   stage.scaleMode = StageScaleMode.NO_SCALE;
   stage.align = StageAlign.TOP_LEFT;   
   stage.addEventListener(Event.RESIZE , resizeHandler);   
   //addChild(new Stats);
  }
  private function onStageVideoState(e:StageVideoAvailabilityEvent):void {
   var _available:Boolean = (e.availability == StageVideoAvailability.AVAILABLE);
   trace(e,_available);
   var nc:NetConnection = new NetConnection();
   nc.connect(null);
   var ns:NetStream = new NetStream(nc);
   ns.addEventListener(NetStatusEvent.NET_STATUS, onNetStatus);
   ns.client = {
    onMetaData:function( o:Object ):void {
     //trace(o.duration);
     resizeHandler();
    }
   };
   
   var v:Vector. = stage.stageVideos;          
   if ( v.length >= 1 ) {       
    sv = v[0];       
   }
   sv.addEventListener(StageVideoEvent.RENDER_STATE, stageVideoStateChange);     
   sv.attachNetStream(ns);
   ns.play(VIDEO_URL);   
  }
  
  private function stageVideoStateChange(e:StageVideoEvent):void {
   trace(e);
  }
  
  
  private function resizeHandler (e:Event = null):void  { 
   sv.viewPort = getVideoRect(sv.videoWidth, sv.videoHeight);   
  }
  /**
   * 等比縮放, centerInside
   * @param pWidth
   * @param pHeight
   * @return
   */
  private function getVideoRect(pWidth:uint, pHeight:uint):Rectangle { 
   var _sw    :int = stage.stageWidth;
   var _sh    :int = stage.stageHeight;
   
   var _videoWidth  :uint = pWidth;
   var _videoHeight :uint = pHeight;
   var _scaling  :Number = Math.min ( _sw / _videoWidth, _sh / _videoHeight );
   
   _videoWidth  *= _scaling;
   _videoHeight *= _scaling;
   
   var _posX:uint = _sw - _videoWidth >> 1;
   var _posY:uint = _sh - _videoHeight >> 1;
   
   var _videoRect:Rectangle = new Rectangle();
   _videoRect.x = _posX;
   _videoRect.y = _posY;
   _videoRect.width = _videoWidth;
   _videoRect.height = _videoHeight;
   
   return _videoRect;
  }
  private function onNetStatus(e:NetStatusEvent):void {
   trace(e);
  }
 }

}

留言

喬治撞到妮寫道…
請問一下奶老師這個也是用flashdevelop complier的嗎?
因為我的flexsdk(4.5.0.18623)一直裝不好,故有一問。
milkmidi寫道…
我更新了教學,你再試一次看看

這個網誌中的熱門文章

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

大家好,我是奶綠茶 今天來教大家如何申請一個無限免費速度又快的網頁空間 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