2011年3月21日月曜日

デジタルサイネージ

自分の住んでる札幌市に、札幌駅から大通駅までの間の地下通路が新たに開通したのですが、お仕事でそこにデジタルサイネージを2台設置させてもらってます。
交通情報と通路の案内のサイネージですが、タッチパネルでサクサク動きます。
自社製のなかでも過去最高の利用率です。みなさん、ぜひ使ってみてください。

SystemManagerを独自実装のモノに差し替える方法

Flex3(3.5)でApplicationの初期化シーケンスの中に、独自の処理を割り込んで、デフォルトのプログレスに出力したいなと思ってたのですが、一定の進展があったので、まとめておく。

まず、Flex3はルートにSystemManagerを継承したクラスが指定される。大雑把に言うとこのクラスはアプリケーションに該当するmxmlファイルのデスクリプタとか初期化情報を持っていて、アプリケーションの初期化を行う。

最初のフレームではプレローダを使って、RSLの読み込みを行ってる。RSL等が読み終わると、次のフレームに移る。次のフレームではMixinの処理やアプリケーションの初期化を行う。アプリケーションの初期化が完了したら、プレローダを消す。

普通にアプリケーションを作る上で初期化シーケンスに介入できるのはMixinの段階で、これはMixinメタタグを指定したクラスがあれば、自動的に特定メソッドが呼ばれる。しかし、すでに1フレーム目に移行したあとで、RSLを読み込んだ後になる。

そこで、独自のSystemManager(SystemManagerを継承した独自クラス)を作成して、必要な処理を書き足せれば、いろいろとフックできるに違いない。(これから調査)

というわけで、その手順。

1.Applicationクラスを継承したMyApplicationを作成
2.SystemManagerを継承したMySystemManagerを作成
3.MyApplicationには[Frame(factoryClass="MySystemManager")]を設定
4.アプリケーションのmxmlのルートタグをMyApplicationにする

これだけでOK。

a.mxmlというアプリケーションがあると、通常なら_a_mx_managers_SystemManagerというクラスが自動的に生成される。これの親クラスはSystemManager。
しかし、上記の方法だと、_a_MySystemManagerというクラスが生成され、親クラスはMySystemManagerとなる。これで好き放題できますね。

2011年3月13日日曜日

やっと帰れました。

東京からなんとか脱出。札幌に戻れました。
被災者の方を思うと自分は全然いい方です。
でも震度5強っていうのは初体験で、命の危険を感じました。
ビッグサイトにいたのですが、隣の西ホールは壁にひび割れがあったようです。
展示品を支えるのが精一杯でしたが、落下物等もあり怖かったです。

2011年3月10日木曜日

東京に来ています

仕事(某展示会)に出展のため、月曜日から東京に来ています。
明日には札幌に帰りますが。

今年は異常に大盛況に思えます。ブース全体での総予算が、
おそらく去年の3倍くらいあるのではないでしょうか。標準のコマはとても少ないです。

製品の方も非常に好評で、制作側としては非常に嬉しい限りです。

2011年3月4日金曜日

ダブルクリックとシングルクリックを区別して処理する方法

ダブルクリックを受け取りたい場合のお話です。

Flashでは通常、最初のクリックの段階でクリックイベントがディスパッチされ、その後のクリックでダブルクリックの要件を満たしたときに、クリックイベントではなく、ダブルクリックイベントがディスパッチされます。

詳しくは調べてませんが、OSの設定によりダブルクリックとみなされたときに、FlashPlayerにクリックではなくダブルクリックとして通知されるのではと予想しています。

テキストボックスで考えてみると、最初のクリックでフォーカスし、ダブルクリックを受け取ったところでテキストを全選択にする、ということで、特にシングルクリックとダブルクリックが逐一発生しても何ら問題ありません。

しかし、ズームできる画像があって、画像はクリッカブルマップになっているケースを考えてください。 仮にオンラインのチラシサイトの画像としましょう。

商品をクリックしたら、商品の詳細ページにジャンプし、ズームしたいときはダブルクリックというのが簡単な操作です。しかし、ズームするためにはダブルクリックを受け取る必要がありますが、シングルクリックがその前に発生します。つまり、ダブルクリックだけを受け取りたい場合、シングルクリックは回避しなければなりません。

以下に解決したコードを掲載しました。


簡単に説明すると、クリックを受け取ったら、座標を記録しタイマーを開始します。
 タイマーが完了するまでに再度クリックがあった場合、
  • 同じ座標ならダブルクリック、その後タイマーを停止
  • 同じ座標ではないなら前回の位置でのシングルクリック、タイマーを再起動
とし、 再度クリックがなければ、そのまま記録した位置でのシングルクリックとみなします。

これを応用すれば、ダブルクリックだけではなく、トリプルクリックも実装できますね。