SHOEISHA iD

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

連載記事

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

CodeZine BOOKS(コードジン・ブックス)は、CodeZineの連載からカットアップした、開発現場の課題解決に役立つ書籍シリーズです。

書籍に関する記事を見る

'); googletag.cmd.push(function() { googletag.pubads().addEventListener('slotRenderEnded', function(e) { var ad_id = e.slot.getSlotElementId(); if (ad_id == 'div-gpt-ad-1659428980688-0') { var ad = $('#'+ad_id).find('iframe'); if ($(ad).width() == 728) { var ww = $(window).width(); ww = ww*0.90; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/728+","+ww/728+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/728+","+ww/728+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/728+","+ww/728+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/728+","+ww/728+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(90*ww/728)+"px;width:"+728+"px;}", 0 ); } else { if ($(window).width() < 340) { var ww = $(window).width(); ww = ww*0.875; var style = document.createElement("style"); document.head.appendChild( style ); var sheet = style.sheet; sheet.insertRule( "#div-gpt-ad-1659428980688-0 iframe {-moz-transform: scale("+ww/320+","+ww/320+");-moz-transform-origin: 0 0;-webkit-transform: scale("+ww/320+","+ww/320+");-webkit-transform-origin: 0 0;-o-transform: scale("+ww/320+","+ww/320+");-o-transform-origin: 0 0;-ms-transform: scale("+ww/320+","+ww/320+");-ms-transform-origin: 0 0;}", 0 ); sheet.insertRule( "#div-gpt-ad-1659428980688-0 div{ height:"+(180*ww/320)+"px;width:"+320+"px;}", 0 ); } } } }); }); } else { document.write('
'); document.write('
'); }
Silverlight 3徹底入門

Silverlightのオフライン機能による新しい可能性

Silverlight 3徹底入門(4)

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

ダウンロード CodezineNavigation.zip (704.9 KB)

 もともとSilverlightはブラウザーのプラグインとして動作するため、オンライン環境が前提でした。しかし、Silverlight 3では、ブラウザー外実行(Out-Of-Browser)と呼ばれる新機能により、オフライン/ブラウザー外でSilvelrightを動作させる機能が追加されています。今回は、Silverlight 3のブラウザー外実行について詳しく触れていきます。

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

はじめに

 もともとSilverlightはブラウザーのプラグインとして動作するため、Silverlightで作成されたページを観覧するには、Silverlightを観覧するWebブラウザーとWebサーバーに接続できるオンライン環境が必要でした。

 しかし、Silverlight 3では、ブラウザー外実行(Out-Of-Browser)と呼ばれる新機能により、Webサーバーにつながらないオフライン環境で、IEやFirefoxといったブラウザーの外でSilvelrightを動作させる機能が追加されています。

 今回は、Silverlight 3のブラウザー外実行について詳しく触れていきます。

今回使うプロジェクト

 今回作成するサンプルのファイルはこの記事に添付していますが、同様のプロジェクトを新しく作成する場合には、Visual Studioの[メニュー]-[ファイル]-[新規作成]-[プロジェクト]から「Silverlightアプリケーション」を選択し、プロジェクト名に「CodeZineOffline」と入力してください。

 新しいSilverlightアプリケーションのダイアログでは、「Silverlightアプリケーションを新しいWebサイトでホストする」を選択し、[OK]ボタンをクリックしてプロジェクトを作成します(図1)。

図1 新しいプロジェクトの作成
図1 新しいプロジェクトの作成

ブラウザー外実行(Out-Of-Browser)

 ブラウザー外実行はSilverlight 3の目玉機能の一つで、SilverlightアプリケーションをIEやFirefoxといったブラウザーの外で動作させたり、それに伴ったAPI群(ネットワークの切断検知や、アプリケーションのインストール、バージョンチェックなど)を提供します。

 外国のSilverlight関連の記事ではOut-Of-Browser(OOB)という名前で検索すると多くの記事がヒットします。

Visual Studioでのブラウザー外実行の設定

 さっそくSilverlightアプリケーションに対し、ブラウザ外実行の設定を行ってみましょう。Silverlight開発にVisual Studioを使っている場合は、設定はとても簡単です。

 Silverlightプロジェクトのプロパティーを開き、Silvelrightタブにある「アプリケーションのブラウザー外実行を有効にする」のチェックボックスをONにするだけです。

図2 ブラウザー外実行機能の有効化
図2 ブラウザー外実行機能の有効化

 そのまま実行しても良いのですが、あまりにものっぺらぼうだとよく分からないので、リスト1のようなXAMLを記述しておきましょう。

[リスト1]今回利用するXAMLコード
<UserControl x:Class="CodeZineOffline.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid x:Name="LayoutRoot">
        <StackPanel>
            <TextBlock Text="ブラウザー外実行の確認" />
            <StackPanel Orientation="Horizontal" >
                <TextBlock Text="ブラウザー外で実行されているか:" />
                <TextBlock x:Name="ブラウザー外で実行されているか" />
            </StackPanel>
            <StackPanel Orientation="Horizontal" >
                <TextBlock Text="ネットワークの状況:"/>
                <TextBlock x:Name="ネットワークの状況" />
            </StackPanel>

            <StackPanel Orientation="Horizontal" >
                <TextBlock Text="実行モード:"/>
                <TextBlock x:Name="実行モード" />
            </StackPanel>
            <StackPanel Orientation="Horizontal">
                <Button Content="アプリケーションのインストール" />
                <Button Content="アプリケーションの更新" />
            </StackPanel>
        </StackPanel>
    </Grid>
