概要
ゲームの広告だがそのゲームの一部を疑似体験できる、プレイアブルアドという代物を実装することになった。
アプリ上のwebviewで表示されるので、ターゲットブラウザはsafariとchrome。
通常のhtml,css,jsでイケるのだが、複雑なことになると工数かかりそうだなーと思っていたがAdobe AnimateCCという持て余しまくっているツールのことを思い出したので、それで作ってみた。快適快適。
が、とある広告プラットフォームの入稿のフォーマットは単一htmlのみ。
画像のパスをbase64にすれば良いだけの話がいたくハマったので、解決策をここに記す。
間違い
animteCCから書き出されたjsにこんな記載があります。
lib.properties = {
id: 'CBE7D0B014C34055B50EB7B1A2F1A211',
width: 640,
height: 1136,
fps: 24,
color: "#FFFFFF",
opacity: 1.00,
manifest: [
{src:"images/test_atlas_.png?1551178733007", id:"test_atlas_"}
],
preloads: []
};
これだけ見ると、srcの中身をbase64化したものに変えるだけで良いと思うが、全然動きません。
理由は、裏でPreloadJSが動いているから。
animateCCは基本的にCreateJSにおんぶにだっこなので、マニフェスト内の画像はPreloadJSによって事前ロードされます。
なので、base64をhtml内のimgタグに書き、jsでそいつを読み込んであげてanimate内の画像管理部分に紐づけてあげる、までを自前でやる必要があります。
htmlに追記する
html内にimgタグでbase64を書いちゃいましょう。
<img id="test_atlas_" style="display:none" width="2048" height="2048" title="" alt="" src="...">
canvasの下あたりにimgタグを追加します。display:noneにしておくことを忘れず。
idは、上で紹介したmanifestのidと同じ名前にしましょう。
jsを改造する
animateでエクスポートしたjsに変数を追記
最後のほうで、グローバル変数を定義している部分があるので、createjs, AdobeAn,に続き、「images」を追加します。
})(createjs = createjs||{}, AdobeAn = AdobeAn||{});
var createjs, AdobeAn, images;
htmlのインラインjsでpreloadの記載を修正
init()の上からすぐに見つかると思うので、この5行をコメントアウトします。
// var loader = new createjs.LoadQueue(false);
// loader.addEventListener("fileload", function(evt){handleFileLoad(evt,comp)});
// loader.addEventListener("complete", function(evt){handleComplete(evt,comp)});
// var lib=comp.getLibrary();
// loader.loadManifest(lib.properties.manifest);
そして、下記を追加します。
images変数を初期化し、htmlにべた書きしたbase64の画像と、manifestのidを紐づけています。
images = images||{};
var manifest = lib.properties.manifest;
for (var i=0, l=manifest.length; i<l; i++) {
var id = manifest[i].id;
var img = document.getElementById(id);
if (img != null) {
images[id] = img;
}
}
handleComplete(comp);
もうちょい修正
loaderの記述のすぐ下のほうに、handleCompleteという関数があります。
修正前はloaderのcompleteイベントも一緒に渡していたのですが、loader使わないので引数を修正します。
//function handleComplete(evt, comp) {
function handleComplete(comp) {
さらにすぐ下のほう、この一文もいらないのでコメントアウト。
// var queue = evt.target;
最後です。さらにすぐ下のほう。for文でloaderから画像の本体を引っ張ってくる部分を、loaderではなく自前で用意したimagesに置き換えてあげます。
for(i=0; i<ssMetadata.length; i++) {
// ss[ssMetadata[i].name] = new createjs.SpriteSheet( {"images": [queue.getResult(ssMetadata[i].name)], "frames": ssMetadata[i].frames} )
ss[ssMetadata[i].name] = new createjs.SpriteSheet( {"images": [images[ssMetadata[i].name]], "frames": ssMetadata[i].frames} )
}
終わり
これで画像をソース内に入れ込むことができました!
cdnから読んでるcreateJSもインラインに含めてしまえば、立派な入稿用単一htmlが完成しました!
プレイアブルアドの実装を考えている方の参考になれば幸いです。ニッチすぎる!!!!
現場からは以上です。
参考(これしかなかった)
https://www.reddit.com/r/createjs/comments/4dfldb/how_do_i_use_base24_instead_of_external_library/