Desktop Window ManagerDWMかつてはDesktop Compositing EngineDCEとも[要出典])は、Windows Vista以降のMicrosoft Windowsオペレーティングシステムで用いられるデスクトップ描画システムである。Windows VistaおよびWindows 7ではWindows Aeroテーマ使用時などに限られていたが、Windows 8からはクラシックテーマが廃止され、常にDWMを使用するようになった。

Desktop Window Manager
Microsoft Windows コンポーネント
詳細
標準提供 Windows Vista
Windows 7
Windows 8
Windows 10
Windows 11
Windows Server 2008
Windows Server 2008 R2
Windows Home Server 2011
Windows Server 2012
Windows Server 2012 R2
Windows Server 2016
Windows Server 2019
Windows Server 2022
サービス名 UxSms
正式名称 Desktop Window Manager
Session Manager
関連コンポーネント
DirectX
Graphics Device Interface
Media Integration Layer
Windows Aero

DWMが有効になる条件 編集

Windows VistaおよびWindows 7では、WindowsテーマとしてのWindows AeroまたはWindows Vistaスタンダード・Windows 7スタンダードの選択時に用いられる。Windows 8以降ではすべての場合においてDWMが使用される。

Windows VistaおよびWindows 7において、DWMの実行には少なくともDirect3D 9.0Exとシェーダーモデル 2.0に対応したグラフィックスハードウェア (GPU)、そしてWindows Display Driver Model (WDDM) 対応のデバイスドライバーが必要である。Windows 8以降では、WDDM準拠のグラフィックスドライバーが存在しない場合、ソフトウェア (Microsoft Basic Display Adapter) でDWMの処理が行われる[1]

DWMはWindows Vista Starter エディションには搭載されていない。Windows Vista Home Basic エディションには DWM が搭載されているが、透明なガラス効果やフリップ3Dなど一部の機能は無効にされている。また、Windows Server 2008およびServer 2008 R2でも、対応GPUを用いて、「デスクトップ エクスペリエンス」機能を有効にすることでDWMが使用可能となる[2]

アーキテクチャ 編集

Windows VistaつまりWDDM 1.0世代のDWMの下では、アプリケーションソフトウェア(以下アプリケーション)の描画出力は直接ビデオメモリ(VRAM)に送られず、システム メモリのオフスクリーンバッファに保持される。そして、各アプリケーションのウィンドウの内容をDWMが最終的に合成して出力する。なお、macOSQuartz Compositorも同様の仕組みを用いている。DWMがすべてのアプリケーションの描画内容を保持するため、透明効果のような複数のアプリケーション ウィンドウに跨る効果が容易に適用できる。DWMではDirect3D 9.0Exを通してGPUを利用し、オフスクリーンバッファから画面への描画に用いる過程にCPUを用いない仕組みとなっている。ただし、アプリケーションがオフスクリーンバッファへ描画する段階では、Graphics Device Interface(GDI)のようなDWMと密な連携を持たない描画技術を用いる場合、オフスクリーンバッファへCPUを用いてビットマップとして描画することになる。Windows Presentation Foundation(WPF)のようなDWM対応の描画技術では、DWM互換の形式の内部データを直接生成する。いずれにせよ、ウィンドウの内容はDirect3Dのテクスチャへ変換される。

Windows 7つまりWDDM 1.1ではDWMのメモリ管理機構が改良され、各アプリケーションのウィンドウ描画結果のコピーをシステムメモリに保持しなくなり、ワーキングメモリの消費を低減させた[3][4]。また、Windows 7のデスクトップ描画にはDirect3D 10.1 APIが使用されている[5]

デスクトップは全画面のDirect3Dサーフェイスとなっている。2次元の矩形を表現する2つの三角形のメッシュからなっており、デスクトップの画面全体を表すテクスチャ(画像)がそこに投影(テクスチャマッピング)される。ウィンドウの遷移(アニメーション)は、シェーダープログラムでメッシュの変形として実装されている[6]。Windows Vistaでは、この遷移はDWM内蔵のもの(組み込みのシェーダー)しか利用できない。マイクロソフトの開発者であるGreg Schechterは、将来的にプラグイン方式で独自の効果を適用できるようにするかもしれないと示唆している[7]。DWMはプライマリのデスクトップ オブジェクトのみを3Dサーフェイスとして扱う。ユーザーアカウント制御(UAC)のセキュア デスクトップを含む他のデスクトップ オブジェクトでは使用できない[8]

すべてのアプリケーションの描画がオフスクリーンバッファへ行われるようになった結果、他のアプリケーションが描画した内容を取り込めるようになった。オフスクリーンバッファはアプリケーションが絶えず更新するため、取り込んだ描画内容も動的に変化し続ける。これによって、ライブ サムネイル プレビューやWindowsフリップ3Dが実現されている。DWMはサムネイルを取得するAPIを公開している[9]。サムネイルの大きさは固定されておらず、好きな大きさに拡大・縮小した画像を取得できる。Windowsフリップ3DはサムネイルAPIを用いてウィンドウの内容をビットマップ画像として取得し、2D長方形のテクスチャに変換し、カスタム シェーダーによって3Dメッシュへ変換して、3D上で回転のする動作を実現している。

