Posts Tagged ‘AS3’

Live2D SDK for Flash をStage3Dで表示させてみる

Live2D SDK for FlashとStarlingを連携してStage3D上で動かしてみました。以前作ったLive2Dをビットマップ化させるライブラリで表示させるだけなら簡単にできました。がそれでは速度的に通常のCPU描画となんら変わりがありませんので、今回はGPUを使用して高速化させてみました。具体的に説明しますとLive2Dをビットマップ化しGPUメモリにバッファして高速化しています。やってみてわかったのですがStage3DでLive2DSDKを使用するのはちょっと大変かもしれないです。まだあんまり試していないのでよくわからないことだらけですが。
速度的には通常ステージの表示に比べると速くなってる気がします。そのかわりできることにかなり色んな制限がかかったりします。ハァ。

ラスタライズ機能

もうすぐflash CS5.5がリリースされますね。ぼくはアンドロイドアプリ開発をするためにtegra2搭載のたっかいタブレットPCを購入したのですがいつの間にかアンドロイドアプリをCS5で開発するためのプラグインが配布終了していました。かんなりショックを受けたのですがCS5.5でアンドロイドアプリが開発できるようです。というかcs5.5買わせるためにプラグイン配布終了とかえげつなぁ~。adobeえげつなぁ。

とりあえずうちのタブレットは読書専用機になってます。正直もったいないです。読書だけなら一番やっすいクラスのタブレットでも良かったので。

さておきFlashCS5.5の新機能にシンボルのラスタライズが搭載されるみたいですね。どういう機能かというとベクター画像をラスター画像に変換して扱えるという物です。

それのどこがおいしいのかといいますと、ベクターデータをビットマップ化(ラスター画像)することにより高速化できる処理があったり、ビットマップ化することによってできる画像処理などがうまみでしょうか。

ちょっと前にベクターデータを扱っていて困ったことがありましたのでその紹介です。

ベクターデータは半透明化するとスケルトン状態に透明化されてしまいます。見えてはいけない内蔵部分がもろに見えてしまったり。まぁそれはそれで用途があるとおもいますが。

そこでベクター画像をビットマップ化することにより自然な半透明化にすることが可能です。見てもらった方が早いので。

This movie requires Flash Player 9

△クリックするとドロイド君カップケーキの色が変わるよ

スプライトのビットマップ化のソース

//透明なBitmapData。背景を塗りつぶすため
modBmd = new BitmapData(146 ,167 ,true ,0x77000000);
 var mtxElem:Matrix = new Matrix();
 //mtxElem.scale(1.1 ,1.1);//拡大縮小
 mtxElem.translate(0 ,0);//位置
 modBmd.draw(modSpt ,mtxElem);//spriteをラスタライズ
 scrBmp1.bitmapData = modBmd;

こないだのLive2Dモデルを組み込むライブラリにLive2Dモデルのビットマップ出力機能を追加したので今度公開します。
利用者がいないのは誰よりも知っているんだよ。

Live2Dモデルを組み込んで使用する

前回のつづき
Live2Dのプログラミングをしていると数十個いや数百個いやそれ以上のモデルデータを使いたいなんてことがありますよね。
そんなときにはこれ、このクラスを使うと大量のモデルデータをスマートに活用できてしまいます。

構成
LoadBinaryL2dModel.fla //タイムラインにメインのコードを記述
moblist.as //mob形式のモデルデータ登録するファイル
monochromebit-L2dLoadCls.as //今回使用するクラス
model //mobデータ置場

使用方法
まず最初にmoblist.asに使用するLive2Dモデルのmobファイルを登録します。
実際はL2dLoadCls.asに記述してあるのですがわかりやすいように切り離してあります。


//埋め込むモデルをリストに登録する
private static const MOB_LIST:Array = [];

//0ドロイド
[Embed(source='/model/android.mob',mimeType='application/octet-stream')]  
private static var embedMod0:Class;
MOB_LIST.push(embedMod0);

//1草
[Embed(source='/model/kusa.mob',mimeType='application/octet-stream')]  
private static var embedMod1:Class;
MOB_LIST.push(embedMod1);

//2アマゾン
[Embed(source='/model/amazon.mob',mimeType='application/octet-stream')]  
private static var embedMod2:Class;
MOB_LIST.push(embedMod2);

