|
6 | 6 | using System.Windows.Navigation; |
7 | 7 | using Microsoft.Phone.Controls; |
8 | 8 | using Microsoft.Phone.Shell; |
9 | | -using MsgPack.UnitTest.Silverlight.WindowsPhone.Resources; |
| 9 | +using MsgPack.Resources; |
10 | 10 |
|
11 | | -namespace MsgPack.UnitTest.Silverlight.WindowsPhone |
| 11 | +namespace MsgPack |
12 | 12 | { |
13 | 13 | public partial class App : Application |
14 | 14 | { |
15 | | - /// <summary> |
16 | | - /// Phone アプリケーションのルート フレームへの容易なアクセスを提供します。 |
17 | | - /// </summary> |
18 | | - /// <returns>Phone アプリケーションのルート フレームです。</returns> |
19 | 15 | public static PhoneApplicationFrame RootFrame { get; private set; } |
20 | 16 |
|
21 | | - /// <summary> |
22 | | - /// Application オブジェクトのコンストラクターです。 |
23 | | - /// </summary> |
24 | 17 | public App() |
25 | 18 | { |
26 | | - // キャッチできない例外のグローバル ハンドラーです。 |
27 | 19 | UnhandledException += Application_UnhandledException; |
28 | | - |
29 | | - // 標準 XAML の初期化 |
30 | 20 | InitializeComponent(); |
31 | | - |
32 | | - // Phone 固有の初期化 |
33 | 21 | InitializePhoneApplication(); |
34 | | - |
35 | | - // 言語表示の初期化 |
36 | 22 | InitializeLanguage(); |
37 | | - |
38 | | - // デバッグ中にグラフィックスのプロファイル情報を表示します。 |
39 | 23 | if ( Debugger.IsAttached ) |
40 | 24 | { |
41 | | - // 現在のフレーム レート カウンターを表示します。 |
42 | 25 | Application.Current.Host.Settings.EnableFrameRateCounter = true; |
43 | | - |
44 | | - // 各フレームで再描画されているアプリケーションの領域を表示します。 |
45 | | - //Application.Current.Host.Settings.EnableRedrawRegions = true; |
46 | | - |
47 | | - // 試験的な分析視覚化モードを有効にします。 |
48 | | - // これにより、色付きのオーバーレイを使用して、GPU に渡されるページの領域が表示されます。 |
49 | | - //Application.Current.Host.Settings.EnableCacheVisualization = true; |
50 | | - |
51 | | - // アプリケーションのアイドル状態の検出を無効にして、デバッガーの実行中に画面が |
52 | | - // オフにならないようにします。 |
53 | | - // 注意: これはデバッグ モードのみで使用してください。ユーザーが電話を使用していないときに、ユーザーのアイドル状態の検出を無効にする |
54 | | - // アプリケーションが引き続き実行され、バッテリ電源が消耗します。 |
55 | 26 | PhoneApplicationService.Current.UserIdleDetectionMode = IdleDetectionMode.Disabled; |
56 | 27 | } |
57 | 28 |
|
58 | 29 | } |
59 | | - |
60 | | - // (たとえば、[スタート] メニューから) アプリケーションが起動するときに実行されるコード |
61 | | - // このコードは、アプリケーションが再アクティブ化済みの場合には実行されません |
62 | 30 | private void Application_Launching( object sender, LaunchingEventArgs e ) |
63 | 31 | { |
64 | 32 | } |
65 | | - |
66 | | - // アプリケーションがアクティブになった (前面に表示された) ときに実行されるコード |
67 | | - // このコードは、アプリケーションの初回起動時には実行されません |
68 | 33 | private void Application_Activated( object sender, ActivatedEventArgs e ) |
69 | 34 | { |
70 | 35 | } |
71 | | - |
72 | | - // アプリケーションが非アクティブになった (バックグラウンドに送信された) ときに実行されるコード |
73 | | - // このコードは、アプリケーションの終了時には実行されません |
74 | 36 | private void Application_Deactivated( object sender, DeactivatedEventArgs e ) |
75 | 37 | { |
76 | 38 | } |
77 | | - |
78 | | - // (たとえば、ユーザーが戻るボタンを押して) アプリケーションが終了するときに実行されるコード |
79 | | - // このコードは、アプリケーションが非アクティブになっているときには実行されません |
80 | 39 | private void Application_Closing( object sender, ClosingEventArgs e ) |
81 | 40 | { |
82 | 41 | } |
83 | | - |
84 | | - // ナビゲーションに失敗した場合に実行されるコード |
85 | 42 | private void RootFrame_NavigationFailed( object sender, NavigationFailedEventArgs e ) |
86 | 43 | { |
87 | 44 | if ( Debugger.IsAttached ) |
88 | 45 | { |
89 | | - // ナビゲーションに失敗しました。デバッガーで中断します。 |
90 | 46 | Debugger.Break(); |
91 | 47 | } |
92 | 48 | } |
93 | | - |
94 | | - // ハンドルされない例外の発生時に実行されるコード |
95 | 49 | private void Application_UnhandledException( object sender, ApplicationUnhandledExceptionEventArgs e ) |
96 | 50 | { |
97 | 51 | if ( Debugger.IsAttached ) |
98 | 52 | { |
99 | | - // ハンドルされない例外が発生しました。デバッガーで中断します。 |
100 | 53 | Debugger.Break(); |
101 | 54 | } |
102 | 55 | } |
103 | 56 |
|
104 | 57 | #region Phone application initialization |
105 | | - |
106 | | - // 初期化の重複を回避します |
107 | 58 | private bool phoneApplicationInitialized = false; |
108 | | - |
109 | | - // このメソッドに新たなコードを追加しないでください |
110 | 59 | private void InitializePhoneApplication() |
111 | 60 | { |
112 | 61 | if ( phoneApplicationInitialized ) |
113 | 62 | return; |
114 | | - |
115 | | - // フレームを作成しますが、まだ RootVisual に設定しないでください。これによって、アプリケーションがレンダリングできる状態になるまで、 |
116 | | - // スプラッシュ スクリーンをアクティブなままにすることができます。 |
117 | 63 | RootFrame = new PhoneApplicationFrame(); |
118 | 64 | RootFrame.Navigated += CompleteInitializePhoneApplication; |
119 | | - |
120 | | - // ナビゲーション エラーを処理します |
121 | 65 | RootFrame.NavigationFailed += RootFrame_NavigationFailed; |
122 | | - |
123 | | - // 次のナビゲーションでバックスタックをクリアして、 |
124 | 66 | RootFrame.Navigated += CheckForResetNavigation; |
125 | | - |
126 | | - // 再初期化しないようにします |
127 | 67 | phoneApplicationInitialized = true; |
128 | 68 | } |
129 | | - |
130 | | - // このメソッドに新たなコードを追加しないでください |
131 | 69 | private void CompleteInitializePhoneApplication( object sender, NavigationEventArgs e ) |
132 | 70 | { |
133 | | - // ルート visual を設定してアプリケーションをレンダリングできるようにします |
134 | 71 | if ( RootVisual != RootFrame ) |
135 | 72 | RootVisual = RootFrame; |
136 | | - |
137 | | - // このハンドラーは必要なくなったため、削除します |
138 | 73 | RootFrame.Navigated -= CompleteInitializePhoneApplication; |
139 | 74 | } |
140 | 75 |
|
141 | 76 | private void CheckForResetNavigation( object sender, NavigationEventArgs e ) |
142 | 77 | { |
143 | | - // アプリが 'リセット' ナビゲーションを受け取った場合、チェックする必要があります |
144 | | - // ページ スタックをリセットする必要があるかどうかを確認するためのリセット要求を処理します |
145 | 78 | if ( e.NavigationMode == NavigationMode.Reset ) |
146 | 79 | RootFrame.Navigated += ClearBackStackAfterReset; |
147 | 80 | } |
148 | 81 |
|
149 | 82 | private void ClearBackStackAfterReset( object sender, NavigationEventArgs e ) |
150 | 83 | { |
151 | | - // もう一度呼び出されないようにイベントの登録を解除します |
152 | 84 | RootFrame.Navigated -= ClearBackStackAfterReset; |
153 | | - |
154 | | - // '新しい' (次の) ナビゲーションおよび '更新' ナビゲーションのスタックのみをクリアします |
155 | 85 | if ( e.NavigationMode != NavigationMode.New && e.NavigationMode != NavigationMode.Refresh ) |
156 | 86 | return; |
157 | | - |
158 | | - // UI の一貫性を維持するため、ページ スタック全体をクリアします |
159 | 87 | while ( RootFrame.RemoveBackEntry() != null ) |
160 | 88 | { |
161 | | - ; // 何も実行しません |
| 89 | + ; |
162 | 90 | } |
163 | 91 | } |
164 | 92 |
|
165 | 93 | #endregion |
166 | | - |
167 | | - // アプリのフォントと方向をそのローカライズされたリソース文字列で定義されたように初期化します。 |
168 | | - // |
169 | | - // アプリケーションのフォントがそのサポートされる言語と一致し、各言語の FlowDirection がその従来の |
170 | | - // 方向に従うようにするには、各 resx ファイルで ResourceLanguage と ResourceFlowDirection を |
171 | | - // 初期化して、これらの値をそのファイルのカルチャと一致させる |
172 | | - // 必要があります。例: |
173 | | - // |
174 | | - // AppResources.es-ES.resx |
175 | | - // ResourceLanguage の値は "es-ES" にする必要があります |
176 | | - // ResourceFlowDirection の値は "LeftToRight" にする必要があります |
177 | | - // |
178 | | - // AppResources.ar-SA.resx |
179 | | - // ResourceLanguage の値は "ar-SA" にする必要があります |
180 | | - // ResourceFlowDirection の値は "RightToLeft" にする必要があります |
181 | | - // |
182 | | - // Windows Phone アプリのローカライズの詳細については、http://go.microsoft.com/fwlink/?LinkId=262072 を参照してください。 |
183 | | - // |
184 | 94 | private void InitializeLanguage() |
185 | 95 | { |
186 | 96 | try |
187 | 97 | { |
188 | | - // サポートされている各言語の ResourceLanguage リソース文字列で定義された |
189 | | - // 表示言語と一致するようにフォントを設定します。 |
190 | | - // |
191 | | - // 電話の表示言語がサポートされていない場合は、ニュートラル |
192 | | - // 言語のフォントにフォールバックします。 |
193 | | - // |
194 | | - // コンパイラ エラーが発生すると、ResourceLanguage がリソース ファイル |
195 | | - // からなくなります。 |
196 | 98 | RootFrame.Language = XmlLanguage.GetLanguage( AppResources.ResourceLanguage ); |
197 | | - |
198 | | - // サポートされる各言語の ResourceFlowDirection リソース文字列に基づいて、 |
199 | | - // ルート フレームのすべての要素の FlowDirection を |
200 | | - // 設定します。 |
201 | | - // |
202 | | - // コンパイラ エラーが発生すると、ResourceFlowDirection がリソース ファイル |
203 | | - // からなくなります。 |
204 | 99 | FlowDirection flow = ( FlowDirection )Enum.Parse( typeof( FlowDirection ), AppResources.ResourceFlowDirection ); |
205 | 100 | RootFrame.FlowDirection = flow; |
206 | 101 | } |
207 | 102 | catch |
208 | 103 | { |
209 | | - // ここで例外が発生した場合、その原因は、 |
210 | | - // ResourceLangauge がサポートされている言語コードに正しく設定されていないこと、 |
211 | | - // または ResourceFlowDirection が LeftToRight または RightToLeft 以外の |
212 | | - // 値に設定されていることである可能性があります。 |
213 | 104 |
|
214 | 105 | if ( Debugger.IsAttached ) |
215 | 106 | { |
|
0 commit comments