DWMはMedia Integration Layer(MIL)を用いている。これは、WPFと共同で使用するネイティブ コードで、各ウィンドウを合成ツリーの中の合成ノードとして扱い、最終的なデスクトップ画面を描画するシステムである[10]。最終的な出力を行う際、複数のウィンドウから出力するピクセルの色を決定する場合もある。つまり、ピクセル毎の透明効果が実装されている。DWMはそれを実現するためにカスタム シェーダーを使用している。これらのシェーダーは、ウィンドウ枠のぼかし効果などにDWMが使っているほか、アプリケーション内部の描画でも任意で使用可能である[6]

MILは合成ツリーのキャッシュという形態による保持モード(Retained Mode)のグラフィック機構である。ウィンドウの移動に伴う再描画・リフレッシュはアプリケーションの関与無しにDWMとMILが制御している。その際、ウィンドウの内容はオフスクリーンバッファのものを用いるため、以前のようにWM_PAINTを投げてアプリケーションに再描画を求めなくなっている[9]。これにより、DWMはダブル バッファによってウィンドウ移動時のちらつきを排除し[6][9]、変化のない領域は再描画しないなどの最適化も行われている[10]。合成処理が複数モニターの環境に対応しているため、DWMも複数モニターに対応している[10]

リダイレクション 編集

DWM非対応の描画技術では、出力をDWMのオフスクリーンバッファへ転送しなければならない。Windowsでは、GDIもしくはDirect3Dが描画に用いられるが、共にDWMへ転送する機構が用意されている。

WindowsでUIの描画に最もよく用いられているGDIは、各アプリケーションはウィンドウが表示される状態になったときに通知を受け、自身で描画するという形態をとっている。DWMのない状態では、VRAM上のバッファへ描画することになる。DWMの下では、ウィンドウと同じ大きさのバッファがシステム メモリ上に確保され、GDIでの描画はそこへ行われるようになる。さらに、VRAM上にDirect3Dサーフェイスが確保され、システム メモリのバッファの内容がそこへDirect3D形式へ変換しながら転送されるようになっている。システム メモリのバッファとVRAM上の内容は常に同期されるようになっている。システム メモリへのGDI描画には一切のハードウェア アクセラレーションが行われない。GDIの制限により、ウィンドウが最小化している間、バッファの内容は更新できない。その間、DWMは最小化直前のバッファの内容を保持し続ける[11]

3Dサーフェイスへ書き込むDirectXアプリケーションの場合、Windows VistaのDirectXの実装がDWMとサーフェイスを共有するようWDDMを用いており、DWMはアプリケーションのサーフェイスを直接、展開する。WPFアプリケーションでも同様に共有のサーフェイスへ書き込む[11]。GDIとDirect3Dのような複数の描画技術を1つのウィンドウで用いることは不可能だが、1つのメイン ウィンドウ内に存在する複数の子ウィンドウ同士の間ではそれぞれ別のものを使用できる。その場合、GDIとDirect3Dの間で描画順序の保証はない。システム メモリのGDIビットマップが既にVRAM上のサーフェイスに変換されたかどうか保証できないためである[11]。これを禁じたため、GDIとDirectXを1つのウィンドウで混合して用いるウィンドウを持つアプリケーションが実行中の場合、DWMは一時的に停止する。

ハードウェア要件 編集

DWMは次の要件を満たすハードウェア(外付けのグラフィックスカードオンボードグラフィックスなどのGPU)を必要とする[12]

脚注 編集

  1. ^ Desktop Window Manager is always on - Win32 apps”. Microsoft Learn. マイクロソフト. 2023年9月23日閲覧。
  2. ^ Windows Server 2008 を実行しているコンピュータで Windows Vista のユーザー エクスペリエンス機能を有効にする方法”. Knowledge Base. マイクロソフト (2008年2月20日). 2009年6月7日閲覧。
  3. ^ ASCII.jp:Windows7で大幅に変わったグラフィックドライバー (1/2)|あなたの知らないWindows
  4. ^ ASCII.jp:メモリー使用量と性能を改善する7のカーネル改良 (1/3)|あなたの知らないWindows
  5. ^ ASCII.jp:DirectX 10.1をベースにするWindows 7 (1/2)|あなたの知らないWindows
  6. ^ a b c Greg Schechter. “DWM's use of DirectX, GPUs, and hardware acceleration” (英語). Microsoft Learn (Archived MSDN Blogs). Greg Schechter's Blog. マイクロソフト. 2023年9月23日閲覧。
  7. ^ Greg Schechter. “Responding to Comments from "DWM's use of DirectX, GPUs, and hardware acceleration"” (英語). Microsoft Learn (Archived MSDN Blogs). Greg Schechter's Blog. マイクロソフト. 2023年9月23日閲覧。
  8. ^ Chris Jackson. “Desktop Window Manager only runs on the primary desktop” (英語). Chris Jackson's Semantic Consonance. MSDN Blogs. 2007年10月14日閲覧。
  9. ^ a b c Greg Schechter. “Under the hood of Desktop Window Manager” (英語). Greg Schechter's Blog. MSDN Blogs. 2007年10月14日閲覧。
  10. ^ a b c Greg Schechter. “How underlying WPF concepts and technology are being used in the DWM” (英語). Greg Schechter's Blog. MSDN Blogs. 2007年10月14日閲覧。
  11. ^ a b c Greg Schechter. “Redirecting GDI, DirectX, and WPF applications” (英語). 2007年10月14日閲覧。
  12. ^ Windows Vista のシステム要件”. マイクロソフト (2008年6月13日). 2009年6月7日閲覧。

関連項目 編集

外部リンク 編集