次はflaファイルのタイムラインにメインのコードを書きます。

//タイムラインに記述しています。

	import jp.live2d.model.Live2DModel;
	import monochromebit.L2dLoadCls;//今回つくったクラス

//組込クラスのインスタンス化
var l2dloadCls:L2dLoadCls = new L2dLoadCls();
//モデルの入れ物
var l2dAndMod:Live2DModel;

//MOB_LIST[xx]のインデックス番号のモデルをセット
l2dAndMod = l2dloadCls.getModel(2); //この場合MOB_LIST[2]=getModel(2)です。
//スプライトにモデルをセット
var modSpt:Sprite = l2dAndMod.getSprite();

			//スプライトを登録
			this.addChild(modSpt) ;

使い方はこんな感じです。
今回CS5でflaファイルにメインコードを記述しましたがクラス自体はflex環境でも使用可能です。
実行にはLive2D SDK for Flash 1.0が必要です。
▽ダウンロードはこちら
zipでやる

ついでにL2dLoadClsクラスの中身

//mobファイルをバイナリとして組み込んでロード
package monochromebit
{
	import jp.live2d.model.Live2DModel;
	import flash.utils.*
	/**
	 * 多量のMOB読み込み
	 */
	public class L2dLoadCls{
		public var l2dMod:Live2DModel;

		/**コンストラクタ**/
		public function L2dLoadCls(){}

		//モデルを生成して返す
		public function getModel(element:int):Live2DModel{
			//MOB_LISTからモデルロード
			l2dMod = loadBinMod(element);//○番めのmob読み込み
			return l2dMod;
		}//getModelEND

		//バイナリからモデルロード
		private function loadBinMod(element:int):Live2DModel{
			var byteArray:ByteArray = new MOB_LIST[element] as ByteArray;
			return Live2DModel.loadFromByteArray(byteArray);
		}//loadBinModEND
	include "../moblist.as"//mob登録リスト
	}//classEND
}/**packageEND**/

WordPressでAS3コードを表示するプラグインを導入してどや顔してみる

よくwebで色つきのコードが表示されているものを見かけてうちでもやりたいなぁとおもっていました。
WPのプラグインですぐできるだろうとおもったところ案の定すぐできました。
そして表示させてみました、うんイカス!

というわけで今回はLive2Dモデルの組み込みのコードです。
Live2D SDK for Flashはmobファイルをバイナリとして組み込めるのですがサンプルにはURLロードの方法しかのっていなかったのでコーディングしました。
パブリッシュした実行ファイルへのmobファイルの組み込みのメリットがいくつかあります。(一部憶測含む)

・データを組み込んでおけばwebからデータをロードをする際の通信の不具合、
 速度や信頼性の問題がありません。
・mobファイルをプログラムに組み込むことによるデータの秘匿性。
・AIRなどの外部と接続の権限の設定が不要。
・単体の実行ファイルしかおけない場所に設置可能。

という理由で基本的にmobファイルを外部から読み込む必要性がないときには組み込むべきだとおもいます。

▽ソース

package
{
	import jp.live2d.model.Live2DModel;
	import flash.display.*;
	import flash.utils.*;
	/**
	 * もっとも簡単なバイナリロードサンプル
	 */
	public class MainAndCls extends MovieClip
	{
		/**コンストラクタ**/
		public function MainAndCls()
		{
			//組み込むmobファイルのパス
       [Embed(source='/model/model_android.mob', mimeType='application/octet-stream')]
			var embedLive2dMod:Class;
			var byteArray:ByteArray = new embedLive2dMod as ByteArray;
			var l2dMod:Live2DModel = Live2DModel.loadFromByteArray(byteArray) ;

			//モデルの表示用Spriteを取得
			var modSpt:Sprite = l2dMod.getSprite() ;
			
			//スプライトを登録
			this.addChild(modSpt) ;
			
		}
		
	}
}

これをつかった簡単にモデルを組み込めるクラスをつくってみたので次に公開しようかと思います。
ん?利用者がいないとかもはや関係ないんです。はい。

サイト内捜索
キャレンダァ
2018年11月
« 4月    
 1234
567891011
12131415161718
19202122232425
2627282930