「Sliverlight 画面遷移」の版間の差分
ナビゲーションに移動
検索に移動
1行目: | 1行目: | ||
− | ==Sliverlight 画面遷移== | + | ==[[Sliverlight 画面遷移]]== |
[[Sliverlight]] | [[VisualStudio]] | [[C Sharp]] | | [[Sliverlight]] | [[VisualStudio]] | [[C Sharp]] | | ||
− | *http://code.msdn.microsoft.com/10-C-Silverlight-b4de09ed | + | *http://code.msdn.microsoft.com/10-C-[[Silverlight]]-b4de09ed |
− | *Silverlight のようなプラグインを使って Web ページに組み込まれたアプリケーションは、その状態に関わらず URL が変わりません | + | *[[Silverlight]] のようなプラグインを使って Web ページに組み込まれたアプリケーションは、その状態に関わらず URL が変わりません |
− | *Silverlight では、ナビゲーション フレームワークという仕組みにより、アプリケーションに配置した複数のページに個別の URL (より広い意味での URI) を与え、ブラウザーの「戻る」「進む」ボタンで切り替えたり、ブックマークが使えるようになります | + | *[[Silverlight]] では、ナビゲーション フレームワークという仕組みにより、アプリケーションに配置した複数のページに個別の URL (より広い意味での URI) を与え、ブラウザーの「戻る」「進む」ボタンで切り替えたり、ブックマークが使えるようになります |
==ナビゲーション フレームワークを使う== | ==ナビゲーション フレームワークを使う== | ||
*プロジェクトを右クリックして [参照の追加] を選び、[参照の追加] ダイアログ ボックスの [.NET] タブから「System.Windows.Controls.Navigation」を選んで、[OK] ボタン | *プロジェクトを右クリックして [参照の追加] を選び、[参照の追加] ダイアログ ボックスの [.NET] タブから「System.Windows.Controls.Navigation」を選んで、[OK] ボタン | ||
13行目: | 13行目: | ||
====ページの作成==== | ====ページの作成==== | ||
*Views フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight ページ] を選んで、という名前の新しいページを作成 | *Views フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight ページ] を選んで、という名前の新しいページを作成 | ||
− | ==== | + | ====ハイパー[[リンク]]ボタンの設置==== |
− | * | + | *ハイパー[[リンク]]ボタンを設置し、追加したページへのURIを指定する |
− | <HyperlinkButton Content="Test" Name="hyperlinkButton1" | + | <HyperlinkButton Content="Test" Name="hyperlinkButton1" Na[[vi]]gateUri="/Views/Test.xaml" /> |
====ページを表示する、Frameの設置==== | ====ページを表示する、Frameの設置==== | ||
− | < | + | <na[[vi]]gation:Frame /> |
====実行==== | ====実行==== | ||
− | * | + | *この状態で、[[リンク]]をクリックすると、Frameにページが読み込まれる |
− | ==== | + | ====U[[R]]Iマッピング==== |
− | * | + | *U[[R]]Iの指定が長くなるような場合、簡潔な表記を割り当てられる |
− | <UserControl. | + | <UserControl.[[R]]esources> |
<uriMapper:UriMapper x:Key="uriMapper"> | <uriMapper:UriMapper x:Key="uriMapper"> | ||
<uriMapper:UriMapping Uri="" MappedUri="/Views/HomePage.xaml" /> | <uriMapper:UriMapping Uri="" MappedUri="/Views/HomePage.xaml" /> | ||
29行目: | 29行目: | ||
<uriMapper:UriMapping Uri="About" MappedUri="/Views/AboutPage.xaml" /> | <uriMapper:UriMapping Uri="About" MappedUri="/Views/AboutPage.xaml" /> | ||
</uriMapper:UriMapper> | </uriMapper:UriMapper> | ||
− | </UserControl. | + | </UserControl.[[R]]esources> |
− | <Grid x:Name=" | + | <Grid x:Name="Layout[[R]]oot"> |
: | : | ||
− | <StackPanel Grid. | + | <StackPanel Grid.[[R]]ow="0" Orientation="Horizontal" Background="LightCyan"> |
− | <HyperlinkButton Content="Home" | + | <HyperlinkButton Content="Home" Na[[vi]]gateUri="Home" /> |
− | <HyperlinkButton Content="Info" | + | <HyperlinkButton Content="Info" Na[[vi]]gateUri="Info" /> |
− | <HyperlinkButton Content="About" | + | <HyperlinkButton Content="About" Na[[vi]]gateUri="About" /> |
</StackPanel> | </StackPanel> | ||
− | < | + | <na[[vi]]gation:Frame Grid.Row="1" Background="LightYellow" |
− | UriMapper="{ | + | UriMapper="{Static[[R]]esource uriMapper}"/> |
</Grid> | </Grid> | ||
− | ==== | + | ====U[[R]]Iマッピングによりパラメータを渡す==== |
− | * | + | *U[[R]]I マッピングでは、単純に文字列を置き換えるだけでなく、パラメーターを渡すこともできます |
=====パラメータを渡す===== | =====パラメータを渡す===== | ||
*Uri プロパティとして「/」を指定した後に「{}」で囲んだ引数を、マッピング先の MappedUri に渡せます | *Uri プロパティとして「/」を指定した後に「{}」で囲んだ引数を、マッピング先の MappedUri に渡せます | ||
52行目: | 52行目: | ||
*これは「/」の直後に渡されたパラメーターを「/Views/InfoPage.xaml?arg=」の後ろに追加してナビゲーションするという意味です | *これは「/」の直後に渡されたパラメーターを「/Views/InfoPage.xaml?arg=」の後ろに追加してナビゲーションするという意味です | ||
=====パラメータを受け取る===== | =====パラメータを受け取る===== | ||
− | * | + | *OnNa[[vi]]gateTo メソッドを次のように記述 |
− | protected override void | + | protected override void OnNa[[vi]]gatedTo(Na[[vi]]gationEventArgs e) |
{ | { | ||
− | if ( | + | if (Na[[vi]]gationContext.QueryString.ContainsKey("arg")) |
{ | { | ||
textInfo.Text = "Information: " + NavigationContext.QueryString["arg"]; | textInfo.Text = "Information: " + NavigationContext.QueryString["arg"]; | ||
71行目: | 71行目: | ||
====ChildWindowを追加==== | ====ChildWindowを追加==== | ||
*フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight 子ウィンドウ] を選択 | *フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight 子ウィンドウ] を選択 | ||
− | *ChildWindowコントロールはファイルそのものがChildWindowコントロールとして定義されています( | + | *ChildWindowコントロールはファイルそのものがChildWindowコントロールとして定義されています(通常[[Silverlight]]で画面を定義する場合はUserControlコントロールとして定義されます) |
====呼び出す==== | ====呼び出す==== | ||
ChildWindow1 childWindow = new ChildWindow1(); | ChildWindow1 childWindow = new ChildWindow1(); | ||
childWindow.Show(); | childWindow.Show(); | ||
− | == | + | ==ブラウザーウインドウに[[Silverlight]]を表示== |
− | *HtmlPage.Window. | + | *HtmlPage.Window.Na[[vi]]gateを使う |
− | *コードによりページを遷移するには、Webブラウザのwindowオブジェクトを示すHtmlWindowクラス(System.Windows.Browser名前空間)のオブジェクトを取得し、そのNavigateメソッドを使用する | + | *コードによりページを遷移するには、Webブラウザのwindowオブジェクトを示すHtmlWindowクラス(System.[[Windows]].Browser名前空間)のオブジェクトを取得し、そのNavigateメソッドを使用する |
===手順=== | ===手順=== | ||
====../index/index.htmlへ移動==== | ====../index/index.htmlへ移動==== | ||
− | Uri linkUri = new Uri("../index/index.html", UriKind. | + | Uri linkUri = new Uri("../index/index.html", UriKind.[[R]]elative); |
− | HtmlPage.Window. | + | HtmlPage.Window.Na[[vi]]gate(linkUri, "_self"); |
− | ==== | + | ====[[Google]]を別ウィンドウで開く==== |
Uri linkUri = new Uri("http://google.co.jp/"); | Uri linkUri = new Uri("http://google.co.jp/"); | ||
− | HtmlPage.Window. | + | HtmlPage.Window.Na[[vi]]gate(linkUri, "_blank"); |
===通信方法=== | ===通信方法=== | ||
*http://social.msdn.microsoft.com/Forums/ja-JP/silverlightgeneralja/thread/e6ce43f5-e233-4a81-83fc-4ec59455bf91 | *http://social.msdn.microsoft.com/Forums/ja-JP/silverlightgeneralja/thread/e6ce43f5-e233-4a81-83fc-4ec59455bf91 | ||
− | ====System.Windows.Browser名前空間のクラスを利用して、親(opener) | + | ====System.Windows.Browser名前空間のクラスを利用して、親(opener)側の[[Silverlight]]に定義されたメソッドを小画面の[[Silverlight]]からHTML(Javascript)経由で動作==== |
*[http://msdn.microsoft.com/ja-jp/library/cc645085(v=vs.95).aspx JavaScript により Silverlight をスクリプト可能にする] | *[http://msdn.microsoft.com/ja-jp/library/cc645085(v=vs.95).aspx JavaScript により Silverlight をスクリプト可能にする] | ||
=====Openerの取得===== | =====Openerの取得===== |
2020年2月16日 (日) 04:32時点における最新版
Sliverlight 画面遷移
Sliverlight | VisualStudio | C Sharp |
- http://code.msdn.microsoft.com/10-C-Silverlight-b4de09ed
- Silverlight のようなプラグインを使って Web ページに組み込まれたアプリケーションは、その状態に関わらず URL が変わりません
- Silverlight では、ナビゲーション フレームワークという仕組みにより、アプリケーションに配置した複数のページに個別の URL (より広い意味での URI) を与え、ブラウザーの「戻る」「進む」ボタンで切り替えたり、ブックマークが使えるようになります
ナビゲーション フレームワークを使う
- プロジェクトを右クリックして [参照の追加] を選び、[参照の追加] ダイアログ ボックスの [.NET] タブから「System.Windows.Controls.Navigation」を選んで、[OK] ボタン
手順
ページフォルダの作成
- ナビゲーションは、Frame コントロールと Page コントロールを組み合わせて実装
- プロジェクトを右クリックして [追加] - [新しいフォルダー] を選び、「Views」という名前のフォルダーを追加
- このフォルダーに、新しいページを作成していく
ページの作成
- Views フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight ページ] を選んで、という名前の新しいページを作成
ハイパーリンクボタンの設置
- ハイパーリンクボタンを設置し、追加したページへのURIを指定する
<HyperlinkButton Content="Test" Name="hyperlinkButton1" NavigateUri="/Views/Test.xaml" />
ページを表示する、Frameの設置
<navigation:Frame />
実行
- この状態で、リンクをクリックすると、Frameにページが読み込まれる
URIマッピング
- URIの指定が長くなるような場合、簡潔な表記を割り当てられる
<UserControl.Resources> <uriMapper:UriMapper x:Key="uriMapper"> <uriMapper:UriMapping Uri="" MappedUri="/Views/HomePage.xaml" /> <uriMapper:UriMapping Uri="Home" MappedUri="/Views/HomePage.xaml" /> <uriMapper:UriMapping Uri="Info" MappedUri="/Views/InfoPage.xaml" /> <uriMapper:UriMapping Uri="About" MappedUri="/Views/AboutPage.xaml" /> </uriMapper:UriMapper> </UserControl.Resources> <Grid x:Name="LayoutRoot"> : <StackPanel Grid.Row="0" Orientation="Horizontal" Background="LightCyan"> <HyperlinkButton Content="Home" NavigateUri="Home" /> <HyperlinkButton Content="Info" NavigateUri="Info" /> <HyperlinkButton Content="About" NavigateUri="About" /> </StackPanel> <navigation:Frame Grid.Row="1" Background="LightYellow" UriMapper="{StaticResource uriMapper}"/> </Grid>
URIマッピングによりパラメータを渡す
- URI マッピングでは、単純に文字列を置き換えるだけでなく、パラメーターを渡すこともできます
パラメータを渡す
- Uri プロパティとして「/」を指定した後に「{}」で囲んだ引数を、マッピング先の MappedUri に渡せます
: <uriMapper:UriMapping Uri="About" MappedUri="/Views/AboutPage.xaml" /> <uriMapper:UriMapping Uri="/{arg}" MappedUri="/Views/InfoPage.xaml?arg={arg}" /> </uriMapper:UriMapper>
- これは「/」の直後に渡されたパラメーターを「/Views/InfoPage.xaml?arg=」の後ろに追加してナビゲーションするという意味です
パラメータを受け取る
- OnNavigateTo メソッドを次のように記述
protected override void OnNavigatedTo(NavigationEventArgs e) { if (NavigationContext.QueryString.ContainsKey("arg")) { textInfo.Text = "Information: " + NavigationContext.QueryString["arg"]; } else { textInfo.Text = "Information: (empty)"; } }
ChildWindowコントロール
- http://www.atmarkit.co.jp/fdotnet/chushin/silverlight3develop_01/silverlight3develop_01_03.html
- 呼び出し元となる親ウィンドウの上に表示される子ウィンドウ
- ChildWindowコントロールが親ウィンドウの上に表示される場合、親ウィンドウはブロックされ、ChildWindowコントロールは親ウィンドウを操作することができないモーダルなウィンドウとして表示
手順
ChildWindowを追加
- フォルダーを右クリックして [追加] - [新しい項目] を選び、[Silverlight 子ウィンドウ] を選択
- ChildWindowコントロールはファイルそのものがChildWindowコントロールとして定義されています(通常Silverlightで画面を定義する場合はUserControlコントロールとして定義されます)
呼び出す
ChildWindow1 childWindow = new ChildWindow1(); childWindow.Show();
ブラウザーウインドウにSilverlightを表示
- HtmlPage.Window.Navigateを使う
- コードによりページを遷移するには、Webブラウザのwindowオブジェクトを示すHtmlWindowクラス(System.Windows.Browser名前空間)のオブジェクトを取得し、そのNavigateメソッドを使用する
手順
../index/index.htmlへ移動
Uri linkUri = new Uri("../index/index.html", UriKind.Relative); HtmlPage.Window.Navigate(linkUri, "_self");
Googleを別ウィンドウで開く
Uri linkUri = new Uri("http://google.co.jp/"); HtmlPage.Window.Navigate(linkUri, "_blank");
通信方法
System.Windows.Browser名前空間のクラスを利用して、親(opener)側のSilverlightに定義されたメソッドを小画面のSilverlightからHTML(Javascript)経由で動作
Openerの取得
HtmlPage.Window.GetProperty("opener");
ローカルメッセージ通信を利用
- クライアントにダウンロードされたSilverlightは、System.Windows.Messaging名前空間のクラスを利用してメッセージのやり取りを行うことができます
- http://msdn.microsoft.com/ja-jp/library/dd833063(v=vs.95).aspx
© 2006 矢木浩人