わんくま同盟 名古屋勉強会 #37
Windows 10
TH2 そろそろリリース
UWP アプリ
開発入門♪
(実践編)
2015/11/14
BluewaterSoft @biac
わんくま同盟 名古屋勉強会 #37
スピーカー紹介
• BluewaterSoft 山本 康彦 a.k.a @biac
まだ人工衛星が飛んでない時代に生まれ、HONDAでクルマの設計やってました
• Microsoft MVP for Windows Development (2014/10-2016/9)
• Windows ランタイム アプリ開発 / 記事や書籍の執筆 やってます
2
わんくま同盟 名古屋勉強会 #37
スピーカー紹介
~ このセッションに関連する@ITの記事
• 徹底予習! Windows 10 のユニバーサルアプリ開発
2015/4/28 http://www.atmarkit.co.jp/ait/articles/1504/28/news015.html
• Windows 10 UWP で業務デスクトップアプリ開発はどう変わるのか?
2015/6/23 http://www.atmarkit.co.jp/ait/articles/1506/23/news012.html
• Build 2015: 全ての開発者が押さえておくべきマイクロソフトの最新技術
動向
2015/5/12 http://www.atmarkit.co.jp/ait/articles/1505/12/news011.html
3
わんくま同盟 名古屋勉強会 #37
Windows 10
どんどんリリース❢
4
Copyright © 2015 Windows Navi+
わんくま同盟 名古屋勉強会 #37
Windows 10 リリース スケジュール
• 7/29 Win7/8.1からの無償アップデート
開始
• 8/1 デスクトップ版 Enterprise 契約 販
売開始
• 9月(?) デスクトップ版パッケージ販売開
始 (USBメモリ)
• 11月 Windows 10 TH2 リリース予定
• 秋以降 Windows Phone 8.1、Xbox One
からの無償アップデート開始
• 来年 Surface Hub / HoloLens 発売
5
DSP 版 Windows 10 自作 PC 応援キャラクター
窓辺 てんこ (仮名)
Copyright © 2015 Windows Navi+
ドイツの Web サイトがリークした
製品パッケージ (左:Pro、右:Home)
背景は Windows 10 標準の壁紙
"Hero Desktop Image"
わんくま同盟 名古屋勉強会 #37
Xbox
One
IoT
Core
Universal
Windows Platform
Core APIs
UWP アプリ
ユニバーサル Windows
プラットフォーム アプリ とは?
6
わんくま同盟 名古屋勉強会 #37
デスクトップで使う分には、
見た目の違いは小さい
• 左: WPF アプリ
右: UWP アプリ
• ウィンドウの違い
は、システムメ
ニューアイコンの
有無くらい
7
わんくま同盟 名古屋勉強会 #37
でも、UWP アプリは、同じバイナリが
Windows 10 搭載スマートフォンでも動く❢
• Windows 10 Mobile
エミュレータの画像
(VS2015RC 付属)
8
わんくま同盟 名古屋勉強会 #37
そのほか、さまざまな
Windows 10 搭載デバイスで動く❢
• 左: HoloLens
Windows 10 搭載
ヘッドマウント型
コンピュータ
• 上右:
Surface Hub
• 下左: Xbox One
• 下右:
組み込み用ボード
コンピュータ
9
わんくま同盟 名古屋勉強会 #37
【参考】 Xbox One が Windows 10 になる!?
• Xbox One には、Windows 8 が 2
つ載っている
• ひとつは、リアルタイム ゲーム用
(図の右側)
これは変わらないだろう
• もうひとつは、Xbox コンソールや
「Shared apps」 などを動かす部分
(図の左側)
⇨ Windows 10 for Xbox (仮)
にアップグレード
10
わんくま同盟 名古屋勉強会 #37
Windows 10 のユニバーサル Windows プラットフォームで動作するアプリ
= Windows 10 用
ユニバーサル Windows プラットフォーム アプリ
略して、
⇨ ユニバーサル Windows プラットフォーム アプリ / UWP アプリ
⇨ ユニバーサル Windows アプリ
⇨ ユニバーサル アプリ / Windows アプリ
ユニバーサル Windows プラットフォーム アプリ
11
わんくま同盟 名古屋勉強会 #37
• Windows 8.x と Windows Phone 7.x/8.x の間でユニバーサルに使える
アプリも、「ユニバーサル Windows アプリ」 (でもこれは別バイナリ)
注意!!
従来と区別が付くように、略称を使ってね♪
12
※ Build 2014 キーノートより
わんくま同盟 名古屋勉強会 #37
• Windows ストアからダウンロード / インストール
※ ストアを介さない「サイドローディング」も可能
• ユーザーごとのインストール
• 改竄チェック / 権限チェック
• サンドボックスでの実行
• 自動アップデート
• クリーンなアンインストール
UWP は、新形式の AppX パッケージを動かす
13
※ Build 2015 セッション 2-695 資料
わんくま同盟 名古屋勉強会 #37
【参考】 AppX 系パッケージの変遷
14
※ Build 2015 セッション 2-695 資料
わんくま同盟 名古屋勉強会 #37
どのデバイスでも共通に使える API
UWP は、単一の API Surface を提供する
15
※ MVA "A Developer's Guide to Windows 10" モジュール01 資料
わんくま同盟 名古屋勉強会 #37
デバイス固有の拡張部分 (Extension) がある
UWP の API は、デバイスによって違いがある
16
UWP 共通部分
デスクトップ用 Extension
スマートフォン用 Extension
UWP 共通部分
ここを
「Windows Core」
と呼ぶこともある
わんくま同盟 名古屋勉強会 #37
デバイス
PC / タブ
レット(大)
スマートフォ
ン / タブレッ
ト(小)
組み込み
ボード
Surface Hub HoloLens Xbox One
Extension Desktop Mobile IoT Team (未発表) (未発表)
Windows 10
エディション
・Home
・Pro
・Enterprise
・Education
・IoT for
industory
devices (仮)
・Mobile
・Mobile
Enterprise
・IoT for
mobile
devices (仮)
・IoT Core ・Surface
Hub 用
・HoloLens用
(仮)
・Xbox用
(仮)
デバイス、エクステンション、
Windows 10 のエディションとの対応
17
わんくま同盟 名古屋勉強会 #37
•今のところ不明瞭 orz
• とりあえず、 「AppX パッケージを動かす仕組み」 と大雑把に把握して
おけば OK だろう
• 将来、きちんとしたドキュメント (書籍?) が出てくることを期待
で、 ユニバーサル Windows プラットフォームの
構造や範囲などの詳細は?
18
わんくま同盟 名古屋勉強会 #37
Xbox
One
IoT
Core
Universal
Windows Platform
Core APIsUWP アプリの
特徴
従来のデスクトップアプリとの
比較
19
わんくま同盟 名古屋勉強会 #37
アプリ
従来の
デスクトップアプリ
UWP アプリ
デバイス PC / タブレット
PC / タブレット
スマートフォン / IoT / Surface
Hub / Hololens / Xbox One
等
Windows バージョン
Windows 7 / 8.x / 10
( Windows RT は除く )
Windows 10
( Windows RT では動かず)
動作するデバイスと Windows
20
わんくま同盟 名古屋勉強会 #37
アプリ 従来のデスクトップアプリ UWP アプリ
UI / プログラミ
ング言語
WinForm + C# / VB
XAML (WPF) + C# / VB
MFC + C++
XAML + C# / VB
HTML + JavaScript
XAML + C++
利用する API
・.NET Framework 主体
・利用可:
Win32 API, COM,
Windows Runtime (一部)
・Windows Runtime 主体
・利用可(一部だけ):
.NET Framework, Win32 API,
COM
タッチ対応 UI
自前で実装
(サードパーティ部品あり)
標準対応
UI / プログラミング言語 / 利用する API / タッチ対応
21
わんくま同盟 名古屋勉強会 #37
アプリ 従来のデスクトップアプリ UWP アプリ
配布パッケージ
・MSI パッケージ
・サードパーティ製インストーラ
・実行ファイルそのまま
AppX パッケージ
配布方法
自由
(Windows ストアを除く)
・Windows ストア
・Windows ストア for
Business
・サイドローディング
インストールの
影響
(可能性)
レジストリーへの書き込み
システム DLL 上書き
⇨ Windows が 「腐る」
ほぼ無し
⇨ Windows が
「腐らない」
配布とインストール
22
わんくま同盟 名古屋勉強会 #37
アプリ
従来のデスクトップア
プリ
UWP アプリ
アプリに対す
る制限
・なし (UACのみ)
・実行中に UAC 昇格
可能
・サンドボックスで動作
・管理者権限不可
・ファイル I/O やプリンター制御などに制限
・DB アクセスやプロセス間通信は不可
アプリ保護 なし
・インストール フォルダーに特殊なアクセス
権 (Adminでもアクセス不可)
・実行時に他アプリからアクセス不可
セキュリティ面での制限と保護
23
≪参考≫ Designing a simple and secure app package – APPX
Delivering reliable and trustworthy Metro style apps
わんくま同盟 名古屋勉強会 #37
アプリ 従来のデスクトップアプリ UWP アプリ
アーキテクチャ
・クライアント = サーバー
・DB直結も可能
(褒められた手法ではない)
・「クラウド型」
・DB直結は不可
(必ず Web サービス経由)
業務アプリで推奨されるアーキテクチャ
24
Webサービス
Webサービスのフロントエンドとしての
Windows 10デバイス
DB 文書
別セグメントのLAN/クラウド
DB サーバー等
DB サーバーなど基幹サーバーに
クライアントから直結も可能
DB 文書
わんくま同盟 名古屋勉強会 #37
Xbox
One
IoT
Core
Universal
Windows Platform
Core APIsUWP アプリの
開発準備
開発を始めるには?
25
わんくま同盟 名古屋勉強会 #37
• UWP アプリを作るには?
* Windows 10 (PC)
* Visual Studio 2015 + Windows 10 SDK
* MS アカウント (開発者用ライセンス取得に必要)
* (できれば) ターゲット デバイス
• UWP アプリを配布するには?
* クレジットカード
* ストアへ開発者登録
(または、サイドローディングのためのデジタル署名)
概要
26
わんくま同盟 名古屋勉強会 #37
• エディションは問わない
• ただし、エミュレータを利用するには、Hyper-V が使えること
* SLAT 対応ハードウェア
* CMPXCHG16b、PrefetchW、LAHF/SAHF サポート
(古いAMDプロセッサだと未対応の可能性あり)
* RAM 4GB 以上
* 64bit版 Windows 10 Pro / Enterprise
• テスト環境では、開発ターゲットに合わせたブランチ (後述) を維持して
おくこと
※ ブランチの更新を止めるには Enterprise と WSUS が必要らしい
Windows 10 (PC)
27
わんくま同盟 名古屋勉強会 #37
• Window Update の方法が変わる
* セキュリティ アップデート ⇨ すべて強制
* 新機能アップデート ⇨ ブランチによって異なる
• PC 向けに 3 種類のブランチ
* CB (Current Branch): 強制アップデート [全エディション]
* CBB (Current Branch for Business): 1サイクル (約4か月) 延期可能
[Pro 版以上で選択可]
* LTSB (Long Term Servicing Branch): 最大10年間延期可能
[Enterprise / Education で選択可]
* 以上の他に、「人柱モード」 IP (Windows Insider Preview Branch) あり
【参考】 Windows 10 (PC) のアップデート ブランチ
28
わんくま同盟 名古屋勉強会 #37
• VS 2015 のエディションは問わない
無償の Express や Community でも OK♪
• Windows 10 SDK、および
Visual Studio Universal Windows app development tools
※ ストアへの提出には、プレビュー版はダメ (次ページ)
Visual Studio 2015 と SDK
29
わんくま同盟 名古屋勉強会 #37
• どちらもプレビュー版が配布されるけど、
Windows 10 新ブランチの正式リリースまでは
ストアでの公開は不可 ☜ 要注意!
• 例:2015/10 のプレビュー版SDK で作ったアプリは、
2015/11(予定)の Windows 10 TH2 のリリースまで公開できない
Windows 10 と SDK のリリース サイクル
30
Windows 10
SDK
2015/7月 10月 11月
★ TH1 リリース
★ TH1用 リリース
★ IP ★ IP … … ★ IP
★ プレビュー版
★ TH2 リリース
★ TH2用 リリース
わんくま同盟 名古屋勉強会 #37
• 「入会金」が必要 (クレジットカード払い)
現在 1,847円 (会社アカウントは 9,800円)
• 登録手順
https://msdn.microsoft.com/ja-jp/library/windows/apps/bg124287.aspx
• アプリ開発者契約書
https://msdn.microsoft.com/ja-jp/library/windows/apps/hh694058.aspx
• そのほか、目を通しておくべきドキュメント
* Windows ストア ポリシー (これに違反するとストアの審査に落ちる)
* 開発者倫理規定
ストアへの開発者登録
~ 開発中はなくてもいい。ストアに提出するときには必要
31
わんくま同盟 名古屋勉強会 #37
Xbox
One
IoT
Core
Universal
Windows Platform
Core APIsUWP アプリの
開発
とくに、複数のデバイスに対
応する方法は?
32
わんくま同盟 名古屋勉強会 #37
VS2015 RC では
「Windows Universal」
・Class Library
=.NET の普通のDLL
・Windows Runtime
Component
= JavaScript からも
使える DLL
・Unit Test App
= ストアアプリ用
MSTest
プロジェクトを作成する
33
わんくま同盟 名古屋勉強会 #37
プロジェクトのプロパティ
UWP ターゲット バージョンの指定
~ Windows 10 には 「バージョン」がある! (≒ブランチ)
34
わんくま同盟 名古屋勉強会 #37
マニフェスト ファイル
~ WPF では App.config、 UWP では Package.appxmanifest
35
動作対象デバイス
「Mobileのみ」 などと指
定が可能
ン
RTM では、自動的に設
定されると思われる
ターゲットバージョン
RTM では、
自動的に設定される
わんくま同盟 名古屋勉強会 #37
例: StreamSocketControl.ClientCertificate
【参考】 MSDN ドキュメントのバージョン情報
36
動作対象デバイス
適用開始バージョン
RTM 以降に追加された API
では 1.0 より大きい値になると
思われる
わんくま同盟 名古屋勉強会 #37
UI は XAML で。
書き方は、WPF と
ほぼ同じ
"Hello, world!"
~ WPF に慣れていれば楽勝♪
37
T e x t B l o c k を 配 置 し て 、
「 H e l l o , U W P ! 」
わんくま同盟 名古屋勉強会 #37
WPF とほぼ同じ。
Compiled Binding という
パフォーマンスの良い
手法も導入された
(右の画像は従来方式)
データ バインディング
~ WPF に慣れていれば、まぁ楽勝
38
1. バインディング
ソース
2. TextBlock に
バインド
3. バインドされた
データが
表示される
わんくま同盟 名古屋勉強会 #37
慣れていないと、
落とし穴がたくさん!
がんばって♪
async / await
~ UWP の世界は非同期 API ばかり!
39
ファイルを読み込むだけでも
非同期処理 !!
※ WinRT/Metro TIPS:「テキストファイルを簡単に読み書きするには?」より
わんくま同盟 名古屋勉強会 #37
画面幅などに応じて
デザインの変更を
指定できる
複数デバイス対応 その1: Adaptive Trigger
~ XAML だけでレスポンシブ デザイン
40
画面幅が狭いときに
適用されるスタイル
画面幅が中間のときに
適用されるスタイル
わんくま同盟 名古屋勉強会 #37
複数デバイス対応 その2: Xaml View
~ 1画面に複数の XAML ファイルを割り当て ⇨ 自動選択
41
Desktop 用の XAML
Mobile 用の XAML
その他のデバイス用の XAML
共通のコードビハインド
わんくま同盟 名古屋勉強会 #37
複数デバイス対応 その3: デバイス固有 API の使用
~ その API が利用できるか確かめてから呼び出す
42
Mobile 固有の API が
使えることをチェック
この例では
Mobile の [戻る] ボタンの
イベントハンドラーを
セットしている
※ PlatformSpecific Analyzer を使うと if 文を自動生成できる
わんくま同盟 名古屋勉強会 #37
【参考】 システム ワイドな [戻る] ボタン対応
~ 前ページの例は、今となってはもう使わない m(_`_)m
43
ウィンドウ左上の [戻る] ボタン
Phone の [戻る] ボタン
タスクバーの [戻る] ボタン
(タブレット モード時)
WinRT/Metro TIPS: 「システムの[戻る]ボタンに対応するには?」 参照
わんくま同盟 名古屋勉強会 #37
※ ストアへ提出するパッケージを作る前に、リリースビルドへ切り替えるのを忘れずに!
AppX パッケージの作成
~ パッケージの作成ウィザードで、さっくり作れる
44
はい: ストアへの提出用
いいえ: テスト用
わんくま同盟 名古屋勉強会 #37
※ パッケージ作成完了時に起動できる。直接起動してからアプリを指定してもよい。
WACK: アプリ認定キット
~ このテストに通らないようなら、ストアで確実にリジェクトされる
45
わんくま同盟 名古屋勉強会 #37
Xbox
One
IoT
Core
Universal
Windows Platform
Core APIs
まとめ
UWP のメリット/デメリット
46
わんくま同盟 名古屋勉強会 #37
UWP アプリ開発をやりますか? (はい/Yes)
• ○ Windows 10 の複数デバイスで動く
• ○ 安心で安全、Windows が「腐らない」
• × Windows 7 / 8.x では動かない
(全てが Window 10 に置き換わった後ではデメリットにならない)
• ☆ 面白いよ♪
そして今ならまだ、先頭に立てるチャンス❢
47
わんくま同盟 名古屋勉強会 #37
ユニバーサル
Windows アプリ
開発入門♪
2015/11/14
BluewaterSoft @biac

わんくま名古屋 #37 (20151114) Windows 10 UWP アプリ開発入門(実践編)

  • 1.
    わんくま同盟 名古屋勉強会 #37 Windows10 TH2 そろそろリリース UWP アプリ 開発入門♪ (実践編) 2015/11/14 BluewaterSoft @biac
  • 2.
    わんくま同盟 名古屋勉強会 #37 スピーカー紹介 •BluewaterSoft 山本 康彦 a.k.a @biac まだ人工衛星が飛んでない時代に生まれ、HONDAでクルマの設計やってました • Microsoft MVP for Windows Development (2014/10-2016/9) • Windows ランタイム アプリ開発 / 記事や書籍の執筆 やってます 2
  • 3.
    わんくま同盟 名古屋勉強会 #37 スピーカー紹介 ~このセッションに関連する@ITの記事 • 徹底予習! Windows 10 のユニバーサルアプリ開発 2015/4/28 http://www.atmarkit.co.jp/ait/articles/1504/28/news015.html • Windows 10 UWP で業務デスクトップアプリ開発はどう変わるのか? 2015/6/23 http://www.atmarkit.co.jp/ait/articles/1506/23/news012.html • Build 2015: 全ての開発者が押さえておくべきマイクロソフトの最新技術 動向 2015/5/12 http://www.atmarkit.co.jp/ait/articles/1505/12/news011.html 3
  • 4.
    わんくま同盟 名古屋勉強会 #37 Windows10 どんどんリリース❢ 4 Copyright © 2015 Windows Navi+
  • 5.
    わんくま同盟 名古屋勉強会 #37 Windows10 リリース スケジュール • 7/29 Win7/8.1からの無償アップデート 開始 • 8/1 デスクトップ版 Enterprise 契約 販 売開始 • 9月(?) デスクトップ版パッケージ販売開 始 (USBメモリ) • 11月 Windows 10 TH2 リリース予定 • 秋以降 Windows Phone 8.1、Xbox One からの無償アップデート開始 • 来年 Surface Hub / HoloLens 発売 5 DSP 版 Windows 10 自作 PC 応援キャラクター 窓辺 てんこ (仮名) Copyright © 2015 Windows Navi+ ドイツの Web サイトがリークした 製品パッケージ (左:Pro、右:Home) 背景は Windows 10 標準の壁紙 "Hero Desktop Image"
  • 6.
    わんくま同盟 名古屋勉強会 #37 Xbox One IoT Core Universal WindowsPlatform Core APIs UWP アプリ ユニバーサル Windows プラットフォーム アプリ とは? 6
  • 7.
    わんくま同盟 名古屋勉強会 #37 デスクトップで使う分には、 見た目の違いは小さい •左: WPF アプリ 右: UWP アプリ • ウィンドウの違い は、システムメ ニューアイコンの 有無くらい 7
  • 8.
    わんくま同盟 名古屋勉強会 #37 でも、UWPアプリは、同じバイナリが Windows 10 搭載スマートフォンでも動く❢ • Windows 10 Mobile エミュレータの画像 (VS2015RC 付属) 8
  • 9.
    わんくま同盟 名古屋勉強会 #37 そのほか、さまざまな Windows10 搭載デバイスで動く❢ • 左: HoloLens Windows 10 搭載 ヘッドマウント型 コンピュータ • 上右: Surface Hub • 下左: Xbox One • 下右: 組み込み用ボード コンピュータ 9
  • 10.
    わんくま同盟 名古屋勉強会 #37 【参考】Xbox One が Windows 10 になる!? • Xbox One には、Windows 8 が 2 つ載っている • ひとつは、リアルタイム ゲーム用 (図の右側) これは変わらないだろう • もうひとつは、Xbox コンソールや 「Shared apps」 などを動かす部分 (図の左側) ⇨ Windows 10 for Xbox (仮) にアップグレード 10
  • 11.
    わんくま同盟 名古屋勉強会 #37 Windows10 のユニバーサル Windows プラットフォームで動作するアプリ = Windows 10 用 ユニバーサル Windows プラットフォーム アプリ 略して、 ⇨ ユニバーサル Windows プラットフォーム アプリ / UWP アプリ ⇨ ユニバーサル Windows アプリ ⇨ ユニバーサル アプリ / Windows アプリ ユニバーサル Windows プラットフォーム アプリ 11
  • 12.
    わんくま同盟 名古屋勉強会 #37 •Windows 8.x と Windows Phone 7.x/8.x の間でユニバーサルに使える アプリも、「ユニバーサル Windows アプリ」 (でもこれは別バイナリ) 注意!! 従来と区別が付くように、略称を使ってね♪ 12 ※ Build 2014 キーノートより
  • 13.
    わんくま同盟 名古屋勉強会 #37 •Windows ストアからダウンロード / インストール ※ ストアを介さない「サイドローディング」も可能 • ユーザーごとのインストール • 改竄チェック / 権限チェック • サンドボックスでの実行 • 自動アップデート • クリーンなアンインストール UWP は、新形式の AppX パッケージを動かす 13 ※ Build 2015 セッション 2-695 資料
  • 14.
    わんくま同盟 名古屋勉強会 #37 【参考】AppX 系パッケージの変遷 14 ※ Build 2015 セッション 2-695 資料
  • 15.
    わんくま同盟 名古屋勉強会 #37 どのデバイスでも共通に使えるAPI UWP は、単一の API Surface を提供する 15 ※ MVA "A Developer's Guide to Windows 10" モジュール01 資料
  • 16.
    わんくま同盟 名古屋勉強会 #37 デバイス固有の拡張部分(Extension) がある UWP の API は、デバイスによって違いがある 16 UWP 共通部分 デスクトップ用 Extension スマートフォン用 Extension UWP 共通部分 ここを 「Windows Core」 と呼ぶこともある
  • 17.
    わんくま同盟 名古屋勉強会 #37 デバイス PC/ タブ レット(大) スマートフォ ン / タブレッ ト(小) 組み込み ボード Surface Hub HoloLens Xbox One Extension Desktop Mobile IoT Team (未発表) (未発表) Windows 10 エディション ・Home ・Pro ・Enterprise ・Education ・IoT for industory devices (仮) ・Mobile ・Mobile Enterprise ・IoT for mobile devices (仮) ・IoT Core ・Surface Hub 用 ・HoloLens用 (仮) ・Xbox用 (仮) デバイス、エクステンション、 Windows 10 のエディションとの対応 17
  • 18.
    わんくま同盟 名古屋勉強会 #37 •今のところ不明瞭orz • とりあえず、 「AppX パッケージを動かす仕組み」 と大雑把に把握して おけば OK だろう • 将来、きちんとしたドキュメント (書籍?) が出てくることを期待 で、 ユニバーサル Windows プラットフォームの 構造や範囲などの詳細は? 18
  • 19.
    わんくま同盟 名古屋勉強会 #37 Xbox One IoT Core Universal WindowsPlatform Core APIsUWP アプリの 特徴 従来のデスクトップアプリとの 比較 19
  • 20.
    わんくま同盟 名古屋勉強会 #37 アプリ 従来の デスクトップアプリ UWPアプリ デバイス PC / タブレット PC / タブレット スマートフォン / IoT / Surface Hub / Hololens / Xbox One 等 Windows バージョン Windows 7 / 8.x / 10 ( Windows RT は除く ) Windows 10 ( Windows RT では動かず) 動作するデバイスと Windows 20
  • 21.
    わんくま同盟 名古屋勉強会 #37 アプリ従来のデスクトップアプリ UWP アプリ UI / プログラミ ング言語 WinForm + C# / VB XAML (WPF) + C# / VB MFC + C++ XAML + C# / VB HTML + JavaScript XAML + C++ 利用する API ・.NET Framework 主体 ・利用可: Win32 API, COM, Windows Runtime (一部) ・Windows Runtime 主体 ・利用可(一部だけ): .NET Framework, Win32 API, COM タッチ対応 UI 自前で実装 (サードパーティ部品あり) 標準対応 UI / プログラミング言語 / 利用する API / タッチ対応 21
  • 22.
    わんくま同盟 名古屋勉強会 #37 アプリ従来のデスクトップアプリ UWP アプリ 配布パッケージ ・MSI パッケージ ・サードパーティ製インストーラ ・実行ファイルそのまま AppX パッケージ 配布方法 自由 (Windows ストアを除く) ・Windows ストア ・Windows ストア for Business ・サイドローディング インストールの 影響 (可能性) レジストリーへの書き込み システム DLL 上書き ⇨ Windows が 「腐る」 ほぼ無し ⇨ Windows が 「腐らない」 配布とインストール 22
  • 23.
    わんくま同盟 名古屋勉強会 #37 アプリ 従来のデスクトップア プリ UWPアプリ アプリに対す る制限 ・なし (UACのみ) ・実行中に UAC 昇格 可能 ・サンドボックスで動作 ・管理者権限不可 ・ファイル I/O やプリンター制御などに制限 ・DB アクセスやプロセス間通信は不可 アプリ保護 なし ・インストール フォルダーに特殊なアクセス 権 (Adminでもアクセス不可) ・実行時に他アプリからアクセス不可 セキュリティ面での制限と保護 23 ≪参考≫ Designing a simple and secure app package – APPX Delivering reliable and trustworthy Metro style apps
  • 24.
    わんくま同盟 名古屋勉強会 #37 アプリ従来のデスクトップアプリ UWP アプリ アーキテクチャ ・クライアント = サーバー ・DB直結も可能 (褒められた手法ではない) ・「クラウド型」 ・DB直結は不可 (必ず Web サービス経由) 業務アプリで推奨されるアーキテクチャ 24 Webサービス Webサービスのフロントエンドとしての Windows 10デバイス DB 文書 別セグメントのLAN/クラウド DB サーバー等 DB サーバーなど基幹サーバーに クライアントから直結も可能 DB 文書
  • 25.
    わんくま同盟 名古屋勉強会 #37 Xbox One IoT Core Universal WindowsPlatform Core APIsUWP アプリの 開発準備 開発を始めるには? 25
  • 26.
    わんくま同盟 名古屋勉強会 #37 •UWP アプリを作るには? * Windows 10 (PC) * Visual Studio 2015 + Windows 10 SDK * MS アカウント (開発者用ライセンス取得に必要) * (できれば) ターゲット デバイス • UWP アプリを配布するには? * クレジットカード * ストアへ開発者登録 (または、サイドローディングのためのデジタル署名) 概要 26
  • 27.
    わんくま同盟 名古屋勉強会 #37 •エディションは問わない • ただし、エミュレータを利用するには、Hyper-V が使えること * SLAT 対応ハードウェア * CMPXCHG16b、PrefetchW、LAHF/SAHF サポート (古いAMDプロセッサだと未対応の可能性あり) * RAM 4GB 以上 * 64bit版 Windows 10 Pro / Enterprise • テスト環境では、開発ターゲットに合わせたブランチ (後述) を維持して おくこと ※ ブランチの更新を止めるには Enterprise と WSUS が必要らしい Windows 10 (PC) 27
  • 28.
    わんくま同盟 名古屋勉強会 #37 •Window Update の方法が変わる * セキュリティ アップデート ⇨ すべて強制 * 新機能アップデート ⇨ ブランチによって異なる • PC 向けに 3 種類のブランチ * CB (Current Branch): 強制アップデート [全エディション] * CBB (Current Branch for Business): 1サイクル (約4か月) 延期可能 [Pro 版以上で選択可] * LTSB (Long Term Servicing Branch): 最大10年間延期可能 [Enterprise / Education で選択可] * 以上の他に、「人柱モード」 IP (Windows Insider Preview Branch) あり 【参考】 Windows 10 (PC) のアップデート ブランチ 28
  • 29.
    わんくま同盟 名古屋勉強会 #37 •VS 2015 のエディションは問わない 無償の Express や Community でも OK♪ • Windows 10 SDK、および Visual Studio Universal Windows app development tools ※ ストアへの提出には、プレビュー版はダメ (次ページ) Visual Studio 2015 と SDK 29
  • 30.
    わんくま同盟 名古屋勉強会 #37 •どちらもプレビュー版が配布されるけど、 Windows 10 新ブランチの正式リリースまでは ストアでの公開は不可 ☜ 要注意! • 例:2015/10 のプレビュー版SDK で作ったアプリは、 2015/11(予定)の Windows 10 TH2 のリリースまで公開できない Windows 10 と SDK のリリース サイクル 30 Windows 10 SDK 2015/7月 10月 11月 ★ TH1 リリース ★ TH1用 リリース ★ IP ★ IP … … ★ IP ★ プレビュー版 ★ TH2 リリース ★ TH2用 リリース
  • 31.
    わんくま同盟 名古屋勉強会 #37 •「入会金」が必要 (クレジットカード払い) 現在 1,847円 (会社アカウントは 9,800円) • 登録手順 https://msdn.microsoft.com/ja-jp/library/windows/apps/bg124287.aspx • アプリ開発者契約書 https://msdn.microsoft.com/ja-jp/library/windows/apps/hh694058.aspx • そのほか、目を通しておくべきドキュメント * Windows ストア ポリシー (これに違反するとストアの審査に落ちる) * 開発者倫理規定 ストアへの開発者登録 ~ 開発中はなくてもいい。ストアに提出するときには必要 31
  • 32.
    わんくま同盟 名古屋勉強会 #37 Xbox One IoT Core Universal WindowsPlatform Core APIsUWP アプリの 開発 とくに、複数のデバイスに対 応する方法は? 32
  • 33.
    わんくま同盟 名古屋勉強会 #37 VS2015RC では 「Windows Universal」 ・Class Library =.NET の普通のDLL ・Windows Runtime Component = JavaScript からも 使える DLL ・Unit Test App = ストアアプリ用 MSTest プロジェクトを作成する 33
  • 34.
    わんくま同盟 名古屋勉強会 #37 プロジェクトのプロパティ UWPターゲット バージョンの指定 ~ Windows 10 には 「バージョン」がある! (≒ブランチ) 34
  • 35.
    わんくま同盟 名古屋勉強会 #37 マニフェストファイル ~ WPF では App.config、 UWP では Package.appxmanifest 35 動作対象デバイス 「Mobileのみ」 などと指 定が可能 ン RTM では、自動的に設 定されると思われる ターゲットバージョン RTM では、 自動的に設定される
  • 36.
    わんくま同盟 名古屋勉強会 #37 例:StreamSocketControl.ClientCertificate 【参考】 MSDN ドキュメントのバージョン情報 36 動作対象デバイス 適用開始バージョン RTM 以降に追加された API では 1.0 より大きい値になると 思われる
  • 37.
    わんくま同盟 名古屋勉強会 #37 UIは XAML で。 書き方は、WPF と ほぼ同じ "Hello, world!" ~ WPF に慣れていれば楽勝♪ 37 T e x t B l o c k を 配 置 し て 、 「 H e l l o , U W P ! 」
  • 38.
    わんくま同盟 名古屋勉強会 #37 WPFとほぼ同じ。 Compiled Binding という パフォーマンスの良い 手法も導入された (右の画像は従来方式) データ バインディング ~ WPF に慣れていれば、まぁ楽勝 38 1. バインディング ソース 2. TextBlock に バインド 3. バインドされた データが 表示される
  • 39.
    わんくま同盟 名古屋勉強会 #37 慣れていないと、 落とし穴がたくさん! がんばって♪ async/ await ~ UWP の世界は非同期 API ばかり! 39 ファイルを読み込むだけでも 非同期処理 !! ※ WinRT/Metro TIPS:「テキストファイルを簡単に読み書きするには?」より
  • 40.
    わんくま同盟 名古屋勉強会 #37 画面幅などに応じて デザインの変更を 指定できる 複数デバイス対応その1: Adaptive Trigger ~ XAML だけでレスポンシブ デザイン 40 画面幅が狭いときに 適用されるスタイル 画面幅が中間のときに 適用されるスタイル
  • 41.
    わんくま同盟 名古屋勉強会 #37 複数デバイス対応その2: Xaml View ~ 1画面に複数の XAML ファイルを割り当て ⇨ 自動選択 41 Desktop 用の XAML Mobile 用の XAML その他のデバイス用の XAML 共通のコードビハインド
  • 42.
    わんくま同盟 名古屋勉強会 #37 複数デバイス対応その3: デバイス固有 API の使用 ~ その API が利用できるか確かめてから呼び出す 42 Mobile 固有の API が 使えることをチェック この例では Mobile の [戻る] ボタンの イベントハンドラーを セットしている ※ PlatformSpecific Analyzer を使うと if 文を自動生成できる
  • 43.
    わんくま同盟 名古屋勉強会 #37 【参考】システム ワイドな [戻る] ボタン対応 ~ 前ページの例は、今となってはもう使わない m(_`_)m 43 ウィンドウ左上の [戻る] ボタン Phone の [戻る] ボタン タスクバーの [戻る] ボタン (タブレット モード時) WinRT/Metro TIPS: 「システムの[戻る]ボタンに対応するには?」 参照
  • 44.
    わんくま同盟 名古屋勉強会 #37 ※ストアへ提出するパッケージを作る前に、リリースビルドへ切り替えるのを忘れずに! AppX パッケージの作成 ~ パッケージの作成ウィザードで、さっくり作れる 44 はい: ストアへの提出用 いいえ: テスト用
  • 45.
    わんくま同盟 名古屋勉強会 #37 ※パッケージ作成完了時に起動できる。直接起動してからアプリを指定してもよい。 WACK: アプリ認定キット ~ このテストに通らないようなら、ストアで確実にリジェクトされる 45
  • 46.
    わんくま同盟 名古屋勉強会 #37 Xbox One IoT Core Universal WindowsPlatform Core APIs まとめ UWP のメリット/デメリット 46
  • 47.
    わんくま同盟 名古屋勉強会 #37 UWPアプリ開発をやりますか? (はい/Yes) • ○ Windows 10 の複数デバイスで動く • ○ 安心で安全、Windows が「腐らない」 • × Windows 7 / 8.x では動かない (全てが Window 10 に置き換わった後ではデメリットにならない) • ☆ 面白いよ♪ そして今ならまだ、先頭に立てるチャンス❢ 47
  • 48.
    わんくま同盟 名古屋勉強会 #37 ユニバーサル Windowsアプリ 開発入門♪ 2015/11/14 BluewaterSoft @biac

