JP4698893B2 - 改良されたフォグ効果を提供するための方法、グラフィックスシステム、およびプログラム - Google Patents
改良されたフォグ効果を提供するための方法、グラフィックスシステム、およびプログラム Download PDFInfo
- Publication number
- JP4698893B2 JP4698893B2 JP2001206702A JP2001206702A JP4698893B2 JP 4698893 B2 JP4698893 B2 JP 4698893B2 JP 2001206702 A JP2001206702 A JP 2001206702A JP 2001206702 A JP2001206702 A JP 2001206702A JP 4698893 B2 JP4698893 B2 JP 4698893B2
- Authority
- JP
- Japan
- Prior art keywords
- fog
- pixel
- viewpoint
- space
- color
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
- G06T15/005—General purpose rendering architectures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
- G06T15/50—Lighting effects
- G06T15/503—Blending, e.g. for anti-aliasing
Landscapes
- Engineering & Computer Science (AREA)
- Computer Graphics (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Image Generation (AREA)
Description
【発明の属する技術分野】
本発明は、コンピュータグラフィックスに関し、より特定的には、家庭用ビデオゲームプラットフォームなどの対話式グラフィックスシステムに関する。本発明は、さらに特定的には、対話式3次元(3D)グラフィックシステムにおいて改良されたフォグ(Fog)効果を提供するためのシステムおよび方法に関する。
【0002】
【従来の技術】
我々の多くは、驚くほどリアルな恐竜、異星人、アニメーション化された玩具、およびその他の空想的な生物を含む映画を観たことがある。このようなアニメーションは、コンピュータグラフィックスによって可能となる。こうした技術を用いることにより、コンピュータグラフィックスアーチストは、各オブジェクトがどのように見えるべきか、また時間とともにどのように外見が変化すべきかを指定することができ、そしてコンピュータがオブジェクトをモデリングし、これらをテレビやコンピュータスクリーンなどのディスプレイ上に表示する。このコンピュータは、シーン中の各オブジェクトの位置および方向、各オブジェクトに光が入射しているように見える方向、各オブジェクトの表面テクスチャ、およびその他の要素に基づき、表示された画像の各部分がちょうど正しく色付けされかつ形付けられていることを確実にするために必要な多くの処理の実行を担当する。
【0003】
コンピュータグラフィックスの生成は複雑であるため、ほんの数年前では、コンピュータ生成された3次元グラフィックスは、高価な専用のフライトシミュレータ、ハイエンドのグラフィックスワークステーション、およびスーパーコンピュータに概ね限定されていた。大衆は、これらのコンピュータシステムによって生成された画像のいくつかを映画や高価なテレビ広告で見ることはあったが、我々の大部分は、グラフィックス生成を行うコンピュータに実際に接触することはできなかった。これが全て、例えばニンテンドウ64(登録商標)などの比較的安価な3Dグラフィックスプラットフォームや、現在パーソナルコンピュータで利用可能な様々な3Dグラフィックスカードが利用可能になることにより変貌した。今や、家庭またはオフィスにて、比較的安価なコンピュータグラフィックスシステム上で刺激的な3Dアニメーションおよびシミュレーションと接触することが可能である。
【0004】
過去において、グラフィックスシステムの設計者が直面した問題は、グラフィックスシステム中の3Dの仮想世界を現実世界により近くモデリングすることによって、グラフィックスシステムのリアリズムを改善することであった。グラフィックスシステムの一つの問題点は、現実世界で霧およびその他の同様な大気条件が創出する効果を、自動的には考慮しないことである。すなわち、画像全体を通じてはっきりと非常に明瞭な質感を持つコンピュータグラフィックスの画像は、現実世界と比較して非現実的に見えることがある。現実世界においては、遠くのオブジェクトは近くのオブジェクトよりも、観察者に対して明瞭さが劣って見える。この明瞭度の差は、霧、スモッグ、もや、煙、汚染、および/またはかすみ(以後単に「フォグ(Fog)」)が、観察者と観察されているオブジェクトとの間の大気中に存在し得ることに起因する。その結果、フォグを構成する分子が光を屈曲させることにより、観察者からオブジェクトへの距離が増すにしたがってオブジェクトの明瞭度が減少する。例えば、現実世界においてフォグは、ある人の近くの木を、同じ人に対してより遠い木よりも明瞭であるように、その人に対して見えるようにする。
【0005】
これに対して、コンピュータグラフィックスシステムの仮想世界においては、グラフィックスシステム中にフォグの効果をシミュレートするメカニズムが用いられない限り、オブジェクトは全て同じ明瞭度を有する。この問題に対して、様々な解決策が提案された。例えば、仮想世界のよりリアルな見え方を提供するために、レンダレングされたシーン中にフォグなどの大気効果を導入するための機能および技術を、多くのグラフィックスシステムが提供している。例えば、OpenGLグラフィックスシステム(グラフィックスハードウェアに対して、一般に用いられるソフトウェアインターフェースを提供するものである)は、プログラマが大気のフォグ効果をレンダリングすることを可能にする。OpenGLは、フォグブレンディング係数fを用いて、フォグ色を受け取ったフラグメントとブレンドすることにより、以下のようにフォギングを実現する。
C=fCin+(1−f)Cfog
【0006】
このブレンディング係数は、以下の3つの等式のうちの1つを用いて、算出される。
1)指数(GL_EXP):f=e-(density*z)
2)指数二乗(GL_EXP2):f=e-(density*z)**2
3)線形(GL_LINEAR):f=(end−z)/(end−start)
式中において、zは、視点とフラグメント中心との間の視点座標距離である。濃度(density)、始点(start)、および終点(end)の値は、全て特定の関数(すなわちglfog*())を用いるプログラマによって指定される。
【0007】
線形フォグは、例えば、輝度−深度キューイング(観察者に対してより近いオブジェクトはより高い輝度で描画される)を実現するためにしばしば用いられる。距離の関数としての輝度の効果は、受け取ったフラグメントを黒色のフォグ色とブレンドすることにより達成される。指数的フォグ等式は、物理的基礎を有している。すなわち、これは、オブジェクトと観察者との間における均一な減衰を積分した結果である。指数関数は、例えば、フォグ色およびフォグ濃度値の異なる組み合わせを用いて、複数の大気効果を表現するために用いられ得る。フォグを用いて、遠い平面の近傍のオブジェクトのぼやけた視認性を援用することにより、描画時間のオーバーラン、詳細度の遷移、およびデータベースページングなどの様々な問題を克服することができる。しかし、実用に際して、指数関数は、遠くのフラグメントを十分に早く減衰しないことがが見いだされている。従って、よりシャープな視認性の降下を提供するために、OpenGLにおいて指数二乗が導入された。グラフィックスハードウェアに対するDirect3D(DirectX)インターフェースもまた、線形、指数、および指数二乗を濃度等式において提供する。
【0008】
【発明が解決しようとする課題】
上述のように、3Dグラフィックス画像をより自然かつリアルに見せるために、過去において様々なフォグメカニズムが用いられてきた。しかし、多大な研究が過去になされてはいるが、フォグシミュレーションに関連するさらなる改良が望まれる。
【0009】
本発明は、グラフィックスシステムにおけるフォグの使用をさらに強化する改良された技術および構成を提供することにより、この問題を解決する。本発明は、グラフィックスシステムにおいて、新しく、面白くかつ視覚的に楽しい効果を達成することを可能にする改良されたフォグ機能を提供する。さらに、本発明は、フォグの水平レンジの調節を提供することにより、効果をよりリアルにするためにスクリーンの端に向かってフォグ濃度を増加する能力を提供する。本発明は、さらに、象限毎につき1つのフォグ値しか定義されない場合に、通常象限およびzblit象限に対するフォグあるいはスクリーン空間zをサンプリングする方法を提供する。
【0010】
【課題を解決するための手段および効果】
本発明により提供される1つの局面によれば、グラフィックスシステムにおいてフォグをシミュレートするための方法およびシステムが提供され、上記方法は、画素のための画素色を得ることと、フォグ色を前記画素色とブレンドすることとを含み、上記画素色とブレンドされるフォグ色の割合は、以下の2つのフォグ濃度関数のうちのいずれかに基づいて決定される。
Fog=2-8*(Ze-Z0)/Z1-Z0) (逆指数)
Fog=2-8*(Ze-Z0)/Z1-Z0)**2 (逆指数二乗)
ここで、Zeは、上記画素の視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値である。
【0011】
好ましくは、フォグ濃度関数を適用する前に、x軸方向において視角がZ軸から離れる方向に増加するにつれるレンジの変化を補正するために、視点空間z値(Ze)に対してレンジ調節がなされる。
【0012】
【発明の実施の形態】
図1は、対話式3Dコンピュータグラフィックスシステム50の一例を示す。システム50は、対話式3Dビデオゲームを面白いステレオ音とともにプレイするために用いられ得る。また、様々な他の応用例にも用いられ得る。
【0013】
本例において、システム50は、3次元世界のデジタル表現物あるいはモデルを、対話式にリアルタイムで処理することが可能である。システム50は、その世界のうちの一部または全部を、いかなる任意の視点から表示することもできる。例えば、システム50は、手持ちコントローラ52a、52bまたはその他の入力デバイスからのリアルタイム入力に応答して、対話式に視点を変更することができる。これにより、ゲームのプレーヤが、その世界の中または外側にいる人の目を通じて、その世界を見ることが可能になる。システム50は、リアルタイム3D対話式表示を必要としない応用例(例えば、2D表示生成および/または非対話式表示)に用いられ得るが、非常に素早く高品質3D画像を表示できる能力を、非常にリアルかつ刺激的なゲームプレイまたはその他のグラフィカルな対話を創出するために用いることができる。
【0014】
システム50を用いて、ビデオゲームまたはその他のアプリケーションをプレイするために、ユーザは、まず、ケーブル58を両者の間に接続することによって、メインユニット54を自分のカラーテレビ56またはその他のディスプレイデバイスに接続する。メインユニット54は、カラーテレビ56を制御するための映像信号と音声信号との両方を生成する。映像信号は、テレビスクリーン59上に表示される画像を制御するものであり、音声信号は、テレビのステレオスピーカ61L、61Rを介して音として再生される。
【0015】
ユーザは、また、メインユニット54を電源に接続する必要がある。この電源は、標準的な家庭用電気コンセントに接続して家庭電流をメインユニット54に電力供給するために、適切なより低いDC電圧信号に変換する従来のACアダプタ(図示せず)であり得る。他の実施形態として、電池を用い得る。
【0016】
ユーザは、メインユニット54を制御するためにハンドコントローラ52a、52bを用い得る。コントロール60は、例えば、テレビ56上に表示されたキャラクターが3D世界内で移動するべき方向(上下、左右、近くあるいは遠く)を指定するために用い得る。コントロール60は、また、他のアプリケーション(例えば、メニュー選択、ポインタ/カーソル制御など)のための入力を提供する。コントローラ52は、様々な形態を取り得る。本例においては、図示したコントローラ52は、それぞれジョイスティック、プッシュボタンおよび/または方向スイッチとしてのコントロール60を含む。コントローラ52は、ケーブルを介して、あるいは電磁(例えば高周波または赤外線)波を介して無線でメインユニット54に接続され得る。
【0017】
ゲームなどのアプリケーションをプレイするためには、ユーザは自分がプレイしたいビデオゲームあるいはその他のアプリケーションを記憶している適切な記憶媒体62を選択し、その記憶媒体をメインユニット54のスロット64に挿入する。記憶媒体62は、例えば、専用にコード化されたおよび/または暗号化された光学および/または磁気ディスクであり得る。ユーザは、パワースイッチ66を操作してメインユニット54をオンにし、記憶媒体62に記憶されたソフトウェアに基づいて、メインユニットにビデオゲームあるいはその他のアプリケーションの実行を開始させ得る。ユーザは、コントローラ52を操作してメインユニット54に入力を供給し得る。例えば、コントロール60を操作することにより、ゲームあるいはその他のアプリケーションを開始させ得る。その他のコントロール60を動かすことにより、アニメーション化されたキャラクターを異なる方向に移動させたり、3D世界におけるユーザの視点を変更することができる。記憶媒体62に記憶された特定のソフトウェアに依存して、コントローラ52上の様々なコントロール60は、異なる時刻において異なる機能を実行することができる。
【0018】
システム全体の電子回路例
図2に、システム50の要素例のブロック図を示す。主要な要素として以下のものを含む。
・メインプロセッサ(CPU)110、
・メインメモリ112、および
・グラフィックスおよび音声プロセッサ114
【0019】
本例において、メインプロセッサ110(例えば、機能拡張型IBM Power PC750)は、手持ちコントローラ108(および/または他の入力装置)からの入力を、グラフィックスおよびプロセッサ114を介して受け取る。メインプロセッサ110は、ユーザ入力に対話式に応答し、例えば、外部記憶媒体62から光ディスクドライブなどの大容量記憶アクセス装置106を介して供給されるビデオゲームあるいはその他のプログラムを実行する。一例としてビデオゲームプレイの場合、メインプロセッサ110は、様々な対話式機能および制御機能に加えて、衝突検出およびアニメーション処理を実行することができる。
【0020】
本例において、メインプロセッサ110は、3Dグラフィックスコマンドおよび音声コマンドを生成し、これらをグラフィックスおよび音声プロセッサ114に送る。グラフィックスおよび音声プロセッサ114は、これらのコマンドを処理することにより、ディスプレイ59上に面白い視覚画像を生成し、ステレオスピーカ61R、61Lまたはその他の適切な音声生成装置上で面白いステレオ音を生成する。
【0021】
例示のシステム50は、グラフィックスおよび音声プロセッサ114から画像信号を受け取って、画像信号をコンピュータモニタまたは家庭用カラーテレビ56などの標準的な表示装置上での表示に適したアナログおよび/またはデジタル映像信号に変換するビデオ符号化器120を有する。システム50はまた、デジタル化された音声信号を圧縮および伸長し、また必要に応じてデジタルおよびアナログの音声信号化フォーマット間の変換を行う音声コーデック(圧縮器/伸長器)122を有する。音声コーデック122は、バッファ124を介して音声入力を受け取り、これらをグラフィックスおよび音声プロセッサ114に処理(例えば、プロセッサが生成する、および/または大容量記憶アクセス装置106の音声ストリーミング出力を介して受け取る他の音声信号との混合)のために供給することができる。本例におけるグラフィックスおよび音声プロセッサ114は、音声関連の情報を、音声タスクについて利用可能である音声メモリ126中に記憶することができる。グラフィックスおよび音声プロセッサ114は、結果として得られた音声出力信号を、伸長およびアナログ信号への変換(例えばバッファアンプ128L、128Rを介して)のために音声コーデック122に供給することにより、スピーカ61L、61Rによって再生できるようにする。
【0022】
グラフィックスおよび音声プロセッサ114は、システム50内に存在し得る様々な追加的なデバイスと連絡する能力を有する。例えば、大容量記憶アクセス装置106および/またはその他の要素と連絡するために、パラレルデジタルバス130を用い得る。シリアル周辺バス132は、例えば、
・プログラム可能なリードオンリーメモリおよび/またはリアルタイムクロック134、
・モデム136その他のネットワーク化インターフェース(これは、プログラム命令および/またはデータをダウンロードまたはアップロードすることができるインターネットあるいはその他のデジタルネットワークなどの通信ネットワーク138に、システム50を接続し得る)、および
・フラッシュメモリ140
を含む、様々な周辺デバイスまたはその他のデバイスと連絡し得る。追加的な拡張メモリ144(例えばメモリカード)やその他のデバイスと連絡するために、さらなる外部シリアルバス142を用い得る。コネクタを用いて様々なデバイスをバス130、132、142に接続し得る。
【0023】
グラフィックスおよび音声プロセッサの例
図3は、グラフィックスおよび音声プロセッサ114の一例のブロック図である。一例において、グラフィックスおよび音声プロセッサ114は、単一チップのASIC(アプリケーション専用集積回路)であり得る。本例において、グラフィックスおよび音声プロセッサ114は、以下を含む。
・プロセッサインターフェース150
・メモリインターフェース/コントローラ152
・3Dグラフィックスプロセッサ154
・音声デジタル信号プロセッサ(DSP)156
・音声メモリインターフェース158
・音声インターフェースおよびミキサ160
・周辺コントローラ162、および
・ディスプレイコントローラ164
【0024】
3Dグラフィックスプロセッサ154は、グラフィックス処理タスクを行う。音声デジタル信号プロセッサ156は、音声処理タスクを行う。ディスプレイコントローラ164は、メインメモリ112からの画像情報にアクセスし、これをディスプレイデバイス56上に表示するためにビデオ符号化器120に供給する。音声インターフェースおよびミキサ160は音声コーデック120とインターフェースし、また異なるソースからの音声(例えば大容量記憶アクセス装置106からの音声ストリーミング、音声DSP156の出力、および音声コーデック122を介して受け取られる外部音声入力)を混合することができる。プロセッサインターフェース150は、メインプロセッサ110とグラフィックスおよび音声プロセッサ114との間のデータおよび制御インターフェースを提供する。
メモリインターフェース152は、グラフィックスおよび音声プロセッサ114とメモリ112との間の、データおよび制御インターフェースを提供する。本例において、メインプロセッサ110は、グラフィックスおよび音声プロセッサ114の一部であるプロセッサインターフェース150およびメモリインターフェース152を介して、メインメモリ112にアクセスする。周辺コントローラ162は、グラフィックスおよび音声プロセッサ114と、上述した様々な周辺機器との間の、データおよび制御インターフェースを提供する。音声メモリインターフェース158は、音声メモリ126とのインターフェースを提供する。
【0025】
グラフィックスパイプラインの例
図4は、3Dグラフィックスプロセッサ154の一例のより詳細な図を示す。3Dグラフィックスプロセッサ154は、特に、コマンドプロセッサ200および3Dグラフィックスパイプライン180を含む。メインプロセッサ110は、データのストリーム(例えば、グラフィックスコマンドストリームおよび表示リスト)を、コマンドプロセッサ200に通信する。メインプロセッサ110は、メモリ待ち時間を最小にするために2レベルキャッシュ115を有し、また、グラフィックスおよび音声プロセッサ114を対象とした非キャッシュデータストリーム用の書き込み収集バッファ111を有している。書き込み収集バッファ111は、部分キャッシュラインを集めて完全なキャッシュラインにし、データを一度につき1キャッシュラインずつグラフィックスおよび音声プロセッサ114に送り出すことにより、バス利用率を最大にする。
【0026】
コマンドプロセッサ200は、メインプロセッサ110から表示コマンドを受け取って解析する(これらを処理するために必要な任意の追加的なデータは、共有メモリ112から得る)。コマンドプロセッサ200は、頂点コマンドのストリームを、2Dおよび/または3D処理およびレンダリングのためにグラフィックスパイプライン180に供給する。グラフィックスパイプライン180は、これらのコマンドに基づいて画像を生成する。得られた画像情報は、ディスプレイコントローラ/ビデオインターフェースユニット164(パイプライン180のフレームバッファ出力をディスプレイ56上に表示する)によるアクセスのために、メインメモリ112に転送され得る。
【0027】
図5は、グラフィックスプロセッサ154の論理フロー図である。メインプロセッサ110は、グラフィックスコマンドストリーム210、表示リスト212、および頂点配列214をメインメモリ112に格納し得、バスインターフェース150を介してコマンドプロセッサ200にポインタを渡し得る。メインプロセッサ110は、メインメモリ112内に割り当てた1つ以上のグラフィックス先入れ先出し(FIFO)バッファ210に、グラフィックスコマンドを格納する。コマンドプロセッサ200は、
・同期/フロー制御および負荷バランスを取るためグラフィックスコマンドを受け取りバッファリングするオンチップFIFOメモリバッファ216を介して、メインメモリ112からのコマンドストリーム、、
・オンチップコールFIFOメモリバッファ218を介して、メインメモリ112からの表示リスト212、および
・頂点キャッシュを介して、コマンドストリームからおよび/またはメインメモリ112中の頂点配列214からの頂点属性)
を取り込む。
【0028】
コマンドプロセッサ200は、属性タイプを浮動小数点フォーマットに変換し、得られた完全な頂点ポリゴンデータをレンダリング/ラスタライゼーションのためにグラフィックスパイプライン180に渡すコマンド処理動作200aを行う。プログラム可能なメモリ調停回路130(図4を参照)は、共有メインメモリ112へのアクセスを、グラフィックスパイプライン180、コマンドプロセッサ200、およびディスプレイコントローラ/ビデオインターフェースユニット164間で調停する。
【0029】
図4は、グラフィックスパイプライン180が以下を含み得ることを示している。
・変換ユニット300
・セットアップ/ラスタライザ400
・テクスチャユニット500
・テクスチャ環境ユニット600、および
・画素エンジン700
【0030】
変換ユニット300は、様々な2Dおよび3D変換ならびにその他の動作300aを行う(図5を参照)。変換ユニット300は、変換処理300aで用いられる行列を格納するための、1つ以上のマトリックスメモリ300bを有し得る。変換ユニット300は、受け取った図形を頂点毎にオブジェクト空間からスクリーン空間に変換し、また、受け取ったテクスチャ座標を変換し投影テクスチャ座標を生成する(300c)。変換ユニット300は、また、ポリゴンクリッピング/間引き300dを行ってもよい。やはり変換ユニット300bによって行われる照明処理300eは、一実施例において最高8個の独立の照明までに対し、頂点毎の照明演算を提供する。変換ユニット300は、また、ポリゴンクリッピング/間引き動作(300d)に加え、エンボス型のバンプマッピング効果のためのテクスチャ座標生成(300c)、を行うことができる。
【0031】
セットアップ/ラスタライザ400は、変換ユニット300から頂点データを受け取り、トライアングルセットアップ情報を、境界のラスタライズ、テクスチャ座標のラスタライズおよび色のラスタライズを行う1つ以上のラスタライザユニット(400b)に送るセットアップユニットを有する。
【0032】
テクスチャユニット500(オンチップテクスチャメモリ(TMEM502)を含み得る)は、テクスチャリングに関連する様々な処理を行う。これには、例えば、
・メインメモリ112からのテクスチャ504の取り出し、
・例えば、マルチテクスチャ処理、キャッシュ後テクスチャ伸長、テクスチャフィルタリング、エンボス化、投影テクスチャの使用を介した陰影および明暗、ならびにアルファ透明度および深度をともなうBLITを含むテクスチャ処理(500a)、
・バンプマッピング、擬似テクスチャ、およびテクスチャタイル化効果(500b)についてのテクスチャ座標変位の演算のためのバンプマップ処理、および
・間接テクスチャ処理(500c)
が含まれる。
【0033】
テクスチャユニット500は、フィルタリングされたテクスチャ値を、テクスチャ環境処理のため(600a)にテクスチャ環境ユニット600に出力する。テクスチャ環境ユニット600は、ポリゴンおよびテクスチャ色/アルファ/深度をブレンドし、また、逆レンジ型フォグ効果を達成するためのテクスチャフォグ処理(600b)を行い得る。テクスチャ環境ユニット600は、例えば色/アルファ変調、エンボス化、詳細テクスチャリング、テクスチャスワッピング、クランピング、および深度ブレンディングに基づき、様々な他の面白い環境関連の機能を行うための段を複数提供し得る。
【0034】
ピクセルエンジン700は、深度(z)比較(700a)およびピクセルブレンディング(700b)を行う。本例において、ピクセルエンジン700は、データを埋め込み(オンチップ)フレームバッファメモリ702に格納する。グラフィックスパイプライン180は、フレームバッファおよび/またはテクスチャ情報をローカルに格納するための1つ以上の埋め込みDRAMメモリ702を有し得る。z比較700a’は、また、現在有効なレンダリングモードに依存して、グラフィックスパイプライン180中のより早い段階で行われ得る(例えば、アルファブレンディングが必要でなければ、z比較は、より早くに行われ得る)。ピクセルエンジン700は、オンチップフレームバッファ702をディスプレイ/ビデオインターフェースユニット164によるアクセスのためにメインメモリ112に周期的に書き込むコピー動作700cを含む。このコピー動作700cは、また、動的テクスチャ合成効果を得るために、埋め込みフレームバッファ702の内容をメインメモリ112内のテクスチャにコピーするためにも用いられ得る。コピーアウト動作中において、アンチエイリアシングおよびその他のフィルタリングを行うことができる。グラフィックスパイプライン180のフレームバッファ出力(最終的には、メインメモリ112に格納される)は、各フレームごとにディスプレイ/ビデオインターフェースユニット164によって読み出される。ディスプレイコントローラ/ビデオインターフェースユニット164は、ディスプレイ102上に表示するためのデジタルRGB画素値を提供する。
【0035】
フォグシミュレーション
フォグが使用可能にされるときには、一定のフォグ色が、最終のアクティブなテクスチャ環境(TEV)段から出力された画素色とブレンドされる。ブレンドされるフォグ色の割合は、フォグ濃度に依存する。フォグ濃度は、ある視点からある象限(2×2画素)への距離の関数である。本例において、グラフィックスプロセッサ114は好ましくは、それぞれ異なるフォグ濃度関数を提供する5つのタイプのフォグをサポートする。
第1のフォグタイプは、図6に示すような従来の線形フォグであり、この場合のフォグ等式は、線形フォグが開始する始点とフォグが最大値に達する終点との間において、フォグ濃度の一定の増加を提供する。この従来の線形フォグについて、フォグ等式は、
Fog=(Ze−Z0)/(Z1−Z0)
である。上式において、Zeは画素の視点空間zである。Z0は「フォグ始点」値であり、これは、線形フォグが開始すなわち「動き出す」視点空間z値である。Z1は、「フォグ終点」値であり、これは、フォグ濃度がその最大値に達する視点空間z値である。図6は、「フォグ始点」=50かつ「フォグ終点」=100の場合の線形フォグ等式のグラフ例を示す。
【0036】
第2および第3のタイプのフォグは、指数フォグおよび指数二乗フォグである。OpenGLおよびDirectXのフォグタイプとは対照的に、本発明は、「フォグ始点」値をフォグ等式に導入することにより、その機能性を高めている。指数および指数二乗フォグについて、各フォグ等式は、
Fog=1−2-8*(Ze-Z0)/Z1-Z0)
Fog=1−2-8*(Ze-Z0)/Z1-Z0)**2
である。上式において、Z1は、フォグ濃度がほぼ1に達する視点空間z値である。図7および図8は、それぞれZ0=50およびZ1=100である指数フォグ等式および指数二乗フォグ等式のグラフ例を示す。
【0037】
第4および第5のタイプのフォグは、全く新規なものであり、OpenGLで提供されるような以前のフォグ等式に基づくものではない。これらの2つの新規なフォグタイプとは、逆指数フォグおよび逆指数二乗フォグである。これら2つのフォグタイプについて、各フォグ等式は、
Fog=2-8*(Ze-Z0)/Z1-Z0)
Fog=2-8*(Ze-Z0)/Z1-Z0)**2
である。上式において、Z1は、フォグ濃度がほぼ1に達する視点空間z値である。図9および図10は、それぞれZ0=50およびZ1=100であるこれら2つのフォグ等式のグラフ例を示す。指数フォグおよび指数二乗フォグとは異なり、逆指数フォグおよび逆指数二乗フォグは、最初はよりなだらかなスロープを有し、終点近くでは急なスロープを有する。これら2つのまったく新規なフォグタイプは、新しくかつ面白いフォグ効果を達成することを可能にすることにより、3Dグラフィックスシステムにおけるフォグの使用をさらに改良する。例えば、これら2つのフォグタイプは、オブジェクトが唐突にそこを通過するような改良されたカーテン型のフォグ効果を提供するために使われることができ、特定のアプリケーションについて、他の公知のフォグタイプよりも優れた面白い視覚効果を提供する。フォグ関数の近く(始点)および遠く(終点)zは、近遠のzのクリッピングに関わらず、プログラミングされ得ることに留意されたい。
【0038】
フォグ計算に用いられる視点空間z値は、上述のように、観察者がZ軸と同じ方向を向いていない限り正しいレンジを表さない。すなわち、図11に示すように、もしレンジの決定に視点空間z値のみを用いた場合、視線がZ軸から遠ざかるにつれてエラーが増大する。図11に示すように、斜線部610aおよび610bによって表されるレンジエラーは、角度αがZ軸から離れる方向に増加するにつれて増大する。しかし、本発明の好適な実施例においては、この不正確さを補正するために、x値に基づくレンジ調節ファクタが用いられる。レンジ調節またはフォグ補正関数は、フォグ効果をより正確かつリアルにするために、スクリーンの端に向かってフォグ濃度を効果的に増大する。
【0039】
好適な実施例において、また図12に示すように、フォグ補正関数は、
sqrt((x−center)2+k2)/k
である。上式において、分割スクリーンのマルチプレーヤゲームをサポートするように、「中心(center)」の値はプログラム可能である。この中心は、好ましくは、スクリーンの幅の半分プラス、ウィンドウの座標系に対するxオフセットに設定される。値kは、xの変化につれてフォグ濃度が変化する早さを決定する。調節は、関数の2つのサンプルを線形補間することにより演算される。レンジ調節関数のサンプル(r0〜r9)が、レンジ調節計算に用いられるために格納される。この関数は上記中心で対称となるため、関数の半分だけを格納する必要があることに留意されたい
【0040】
本例において、各象限につき1つのフォグ値しかない。従って、フォグまたはスクリーン空間z(Zs)がサンプルされる位置は非常に重要である。通常の象限に対しては、以下の規則を用い得る。
・1画素だけがカバーされる場合、その画素が選択される。
・2画素がカバーされる場合、1つの画素が以下の順で選択される:左上、右上、左下、右下。
・3画素がカバーされる場合、2つの隣接する画素に接する画素が選択される。
・選択された画素内において、サブサンプル位置が以下の順で選択される:マルチサンプル0(MS0)、MS1、MS2。
・4つ全ての画素がカバーされる場合、象限の中心が用いられる。
【0041】
通常の象限ではなくzblit象限については、zブレンディング後の4つの画素のzの最小値が、サンプル位置として用いられる。
【0042】
サンプリング位置が決定された後、Zsがs2.24においてz0+zx*dx+zy*dyとして演算される。上位3ビットは、オーバーフローまたはアンダーフローを検出するために用いられる。次に、Zsは以下のようにしてU0.24にクランプされる。
000 オーバーフロー/アンダーフローなし
01X オーバーフロー、Zsは1.0(0xFFFFFF)にクランプされる
0X1 オーバーフロー、Zsは1.0(0xFFFFFF)にクランプされる
1XX アンダーフロー、Zsは0.0(0x000000)にクランプされる
【0043】
透視投影を用いるとき、フォグタイプは数個の等式にプログラムされ得る。第1の等式はスクリーン空間zから視点空間z値を演算する。
Ze=f*n/(f−(f−n)*Zs)
Ze=[n,f]およびZs=[0,1]。結果として、Zs=0のときZe=nであり、Zs=1のときZe=fである(Zeの方向が逆転している)。次のステップは、Zeを現在の象限x位置の関数である係数で乗算することにより、Zeを補正する。
Ze'=Ze*r(x)
第2の等式は、ZeをZnに対して正規化する。ここで、Ze=Z0 のときZn=0であり(フォグ始点)、Ze=Z1のときZn=1である。
Zn=(Ze'−Z0)/(Z1−Z0)
2つの等式を組み合わせることにより、
Zn=A*r(x)/(B−Zs)−C
が得られる。
ここで:
A=f*n/((f−n)*(Z1−Z0))
B=f/(f−n)
C=Z0/(Z1−Z0)
である。
ハードウェアを単純化するためには、Zeは以下のように表現され得る。
Ze=A/(B−Zs)
=A/((B_mant/2−(Zs>>B_expn+1))*2(B_expn+1))
=(A/2(B_expn+1))/(B_mant/2−(Zs>>B_expn+1))
=a/(b−(zs>>b_shf))
そして、
a=A/2(B_expn+1)
b_mag=B_mant2
b_shf=B_expn+1
である。
【0044】
一方、直交投影については、以下の等式が適用される。
Zn=a*r(x)*Zs−c
a=1(Z1−Z0)
c=Z0/(Z1−Z0)
Z0およびZ1は、視点空間ではなくスクリーン空間で指定される。
【0045】
Znが演算された後、上述のように、選択されたフォグタイプ(すなわち線形、指数、指数二乗、逆指数、または逆指数二乗)に応じてフォグ濃度を演算するために用いることができる。
【0046】
実施例の詳細
図13は、本発明に従ってフォグを計算するために用いられ得るフォグ計算ユニット600bの一例を示す。図5に関連して説明したように、フォグ計算ユニット600bは、テクスチャ環境ユニット(TEV)600aの最終のアクティブなテクスチャ環境(TEV)段からの入力を受け取る。フォグ計算ユニットは次に、コンスタントなフォグ色を、その最終のアクティブなTEV段から出力された画素色とブレンドする。ブレンドされるフォグ色の割合はフォグ濃度に依存する。フォグ濃度は、ある視点からある象限への距離の関数である。
【0047】
図13に示すように、適切な入力を受け取った後、フォグ計算ユニットのzオフセットブロック602は、現在の象限の重心の値(上述のように象限内の画素のカバー範囲を用いて決定される)を演算する。スクリーン−視点空間部604は、次に、スクリーン空間zからの値を視点空間zに変換し、結果を、必要なフォグ濃度に関連する定数「a」で(乗算器616を介して)乗算する。より詳細に後述するように、スクリーン−視点空間z変換関数のために減算器618で導入されるパラメータ「b」は、tev_fog_param_1レジスタにより供給される。
【0048】
スクリーン−視点空間変換関数のパラメータ「a」は、tev_fog_param_0レジスタにより供給される。図13中の点線は、透視投影ではなく直交投影の場合においてこの動作を行うための別法を示している。
【0049】
レンジ調節ブロック606は、現在の象限のx位置に基づいてレンジ調節値を演算する。次に、乗算器608によってスクリーンzはレンジ調節値で乗算される。次に、tev_fog_param_3レジスタにより供給されるパラメータ「c」が、減算器610においてレンジ調節後に視点空間Zから減算すべき量を指定するために導入される。次にブロック612においてクランピング動作を行うことにより、Znが得られる。
【0050】
Znが演算された後、これを、選択された特定のフォグタイプに応じてフォグ濃度を演算するために用いることができる。具体的には、マルチプレクサ614a、614b、614cおよび614dへの適切な入力を選択することにより、すなわちセクション615a、615b、615cおよび615dを選択的に適用することにより、5つの利用可能なフォグタイプ(すなわち線形、指数、指数二乗、逆指数、または逆指数二乗)のうちの所望の1つを選択することができる。このように、最終のアクティブなTEV段から出力された画素色とブレンドされるフォグ色の割合を決定するために、適切なフォグ濃度が用いられる。次に計算されたフォグは、グラフィックスシステムによるさらなる処理のために、最終のマルチプレクサ614dから出力される。
【0051】
好適な実施例において、フォグは以下の関数を用いて制御される。
【0052】
この関数は、ハードウェアによって要求されるフォグパラメータを演算し、これらをフォグ計算ユニットにロードする。NearZ値およびFarZ値は、投影行列パラメータと一貫性を有するものでなければならない。フォグのStartZ値およびEndZ値は、NearZ値およびFarZ値と同じ単位でなければならない。パラメータStartZおよびEndZは、それぞれ、フォグ関数がどこで始まりまた終わるかを制御する。通常、EndZ値は遠平面zに設定される。NearZおよびFarZは、フォグ演算のため、ラスタライズされたスクリーンZ値を視点空間Zに変換するために必要である。Colorパラメータは、フォグ濃度が1.0のときの画素の色である。
【0053】
GXInit()において、デフォルトでは、水平フォグレンジ調節はオフにされる。この特徴を使用するためには、以下の関数を呼び出し得る。:
【0054】
上記の最初の関数は、調節テーブルを演算するために用いられる。ユーザは、このテーブルのために割り当てられた領域を提供しなければならない。widthパラメータは、視点の幅を指定する。projmtxパラメータは、ビューポートにレンダリングするために用いられる投影行列である。このパラメータは、ビューポートの視点空間における水平方向の広がりをこの関数が演算するために必要である。
【0055】
このテーブルは、演算されると、GXSetFogRangeAdj()関数に渡され得る。enableパラメータは、水平フォグレンジ調節が許可されているか否かを示す。centerパラメータは、ビューポートの中心にあるX座標でなければならない。上述のように、レンジ調節関数は好ましくは中心に関して対称である。
【0056】
以下のテーブルは、レジスタ種類およびフォーマットの例を示す。
【表1】
【0057】
他の互換性のある実施例
上述のシステム装置50は、上述の家庭用ビデオゲームコンソール構成以外としても実施可能である。例えば、システム50用に書かれたグラフィックスアプリケーションまたはその他のソフトウェアを、システム50をエミュレートするなどして互換性を有する異なる構成を持ったプラットフォーム上で実行することができる。もしその別のプラットフォームがシステム50のハードウェアおよびソフトウェアリソースの一部または全部をうまくエミュレート、シミュレートおよび/または提供することができれば、その別のプラットフォームは、ソフトウェアを首尾よく実行することができる。
【0058】
一例として、エミュレータは、システム50のハードウェアおよび/またはソフトウェア構成(プラットフォーム)とは異なるハードウェアおよび/またはソフトウェア構成(プラットフォーム)を提供し得る。このエミュレータシステムは、アプリケーションソフトウェアが書かれたシステムのハードウェアおよび/またはソフトウェア要素の一部または全部をエミュレートまたはシミュレートする、ソフトウェアおよび/またはハードウェア要素を有し得る。例えば、エミュレータシステムは、システム50のハードウェアおよび/またはファームウェアをシミュレートするソフトウェアエミュレータプログラムを実行するパーソナルコンピュータなどの汎用のデジタルコンピュータからなっていてもよい。
【0059】
汎用デジタルコンピュータのいくつか(例えばIBMまたはマッキントッシュのパーソナルコンピュータおよび互換機)は現在、DirectXまたはその他の標準的な3DグラフィックスコマンドAPIと適合する3Dグラフィックスパイプラインを提供する3Dグラフィックスカードを備えている。また、標準的な音声コマンドのセットに基づいて高品質なステレオ音を提供するステレオサウンドカードを備えている場合もある。このようなマルチメディア−ハードウェアを備えたパーソナルコンピュータがエミュレータソフトウェアを実行すれば、システム50のグラフィックスおよびサウンド性能に匹敵する十分な能力を有し得る。エミュレータソフトウェアは、ゲームプログラマがゲームソフトウェアを書いた対象である家庭用ビデオゲームコンソールプラットフォームの処理、3Dグラフィックス、音声、周辺およびその他の機能をシミュレートするように、パーソナルコンピュータプラットフォーム上のハードウェアリソースを制御する。
【0060】
図14は、ホストプラットフォーム1201、エミュレータ要素1303、および記憶媒体62上に記憶されたゲームソフトウェア実行可能2値画像を用いたエミュレーション処理の全体例を示す。ホスト1201は、例えばパーソナルコンピュータ、ビデオゲームコンソール、または十分な演算能力を有する任意のその他のプラットフォームなどの、汎用あるいは専用のデジタル演算装置であり得る。エミュレータ1303は、ホストプラットフォーム1201上で稼働し、記憶媒体62からのコマンド、データおよびその他の情報の、ホストによって処理される形式へのリアルタイム変換を提供するソフトウェアおよび/またはハードウェアであり得る。例えば、エミュレータ1303は、システム50によって実行されることが意図される「ソース」2値画像プログラム命令を記憶媒体62から取り込み、これらのプログラム命令を、ホスト1201によって実行その他の処理を行われ得る対象形式に変換する。
【0061】
一例として、ソフトウェアが、IBM PowerPCまたはその他の特定のプロセッサを用いたプラットフォーム上で実行されるように書かれており、ホスト1201が異なる(例えばインテルの)プロセッサを用いたパーソナルコンピュータである場合は、エミュレータ1303は、1つまたは一連の2値画像プログラム命令を記憶媒体62から取り込み、これらのプログラム命令を、1つ以上の同等なインテルの2値画像プログラム命令に変換する。エミュレータ1303はまた、グラフィックスおよび音声プロセッサ114によって処理されることを意図されたグラフィックスコマンドおよび音声コマンドを取り込みおよび/または生成し、これらのコマンドを、ホスト1201上において利用可能であるハードウェアおよび/またはソフトウェアグラフィックスおよび音声処理リソースによって処理され得る単数または複数のフォーマットに変換する。一例として、エミュレータ1303は、これらのコマンドを、ホスト1201の特定のグラフィックスおよび/または音声ハードウェアによって処理され得るコマンドに変換し得る(例えば、標準的なDirectX、OpenGL、および/または音声APIを用いて)。
【0062】
上述のビデオゲームシステムの一部または全ての特徴を提供するために用いられるエミュレータ1303には、また、そのエミュレータを用いて実行されるゲームの様々なオプションやスクリーンモードの選択を単純化あるいは自動化するグラフィックスユーザインターフェース(GUI)が備えられてもよい。一例において、そのようなエミュレータ1303は、また、ソフトウェアが本来意図されたホストプラットフォームに比較して、より高度な機能性をさらに含んでもよい。
【0063】
図15は、エミュレータ1302とともに適切に用いられるエミュレーションホストシステム1201を示す。システム1201は、処理ユニット1203およびシステムメモリ1205を有する。システムバス1207が、システムメモリ1205を含む様々なシステム要素を、処理ユニット1203に接続する。システムバス1207は、メモリバスまたはメモリコントローラを含む数種のタイプのバス構造、周辺バス、および様々なバスアーキテクチャのうちのいずれかを用いたローカルバスのうちのいずれでもよい。システムメモリ1207は、リードオンリーメモリ(ROM)1252およびランダムアクセスメモリ(RAM)1254を有する。パーソナルコンピュータシステム1201内の要素間の情報の転送(例えばスタートアップ中など)に役立つ基本的なルーチンを含んだ基本入力/出力システム(BIOS)1256が、ROM1252に格納されている。システム1201はさらに、様々なドライブおよび関連するコンピュータ可読性の媒体を有する。ハードディスクドライブ1209は、(典型的には固定の)磁気ハードディスク1211から読み出し、またこれに対して書き込む。追加的な(可能なオプションである)磁気ディスクドライブ1213は、着脱可能な「フロッピー」またはその他の磁気ディスク1215から読み出し、また、これに対して書き込む。光ディスクドライブ1217は、CD ROMまたはその他の光メディアなどの着脱可能な光ディスク1219から読み出し、また、いくつかの構成においては、これに対して書き込む。ハードディスクドライブ1209および光ディスクドライブ1217は、それぞれハードディスクドライブインターフェース1221および光ディスクドライブインターフェース1225によって、システムバス1207に接続されている。そのドライブおよびそれに対応するコンピュータ可読性媒体は、コンピュータ可読性の命令、データ構造、プログラムモジュール、ゲームプログラムおよびパーソナルコンピュータシステム1201のためのその他のデータを、不揮発的に記憶する。その他の構成において、コンピュータによりアクセス可能なデータを格納することができる他のタイプのコンピュータ可読性媒体、例えば、磁気カセット、フラッシュメモリカード、デジタルビデオディスク、ベルヌーイ(Bernoulli)カートリッジ、ランダムアクセスメモリ(RAM)リードオンリーメモリ(ROM)などもまた使用され得る。
【0064】
エミュレータ1303を含む複数のプログラムモジュールは、ハードディスク1211、着脱式磁気ディスク1215、光ディスク1219、および/またはシステムメモリ1205のROM1252および/またはRAM1254上に記憶され得る。このようなプログラムモジュールは、グラフィックスおよび音声APIを提供するオペレーティングシステム、1つ以上のアプリケーションプログラム、その他のプログラムモジュール、プログラムデータおよびゲームデータを含んでもよい。ユーザは、キーボード1227、ポインティング装置1229、マイク、ジョイスティック、ゲームコントローラ、衛星放送用アンテナ、スキャナなどの入力装置を介して、コマンドおよび情報を、パーソナルコンピュータシステム1201に入力し得る。これらおよびその他の入力装置は、システムバス1207に接続されたシリアルポートインターフェース1231を介して処理ユニット1203に接続されることができるが、パラレルポート、ゲームポートファイヤワイヤバスまたはユニバーサルシリアルバス(USB)などの他のインターフェースによって接続されてもよい。また、モニタ1233またはその他のタイプの表示装置が、ビデオアダプタ1235などのインターフェースを介して、システムバス1207に接続される。
【0065】
システム1201は、インターネットなどのネットワーク1152を介して通信を確立するための、モデム1154やその他のネットワークインターフェース手段を有し得る。内部でも外部でもよいモデム1154が、シリアルポートインターフェース1231を介してシステムバス123に接続されている。また、システム1201が、ローカルエリアネットワーク1158を介してリモート演算装置1150(例えば、別のシステム1201)と通信することを可能にするために、ネットワークインターフェース1156が提供され得る(あるいはこのような通信は、広域ネットワーク1152またはダイヤルアップやその他の通信手段などの他の通信パスを介して行われてもよい)。システム1201は典型的には、プリンタその他の標準的な周辺デバイスなどの、他の周辺出力デバイスを有し得る。
【0066】
一例において、ビデオアダプタ1235は、マイクロソフトのDirectX7.0または他バージョンなどの標準的な3Dグラフィックスアプリケーションプログラマインターフェースに基づいて発せられる3Dグラフィックスコマンドに応答して、高速な3Dグラフィックスレンダリングを提供する3Dグラフィックスパイプラインチップセットを有し得る。また1組のステレオスピーカ1237が、従来の「サウンドカード」などのサウンド発生インターフェースを介してシステムバス1207に接続されていることにより、バス1207によって供給される音声コマンドに基づいて高品質なステレオ音声を生成するためのハードウェアおよび埋め込みソフトウェアサポートを提供する。これらのハードウェア能力は、システム1201が、記憶媒体62に格納されたソフトウェアをプレイするために十分なグラフィックスおよびサウンド速度能力を提供することを可能にする。
【0067】
上述のビデオゲームシステムの特徴の一部または全部を提供するために用いられるエミュレータ1303には、また、そのエミュレータを用いて実行されるゲームの様々なオプションやスクリーンモードの選択を単純化あるいは自動化するグラフィックスユーザインターフェース(GUI)が備えられてもよい。一例において、そのようなエミュレータ1303はまた、ソフトウェアが本来意図されたホストプラットフォームに比較してより高度な機能性をさらに含んでもよい。エミュレータ内の特定のグラフィックスサポートハードウェアが、図13に示すフォグ関数を含まない場合は、エミュレータの設計者は、以下のいずれかの選択肢を有する。
・フォグコマンドを、グラフィックスハードウェアがサポートしている他のグラフィックスAPIコマンドに変換するか、
・プロセッサの速度に依存して能力の低下がおこり得るが、フォグ関数をソフトウェアで実現するか、
・フォグコマンドを「引き抜く」ことによって、フォグ効果を有さないレンダリング画像を提供する。
【0068】
以上、本発明を、最も実用的で好ましい実施形態であると現時点で判断される内容について説明してきたが、本発明は、開示された実施形態にのみ制限されるべきものではなく、反対に記載したクレームの範囲内において、様々に変更、および同等な内容が適用されるものとする。
【図面の簡単な説明】
【図1】対話式コンピュータグラフィックスシステムの一例の全体図である。
【図2】図1の例のコンピュータグラフィックスシステムのブロック図である。
【図3】図2に示す例のグラフィックスおよび音声プロセッサのブロック図である。
【図4】図3に示す例の3Dグラフィックスプロセッサのブロック図である。
【図5】図4のグラフィックスおよび音声プロセッサの、論理フロー図例である。
【図6】従来の線形フォグ曲線を示す。
【図7】本発明による指数フォグ曲線例を示す。
【図8】本発明による指数二乗フォグ曲線例を示す。
【図9】本発明による逆指数フォグ曲線例を示す。
【図10】本発明による逆指数二乗フォグ曲線例を示す。
【図11】水平レンジ調節を用いなかったときに得られるフォグエラーの増加を示すグラフである。
【図12】図11に示すエラーを訂正するために用いられ得るフォグ補正関数の例である。
【図13】本発明に従ってフォグを計算するためのフォグ計算ユニットの一実施例である。
【図14】別の互換的な実施例を示す図である。
【図15】別の互換的な実施例を示す図である。
Claims (14)
- メモリおよび演算手段を備えたグラフィックスシステムにおいてフォグ(Fog)をシミュレートするための方法であって、
前記演算手段が、
前記メモリに記憶された画素のための画素色を得る処理と、
フォグ色を前記画素色とブレンドする処理とを実行し、
前記画素色とブレンドされるフォグ色の割合は、以下のフォグ濃度関数に基づいて決定され、
Fog=2-8*(Ze-Z0)/Z1-Z0)
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
前記演算手段が、さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行する方法。 - 前記演算手段が、さらに、中心点のまわりに対称である調節関数をZeの前記調節のために用いる処理を実行する、請求項1に記載の方法。
- 前記調節関数は、
sqrt((x−center)2+k2)/kであり、
ここで、centerは画像の中心のX位置であり、kは前記中心から離れるにつれてフォグ濃度が変化する早さを決定する、請求項2に記載の方法。 - メモリおよび演算手段を備えたグラフィックスシステムにおいてフォグ(fog)をシミュレートするための方法であって、
前記演算手段が、
前記メモリに記憶された画素のための画素色を得る処理と、
フォグ色を前記画素色とブレンドする処理とを実行し、
前記画素色とブレンドされるフォグ色の割合は、以下のフォグ濃度関数に基づいて決定され、
Fog=2-8*(Ze-Z0)/Z1-Z0)**2
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
前記演算手段が、さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行する方法。 - 前記演算手段が、さらに、中心点のまわりに対称である調節関数をZeの前記調節のために用いる処理を実行する、請求項4に記載の方法。
- 前記調節関数は、
sqrt((x−center)2+k2)/kであり、
ここで、centerは画像の中心のX位置であり、kは前記中心から離れるにつれてフォグ濃度が変化する早さを決定する、請求項5に記載の方法。 - メモリに記憶された画素のための画素色を得る処理を行う第1の演算部と、
フォグ(Fog)色を前記画素色とブレンドする処理を行う第2の演算部とを備えるグラフィックスシステムであって、
前記第2の演算部は、以下のフォグ濃度関数に基づいて前記画素色とブレンドされるフォグ色の割合を決定し、
Fog=2-8*(Ze-Z0)/Z1-Z0)
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行する第3の処理部を備えるグラフィックスシステム。 - 前記第3の演算部は、中心点のまわりに対称である調節関数をZeの前記調節のために適用する処理を行う、請求項7に記載のグラフィックスシステム。
- 前記調節関数は、
sqrt((x−center)2+k2)/kであり、
ここで、centerは画像の中心のX位置であり、kは前記中心から離れるにつれてフォグ濃度が変化する早さを決定する、請求項8に記載のグラフィックスシステム。 - メモリに記憶された画素のための画素色を得る処理を行う第1の演算部と、;
フォグ(Fog)色を前記画素色とブレンドする処理を行う第2の演算部とを備えるグラフィックスシステムであって、
前記第2の演算部は、以下のフォグ濃度関数に基づいて前記画素色とブレンドされるフォグ色の割合を決定し、
Fog=2-8*(Ze-Z0)/Z1-Z0)**2
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行する第3の処理部を備えるグラフィックスシステム。 - 前記第3の演算部は、中心点のまわりに対称である調節関数をZeの前記調節のために適用する処理を行う、請求項10に記載のグラフィックスシステム。
- 前記調節関数は、
sqrt((x−center)2+k2)/kであり、
ここで、centerは画像の中心のX位置であり、kは前記中心から離れるにつれてフォグ濃度が変化する早さを決定する、請求項11に記載のグラフィックスシステム。 - フォグ(Fog)をシミュレートするグラフィックスシステムのコンピュータに、
メモリに記憶された画素のための画素色を得る処理と、
フォグ色を前記画素色とブレンドする処理とを実行させ、
前記画素色とブレンドされるフォグ色の割合は、以下のフォグ濃度関数に基づいて決定され、
Fog=2 -8*(Ze-Z0)/Z1-Z0)
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行させるための、プログラム。 - フォグ(Fog)をシミュレートするグラフィックスシステムのコンピュータに、
メモリに記憶された画素のための画素色を得る処理と、
フォグ色を前記画素色とブレンドする処理とを実行させ、
前記画素色とブレンドされるフォグ色の割合は、以下のフォグ濃度関数に基づいて決定され、
Fog=2 -8*(Ze-Z0)/Z1-Z0)**2
ここで、Zeは前記画素の3次元空間における視点からの深度を示す視点空間z値であり、Z0はフォグが開始する視点空間z値であり、Z1はフォグ濃度が実質的に最大値に達する視点空間z値であり、
さらに、前記フォグ濃度関数を適用する前に、前記画素の前記視点空間z値(Ze)を、前記画素の3次元空間における視点からの深度の方向に対して垂直な方向への位置を示すX位置(x)に基づいて調節する処理を実行させるための、プログラム。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US22703200P | 2000-08-23 | 2000-08-23 | |
US60/227032 | 2000-08-23 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2002236934A JP2002236934A (ja) | 2002-08-23 |
JP4698893B2 true JP4698893B2 (ja) | 2011-06-08 |
Family
ID=22851463
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2001206702A Expired - Fee Related JP4698893B2 (ja) | 2000-08-23 | 2001-07-06 | 改良されたフォグ効果を提供するための方法、グラフィックスシステム、およびプログラム |
Country Status (2)
Country | Link |
---|---|
US (1) | US6580430B1 (ja) |
JP (1) | JP4698893B2 (ja) |
Families Citing this family (63)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6943803B1 (en) * | 1998-09-21 | 2005-09-13 | Evans & Sutherland Computer Corporation | Anti-aliased, textured, geocentric and layered fog graphics display method and apparatus |
US7538772B1 (en) | 2000-08-23 | 2009-05-26 | Nintendo Co., Ltd. | Graphics processing system with enhanced memory controller |
US6940504B1 (en) * | 2000-11-21 | 2005-09-06 | Microsoft Corporation | Rendering volumetric fog and other gaseous phenomena using an alpha channel |
US7046243B1 (en) * | 2000-11-21 | 2006-05-16 | Microsoft Corporation | Rendering volumetric fog and other gaseous phenomena |
JP2002163672A (ja) * | 2000-11-28 | 2002-06-07 | Mitsubishi Electric Corp | 3次元グラフィックス描画装置およびその方法 |
US20030016222A1 (en) * | 2001-03-27 | 2003-01-23 | Budin Clay A. | Process for utilizing a pressure and motion sensitive pad to create computer generated animation |
JP2004005452A (ja) * | 2002-04-16 | 2004-01-08 | Sony Computer Entertainment Inc | 画像処理装置、画像処理方法、半導体デバイス、コンピュータプログラム、記録媒体 |
US7681112B1 (en) | 2003-05-30 | 2010-03-16 | Adobe Systems Incorporated | Embedded reuse meta information |
US7636489B2 (en) * | 2004-04-16 | 2009-12-22 | Apple Inc. | Blur computation algorithm |
US7248265B2 (en) * | 2004-04-16 | 2007-07-24 | Apple Inc. | System and method for processing graphics operations with graphics processing unit |
US8704837B2 (en) * | 2004-04-16 | 2014-04-22 | Apple Inc. | High-level program interface for graphics operations |
US8134561B2 (en) * | 2004-04-16 | 2012-03-13 | Apple Inc. | System for optimizing graphics operations |
US7231632B2 (en) | 2004-04-16 | 2007-06-12 | Apple Computer, Inc. | System for reducing the number of programs necessary to render an image |
US7847800B2 (en) * | 2004-04-16 | 2010-12-07 | Apple Inc. | System for emulating graphics operations |
US8068103B2 (en) * | 2004-06-24 | 2011-11-29 | Apple Inc. | User-interface design |
US8130237B2 (en) * | 2004-06-24 | 2012-03-06 | Apple Inc. | Resolution independent user interface design |
US7397964B2 (en) * | 2004-06-24 | 2008-07-08 | Apple Inc. | Gaussian blur approximation suitable for GPU |
US7546543B2 (en) | 2004-06-25 | 2009-06-09 | Apple Inc. | Widget authoring and editing environment |
US8302020B2 (en) | 2004-06-25 | 2012-10-30 | Apple Inc. | Widget authoring and editing environment |
US8566732B2 (en) | 2004-06-25 | 2013-10-22 | Apple Inc. | Synchronization of widgets and dashboards |
US8239749B2 (en) * | 2004-06-25 | 2012-08-07 | Apple Inc. | Procedurally expressing graphic objects for web pages |
US8453065B2 (en) | 2004-06-25 | 2013-05-28 | Apple Inc. | Preview and installation of user interface elements in a display environment |
US7490295B2 (en) | 2004-06-25 | 2009-02-10 | Apple Inc. | Layer for accessing user interface elements |
US7761800B2 (en) * | 2004-06-25 | 2010-07-20 | Apple Inc. | Unified interest layer for user interface |
US7652678B2 (en) * | 2004-06-25 | 2010-01-26 | Apple Inc. | Partial display updates in a windowing system using a programmable graphics processing unit |
US20050285866A1 (en) * | 2004-06-25 | 2005-12-29 | Apple Computer, Inc. | Display-wide visual effects for a windowing system using a programmable graphics processing unit |
US7620530B2 (en) * | 2004-11-16 | 2009-11-17 | Nvidia Corporation | System with PPU/GPU architecture |
US7227551B2 (en) * | 2004-12-23 | 2007-06-05 | Apple Inc. | Manipulating text and graphic appearance |
US8140975B2 (en) * | 2005-01-07 | 2012-03-20 | Apple Inc. | Slide show navigation |
US8543931B2 (en) | 2005-06-07 | 2013-09-24 | Apple Inc. | Preview including theme based installation of user interface elements in a display environment |
US7743336B2 (en) | 2005-10-27 | 2010-06-22 | Apple Inc. | Widget security |
US7954064B2 (en) | 2005-10-27 | 2011-05-31 | Apple Inc. | Multiple dashboards |
US9104294B2 (en) | 2005-10-27 | 2015-08-11 | Apple Inc. | Linked widgets |
US8543824B2 (en) | 2005-10-27 | 2013-09-24 | Apple Inc. | Safe distribution and use of content |
US7752556B2 (en) * | 2005-10-27 | 2010-07-06 | Apple Inc. | Workflow widgets |
US7707514B2 (en) | 2005-11-18 | 2010-04-27 | Apple Inc. | Management of user interface elements in a display environment |
JP5025950B2 (ja) * | 2005-12-12 | 2012-09-12 | 任天堂株式会社 | 情報処理プログラム、情報処理装置、情報処理システムおよび情報処理方法 |
US8155682B2 (en) * | 2006-05-05 | 2012-04-10 | Research In Motion Limited | Handheld electronic device including automatic mobile phone number management, and associated method |
US8869027B2 (en) | 2006-08-04 | 2014-10-21 | Apple Inc. | Management and generation of dashboards |
KR100818286B1 (ko) * | 2006-11-23 | 2008-04-01 | 삼성전자주식회사 | 안개 효과를 고려하여 3차원 그래픽스 데이터를 렌더링하는방법 및 장치 |
EP2104930A2 (en) | 2006-12-12 | 2009-09-30 | Evans & Sutherland Computer Corporation | System and method for aligning rgb light in a single modulator projector |
US20080168367A1 (en) * | 2007-01-07 | 2008-07-10 | Chaudhri Imran A | Dashboards, Widgets and Devices |
JP4987070B2 (ja) * | 2007-04-11 | 2012-07-25 | パナソニック株式会社 | 画像生成装置及び画像生成方法 |
US8009168B2 (en) * | 2007-06-26 | 2011-08-30 | Microsoft Corporation | Real-time rendering of light-scattering media |
US7990377B2 (en) * | 2007-06-26 | 2011-08-02 | Microsoft Corporation | Real-time rendering of light-scattering media |
US8190403B2 (en) * | 2007-06-26 | 2012-05-29 | Microsoft Corporation | Real-time rendering of light-scattering media |
US7940269B2 (en) * | 2007-06-29 | 2011-05-10 | Microsoft Corporation | Real-time rendering of light-scattering media |
US7940268B2 (en) * | 2007-06-29 | 2011-05-10 | Microsoft Corporation | Real-time rendering of light-scattering media |
US8954871B2 (en) | 2007-07-18 | 2015-02-10 | Apple Inc. | User-centric widgets and dashboards |
US8667415B2 (en) | 2007-08-06 | 2014-03-04 | Apple Inc. | Web widgets |
US8156467B2 (en) * | 2007-08-27 | 2012-04-10 | Adobe Systems Incorporated | Reusing components in a running application |
US8176466B2 (en) | 2007-10-01 | 2012-05-08 | Adobe Systems Incorporated | System and method for generating an application fragment |
US9619304B2 (en) | 2008-02-05 | 2017-04-11 | Adobe Systems Incorporated | Automatic connections between application components |
US8358317B2 (en) | 2008-05-23 | 2013-01-22 | Evans & Sutherland Computer Corporation | System and method for displaying a planar image on a curved surface |
US8702248B1 (en) | 2008-06-11 | 2014-04-22 | Evans & Sutherland Computer Corporation | Projection method for reducing interpixel gaps on a viewing surface |
US8656293B1 (en) | 2008-07-29 | 2014-02-18 | Adobe Systems Incorporated | Configuring mobile devices |
US8077378B1 (en) | 2008-11-12 | 2011-12-13 | Evans & Sutherland Computer Corporation | Calibration system and method for light modulation device |
US8411089B2 (en) * | 2009-07-27 | 2013-04-02 | Disney Enterprises, Inc. | Computer graphics method for creating differing fog effects in lighted and shadowed areas |
US9053562B1 (en) | 2010-06-24 | 2015-06-09 | Gregory S. Rabin | Two dimensional to three dimensional moving image converter |
US9641826B1 (en) | 2011-10-06 | 2017-05-02 | Evans & Sutherland Computer Corporation | System and method for displaying distant 3-D stereo on a dome surface |
US9992021B1 (en) | 2013-03-14 | 2018-06-05 | GoTenna, Inc. | System and method for private and point-to-point communication between computing devices |
JP6732439B2 (ja) * | 2015-12-03 | 2020-07-29 | 株式会社バンダイナムコエンターテインメント | プログラム及び画像生成システム |
US10445319B2 (en) | 2017-05-10 | 2019-10-15 | Oracle International Corporation | Defining subgraphs declaratively with vertex and edge filters |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0721407A (ja) * | 1993-07-06 | 1995-01-24 | Sony Corp | 画像表示方法 |
Family Cites Families (88)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4425559A (en) | 1980-06-02 | 1984-01-10 | Atari, Inc. | Method and apparatus for generating line segments and polygonal areas on a raster-type display |
US4388620A (en) | 1981-01-05 | 1983-06-14 | Atari, Inc. | Method and apparatus for generating elliptical images on a raster-type video display |
US4463380A (en) | 1981-09-25 | 1984-07-31 | Vought Corporation | Image processing system |
US4570233A (en) | 1982-07-01 | 1986-02-11 | The Singer Company | Modular digital image generator |
US4725831A (en) | 1984-04-27 | 1988-02-16 | Xtar Corporation | High-speed video graphics system and method for generating solid polygons on a raster display |
US4658247A (en) | 1984-07-30 | 1987-04-14 | Cornell Research Foundation, Inc. | Pipelined, line buffered real-time color graphics display system |
JPS62192878A (ja) | 1986-02-20 | 1987-08-24 | Nippon Gakki Seizo Kk | 多角形の塗りつぶし方法 |
US4862392A (en) | 1986-03-07 | 1989-08-29 | Star Technologies, Inc. | Geometry processor for graphics display system |
JPS62231380A (ja) | 1986-03-31 | 1987-10-09 | Namuko:Kk | 画像合成装置 |
US5504917A (en) | 1986-04-14 | 1996-04-02 | National Instruments Corporation | Method and apparatus for providing picture generation and control features in a graphical data flow environment |
US5170468A (en) | 1987-08-18 | 1992-12-08 | Hewlett-Packard Company | Graphics system with shadow ram update to the color map |
US4866637A (en) | 1987-10-30 | 1989-09-12 | International Business Machines Corporation | Pipelined lighting model processing system for a graphics workstation's shading function |
US4901064A (en) | 1987-11-04 | 1990-02-13 | Schlumberger Technologies, Inc. | Normal vector shading for 3-D graphics display system |
US4945500A (en) | 1987-11-04 | 1990-07-31 | Schlumberger Technologies, Inc. | Triangle processor for 3-D graphics display system |
CA1309198C (en) | 1987-12-10 | 1992-10-20 | Carlo J. Evangelisti | Parallel rendering of smoothly shaded color triangles with anti-aliased edges for a three dimensional color display |
US5136664A (en) | 1988-02-23 | 1992-08-04 | Bersack Bret B | Pixel rendering |
GB8828342D0 (en) | 1988-12-05 | 1989-01-05 | Rediffusion Simulation Ltd | Image generator |
RU2106012C1 (ru) | 1990-02-05 | 1998-02-27 | Нинтендо Ко. Лтд. | Устройство дисплея подвижного изображения и внешнее запоминающее устройство, используемое для него |
US5412796A (en) | 1990-05-12 | 1995-05-02 | Rediffusion Simulation Limited | Method and apparatus for generating images simulating non-homogeneous fog effects |
US6020894A (en) | 1990-08-16 | 2000-02-01 | Canon Kabushiki Kaisha | Full-color desktop publishing system |
JP2725915B2 (ja) | 1990-11-15 | 1998-03-11 | インターナショナル・ビジネス・マシーンズ・コーポレイション | 三角形描画装置及び方法 |
US5268996A (en) | 1990-12-20 | 1993-12-07 | General Electric Company | Computer image generation method for determination of total pixel illumination due to plural light sources |
US5774133A (en) | 1991-01-09 | 1998-06-30 | 3Dlabs Ltd. | Computer system with improved pixel processing capabilities |
US5421028A (en) | 1991-03-15 | 1995-05-30 | Hewlett-Packard Company | Processing commands and data in a common pipeline path in a high-speed computer graphics system |
US5415549A (en) | 1991-03-21 | 1995-05-16 | Atari Games Corporation | Method for coloring a polygon on a video display |
TW225595B (ja) | 1991-09-03 | 1994-06-21 | Gen Electric | |
US5366376A (en) | 1992-05-22 | 1994-11-22 | Atari Games Corporation | Driver training system and method with performance data feedback |
CA2070934C (en) | 1992-06-10 | 1998-05-05 | Benny Chi Wah Lau | Graphics display system |
US5828907A (en) | 1992-06-30 | 1998-10-27 | Discovision Associates | Token-based adaptive video processing arrangement |
US5432895A (en) | 1992-10-01 | 1995-07-11 | University Corporation For Atmospheric Research | Virtual reality imaging system |
WO1994010641A1 (en) | 1992-11-02 | 1994-05-11 | The 3Do Company | Audio/video computer architecture |
US5392393A (en) | 1993-06-04 | 1995-02-21 | Sun Microsystems, Inc. | Architecture for a high performance three dimensional graphics accelerator |
JP3240821B2 (ja) | 1994-04-22 | 2001-12-25 | 株式会社日立製作所 | 高機能画像メモリlsi及びそれを用いた表示装置 |
US5768626A (en) | 1994-06-24 | 1998-06-16 | Intel Corporation | Method and apparatus for servicing a plurality of FIFO's in a capture gate array |
US5701444A (en) | 1995-03-24 | 1997-12-23 | 3Dlabs Inc. Ltd. | Three-dimensional graphics subsystem with enhanced support for graphical user interface |
US5815166A (en) | 1995-03-24 | 1998-09-29 | 3Dlabs Inc., Ltd. | Graphics subsystem with slaveable rasterizer |
US5798770A (en) | 1995-03-24 | 1998-08-25 | 3Dlabs Inc. Ltd. | Graphics rendering system with reconfigurable pipeline sequence |
US5594854A (en) | 1995-03-24 | 1997-01-14 | 3Dlabs Inc. Ltd. | Graphics subsystem with coarse subpixel correction |
US6025853A (en) | 1995-03-24 | 2000-02-15 | 3Dlabs Inc. Ltd. | Integrated graphics subsystem with message-passing architecture |
US5805868A (en) | 1995-03-24 | 1998-09-08 | 3Dlabs Inc. Ltd. | Graphics subsystem with fast clear capability |
US5764243A (en) | 1995-03-24 | 1998-06-09 | 3Dlabs Inc. Ltd. | Rendering architecture with selectable processing of multi-pixel spans |
US5777629A (en) | 1995-03-24 | 1998-07-07 | 3Dlabs Inc. Ltd. | Graphics subsystem with smart direct-memory-access operation |
US5727192A (en) | 1995-03-24 | 1998-03-10 | 3Dlabs Inc. Ltd. | Serial rendering system with auto-synchronization on frame blanking |
US5687357A (en) | 1995-04-14 | 1997-11-11 | Nvidia Corporation | Register array for utilizing burst mode transfer on local bus |
US5758182A (en) | 1995-05-15 | 1998-05-26 | Nvidia Corporation | DMA controller translates virtual I/O device address received directly from application program command to physical i/o device address of I/O device on device bus |
US5721947A (en) | 1995-05-15 | 1998-02-24 | Nvidia Corporation | Apparatus adapted to be joined between the system I/O bus and I/O devices which translates addresses furnished directly by an application program |
US6008820A (en) | 1995-08-04 | 1999-12-28 | Microsoft Corporation | Processor for controlling the display of rendered image layers and method for controlling same |
US5724561A (en) | 1995-11-03 | 1998-03-03 | 3Dfx Interactive, Incorporated | System and method for efficiently determining a fog blend value in processing graphical images |
US6331856B1 (en) * | 1995-11-22 | 2001-12-18 | Nintendo Co., Ltd. | Video game system with coprocessor providing high speed efficient 3D graphics and digital audio signal processing |
US5949440A (en) | 1996-04-30 | 1999-09-07 | Hewlett Packard Compnay | Method and apparatus for processing graphics primitives in multiple modes using reconfigurable hardware |
US5821949A (en) | 1996-07-01 | 1998-10-13 | Sun Microsystems, Inc. | Three-dimensional graphics accelerator with direct data channels for improved performance |
US5874969A (en) | 1996-07-01 | 1999-02-23 | Sun Microsystems, Inc. | Three-dimensional graphics accelerator which implements multiple logical buses using common data lines for improved bus communication |
US6028611A (en) | 1996-08-29 | 2000-02-22 | Apple Computer, Inc. | Modular digital image processing via an image processing chain |
JP3738924B2 (ja) | 1996-12-24 | 2006-01-25 | ソニー株式会社 | 描画装置および方法 |
US5940086A (en) | 1997-01-10 | 1999-08-17 | Hewlett Packard Company | System and method for dynamically allocating data among geometry accelerators in a computer graphics system |
US5990903A (en) | 1997-02-03 | 1999-11-23 | Micron Technologies, Inc. | Method and apparatus for performing chroma key, transparency and fog operations |
US5949424A (en) | 1997-02-28 | 1999-09-07 | Silicon Graphics, Inc. | Method, system, and computer program product for bump mapping in tangent space |
US6057852A (en) | 1997-04-30 | 2000-05-02 | Hewlett-Packard Company | Graphics accelerator with constant color identifier |
US5969726A (en) | 1997-05-30 | 1999-10-19 | Hewlett-Packard Co. | Caching and coherency control of multiple geometry accelerators in a computer graphics system |
US6437781B1 (en) * | 1997-05-30 | 2002-08-20 | Hewlett-Packard Company | Computer graphics system having per pixel fog blending |
US5920326A (en) | 1997-05-30 | 1999-07-06 | Hewlett Packard Company | Caching and coherency control of multiple geometry accelerators in a computer graphics system |
JPH1153580A (ja) | 1997-07-31 | 1999-02-26 | Sony Corp | 3次元画像処理装置及びビデオ合成方法 |
US6037949A (en) | 1997-08-04 | 2000-03-14 | Pixar Animation Studios | Texture mapping and other uses of scalar fields on subdivision surfaces in computer graphics and animation |
JPH1176614A (ja) | 1997-09-11 | 1999-03-23 | Sega Enterp Ltd | コンピュータゲーム装置 |
US6002409A (en) | 1997-10-29 | 1999-12-14 | Cirrus Logic, Inc. | Arbitration for shared graphics processing resources |
JPH11161819A (ja) | 1997-11-27 | 1999-06-18 | Sega Enterp Ltd | 画像処理装置、画像処理方法、及び画像処理プログラムを記録した記録媒体 |
JPH11203500A (ja) | 1998-01-09 | 1999-07-30 | Sega Enterp Ltd | 画像処理装置及びそれに利用されるバンプマップデータを格納した記録媒体 |
JPH11226257A (ja) | 1998-02-16 | 1999-08-24 | Sony Computer Entertainment Inc | 携帯用電子機器及びエンタテインメントシステム並びに記録媒体 |
JP4061697B2 (ja) | 1998-03-12 | 2008-03-19 | 株式会社セガ | 画像表示方法及びそれを実行する画像表示装置 |
JPH11259678A (ja) | 1998-03-12 | 1999-09-24 | Sega Enterp Ltd | 画像表示装置及びそれによる画像表示方法 |
US6064392A (en) | 1998-03-16 | 2000-05-16 | Oak Technology, Inc. | Method and apparatus for generating non-homogenous fog |
US6023738A (en) | 1998-03-30 | 2000-02-08 | Nvidia Corporation | Method and apparatus for accelerating the transfer of graphical images |
US6226012B1 (en) | 1998-04-02 | 2001-05-01 | Nvidia Corporation | Method and apparatus for accelerating the rendering of graphical images |
US6092124A (en) | 1998-04-17 | 2000-07-18 | Nvidia Corporation | Method and apparatus for accelerating the rendering of images |
US6492991B1 (en) | 1998-08-28 | 2002-12-10 | Ati International Srl | Method and apparatus for controlling compressed Z information in a video graphics system |
US6268861B1 (en) * | 1998-08-25 | 2001-07-31 | Silicon Graphics, Incorporated | Volumetric three-dimensional fog rendering technique |
JP4399910B2 (ja) | 1998-09-10 | 2010-01-20 | 株式会社セガ | ブレンディング処理を含む画像処理装置及びその方法 |
JP2000132704A (ja) | 1998-10-26 | 2000-05-12 | Sony Corp | 画像情報処理装置及び方法 |
JP3668019B2 (ja) | 1998-10-27 | 2005-07-06 | 株式会社ソニー・コンピュータエンタテインメント | 記録媒体、画像処理装置および画像処理方法 |
JP2000156875A (ja) | 1998-11-19 | 2000-06-06 | Sony Corp | 映像制作装置および映像表示システムおよびグラフィックス制作方法 |
JP4240343B2 (ja) | 1998-12-19 | 2009-03-18 | 株式会社セガ | 画像生成装置および画像生成方法 |
JP4395902B2 (ja) | 1999-01-19 | 2010-01-13 | 株式会社セガ | 画像処理方法及び、これを利用した画像処理装置 |
JP2000215325A (ja) | 1999-01-21 | 2000-08-04 | Sega Enterp Ltd | 画像処理方法および画像処理装置並びにプログラムを記録した記録媒体 |
US6181352B1 (en) | 1999-03-22 | 2001-01-30 | Nvidia Corporation | Graphics pipeline selectively providing multiple pixels or multiple textures |
US6173367B1 (en) | 1999-05-19 | 2001-01-09 | Ati Technologies, Inc. | Method and apparatus for accessing graphics cache memory |
US6807311B1 (en) | 1999-07-08 | 2004-10-19 | Ati International Srl | Method and apparatus for compressing and storing image data |
US6476811B1 (en) | 1999-09-01 | 2002-11-05 | Ati International, Srl | Method and apparatus for compressing parameter values for pixels in a display frame |
US6198488B1 (en) | 1999-12-06 | 2001-03-06 | Nvidia | Transform, lighting and rasterization system embodied on a single semiconductor platform |
-
2000
- 2000-11-28 US US09/726,225 patent/US6580430B1/en not_active Expired - Lifetime
-
2001
- 2001-07-06 JP JP2001206702A patent/JP4698893B2/ja not_active Expired - Fee Related
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0721407A (ja) * | 1993-07-06 | 1995-01-24 | Sony Corp | 画像表示方法 |
Also Published As
Publication number | Publication date |
---|---|
JP2002236934A (ja) | 2002-08-23 |
US6580430B1 (en) | 2003-06-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4698893B2 (ja) | 改良されたフォグ効果を提供するための方法、グラフィックスシステム、およびプログラム | |
JP4790150B2 (ja) | 低価格のグラフィックスシステムにおけるシャドウマッピング | |
JP4691273B2 (ja) | グラフィクス処理システムおよびエンボス型バンプマッピングを行う方法 | |
US6618048B1 (en) | 3D graphics rendering system for performing Z value clamping in near-Z range to maximize scene resolution of visually important Z components | |
US6707458B1 (en) | Method and apparatus for texture tiling in a graphics system | |
US6700586B1 (en) | Low cost graphics with stitching processing hardware support for skeletal animation | |
US6664958B1 (en) | Z-texturing | |
US7176919B2 (en) | Recirculating shade tree blender for a graphics system | |
US6867781B1 (en) | Graphics pipeline token synchronization | |
JP4719363B2 (ja) | 内部フレームバッファと主メモリ間でのコピーアウト変換を有するグラフィクスシステム | |
US7061502B1 (en) | Method and apparatus for providing logical combination of N alpha operations within a graphics system | |
EP1189173A2 (en) | Achromatic lighting in a graphics system and method | |
JP4672072B2 (ja) | 三次元ビデオグラフィックスシステムにおける非写実的な漫画的な輪郭線提供方法およびその装置 | |
JP2002269583A (ja) | 描画モードに基づいて隠面処理の順番を動的に再構成する方法および装置 | |
JP4975159B2 (ja) | グラフィックシステム、グラフィックス画像を生成する方法およびプログラムにおける無色光のライティング | |
US6717575B2 (en) | Image drawing method, image drawing apparatus, recording medium, and program | |
EP1081654A2 (en) | Method and apparatus for providing depth blur effects within a 3d videographics system | |
JP4740490B2 (ja) | グラフィックスレンダリングシステムにおいて視覚的に重要なz成分の精度を最大化しz近傍クリッピングを回避するためのz近傍範囲におけるz値のクランピング | |
JP4740476B2 (ja) | グラフィックスシステム内におけるn個のアルファ演算の論理結合を提供する方法および装置 | |
JP4698894B2 (ja) | グラフィックスシステムにおけるテクスチャタイリングのための方法、装置およびプログラム | |
CN114332316A (zh) | 一种虚拟角色的处理方法、装置、电子设备及存储介质 | |
JP2002163144A (ja) | 共有リソースへのアクセス方法及び装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20080627 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20100913 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20100929 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20101122 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20110203 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20110302 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 4698893 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
LAPS | Cancellation because of no payment of annual fees |