Project Reunionのプレビュー0.5が公開され、プロジェクトはその中間地点まで来たようだ。今回は、Project Reunion 0.5(以下、Reunion 0.5などと略記する)の発表を“祝し”、その解説をする。
Reunionの背景的な部分については、本連載で昨年8月に扱った。概要については、その記事を参照していただきたい。
●UWPからデスクトップアプリに回帰すべく、MSが送り出した「Project REUNION」
https://ascii.jp/elem/000/004/014/4014034/
簡単に言えば、Project Reunionとは、分離させたUWPとデスクトップ環境を統合して、どちらでも同じようなアプリケーションが開発できるようにするためのものだ。昨年の時点では、概要しかわからなかったが、Reunion 0.5で具体的な成果が発表されて、内容が見えてきた。
あらためてUDPとDWPの関係をおさらいする
現在のWindowsには、大きく2つのアプリケーション動作環境がある。それがDesktop Windows Platform(デスクトップ環境)とUWP(Universal Windows Platform)だ。両者は、APIやアプリケーションの挙動などに違いがある。
これまでMicrosoftは開発者をUWPに移行させようと、UWPを強化してきた。しかし、まったく人気がなく、多くのデスクトップアプリケーションはUWPには移行しないままだった。
そのため、UWP唯一の配付場所(インストールポイント)であったMicrosoftストアは閑古鳥が鳴いていた。というのも、UWPにはセキュリティのために「サンドボックス」というキツい制限がかけられており、できることも限られていたからだ。そこで、UWPへの移行は断念し、デスクトップアプリにもUWPで開発した新しいUIやAPIを利用できるようにすることを目的にしたProject Reunionを開始したわけだ。
Reunionは、Microsoftが進めている.NET Coreをベースにしたマルチプラットフォーム対応をさらに前進させる。Microsoftの「なんとかCore」と呼ばれる技術は、すべて、Windowsが内蔵していた機能をWindowsから切り離して、マルチプラットフォーム展開するためのものだ。
Project Reunionには何が含まれているのか?
Project Reunionに、UWPで使われていたGUI要素(UWP XAMLやWinUIと呼ばれていた)が含まれることは前記の記事で解説した。具体的には、以下の機能がReunionでは開発され、デスクトップアプリから利用できるようになる。
WinUI3
DirectWriteCore
MRT Core
アプリのライフサイクル
電源状態通知
ウィンドウ管理
「WinUI」とは、現在のUWPで使われているGUI部品などからなるGUIフレームワーク(かつてはUWP XAMLと呼んで、Win32 WPFのXAMLと区別していた)である。UWPが現在利用しているWinUI2をベースに開発したWinUI3を使うことで、デスクトップアプリケーションは、UWPのGUI部品を利用できるようになり、見た目をUWPアプリと同じように開発できる。
「DirectWrite Core」は、Windowsに組み込まれていたDirectWriteを独立させたものだ。DirectWriteは、DirectX(Direct3D)の上に作られた2次元の文字描画システムで、文字のレイアウトやフォント処理(ラスタライザー)、言語処理などを含んでいる。DirectWriteはWindowsに組み込まれているため、DirectWriteのバージョンアップはWindowsのバージョンアップと同期する。このため、古いWindowsでは古いバージョンのDirectWriteしか搭載されていない。
DirectWrite Coreは、DirectWriteをWindowsから切り離し、動作環境とは独立して最新機能を提供できるようにした。これにより、最新のDirectWrite Coreを使って作られたアプリは、Reunionの対象プラットフォーム(ReunionではRS5、Windows 10 Ver.1809以降をターゲットにしている)であれば、古いものであっても最新のDirectWrite Core機能が利用できるようになる。
「MRT Core」は、現在UWPアプリで使われているリソースの管理機構MRT(Modern Resource Tooling)を簡易バージョンとして独立させたもの。MRTは、その機構からPRI(Package Resource Index)などとも呼ばれ、UWPのパッケージであるAPPXで使われている。Reunionでは、このMRT Coreを主にデスクトップアプリのローカライゼーションのためのメッセージ文字列管理などに利用する。なお、PRIに関しては簡単ながら、過去記事で扱ったことがある。以下の記事を参考にされたい。
●Windows 10に標準搭載のUWPアプリの中身を掘り下げる
https://ascii.jp/elem/000/001/922/1922662/
「アプリのライフサイクル」とは、UWPアプリの起動から終了までの振る舞いのことだ。UWPアプリは、フォーカスを失うと停止され、必要に応じてメモリからも削除される。このため、すべてのUWPアプリは、停止するときに状態を記憶し、復帰後にフォアグラウンドのときの状態に復帰できるように作られている。これは、主にバッテリ消費やメモリの有効活用などのためだ。Reunionでは、このライフサイクルをデスクトップアプリケーションでも対応できるようにする。
「電源状態通知」は、UWPに対してなされている電源状態イベントをデスクトップアプリからも利用できるようにするものだ。上記のライフサイクルに関連して、アプリは電源状態をより細かく判断できるようになり、電源状態に応じた処理切り替えなどが可能になる。
デスクトップアプリであるWindows FormsアプリなどとUWPでは、アプリから行なうウィンドウの制御が完全に違っている。Win32APIでは、ウィンドウハンドルをベースにして、整数のドットアドレスでウィンドウのサイズや位置を管理する仕組みを使う。
これに対してUWPでは、ウィンドウの自由な拡大や、マルチディスプレイでの拡大率の違いなどに対応するため、浮動小数点でウィンドウの位置やサイズを表現している。この2つのAPIには大きな機能の違いがある。Reunionは、WindowsのウィンドウマネージャーであるUser32から旧来のウィンドウ管理APIの機能を独立させ、UWPアプリのウィンドウ管理APIと同時に利用できるようにする。
Reunionは具体的には、Visual Studioなどの開発環境を強化するモジュールなどの開発側のソフトウェアと、Reunionでアプリケーションを作るための「Reunion Framework」を定義し、そのランタイムパッケージ(アプリケーションの実行時に必要になるソフトウェアモジュール)である「Reunion Framework Package」を提供する。
このランタイムパッケージは、Microsoftストア経由で配布されるとのこと。なお、Reunion自体には、このランタイムパッケージのバージョン依存性(開発時よりも後のバージョンのランタイムを使うかどうか)を判断するための「Deploy Option」機能が含まれ、Reunionアプリケーションは、これによりランタイムとの整合性を取るようだ。
この連載の記事
-
第448回
PC
PowerShellで面倒なオブジェクトはPSCustomObjectに変換するのが早道 -
第447回
PC
この秋登場のWindows 11の新バージョン、Ver.24H2の状況を見る -
第446回
PC
Windows 11のフォトアプリがUWPからWin32アプリになったことで今更わかるUWPの問題点 -
第445回
PC
次期Windows 11ではAndroidのファイルをエクスプローラーからアクセス可能になる -
第444回
PC
外部ファイルをExcelに読み込む際の作業を効率化するPower Queryの活用 -
第443回
PC
Windows Terminalで採用されたCascadia Codeフォントを使うとプログラムを書くとき断然見やすい -
第442回
PC
Copilot+ PCで実現されるローカル推論で「対クラウド企業」を指向するMicrosoft -
第441回
PC
WSL以前から40年以上続く、Windows(Microsoft)とUNIXとの関わり -
第440回
PC
そもそも「Copilot+ PC」とは何なのか? -
第439回
PC
今更more.comを使うのか!? Windowsでのページングを考える -
第438回
PC
Windowsはなぜ再起動が必要になるのか? - この連載の一覧へ