Editor's Notes

  • #2 前回の勉強会では、Windows 10 UWP アプリ開発の概要を解説しました。今回は、実際にコードを作って動かすところをご紹介。 Windows phone 用の Windows 10 も RTM になっているので (そのハズ)、1ソースでマルチデバイスに対応する実際も見ていただけるはず。 ⇒ ゴメンナサイ m(_`_)m なんと、まだ Win10Mobile が RTM してないとは… orz
  • #5 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる
  • #7 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる
  • #12 これからはずっと「Windows 10」だというが、何年か先には UWP の刷新があるだろう。 そのとき何と呼ぶことになるのか? 今から頭が痛い。 「Windows 10 "Amber"(仮) 用 UWP」 とか!?
  • #15 AppX 8.1 や XAP を扱う部分まで UWP に含めるのかどうかは、今のところ不明。
  • #17 Windows 10 の NT カーネル (+α) を Windows Core と呼ぶこともある。 Windows 10 Home エディションのことを Windows 10 Core と呼ぶこともある。
  • #19 これからはずっと「Windows 10」だというが、何年か先には UWP の刷新があるだろう。 そのとき何と呼ぶことになるのか? 今から頭が痛い。 「Windows 10 "Amber"(仮) 用 UWP」 とか!?
  • #20 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる
  • #26 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる
  • #33 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる
  • #37 プロジェクトで指定する「バージョン」と、この ApiContract のバージョンは表記法が違う。どうやってマッチングすればいいのか、今のところ不明。
  • #44 イベントハンドラー内で、CanGobackを見ること! タブレットモード時、最初の画面でタスクバーの [←] をタップされたときは、スタート画面に戻らないといけない。
  • #47 http://download.microsoft.com/download/C/E/B/CEBFC4DD-B9DF-4A62-8B65-4944B7489E91/RelNotes_VSTools_Windows10TP.docx metadata の更新 Exit Visual Studio. Open a command prompt as administrator. Run this script: \Program Files (x86)\Windows Kits\10\bin\x86\GenerateUnionWinMD.cmd または、最新の Win10 SDK が出てるなら、それを入れる