ビットブロック転送 (英 : Bit Block Transfer 、ビット・ブロック・トランスファー)は、コンピュータグラフィックス における画像 データ(ビットマップ )操作およびそれに関連するハードウェア機能のひとつである。ビットブロック転送の操作には少なくとも2つのビットマップを必要とし、転送の際にビット単位の論理演算 (ラスターオペレーション)を伴うこともある。
BitBlt (読みは「ビットブリット 」) と略されるが、これをデバイスドライバ やゲームの設定ファイルなどでBitBi t(lではなくてi)と表現してしまう間違いも多く見られる [要出典 ] 。
概要
ダブルバッファリング
CPU からVRAM に対する直接アクセスはCRTC からのアクセスの干渉などハードウェア的な制約が多いため、メインメモリ に対するアクセスよりも低速であることが多い。このため [疑問点 – ノート ] 、画像操作の度にVRAM にアクセスを行うことは描画速度を低下させるばかりか、描画途中で画面のフレーム が切り替わってしまう状況を生じやすく、ちらつき (フリッカー )、テアリング 、カクつき(スタッタリング )を発生させる原因となる。これらの問題の解決方法の一つとして、モニターに表示するための表画面となる画像データ領域をVRAMに、そして裏画面となる同サイズのデータ領域をメインメモリに確保しておき、画像操作は裏画面にて行ない、最終的に裏画面のデータを表画面に一括転送するというダブルバッファリング 手法がある。この転送時にビットブロック転送が利用される。Windows API (GDI )におけるBitBlt関数のように、グラフィックスデバイス(グラフィックスチップ、GPU )によるハードウェアアクセラレーション 機能を備えるものもある。CPU の代わりにDMA コントローラを用いてメインメモリからVRAM にビットマップ を転送するアーキテクチャ[要説明 ] も存在する。Macintosh では「オフスクリーン描画」と呼ぶのが普通で、"Bit Block Transfer"や"BitBlt"という語句はめったに出てこない。
ダブルバッファリングの裏画面用に確保したメモリ領域はオフスクリーン 、オフスクリーンバッファ あるいはバックバッファ と呼ぶ。またわかりやすく仮想画面 と呼ぶこともある。
Direct3D やOpenGL などのグラフィックスハードウェアアクセラレーションに対応したAPIを利用してGPU上で画像処理を行なう場合は、メインメモリを介することなくVRAM上で直接画像データを高速に操作できるが、表画面に対する直接操作は依然としてちらつきの問題を生じるため、VRAM上に裏画面を用意しておき、フリップ(スワップ)機能を用いてダブルバッファリングを行なうのが通例である。同様に、メインメモリの一部をVRAMとしてGPUと共用するオンボードグラフィックス などの環境であっても、ダブルバッファリングが必要である。
逸話
1970年代半ば頃、BitBltを活用して構築された暫定Dynabook環境(Altoで動作するSmalltalk-76)のGUI 当初は、PARC で開発されたAlto 向けに開発されたSmalltalk システムで、ポップアップするメニューやオーバーラップするウインドウを有するGUI の効率化を図るためにダン・インガルスらにより考案・実装されたものだが、後にマイクロコード化され、Altoの組み込みの機能としてSmalltalk以外のGUIシステムでも広く利用されるようになった。Smalltalkシステムでは、GUIウィジェットの通常描画の他にも、タートルグラフィックス、フォントの複数のスタイル(ボールド、イタリック、アンダーライン、取り消し線)の自動生成、あるいは、描画ツールでドット単位の部分編集を可能にする拡大表示、図形の回転処理などを行なう際などに活用された。なお、1979年時点でのSmalltalkでは隠れたウインドウの見える部分だけの描画更新処理は行なっていなかったのだが、おそらく前述マイクロコード化などのハードウェア支援も手伝って比較的高速にウインドウ処理をこなすSmalltalkシステムのデモを見たビル・アトキンソン が思い込みで、不定形領域を対象にでき、しかもソフトウェアのみで部分的な再描画を行なっているものと誤解。その認識のまま、後にApple 製Lisa やMacintosh でGUI描画の中核を担う、“リージョン”の扱いと比較的高速な描画が可能なQuickDraw として、ついに完成させてしまったという逸話がある。
関連項目