</UserControl>

 Visual Studioで[F5]ボタンを押して、デバック実行でしてみましょう。

 まだプログラム側のコードを記述していないので、実行モードやネットワークの状況といったテキストは空のままですが、右クリックをするとコンテキストメニューの「Silverlight」の下に「このコンピューターにCodeZineOfflineアプリケーションをインストールします...」のメニューが追加されていることに気が付くと思います(図3)。

図3 ブラウザー外実行のインストールメニュー
図3 ブラウザー外実行のインストールメニュー

 インストールをクリックすると図4のダイアログが表示されます。

 チェックボックスでどこにアプリケーションへのショートカットを配置するかを選択して[OK]ボタンをクリックし、アプリケーションをブラウザー外で実行できるようにしましょう。

図4 ブラウザー外実行のインストールダイアログ
図4 ブラウザー外実行のインストールダイアログ

 インストールが完了すると、ブラウザーとは別に図3のウインドウが起動し、先ほどインストールしたアプリケーションがブラウザー外で実行されたのを確認できると思います。また、スタートメニュー(チェックボックスで選択した場合はデスクトップにも)にアプリケーションのアイコンが登録され、先ほどのアプリケーションを起動できるのも確認できます(図5)。

図5 スタートメニューからの起動
図5 スタートメニューからの起動

会員登録無料すると、続きをお読みいただけます

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

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

メールバックナンバー

次のページ
ブラウザー外実行の設定

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

  • X ポスト
  • このエントリーをはてなブックマークに追加
Silverlight 3徹底入門連載記事一覧

もっと読む

この記事の著者

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

静岡県榛原町生まれ。一橋大学経済学部卒業後、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 X: @WingsPro_info(公式)、@WingsPro_info/wings(メンバーリスト) Facebook

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

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

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/4702 2010/01/18 14:00
" ); }

おすすめ

アクセスランキング

  1. 1
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  2. 2
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載 NEW
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    AppleがSiriとChatGPTを統合、Apple Intelligence強化
  5. 5
    【超時短テクニカルライティング】生成AIを活用してドキュメントを書く流れを掴もう!
  1. 6
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  2. 7
    Google、XRデバイス用OS「Android XR」発表 NEW
  3. 8
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化 NEW
  4. 9
    「CUDA」 ~マンガでプログラミング用語解説
  5. 10
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説

アクセスランキング

  1. 1
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  2. 2
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載 NEW
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    AppleがSiriとChatGPTを統合、Apple Intelligence強化
  5. 5
    【超時短テクニカルライティング】生成AIを活用してドキュメントを書く流れを掴もう!
  6. 6
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  7. 7
    Google、XRデバイス用OS「Android XR」発表 NEW
  8. 8
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化 NEW
  9. 9
    「CUDA」 ~マンガでプログラミング用語解説
  10. 10
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  6. 6
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  7. 7
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  8. 8
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    Python 3.13の新機能、対話型インタプリタの機能強化や高速化などを解説

イベント

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

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

メールバックナンバー

アクセスランキング

  1. 1
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  2. 2
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載 NEW
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    AppleがSiriとChatGPTを統合、Apple Intelligence強化
  5. 5
    【超時短テクニカルライティング】生成AIを活用してドキュメントを書く流れを掴もう!
  1. 6
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  2. 7
    Google、XRデバイス用OS「Android XR」発表 NEW
  3. 8
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化 NEW
  4. 9
    「CUDA」 ~マンガでプログラミング用語解説
  5. 10
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説

アクセスランキング

  1. 1
    ランサーズ、「2024年必要とされたスキルランキング」を公開。「Lancers」上のデータを集計
  2. 2
    「CentOS Stream 10」発表、Linuxカーネル 6.12 LTSを搭載 NEW
  3. 3
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  4. 4
    AppleがSiriとChatGPTを統合、Apple Intelligence強化
  5. 5
    【超時短テクニカルライティング】生成AIを活用してドキュメントを書く流れを掴もう!
  6. 6
    2024年の提示年収が高いプログラミング言語は? paiza調査によるランキングが発表
  7. 7
    Google、XRデバイス用OS「Android XR」発表 NEW
  8. 8
    フロントエンドの定番ライブラリ「React」バージョン19の新機能を紹介──アクションによる非同期処理の進化 NEW
  9. 9
    「CUDA」 ~マンガでプログラミング用語解説
  10. 10
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  1. 1
    いいエンジニアになるための2つのポイント ──元Google技術者・石原氏が説く「シリコンバレー流ソフトウェア開発術」
  2. 2
    「CUDA」 ~マンガでプログラミング用語解説
  3. 3
    ITエンジニア本大賞2025、投票締切直前! みんなで選んだ歴代の大賞本を振り返って一挙紹介
  4. 4
    デスクトップアプリを開発しよう! 「Rust」と「Tauri 2.0」の基本情報と環境整備の仕方を解説
  5. 5
    今後生成AIとどう向き合うべきなのか? 現場のエンジニアと研究者が最新研究事例から語り合う
  6. 6
    2024年12月に開催される注目のITエンジニア向けカンファレンス5選
  7. 7
    日本在住の英語を話すソフトウェア開発者、年収の中央値は950万円に
  8. 8
    Vue.js3.4~3.5の新機能をまとめて紹介! 新しいAPIやSSRの改善
  9. 9
    VSCodeをドキュメント作成に活用――テキストエディタ、Markdownエディタの設定と拡張機能を解説
  10. 10
    Python 3.13の新機能、対話型インタプリタの機能強化や高速化などを解説