0

chumbyで日本語Twitterを読めるwidgetを作った

chumbyは日本語フォントが入っていないので日本語が表示できないが、Flashの中のダイナミックテキストそのものにフォントを埋め込めば日本語が出せる。

ちょうどIMのAPIが動いてなかったので、twitterのfriends timelineを表示するchumby widgetを作ってみた。ただしフォントデータそのものを埋め込んで配布するのはライセンス的にまずそうなので、flaファイルのみの公開になります。自分の環境でコンパイルしてくださいIPAフォントを埋め込んで、swfも公開しました

ダウンロード → SourceCode (Flash CS3 / AS2)

(AS2が久しぶりすぎてやばかった)

twitter on chumby

ただしこの方法だとファイルサイズが100kb(chumby widgetの容量制限)を超えるので、USBから起動するしかない。

s.h.log chumbyで自作widgetをUSBメモリから起動する

japanese twitter on chumby

profile.xml

profile.xmlのusernumの数値を、自分のtimeline用に書き換える。これはtwitter上でのID。

twitter.com/homeで、自分のRSSフィードを見ると 123456.atom みたいな感じになっているので、その数値に書き換える。

intervalの秒数だけ、次の記事を読むまでwaitがかかる。デフォルトは8秒。

■Twitter APIをAS2で読む

XPath4AS2でxml版のフィードを読んだ。

FlashでBasic認証を通る方法がわからなかったので、protectをかけているユーザのtimelineは読めないかも知れない。

前に作ったXPath4AS2テスターが役に立った。

■favorite

どうしてもふぁぼりたかったんだけど、FlashからBasic認証を通る事ができなくて無理だった。

http://user:pass@twitter.comの方法も、Base64エンコードしてLoadVarsにaddRequestHeaderするのも、getURLも駄目。

ブラウザの中で動いているわけではないのでログイン済みのcookieを共有するも出来ない。

cgiでproxyすればいいんだけど。

■thumbnail

USBから起動した場合、サムネイルが読めない。

同じ画像ファイルでwebにアップした場合は読めたので、profile.xmlの記述ミスかも。

■setIntervalがおかしい

PC上で実行している時は問題ないんだけど、ChumbyのFlashLite3上でsetIntervalを使ってタイマ処理を行っている時、4秒以上待てない。10秒などを指定すると、4秒ぐらいでタイマ処理が回ってしまう。調べても特にFlashLiteは特別という記述は見あたらなかったので、なんだかわからないけど、さすがに4秒はchumbyから目を離せなくなってしまうので今回は1秒を数えるsetIntervalを作ってさらにカウントアップする変数を用意して、時間を数えるようにした。

■プログラム

全部twitter.flaの1フレーム目に書いた

importcom.xfactorstudio.xml.xpath.*;

if(!interval)interval=10;

if(!usernum)usernum=3631571;

vartwitterXml:XML=newXML();

twitterXml.ignoreWhite=false;

varxmlUrl=”http://twitter.com/statuses/friends_timeline/”+usernum+”.xml”;

twitterXml.onLoad=twitterXml_onLoad;

twitterXml.load(xmlUrl);

varint_id;

functiontwitterXml_onLoad(success:Boolean){

if(success){

trace(“XMLloadsuccess!!”);

loading._visible=false;

preLoadIcon(twitterXml);

int_id=setInterval(count_sec,1000);

loadNextStat();

}

else{

trace(“XMLloaderror!!”);

}

}

functionpreLoadIcon(stats:XML){

//trace(stats);

varicons:Array=XPath.selectNodes(stats,”statuses/status/user/profile_image_url/text()”);

trace(icons.length);

for(vari:Number=0;i<icons.length;i++){

varloader=newmx.controls.Loader();

loader.contentPath=icons[i];

//loader.load();

//trace(loader.autoLoad);

trace(loader.contentPath);

}

}

varstat_id=0;

varfav=”false”;

functionloadStats(stats:XML,num:Number){

varlen=XPath.selectNodes(stats,”statuses/status”).length;

if(num>len){

clearInterval(int_id);

loading._visible=true;

twitterXml.load(xmlUrl);

n=1;

return;

}

varupdate=XPath.selectNodes(stats,”statuses/status[“+num+”]/text/text()”);

fav=XPath.selectNodes(stats,”statuses/status[“+num+”]/favorited/text()”);

variconUrl=XPath.selectNodes(stats,”statuses/status[“+num+”]/user/profile_image_url/text()”);

varuserName=XPath.selectNodes(stats,”statuses/status[“+num+”]/user/name/text()”);

varscreenName=XPath.selectNodes(stats,”statuses/status[“+num+”]/user/screen_name/text()”);

vardate=XPath.selectNodes(stats,”statuses/status[“+num+”]/created_at/text()”);

stat_id=XPath.selectNodes(stats,”statuses/status[“+num+”]/id/text()”);

iconLoader.contentPath=iconUrl;

//favStar.gotoAndStop(fav);//labelで移動

labelUpdate.text=update;

labelUserName.text=userName+”(“+screenName+”)”;

labelDate.text=date;

trace(fav);

}

varsec=0;

functioncount_sec(){

sec++;

if(sec>=interval){

sec=0;

loadNextStat();

}

}

varn=1;

functionloadNextStat(){

trace(“loadNextStat”);

loadStats(twitterXml,n++);

}

0

chumbyで自作widgetをUSBメモリから起動する

MakerFaireで買ってきたchumbyにFlashLite3が入っていて、ActionScript2.0が動く。

ちょうど良い事に俺がFlasherなので、自分でwigetを作って動かしてみた。

yoggyさんに教えてもらったScott Janousekさんのスライドが凄くまとまっている。chumby独自の変数(内蔵の加速度センサー、タッチパネル等)の取得の仕方なども書いてある

Developing Flash Lite Widgets For The Chumby Platform SlideShare

あと、Scottさんの作ったFlash CS3用のデバイスプロファイルを入れると、ケータイ用Flashを試すエミュレータであるAdobe Device Centralでchumbyが動く様になる。

Scott Janousek Blog Archive Chumby Device Profile for Adobe Device Central CS3

■USBメモリで動かす

chumby.comのsubmit a widgetからprivate設定でuploadして試す方法もあるが、ローカルで開発する方法としてUSBメモリからブートする方法もある。今回はUSBメモリが余っていたのでそれでやってみた。

Chumby tricks – ChumbyWiki – Mixing local widgets into a channel

を参考に、USBメモリの中にprofile.xmlというファイルを置くと、USBメモリ内のswfを読み込まれる。

chumby usb boot

USBメモリに入れたファイル(Flash AS2 / CS3)

FlashはFlashLite3とのことだったんだけど、ChumbyWikiのwidgetサンプルを見たら、みんなパブリッシュ設定でFlashPlayer6 + AS1.0の組み合わせを指定していた。なんとなくAS1は嫌だったので俺はFlashPlayer6+AS2.0で書き出してみた。

そして、USBメモリを刺して動かしてみた結果がこれだよ!

channelのreloadをすれば読み込まれた。

あと、profile.xmlでwidget_parameterタグで値を渡す事ができる。

上のビデオではやってなかったけど、例えば適当なダイナミックテキストを置いて

labelParam1.text = param1;

などとすれば、下のprofile.xmlだったら zanmai というテキストが読み込める。この辺はFlashをActiveX Objectとして埋め込む時に使うSetVariableとかと同じ感じ。

profile.xml






Test Widget

this is test widget hellohello

1.0




















param1

zanmai





param2

kazusuke