SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

Silverlight 4で作る新しいRIAアプリケーション

MVVMによるSilverlightアプリケーションの開発(その2)

Silverlight4で作る新しいRIAアプリケーション(7)

  • X ポスト
  • このエントリーをはてなブックマークに追加

ダウンロード sample.zip (177.5 KB)

デザインモードの判断

 現在のサーバの稼働状況を確認するために、Silverlightのページが読み込まれたタイミングで、サーバ側のサービスを呼び出したいことがありますが、Visual StudioやExpression BlendでSilverlightのデザイン画面を開いている場合は注意が必要です。

 Visual StudioでもExpression Blendでも、ページのロード時のイベント自体はデザイナの裏で動いているため、サーバのリソースを利用してページの初期化処理を行っている場合は、図1のようなエラーがデザイナ上に表示されて、デザイナが利用できなくなってしまいます。

図1 Visual StudioやExpression Blendで表示できなかった場合の画面
caption

 このような場合、リスト3のようにDesignerPropertiesクラスのIsInDesignToolプロパティを参照して、デザイン時には実行しないといった処理を記述することが可能です。

リスト3 デザインモード時の判断
// 動作モードによって初期化処理を切り替える。
if (DesignerProperties.IsInDesignTool)
{
    // デザイナ用の初期化コード
}
else
{
    // 実行時の初期化コード
}

ビヘイビア

 ページが読み込まれたタイミングでページに検索した値を表示したい場合、通常であれば、ページのLoadedイベントが発生したタイミングで検索処理を実行します。しかし、前述のとおり、コマンドバインディングは、ICommandSourceインターフェイスを実装したコントロールでなければ利用できません。

 Loadedイベント発生時にコマンドを実行する一番簡単な方法は、Blend SDKに含まれるInvokeCommandActionビヘイビアを利用する方法です。

 Expression Blendを利用して、LayoutRootのLoadedイベント発生時にInvokeCommandActionビヘイビアでコマンドを実行する場合は、AssetライブラリのInvokeCommandActionビヘイビアをLayoutRootsにドロップします(図2)。

図2 ビヘイビアの適用
caption

 ビヘイビアのプロパティで、EventNameをLoadedとしてイベントと関連を設定します(図3)。

図3 Loadedイベントへの関連付け
caption

 図3のようにコマンドプロパティペインのバインディングアイコンを押して、バインドしたいコマンドを選択すれば、バインディングの設定は完了です。

図4 検索コマンドのバインディング
caption

 この設定をすると、リスト4のようなXAMLがExpression Blendによって記述されます。

リスト4 ビヘイビアによるコマンドバインディングの記述
<UserControl
    ... 略 ...
    xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity" 
    >
    <StackPanel x:Name="LayoutRoot" DataContext="{StaticResource vm}">
        <i:Interaction.Triggers>
            <i:EventTrigger>
                <i:InvokeCommandAction Command="{Binding 検索Command, Mode=OneWay}"/>
            </i:EventTrigger>
        </i:Interaction.Triggers>
        ... 略 ...
    </StackPanel>
</UserControl>
標準ビヘイビアとExpressonBlendのビヘイビア

 ビヘイビアには、Silverlightの標準ライブラリに含まれるビヘイビアと、Expression Blend SDKに含まれるビヘイビアの2種類があります。Blend SDKに含まれるビヘイビアは、開発者が拡張しやすく利用しやすいように設計し直されたものです。Expression Blendを持っていなくてもBlend SDKは無料で利用できるので、Exression Blendを持っていない方はここからダウンロードして利用してください。

次のページ
MVVMフレームワーク

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Silverlight 4で作る新しいRIAアプリケーション連載記事一覧

もっと読む

この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト かるあ (杉山 洋一)(カルア(スギヤマ ヨウイチ))

WINGSプロジェクトについて> 有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/5746 2011/02/22 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング