JP3990258B2 - Image generation system, program, and information storage medium - Google Patents
Image generation system, program, and information storage medium Download PDFInfo
- Publication number
- JP3990258B2 JP3990258B2 JP2002329814A JP2002329814A JP3990258B2 JP 3990258 B2 JP3990258 B2 JP 3990258B2 JP 2002329814 A JP2002329814 A JP 2002329814A JP 2002329814 A JP2002329814 A JP 2002329814A JP 3990258 B2 JP3990258 B2 JP 3990258B2
- Authority
- JP
- Japan
- Prior art keywords
- drawing area
- divided
- image
- frame
- area
- 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
Landscapes
- Digital Computer Display Output (AREA)
- Controls And Circuits For Display Device (AREA)
Description
【0001】
【発明の属する技術分野】
本発明は、画像生成システム、プログラム及び情報記憶媒体に関する。
【0002】
【従来技術】
従来より、仮想的な3次元空間であるオブジェクト空間内において所与の視点(仮想カメラ)から見える画像を生成する画像生成システム(ゲームシステム)が知られており、いわゆる仮想現実を体験できるものとして人気が高い。競争ゲーム(カーゲーム)を楽しむことができる画像生成システムを例にとれば、プレーヤは、操作部(ステアリング、シフトレバー、アクセルペダル、ブレーキペダル等)を用いて移動オブジェクト(自プレーヤ移動オブジェクト、自車)を操作し、他のプレーヤ(コンピュータプレーヤ又は他の人間プレーヤ)が操作する移動オブジェクト(他プレーヤ移動オブジェクト、他車)と競争することでゲームを楽しむ。
【0003】
さて、このような画像生成システムでは、1フレーム周期に全てのオブジェクトの描画処理を完了しなければならないという課題がある。このような課題を解決する従来技術としては、例えば、視点からの距離に応じて移動オブジェクトの精密度(ポリゴン数)を変化させるLOD(Level Of Detail)と呼ばれる技術や、視点から近い順に移動オブジェクトに付された順序番号に基づいて移動オブジェクトの精密度を変化させる技術などがある。
【0004】
【特許文献1】
国際公開第96/08298号公報
【0005】
【発明が解決しようとする課題】
しかしながら、例えば、マルチプレーヤゲーム用に表示画面を分割する場合などにおいては、上記のような従来技術を用いても、1フレーム周期に描画処理を完了させることが間に合わなくなる場合がある。
【0006】
本発明は、以上のような課題に鑑みてなされたものであり、その目的とするところは、画面分割モード等のモードにおいて高品質な画像を生成できる画像生成システム、プログラム及び情報記憶媒体を提供することにある。
【0007】
【課題を解決するための手段】
本発明は、画像生成を行う画像生成システムであって、オブジェクトに対してジオメトリ処理を施すジオメトリ処理部と、ジオメトリ処理後のオブジェクトの画像を含むフレーム画像をフレームバッファの描画領域に描画し、周期T毎に描画領域の書き換えを行う描画部とを含み、前記描画部が、表示画面が複数の画面に分割される画面分割モード時に、周期N×T毎(Nは2以上の整数)に描画領域の書き換えを行う画像生成システムに関係する。また本発明は、上記各部としてコンピュータを機能させるプログラムに関係する。また本発明は、コンピュータ読み取り可能な情報記憶媒体であって、上記各部としてコンピュータを機能させるプログラムを記憶(記録)した情報記憶媒体に関係する。
【0008】
本発明によれば、画面分割モード時においては、周期T(例えばフレーム周期)ではなく周期N×T毎に描画領域(全描画領域)の書き換えが行われる(描画領域の更新周期がN×Tになる)。従って、画面分割モード時における描画処理に時間的な余裕が生まれ、高品質な画像を生成できるようになる。なお画面分割モードにおいても、画面分割数が少ない場合(例えば2画面分割又は3画面分割等)には、周期T毎に描画領域の書き換えを行ってもよい。
【0009】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、前記画面分割モード時には、表示画面が第1〜第Kのプレーヤ用(Kは2以上の整数)の第1〜第Kの画面に分割され、前記描画部が、オブジェクト空間において第1〜第Kのプレーヤの視点から見えるべき第1〜第Kの画像を、第1〜第Kの画面に対応する、フレームバッファの第1〜第Kの描画領域に描画するようにしてもよい。
【0010】
このように表示画面を分割し、各プレーヤの視点から見えるべき画像を分割画面に表示する手法では、プレーヤの人数が増えるほど描画処理の負荷が重くなってしまう。しかしながら本発明では、このような場合にも、周期N×T毎に描画処理が行われるようになるため、高品質な画像を生成できる。
【0011】
なお、本発明の画面分割モードは、上記のようなマルチプレーヤゲーム用に表示画面が分割されるモードには限定されない。
【0012】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、移動オブジェクトの移動情報を求め、移動オブジェクトをオブジェクト空間内で移動させる処理を行う移動処理部を含み(該移動処理部として機能させるプログラム又は該プログラムを記憶した情報記憶媒体であって)、前記移動処理部が、画面分割モード時に周期N×T毎に描画領域の書き換えが行われている場合にも、移動オブジェクトの移動情報を求める処理を周期T毎に行うようにしてもよい。
【0013】
このようにすれば、描画領域の書き換えについては周期N×T毎に行われている場合にも、移動処理については周期T毎に行われるようになり、移動処理の演算精度については維持できる。また描画領域の描画周期が変化した場合にも、移動処理の処理内容(プログラム)については変更しなくても済むようになる。
【0014】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、フレームバッファが第1〜第Nの描画領域を有し、前記描画部が、第1〜第Nの描画領域を第1〜第Nの描画領域の順に周期T毎に順次書き換えることで、全描画領域の書き換えを周期N×T毎に行うようにしてもよい。
【0015】
本発明によれば、第1の描画領域が書き換えられ、次に第2の描画領域の書き換えられ・・・次に第Nの描画領域が書き換えられるというように、周期T毎に第1〜第Nの描画領域が順次書き換えられる(順次描画される)。これにより、全描画領域の書き換えを周期N×T毎に行う処理を実現できる。
【0016】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、前記画面分割モード時には、表示画面が第1〜第Kのプレーヤ用(Kは2以上の整数)の第1〜第Kの画面に分割され、前記描画部が、オブジェクト空間において第1〜第Kのプレーヤの視点から見えるべき第1〜第Kの画像を、第1〜第Kの画面に対応する、フレームバッファの第1〜第Kの描画領域に描画し、前記第1〜第Nの描画領域の境界が、前記第1〜第Kの描画領域の境界の一部又は全部と一致するようにしてもよい。
【0017】
このようにすれば、第1〜第Kの画面の境界の一部又は全部が、第1〜第Nの描画領域の境界と一致するようになるため、その境界において表示物にずれが生じる事態の発生を防止できる。
【0018】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、フレームバッファが描画領域と表示領域を有し、前記描画部が、フレームバッファの描画領域の奇数走査ラインのフレーム画像と偶数走査ラインのフレーム画像のいずれか一方を、周期T毎に交互に、フレームバッファの表示領域にコピーしてもよい。
【0019】
このようにすれば、例えばインタレース走査方式の場合に、フレームバッファの表示領域の大きさを小さくすることが可能になり、メモリ容量を節約できる。
【0020】
また本発明に係る画像生成システム、プログラム及び情報記憶媒体では、前記描画部が、周期N×T毎に描画領域の書き換えを行う場合には、周期T毎に描画領域の書き換えを行う場合に比べて、より高精細のフレーム画像を描画領域に描画してもよい。
【0021】
また本発明は、画像生成を行う画像生成システムであって、オブジェクトに対してジオメトリ処理を施すジオメトリ処理部と、ジオメトリ処理後のオブジェクトの画像を含むフレーム画像をフレームバッファの描画領域に描画し、周期T毎に描画領域の書き換えを行う描画部とを含み、前記描画部が、第1のモードでは周期T毎に描画領域の書き換えを行い、第2のモードでは周期N×T毎(Nは2以上の整数)に描画領域の書き換えを行うと共に、周期T毎に描画領域の書き換えを行う場合に比べて、より高精細のフレーム画像を描画領域に描画する画像生成システムに関係する。また本発明は、上記各部としてコンピュータを機能させるプログラムに関係する。また本発明は、コンピュータ読み取り可能な情報記憶媒体であって、上記各部としてコンピュータを機能させるプログラムを記憶(記録)した情報記憶媒体に関係する。
【0022】
本発明によれば、第1のモードでは周期T毎に描画領域(全描画領域)の書き換えが行われる(描画領域の更新周期がTになる)。一方、第2のモードでは周期N×T毎に描画領域(全描画領域)の書き換えが行われるようになる(描画領域の更新周期がN×Tになる)。そして第2のモードでは、第1のモードに比べて高精細の描画処理が行われる。従って、描画周期は長くなるものの、描画フレーム画像の精細度については向上できるようになる。
【0023】
【発明の実施の形態】
以下、本実施形態について図面を用いて説明する。
【0024】
なお、以下に説明する本実施形態は、特許請求の範囲に記載された本発明の内容を不当に限定するものではない。また本実施形態で説明される構成の全てが、本発明の必須構成要件であるとは限らない。
【0025】
1.構成
図1に、本実施形態の画像生成システム(ゲームシステム)の機能ブロック図の例を示す。なお、本実施形態の画像生成システムは、図1の構成要素(各部)を全て含む必要はなく、その一部(例えば操作部160、携帯型情報記憶装置194又は通信部196等)を省略した構成としてもよい。
【0026】
操作部160は、プレーヤが操作データを入力するためのものであり、その機能は、レバー、ボタン、ステアリング、シフトレバー、アクセルペダル、ブレーキペダル、マイク、センサー、タッチパネル、或いは筺体などのハードウェアにより実現できる。
【0027】
記憶部170は、処理部100や通信部196などのワーク領域となるもので、その機能はRAMなどのハードウェアにより実現できる。
【0028】
情報記憶媒体180(コンピュータにより読み取り可能な媒体)は、プログラムやデータなどを格納するものであり、その機能は、光ディスク(CD、DVD)、光磁気ディスク(MO)、磁気ディスク、ハードディスク、磁気テープ、或いはメモリ(ROM)などのハードウェアにより実現できる。処理部100は、この情報記憶媒体180に格納されるプログラム(データ)に基づいて本実施形態の種々の処理を行う。即ち情報記憶媒体180には、本実施形態の各部としてコンピュータを機能させるためのプログラム(各部の処理をコンピュータに実行させるためのプログラム)が記憶(記録、格納)される。
【0029】
表示部190は、本実施形態により生成された画像を出力するものであり、その機能は、CRT、LCD、タッチパネル、或いはHMD(ヘッドマウントディスプレイ)などのハードウェアにより実現できる。
【0030】
音出力部192は、本実施形態により生成された音を出力するものであり、その機能は、スピーカ、或いはヘッドフォンなどのハードウェアにより実現できる。
【0031】
携帯型情報記憶装置194は、プレーヤの個人データやゲームのセーブデータなどが記憶されるものであり、この携帯型情報記憶装置194としては、メモリカードや携帯型ゲーム装置などがある。
【0032】
通信部196は、外部(例えばホスト装置や他の画像生成システム)との間で通信を行うための各種の制御を行うものであり、その機能は、各種プロセッサ又は通信用ASICなどのハードウェアや、プログラムなどにより実現できる。
【0033】
なお本実施形態の各部としてコンピュータを機能させるためのプログラム(データ)は、ホスト装置(サーバー)が有する情報記憶媒体からネットワーク及び通信部196を介して情報記憶媒体180(記憶部170)に配信するようにしてもよい。このようなホスト装置(サーバー)の情報記憶媒体の使用も本発明の範囲内に含まれる。
【0034】
処理部100(プロセッサ)は、操作部160からの操作データやプログラムなどに基づいて、ゲーム処理、画像生成処理、或いは音生成処理などの各種の処理を行う。この場合、処理部100は、記憶部170内の主記憶部172をワーク領域として使用して、各種の処理を行う。この処理部100の機能は、各種プロセッサ(CPU、DSP等)又はASIC(ゲートアレイ等)などのハードウェアや、プログラム(ゲームプログラム)により実現できる。
【0035】
処理部100が行うゲーム処理としては、例えば、ゲームに登場するオブジェクト(表示物)を配置する処理、オブジェクトを移動させる処理、オブジェクトを動作させる処理(モーション再生処理)、オブジェクトを表示する処理、ゲームを進行させる処理、或いはゲーム結果を演算する処理などがある。
【0036】
処理部100は、モード設定部110、移動処理部112、動作処理部114、ジオメトリ処理部116、描画部(画像生成部)120、音生成部130を含む。
【0037】
モード設定部110は、ゲームにおける各種のモードを設定するための処理を行う。具体的には、モード設定画面を表示するための処理、操作部160によりプレーヤがモード設定画面で入力した操作データを受け付ける処理、或いは受け付けた操作データに基づいてモードを決定する処理などを行う。
【0038】
モード設定部110により設定されるモードとしては、ゲームに参加するプレーヤの人数(画面分割数)についてのモード(1人プレーヤモード〜4人プレーヤモード)、フレームレート(1秒間当たりのフレーム数、Frame Per Second)の設定モード、或いは描画の精細度(ポリゴン数、マップ分割数、又はレンダリング方式等)の設定モードなどがある。
【0039】
移動処理部112(シミュレーション演算部)は、移動オブジェクト(オブジェクト)の移動情報(位置情報、方向情報、速度情報或いは加速度情報)を求める処理を行う。即ち、操作部160によりプレーヤが入力した操作データやゲームプログラムなどに基づいて、移動オブジェクトをオブジェクト空間内で移動させる処理を行う。
【0040】
より具体的には、移動処理部112は、移動オブジェクトの位置や回転角度(方向)を例えば1フレーム(1/60秒等)毎に変化させる。例えば(k−1)フレームでの移動オブジェクトの位置(X、Y又はZ座標)、回転角度(X、Y又はZ軸回りの回転角度)をPk-1、θk-1とし、オブジェクトの1フレームでの位置変化量(速度)、回転変化量(回転速度)を△P、△θとする。するとkフレームでの移動オブジェクトの位置Pk、回転角度θkは例えば下式(1)、(2)のように求められる。
【0041】
Pk=Pk-1+△P (1)
θk=θk-1+△θ (2)
なお移動処理部112で行われる処理は上式(1)(2)の処理に限定されず、(1)(2)と均等な処理でもよい。
【0042】
動作処理部114(シミュレーション演算部)は、移動オブジェクトの動作情報(移動オブジェクトの各パーツの位置情報、方向情報)を求める処理を行う。即ち、操作部160によりプレーヤが入力した操作データやゲームプログラムなどに基づいて、移動オブジェクトを動作(モーション、アニメーション)させる処理を行う。
【0043】
より具体的には、動作処理部114は、移動オブジェクトのモーションをモーションデータに基づいて再生する処理等を行う。即ち、移動オブジェクト(モデルオブジェクト、スケルトン、キャラクタ)を構成する各パーツオブジェクト(スケルトンを構成する骨)の位置又は回転角度(方向)等を含むモーションデータを、記憶部170(モーションデータ記憶部)から読み出す。そして、移動オブジェクトの各パーツオブジェクト(骨)を動かすことで(スケルトン形状を変形させることで)、移動オブジェクトのモーションを再生する。
【0044】
ジオメトリ処理部116はオブジェクトに対してジオメトリ処理を施す。より具体的には、座標変換、クリッピング処理、透視変換、或いは光源計算等のジオメトリ処理を行う。そしてジオメトリ処理結果に基づいて、描画データ(プリミティブ面の頂点の位置座標、テクスチャ座標、色データ、法線ベクトル、或いはα値等)を作成し、作成された描画データ(プリミティブ面データ)を描画部120に出力する。
【0045】
描画部120は、処理部100で行われる種々の処理の結果に基づいて描画処理を行い、これにより画像を生成し、表示部160に出力する。より具体的には、ジオメトリ処理部116からの描画データ(プリミティブ面データ)に基づいて、ジオメトリ処理後のオブジェクト(1又は複数のプリミティブ面)の画像を、フレームバッファ(ピクセル単位で画像情報を記憶できるバッファ)174に描画する。更に具体的には、ジオメトリ処理後のオブジェクトの画像を含むフレーム画像(1画面分の画像)をフレームバッファ174(VRAM)の描画領域(描画用に確保された領域)に描画し、周期T(フレーム周期。例えば1/60秒)毎に描画領域の書き換え(更新)を行う。これにより、オブジェクト空間内において仮想カメラ(所与の視点)から見える画像が生成されるようになる。
【0046】
そして本実施形態では描画部120が、画面分割モード(表示画面が複数の画面に分割されるモード)時において、周期N×T毎(Nは2以上の整数)に描画領域の書き換えを行う。より具体的には、表示画面が分割されない通常モードでは、周期T毎に(フレームレートFPSで)、フレームバッファ174の描画領域の書き換えを行う。一方、画面分割モードでは、周期N×T毎に(FPS/Nで)、描画領域の書き換えを行う。別の言い方をすれば表示画面の分割数に応じて(設定されるモードに応じて)、描画周期(フレームレート)を変化させる。このようにすることで、描画処理に時間的な余裕ができるため、画面分割モード時においても高品質な画像を生成できる。
【0047】
なお画面分割モードの設定はモード設定部110により行われる。また、描画周期がT(フレーム周期)からN×T(フレーム周期のN倍)に切り替えられる画面分割数は任意である。例えば通常モードから2画面分割モードになった時に描画周期をTからN×Tに切り替えてもよいし、2画面分割モードから3画面分割モードになった時、或いは3画面分割モードから4画面分割モードになった時に、TからN×Tに切り替えてもよいし、また画面分割数が増えるにつれて、周期N×TのNを次第に増やすようにしてもよい。
【0048】
また描画部120は、第1のモード(例えばフレームレートが大きく設定されるモード、描画処理の精細度が低精細に設定されるモード、画面分割数が少なく設定されるモード、或いは参加プレーヤ又は移動オブジェクトの数が少なく設定されるモード)では、周期T(フレームレートFPS)毎にフレームバッファ174の描画領域の書き換えを行う。一方、第2のモード(例えばフレームレートが小さく設定されるモード、描画処理の精細度が高精細に設定されるモード、画面分割数が多く設定されるモード、或いは参加プレーヤ又は移動オブジェクトの数が多く設定されるモード)では、周期N×T毎(Nは2以上の整数)に描画領域の書き換えを行うと共に、より高精細のフレーム画像(オブジェクトのポリゴン数が多い、表示されるオブジェクトの数が多い、或いはレンダリングの精度が高いフレーム画像)を描画領域に描画する。このようにすることで、描画周期(フレームレート)とLOD(Level Of detail)とのトレードオフを図ることができる。
【0049】
音生成部130は、処理部100で行われる種々の処理の結果に基づいて音処理を行い、BGM、効果音、又は音声などのゲーム音を生成し、音出力部192に出力する。
【0050】
なお、本実施形態の画像生成システムは、1人のプレーヤのみがプレイできるシングルプレーヤモード専用のシステムにしてもよいし、このようなシングルプレーヤモードのみならず、複数のプレーヤがプレイできるマルチプレーヤモードも備えるシステムにしてもよい。
【0051】
また複数のプレーヤがプレイする場合に、これらの複数のプレーヤに提供するゲーム画像やゲーム音を、1つの端末を用いて生成してもよいし、ネットワーク(伝送ライン、通信回線)などで接続された複数の端末(ゲーム機、携帯電話)を用いて生成してもよい。
【0052】
2.本実施形態の手法
次に本実施形態の手法について図面を用いて説明する。
【0053】
2.1 画面分割数に応じた描画周期の制御
本実施形態では、画面分割数に応じて描画周期(フレームレート)を制御している。
【0054】
図2(A)に、表示画面SC(表示部の画面)が分割されない通常モード時のゲーム画像の例を示す。プレーヤはこの表示画面SCに表示されるゲーム画像を見ながら、操作部を用いて移動オブジェクトMOB(車等)を操作し、コース上で走行させる。そして表示画面SCには、オブジェクト空間(仮想3次元空間)においてそのプレーヤの視点から見える画像(フレーム画像)が表示される。
【0055】
一方、図2(B)に、表示画面が複数の画面に分割される画面分割モード時のゲーム画像の例を示す。図2(B)では、表示画面SCが第1、第2、第3、第4のプレーヤ(以下、適宜1P、2P、3P、4Pプレーヤと呼ぶ)用の画面SC1、SC2、SC3、SC4に分割されている。
【0056】
そして図3に示すように、これらの画面SC1〜SC4(広義には第1〜第Kの画面)には、オブジェクト空間において1P〜4Pプレーヤ(広義には第1〜第Kのプレーヤ)の視点VP1〜VP4から見える画像が表示される。即ち、オブジェクト空間において1P〜4Pプレーヤの視点から見えるべき画像(第1〜第Kの画像、透視変換画像)が、画面SC1〜SC4に対応する、フレームバッファの描画領域DR1〜DR4に描画される。
【0057】
そして1P〜4Pプレーヤは、これらの画面SC1〜SC4に表示される画像(1P〜4Pプレーヤ用の画像)を見ながら、操作部を用いて移動オブジェクトMOB1〜MOB4を操作し、マルチプレーヤゲーム(競争ゲーム、対戦ゲーム、協力ゲーム)を楽しむ。
【0058】
さて図2(B)に示す画面分割モードでは、1P〜4Pプレーヤ用の移動オブジェクトMOB1〜MOB4や、マップ、建物、空などの背景についても、画面SC1〜SC4に表示しなければならない。即ち図2(B)では、図2(A)と同じ描画データ量の表示物を4セット分描画しなければならない。従って、図2(A)に比べて描画処理の負荷は4倍程度になってしまう。このため、LODなどの技術により描画データ量を減らしても、1フレーム周期T(例えば1/60秒)内で描画処理を完了できないおそれがあることが判明した。
【0059】
そこで本実施形態では画面分割数に応じて描画周期(フレームレート)を可変に制御する手法を採用している。
【0060】
具体的には図4に示すように、通常モード時(図2(A))には、周期T(フレーム周期)毎にフレームバッファの描画領域の書き換え(全描画領域の画像データの書き換え。描画領域の書き換えの開始)を行う。即ち全てのフレーム1、2、3、4、5、6・・・において描画領域の書き換え(更新)を行う。別の言い方をすれば描画領域の更新周期をTに設定する。
【0061】
一方、画面分割モード時(図2(B))には、例えば周期2T(広義にはN×T。以下も同様)毎に描画領域の書き換え(全描画領域の画像データの書き換え。描画領域の書き換えの開始)を行う。即ち例えば奇数フレーム1、3、5・・・(又は偶数フレーム2、4、6・・・)の開始(垂直同期割り込み)に同期して、描画領域の書き換え(更新)を開始する。別の言い方をすれば画面更新周期を2T(N×T)に設定する。
【0062】
このようにすれば、画面分割モード時においては、周期Tではなく周期2Tの期間内に、描画領域の書き換え処理(画像データの描画処理)を完了できればよいことになる。従って、描画処理に時間的な余裕が生じ、例えば4セット分のオブジェクト(移動オブジェクト、背景オブジェクト)を描画しなければならない4画面分割モードでも、描画周期内に全てのオブジェクトを描画することが可能になる。これにより、表示されないオブジェクトが生じたり、映像が分解写真のように飛び飛びになってしまうような事態が発生するのを防止できる。
【0063】
なお図4では、通常モード時における描画周期をTとし、4画面分割モード時における描画周期を2Tとしているが、描画周期N×TのNの設定は任意である。例えば、2画面分割モード又は3画面分割モードになったときに、描画周期をTから2Tに切り替えてもよい。或いは、2画面分割モードではN=2に設定し、3画面分割モード以上ではN>3に設定することも可能である。
【0064】
またフレーム周期Tは、表示部の垂直同期割り込み(垂直同期信号)に基づいて決められる。具体的にはフレーム周期Tは、垂直同期割り込み(VSYNC)の第1のパルスがアクティブになってから次の第2のパルスがアクティブになるまでの間の期間である。例えばフレームレートFPS(Frame Per Second)が60である場合には、T=1/60秒になる。従って周期T毎に描画領域を更新する場合には、垂直同期割り込みがアクティブになる毎に、描画領域の更新を1回行い、周期N×T毎に描画領域を更新する場合には、垂直同期割り込みがN回アクティブになる毎に、描画領域の更新を1回行うことになる。
【0065】
また図2(B)、図3では、マルチプレーヤゲームの各プレーヤ用に表示画面を分割する例について説明したが、本実施形態の画面分割モードはこれに限定されない。例えば、サブ画面(バックミラーに映る画像、又は双眼鏡やスコープなどの光学機器を介して見える画像などが表示される画面)とメイン画面に分割するような画面分割モードにも、本実施形態の原理は適用できる。
【0066】
2.2 移動オブジェクトの移動処理
本実施形態では図4に示すように描画周期(フレームレート)については画面分割数に応じて変化させている。しかしながら、その一方で、移動オブジェクトの移動処理(シミュレーション処理、パラメータの数値演算処理、操作データを受け付ける処理、動作処理)の周期については、画面分割数に依らずに一定にしている。
【0067】
より具体的には図5のA1に示すように、操作部からの操作データ等に基づいて移動オブジェクトMOBの移動情報(位置、方向、速度又は加速度等)を求め、MOBをオブジェクト空間内で移動させる処理については、例えばフレーム周期T毎に行う。即ちフレーム1、2、3、4、5・・・における移動オブジェクトMOBの位置P1、P2、P3、P4、P5・・・、方向(角度)D1、D2、D3、D4、D5・・・を所定のアルゴリズムに従ったシミュレーション演算(数値演算)により求める。例えば、フレーム2での位置P2は、フレーム1での位置P1と、フレーム1での速度(フレーム周期Tで移動する距離)に基づき求めることができる(前述の式(1)(2)参照)。そして、この速度は、加速度や空力抵抗や摩擦抵抗などに基づき求めることができ、加速度は、アクセルの踏み具合(エンジン出力)やブレーキの踏み具合(ブレーキング能力)などに基づき求めることができる。
【0068】
一方、図5のA2に示すように、描画領域の書き換え(描画領域への描画)については、周期2×T(N×T)毎に行う。即ち例えば奇数フレーム1、3、5・・・(又は偶数フレーム2、4、6・・・)の開始に同期して、描画処理の書き換えを開始する。
【0069】
このようにすれば、移動オブジェクトMOBの移動処理については、短い周期T毎に行われるため、正確な数値演算が可能になる。従って、移動オブジェクトMOBの動きが不自然になったり、数値演算の誤差が大きくなりすぎてしまう事態を防止できる。一方、描画領域の書き換えは周期2T毎に行われるため、描画処理に時間的な余裕ができ、高品質な画像を生成できる。更に、描画領域の書き換えを周期T毎に行う場合と周期2T毎に行う場合とで、移動処理(シミュレーション処理)のプログラムモジュールについては、共通に使用できる。従って、プログラムの開発労力の軽減化や開発期間の短縮化を図れる。
【0070】
なお、描画領域の書き換えを周期N×T毎に行っている場合にも周期T毎に行うことが望ましい処理は、移動オブジェクトの移動処理に限定されない。例えば、操作データを受け付ける処理(サンプリングする処理)、オブジェクトのモーション再生処理、或いはステータスパラメータなどの各種パラメータ値を演算する処理なども、周期T毎に行うことが望ましい。
【0071】
2.3 分割された描画領域毎の描画処理
本実施形態では、フレームバッファに第1〜第Nの描画領域を確保する。そして、第1〜第Nの描画領域を、例えば第1〜第Nの描画領域の順に、周期T毎に順次書き換えて行くことで、周期N×T毎の全描画領域の書き換えを実現している。
【0072】
具体的には図6に示すように、フレーム1では上側の第1の描画領域DRAの書き換えを行い、フレーム2では下側の第2の描画領域DRBの書き換えを行う。同様に、フレーム3、4、5では、描画領域DRA、DRB、DRAの順で書き換えを行う。即ち描画領域DRA、DRBを周期T毎に交互に書き換える(半分ずつ書き換える)。このようにすれば、結局、全描画領域の書き換えは、周期2T(N×T)毎に完了するようになる。従って、画面分割モード時等に描画領域の書き換えを周期2T(N×T)毎に行う手法を、簡単に実現できるようになる。
【0073】
なお図6ではフレームバッファの描画領域を2分割にした場合を示したが、3分割以上にしてもよい。例えば、描画領域を、第1、第2、第3、第4の描画領域に分割した場合には、フレーム1では第1の描画領域、フレーム2では第2の描画領域、フレーム3では第3の描画領域、フレーム4では第4の描画領域、フレーム5では第1の描画領域、フレーム6では第2の描画領域というように、描画領域を書き換えればよい。
【0074】
またフレームバッファ(VRAM)に、描画領域(描画バッファ)に加えて表示領域(表示バッファ)を確保する場合には、フレームバッファの描画領域の書き換えの前に、フレームバッファの描画領域からフレームバッファの表示領域へと、フレーム画像(既に書き換えが完了したフレーム画像)をコピーする。この場合のコピーは例えば全てのフレームで行う。また表示部には、フレームバッファの表示領域に記憶されるフレーム画像が表示される。
【0075】
そしてインタレース方式の場合には、フレームバッファの描画領域の奇数走査ラインのフレーム画像と、偶数走査ラインのフレーム画像のいずれか一方を、周期T毎に交互に、フレームバッファの表示領域にコピーする。
【0076】
より具体的には図7に示すように、例えば奇数フレーム1、3、5・・・では、奇数走査ラインのフレーム画像を描画領域から表示領域にコピーし、偶数フレーム2、4、6・・・では、偶数走査ラインのフレーム画像を描画領域から表示領域にコピーする。このようにすれば図7に示すように表示領域の大きさ(メモリ容量)を描画領域の半分にすることができ、メモリ容量を節約できる。
【0077】
即ち、描画領域を分割せずに全描画領域を周期2T毎に書き換える手法では、表示領域は、周期2Tの期間に亘ってフレーム画像を保持しておく必要があるため、表示領域の大きさを描画領域と同じ大きさに設定する必要がある。
【0078】
これに対して、図6、図7の手法では、全描画領域の半分の領域であるDRA又はDRBだけを書き換えればよいため、周期T内で書き換えを完了できる。従って、周期T毎に描画領域から表示領域へとフレーム画像をコピーしても、描画途中の画像がコピーされてしまうというような不具合が生じない。従って、表示領域の大きさを描画領域の半分に設定しても、上記のような不具合が生じなくなり、描画領域を分割せずに全描画領域を周期2T毎に書き換える手法に比べて、表示領域の大きさを小さくでき、メモリ容量を節約できる。
【0079】
さて、図6のように描画領域を分割して描画処理を行う場合には、分割描画領域の境界と、分割画面(分割画面に対応する描画領域)の境界とを、少なくとも一部において一致させることが望ましい。
【0080】
具体的には図8(A)に示すように、図2(B)の分割画面SC1〜SC4(第1〜第Kの画面)に対応する描画領域DR1〜DR4(第1〜第Kの描画領域)における境界BD13と、図6の手法で交互に書き換えられる上半分の描画領域DRAと下半分の描画領域DRB(第1〜第Nの描画領域)の境界BDABとが一致するようにする。或いは、左半分の描画領域DRCと右半分の描画領域DRDを交互に書き換える場合には、図8(B)に示すように、描画領域DR1〜DR4における境界BD12と、描画領域DRC、DRDの境界BDCDとが一致するようにする。
【0081】
このようにすれば、例えば図8(C)のように境界BD13(BDAB)で表示物にずれが生じて画像が低品質化してしまう事態を防止できる。即ち、図8(A)の手法によれば、描画領域DRA、DRBの境界BDABは、図2(B)の分割画面SC1、SC2とSC3、SC4の境界BDSC(BD13)に一致するようになる。そして、この境界BDSCの上側と下側には、異なるプレーヤのゲーム画像を表示されるため、図8(C)に示すような表示物のずれは、元々、問題にならない。従って、表示物のずれにより画像が低品質化してしまう事態を防止でき、高品質な画像を生成できる。
【0082】
2.4 LODとのトレードオフ
周期N×T毎に描画領域を書き換える手法は、LODとのトレードオフとしても用いることができる。
【0083】
例えば図9のように、第1のモードにおいては、周期T毎に描画領域の書き換えを行う。一方、第2のモードにおいては、周期2T(N×T)毎に描画領域の書き換えを行うと共に、周期T毎に描画領域の書き換えを行う場合に比べて、より高精細(高精密度)のフレーム画像を描画領域に描画する。
【0084】
即ち第1のモードでは、通常の精細度で描画処理が行われるため、周期T(フレーム周期)に同期して描画領域の書き換えを行っても、周期T内で描画処理を完了させることができる。一方、第2のモードでは、高精細で描画処理が行われるため、周期T内では描画処理を完了できないおそれがある。しかしながら図9の手法では第2のモードにおいては周期2T内に描画領域の書き換えを完了すればよいため、高精細モードであっても描画処理を無事に完了できる。
【0085】
従って、例えばフレーム画像の精細度よりもフレームレートの速さを優先する場合には、第1のモードで描画処理を行う。一方、フレームレートの速さよりもフレーム画像の精細度を優先する場合には、第2のモードで描画処理を行う。このようにすれば、プレーヤに種々の選択枝を与えることができ、生成される画像のバラエティ度を増すことができる。
【0086】
なおフレーム画像の精細度を制御する手法としては種々の手法がある。例えば図10(A)に示すように移動オブジェクトのポリゴン数(広義にはプリミティブ面数)を変化させて、描画処理の精細度を制御してもよい。例えば第1のモードではポリゴン数の少ない移動オブジェクトを使用し、第2のモードではポリゴン数の多い移動オブジェクトを使用する。
【0087】
また、図10(B)に示すようにマップ(地形を表現するマップ)の分割数を変化させて、描画処理の精細度を制御してもよい。例えば、第1のモードでは分割数の少ないマップを使用し、第2のモードでは分割数の多いマップを使用する。
【0088】
また、表示画面に表示するオブジェクト(表示物)の数を変化させて、描画処理の精細度を制御してもよい。例えば第1のモードでは、登場するオブジェクトの数を少なくし、第2のモードではオブジェクト数を多くする。
【0089】
また、オブジェクトにマッピングするテクスチャの種類を変化させて、描画処理の精細度を制御してもよい。例えば第1のモードでは、通常の精細度のテクスチャをオブジェクトにマッピングし、第2のモードでは高精細なテクスチャをオブジェクトにマッピングする。
【0090】
また、レンダリング方式を変化させて、描画処理の精細度を制御してもよい。例えば、第1のモードでは、通常の精細度のフレーム画像を生成できるレンダリング方式を採用し、第2のモードでは、高精細なフレーム画像を生成できるレンダリング方式を採用する。より具体的には、例えば第1のモードではグーローシェーディングの照明モデルでレンダリングを行い、第2のモードではフォンシェーディングの照明モデルでレンダリングを行う。或いは第1のモードでは通常の光源数でシェーディング処理を行い、第2のモードでは光源数を増やしてシェーディング処理を行う。或いは第1のモードでは処理負荷が低い影生成アルゴリズムを採用し、第2のモードでは処理負荷は高いがリアルな影を生成できる影生成アルゴリズムを採用する。
【0091】
なお、第1、第2のモードの切り替えは、プレーヤがモード設定画面で選択することで行ってもよいし、ゲームの進行状況や、ゲーム場面や、ゲームの内容などに応じて、コンピュータ(プログラム)が自動的に切り替えてもよい。
【0092】
3.本実施形態の処理
次に、本実施形態の処理の詳細例について、図11〜図13のフローチャートを用いて説明する。
【0093】
図11は、画面分割数に応じて描画周期を変化させる処理を実現するフローチャートである。
【0094】
まず、プレーヤの人数の設定が行われる(ステップS1)。そして、iを0に設定する(ステップS2)。そしてプレーヤの人数が3〜4人か否かを判断し(ステップS3)、3〜4人(3〜4画面分割)の場合にはNを2に設定し、1〜2人(画面分割無し。2画面分割)の場合には、N=1に設定する(ステップS4、S5)。
【0095】
次にiが0か否かを判断する(ステップS6)。そして、iが0の場合には、フレームバッファの描画領域から表示領域へのフレーム画像(画像データ)のコピーを行う(ステップS7)。一方、iが0ではない場合にはステップS7の処理を省略する。
【0096】
次に図5で説明した移動オブジェクトの移動処理(1フレーム単位の数値パラメータ類の演算を行うシミュレーション処理)を行う(ステップS8)。
【0097】
次に、iが0か否かを判断し(ステップS9)、iが0の場合には全描画領域の描画・書き換え処理を行う(ステップS10)。一方、iが0ではない場合には、ステップS10の処理を省略する。
【0098】
次に、iをi+1にインクリメントする(ステップS11)。そして、Nがiに等しいか否かを判断し(ステップS12)、等しい場合にはiを0に設定する(ステップS13)。そして、その他の処理を行う(ステップS14)。
【0099】
そして、次のフレームが始まっているか否かを判断する(ステップS15)。例えば、垂直同期割り込みが発生している場合には、次のフレームが始まっていると判断できる。そして、次のフレームが始まっている場合には、ゲーム終了か否かを判断し(ステップS16)、ゲーム終了ではない場合にはステップS6に戻る。
【0100】
図11の処理によれば、3〜4画面分割の時には、例えば最初のフレーム(奇数フレーム)ではステップS7、S10のコピー及び描画・書き換え処理が行われ、次のフレーム(偶数フレーム)ではステップS7、S10のコピー及び描画・書き換え処理が行われないようになる。一方、画面分割無し又は2画面分割の場合には、どのフレームにおいてもステップS7、S10のコピー及び描画・書き換え処理が行われるようになる。これにより図4で説明した手法を実現できる。
【0101】
図12は図6で説明した処理を実現するフローチャートである。
【0102】
まず、プレーヤの人数の設定が行われる(ステップS21)。そして、iを2に設定する(ステップS22)。
【0103】
次に、フレームバッファの描画領域から表示領域へのフレーム画像のコピーを行う(ステップS23)。そして図5で説明した移動オブジェクトの移動処理(シミュレーション処理)を行う(ステップS24)。
【0104】
次に、プレーヤの人数が3〜4人か否かを判断し(ステップS25)、1〜2人(画画面分割無し、2画面分割)の場合には、全描画領域の描画・書き換え処理を行う(ステップS26)。
【0105】
一方、3〜4人(3〜4画面分割)の場合には、iが1か否かを判断する(ステップS27)。そしてiが1の場合には上側の第1の描画領域(DRA)の描画・書き換え処理を行う(ステップS28)。一方、iが1ではない場合には下側の第2の描画領域(DRB)の描画・書き換え処理を行う(ステップS29)。
【0106】
次に、iをi−1にデクリメントし(ステップS30)、iが0か否かを判断する(ステップS31)。そして、iが0の場合には、iを2に設定し直す(ステップS32)。一方、iが0ではない場合にはステップS32の処理を省略する。
【0107】
次に、その他の処理を行う(ステップS33)。そして次のフレームが始まっているか否かを判断する(ステップS34)。そして、次のフレームが始まっている場合には、ゲーム終了か否かを判断し(ステップS35)、ゲーム終了ではない場合にはステップS23に戻る。
【0108】
図12の処理によれば、3〜4画面分割の時には、例えば最初のフレーム(奇数フレーム)では、ステップS28の第1の描画領域の描画・書き換え処理が行われ、次のフレーム(偶数フレーム)では、ステップS29の第2の描画領域の描画・書き換え処理が行われるようになる。一方、画面分割無し又は2画面分割の場合には、どのフレームにおいてもステップS26の全画面領域の描画・書き換え処理が行われるようになる。これにより図6で説明した手法を実現できる。
【0109】
図13は図9で説明した処理を実現するフローチャートである。
【0110】
まず、iを0に設定する(ステップS41)。またフレームレート(描画周期)の設定が行われる(ステップS42)。
【0111】
次に、設定されたフレームレートが30FPS(Frame Per Second)か否かを判断し(ステップS43)、フレームレートが30FPSの場合にはNを2に設定する(ステップS44)。一方、フレームレートが60FPSの場合にはNを1に設定する(ステップS45)。
【0112】
次に、iが0か否かを判断し(ステップS46)、iが0ならばフレームバッファの描画領域から表示領域へのコピーを行う(ステップS47)。一方、iが0ではない場合にはステップS47の処理を省略する。
【0113】
次に、移動処理(シミュレーション処理)を行う(ステップS48)。そして、iが0か否かを判断し(ステップS49)、iが0の場合には、Nが1か否かを判断する(ステップS50)。そして、Nが1の場合には、通常の精細度の描画処理で描画領域の描画・書き換えを行う(ステップS51)。一方、Nが1ではない場合には、高精細の描画処理で描画領域の描画・書き換えを行う(ステップS52)。なお、iが0ではない場合にはステップS50、S51、S52の処理を省略する。
【0114】
次に、iをi+1にインクリメントする(ステップS53)。そして、Nがiと等しいか否かを判断し(ステップS54)、等しい場合にはiを0に設定する(ステップS55)。一方、等しくない場合にはステップS55の処理を省略する。
【0115】
次に、その他の処理を行う(ステップS56)。そして次のフレームが始まっているか否かを判断する(ステップS57)。そして、次のフレームが始まっている場合には、ゲーム終了か否かを判断し(ステップS58)、ゲーム終了ではない場合にはステップS46に戻る。
【0116】
図13の処理によれば、フレームレートが30FPSの場合(第2のモードの場合)には、例えば最初のフレーム(奇数フレーム)では、ステップS52の高精細の描画・書き換え処理が行われ、次のフレーム(偶数フレーム)では、ステップS52の描画・書き換え処理は行われないようになる。一方、フレームレートが60FPSの場合(第1のモードの場合)には、どのフレームにおいても、ステップS51の通常の精細度の描画・書き換え処理が行われるようになる。これにより図9で説明した手法を実現できる。
【0117】
4.ハードウェア構成
次に、本実施形態を実現できるハードウェアの構成の一例について図14を用いて説明する。
【0118】
メインプロセッサ900は、CD982(情報記憶媒体)に格納されたプログラム、通信インターフェース990を介して転送されたプログラム、或いはROM950(情報記憶媒体の1つ)に格納されたプログラムなどに基づき動作し、ゲーム処理、画像処理、音処理などの種々の処理を実行する。
【0119】
コプロセッサ902は、メインプロセッサ900の処理を補助するものであり、高速並列演算が可能な積和算器や除算器を有し、マトリクス演算(ベクトル演算)を高速に実行する。例えば、オブジェクトを移動させたり動作(モーション)させるための物理シミュレーションに、マトリクス演算などの処理が必要な場合には、メインプロセッサ900上で動作するプログラムが、その処理をコプロセッサ902に指示(依頼)する。
【0120】
ジオメトリプロセッサ904は、座標変換、透視変換、光源計算、曲面生成などのジオメトリ処理を行うものであり、高速並列演算が可能な積和算器や除算器を有し、マトリクス演算(ベクトル演算)を高速に実行する。例えば、座標変換、透視変換、光源計算などの処理を行う場合には、メインプロセッサ900で動作するプログラムが、その処理をジオメトリプロセッサ904に指示する。
【0121】
データ伸張プロセッサ906は、圧縮された画像データや音データを伸張するデコード処理を行ったり、メインプロセッサ900のデコード処理をアクセレートする処理を行う。これにより、オープニング画面、インターミッション画面、エンディング画面、或いはゲーム画面などにおいて、MPEG方式等で圧縮された動画像を表示できるようになる。なお、デコード処理の対象となる画像データや音データは、ROM950、CD982に格納されたり、或いは通信インターフェース990を介して外部から転送される。
【0122】
描画プロセッサ910は、ポリゴンや曲面などのプリミティブ(プリミティブ面)で構成されるオブジェクトの描画(レンダリング)処理を高速に実行するものである。オブジェクトの描画の際には、メインプロセッサ900は、DMAコントローラ970の機能を利用して、オブジェクトデータを描画プロセッサ910に渡すと共に、必要であればテクスチャ記憶部924にテクスチャを転送する。すると、描画プロセッサ910は、これらのオブジェクトデータやテクスチャに基づいて、Zバッファなどを利用した隠面消去を行いながら、オブジェクトをフレームバッファ922に高速に描画する。また、描画プロセッサ910は、αブレンディング(半透明処理)、デプスキューイング、ミップマッピング、フォグ処理、バイリニア・フィルタリング、トライリニア・フィルタリング、アンチエリアシング、シェーディング処理なども行うことができる。そして、1フレーム分の画像がフレームバッファ922に書き込まれると、その画像はディスプレイ912に表示される。
【0123】
サウンドプロセッサ930は、多チャンネルのADPCM音源などを内蔵し、BGM、効果音、音声などの高品位のゲーム音を生成する。生成されたゲーム音は、スピーカ932から出力される。
【0124】
ゲームコントローラ942(レバー、ボタン、筺体、パッド型コントローラ又はガン型コントローラ等)からの操作データや、メモリカード944からのセーブデータ、個人データは、シリアルインターフェース940を介してデータ転送される。
【0125】
ROM950にはシステムプログラムなどが格納される。なお、業務用ゲームシステムの場合には、ROM950が情報記憶媒体として機能し、ROM950に各種プログラムが格納されることになる。なお、ROM950の代わりにハードディスクを利用するようにしてもよい。
【0126】
RAM960は、各種プロセッサの作業領域として用いられる。
【0127】
DMAコントローラ970は、プロセッサ、メモリ(RAM、VRAM、ROM等)間でのDMA転送を制御するものである。
【0128】
CDドライブ980は、プログラム、画像データ、或いは音データなどが格納されるCD982(情報記憶媒体)を駆動し、これらのプログラム、データへのアクセスを可能にする。
【0129】
通信インターフェース990は、ネットワークを介して外部との間でデータ転送を行うためのインターフェースである。この場合に、通信インターフェース990に接続されるネットワークとしては、通信回線(アナログ電話回線、ISDN)、高速シリアルバスなどを考えることができる。そして、通信回線を利用することでインターネットを介したデータ転送が可能になる。また、高速シリアルバスを利用することで、他の画像生成システムとの間でのデータ転送が可能になる。
【0130】
なお、本実施形態の各部(各手段)は、その全てを、ハードウェアのみにより実現してもよいし、情報記憶媒体に格納されるプログラムや通信インターフェースを介して配信されるプログラムのみにより実現してもよい。或いは、ハードウェアとプログラムの両方により実現してもよい。
【0131】
そして、本実施形態の各部をハードウェアとプログラムの両方により実現する場合には、情報記憶媒体には、ハードウェア(コンピュータ)を本実施形態の各部として機能させるためのプログラムが格納されることになる。より具体的には、上記プログラムが、ハードウェアである各プロセッサ902、904、906、910、930等に処理を指示すると共に、必要であればデータを渡す。そして、各プロセッサ902、904、906、910、930等は、その指示と渡されたデータとに基づいて、本発明の各部を実現することになる。
【0132】
図15(A)に、本実施形態を業務用ゲームシステム(画像生成システム)に適用した場合の例を示す。プレーヤは、ディスプレイ1100上に映し出されたゲーム画像を見ながら、操作部1102(レバー、ボタン)を操作してゲームを楽しむ。内蔵されるシステムボード(サーキットボード)1106には、各種プロセッサ、各種メモリなどが実装される。そして、本実施形態の各部を実現するためのプログラム(データ)は、システムボード1106上の情報記憶媒体であるメモリ1108に格納される。以下、このプログラムを格納プログラム(格納情報)と呼ぶ。
【0133】
図15(B)に、本実施形態を家庭用のゲームシステム(画像生成システム)に適用した場合の例を示す。プレーヤはディスプレイ1200に映し出されたゲーム画像を見ながら、コントローラ1202、1204などを操作してゲームを楽しむ。この場合、上記格納プログラム(格納情報)は、本体システムに着脱自在な情報記憶媒体であるCD1206、或いはメモリカード1208、1209などに格納されている。
【0134】
図15(C)に、ホスト装置1300と、このホスト装置1300とネットワーク1302(LANのような小規模ネットワークや、インターネットのような広域ネットワーク)を介して接続される端末1304-1〜1304-n(ゲーム機、携帯電話)とを含むシステムに本実施形態を適用した場合の例を示す。この場合、上記格納プログラム(格納情報)は、例えばホスト装置1300が制御可能な磁気ディスク装置、磁気テープ装置、メモリなどの情報記憶媒体1306に格納されている。端末1304-1〜1304-nが、スタンドアロンでゲーム画像、ゲーム音を生成できるものである場合には、ホスト装置1300からは、ゲーム画像、ゲーム音を生成するためのゲームプログラム等が端末1304-1〜1304-nに配送される。一方、スタンドアロンで生成できない場合には、ホスト装置1300がゲーム画像、ゲーム音を生成し、これを端末1304-1〜1304-nに伝送し端末において出力することになる。
【0135】
なお、図15(C)の構成の場合に、本実施形態の各部を、ホスト装置(サーバー)と端末とで分散して実現するようにしてもよい。また、本実施形態の各部を実現するための上記格納プログラム(格納情報)を、ホスト装置(サーバー)の情報記憶媒体と端末の情報記憶媒体に分散して格納するようにしてもよい。
【0136】
またネットワークに接続する端末は、家庭用ゲームシステムであってもよいし業務用ゲームシステムであってもよい。
【0137】
なお本発明は、上記実施形態で説明したものに限らず、種々の変形実施が可能である。
【0138】
例えば、明細書又は図面中の記載において広義な用語(第1〜第Kの画面、第1〜第Kのプレーヤ、N×T、プリミティブ面、シミュレーション処理、第1〜第Nの描画領域等)として引用された用語(画面SC1〜SC4、1P〜4Pプレーヤ、2T、ポリゴン、移動処理、描画領域DRA・DRB等)は、明細書又は図面中の他の記載においても広義な用語に置き換えることができる。
【0139】
また画面や描画領域の分割数や分割の仕方も、本実施形態で説明したものに限定されず、種々の変形実施が可能である。
【0140】
また描画処理(書き換え処理)、コピー処理の順序や手法等も、本実施形態で説明したものに限定されず、種々の変形実施が可能である。
【0141】
また、本発明のうち従属請求項に係る発明においては、従属先の請求項の構成要件の一部を省略する構成とすることもできる。また、本発明の1の独立請求項に係る発明の要部を、他の独立請求項に従属させることもできる。
【0142】
また、本発明は種々のゲーム(格闘ゲーム、競争ゲーム、シューティングゲーム、ロボット対戦ゲーム、スポーツゲーム、ロールプレイングゲーム等)に適用できる。
【0143】
また本発明は、業務用ゲームシステム、家庭用ゲームシステム、多数のプレーヤが参加する大型アトラクションシステム、シミュレータ、マルチメディア端末、ゲーム画像を生成するシステムボード等の種々の画像生成システム(ゲームシステム)に適用できる。
【図面の簡単な説明】
【図1】本実施形態の画像生成システムの機能ブロック図である。
【図2】図2(A)(B)は画面分割モードの説明図である。
【図3】画面分割モード時の画像生成手法の説明図である。
【図4】画面分割数に応じてフレームレートを変える手法の説明図である。
【図5】移動処理(シミュレーション処理)の説明図である。
【図6】描画領域を分割して書き換える手法の説明図である。
【図7】インタレース走査方式の場合のコピー手法の説明図である。
【図8】図8(A)(B)(C)は境界を一致させる手法の説明図である。
【図9】描画処理の精細度に応じてフレームレートを変える手法の説明図である。
【図10】図10(A)(B)は描画精細度を変える手法の説明図である。
【図11】本実施形態の処理のフローチャート例である。
【図12】本実施形態の処理のフローチャート例である。
【図13】本実施形態の処理のフローチャート例である。
【図14】ハードウェア構成例である。
【図15】図15(A)〜(C)は種々の形態のシステム例である。
【符号の説明】
100 処理部、110 モード設定部、112 移動処理部、
114 動作処理部、116 ジオメトリ処理部、120 描画部、
130 音生成部、160 操作部、170 記憶部、172 主記憶部、
174 フレームバッファ、180 情報記憶媒体、190 表示部
192 音出力部、194 携帯型情報記憶装置、196 通信部[0001]
BACKGROUND OF THE INVENTION
The present invention relates to an image generation system, a program, and an information storage medium.
[0002]
[Prior art]
Conventionally, an image generation system (game system) that generates an image that can be seen from a given viewpoint (virtual camera) in an object space, which is a virtual three-dimensional space, is known. Popular. Taking an image generation system capable of enjoying a competitive game (car game) as an example, a player uses a control unit (steering, shift lever, accelerator pedal, brake pedal, etc.) to move a moving object (own player moving object, own game object). A game is enjoyed by operating a car and competing with a moving object (another player moving object, another car) operated by another player (a computer player or another human player).
[0003]
Now, in such an image generation system, there is a problem that drawing processing of all objects must be completed in one frame period. As a conventional technique for solving such a problem, for example, a technique called LOD (Level Of Detail) that changes the precision (number of polygons) of a moving object according to the distance from the viewpoint, or a moving object in order from the viewpoint For example, there is a technique for changing the precision of a moving object based on the sequence number attached to the.
[0004]
[Patent Document 1]
International Publication No. 96/08298
[0005]
[Problems to be solved by the invention]
However, for example, when the display screen is divided for a multiplayer game, it may not be possible to complete the drawing process in one frame period even if the conventional technique as described above is used.
[0006]
The present invention has been made in view of the above problems, and an object of the present invention is to provide an image generation system, a program, and an information storage medium capable of generating a high-quality image in a mode such as a screen division mode. There is to do.
[0007]
[Means for Solving the Problems]
The present invention is an image generation system that performs image generation, and includes a geometry processing unit that performs geometry processing on an object, a frame image including an image of the object after geometry processing is rendered in a rendering area of a frame buffer, and a period A drawing unit that rewrites the drawing area every T, and the drawing unit draws every cycle N × T (N is an integer of 2 or more) in a screen division mode in which the display screen is divided into a plurality of screens. The present invention relates to an image generation system that rewrites an area. The present invention also relates to a program that causes a computer to function as each of the above-described units. The present invention also relates to a computer-readable information storage medium that stores (records) a program that causes a computer to function as each unit.
[0008]
According to the present invention, in the screen division mode, the drawing area (all drawing areas) is rewritten every cycle N × T instead of the cycle T (for example, the frame cycle) (the drawing region update cycle is N × T). become). Therefore, a time margin is created in the drawing process in the screen split mode, and a high-quality image can be generated. Even in the screen division mode, when the number of screen divisions is small (for example, two-screen division or three-screen division), the drawing area may be rewritten every period T.
[0009]
In the image generation system, the program, and the information storage medium according to the present invention, in the screen division mode, the display screen is changed to the first to Kth screens for the first to Kth players (K is an integer of 2 or more). The first to Kth images of the frame buffer corresponding to the first to Kth screens are divided and the drawing unit displays the first to Kth images that should be seen from the viewpoints of the first to Kth players in the object space. You may make it draw in the drawing area of K.
[0010]
In such a method of dividing the display screen and displaying an image that should be seen from the viewpoint of each player on the divided screen, the load of the drawing process increases as the number of players increases. However, in the present invention, even in such a case, drawing processing is performed every cycle N × T, so that a high-quality image can be generated.
[0011]
The screen division mode of the present invention is not limited to the mode in which the display screen is divided for the multiplayer game as described above.
[0012]
In addition, the image generation system, the program, and the information storage medium according to the present invention include a movement processing unit that obtains movement information of a moving object and performs a process of moving the moving object in the object space (a program that functions as the movement processing unit). (Or an information storage medium storing the program), and the movement processing unit obtains the movement information of the moving object even when the drawing area is rewritten every cycle N × T in the screen division mode. The processing may be performed every period T.
[0013]
In this way, even when the rewriting of the drawing area is performed every cycle N × T, the movement process is performed every cycle T, and the calculation accuracy of the movement process can be maintained. Further, even when the drawing cycle of the drawing area changes, it is not necessary to change the processing content (program) of the movement process.
[0014]
In the image generation system, the program, and the information storage medium according to the present invention, the frame buffer has the first to Nth drawing areas, and the drawing unit sets the first to Nth drawing areas as the first to Nth drawing areas. The entire drawing area may be rewritten every period N × T by sequentially rewriting the drawing areas every period T.
[0015]
According to the present invention, the first drawing area is rewritten, then the second drawing area is rewritten, and then the Nth drawing area is rewritten every period T, so that N drawing areas are rewritten sequentially (drawn sequentially). Thereby, the process which rewrites all the drawing areas for every period NxT is realizable.
[0016]
In the image generation system, the program, and the information storage medium according to the present invention, in the screen division mode, the display screen is changed to the first to Kth screens for the first to Kth players (K is an integer of 2 or more). The first to Kth images of the frame buffer corresponding to the first to Kth screens are divided and the drawing unit displays the first to Kth images that should be seen from the viewpoints of the first to Kth players in the object space. The drawing may be performed in a K drawing area, and a boundary of the first to Nth drawing areas may coincide with a part or all of a boundary of the first to Kth drawing areas.
[0017]
In this way, a part or all of the boundaries of the first to Kth screens coincide with the boundaries of the first to Nth drawing areas, and the display object is displaced at the boundary. Can be prevented.
[0018]
In the image generation system, the program, and the information storage medium according to the present invention, the frame buffer includes a drawing area and a display area, and the drawing unit includes the frame image of the odd scan line and the even scan line of the drawing area of the frame buffer. Any one of the frame images may be copied to the display area of the frame buffer alternately every period T.
[0019]
In this way, for example, in the case of the interlace scanning method, the size of the display area of the frame buffer can be reduced, and the memory capacity can be saved.
[0020]
In the image generation system, the program, and the information storage medium according to the present invention, when the drawing unit rewrites the drawing area every cycle N × T, the drawing unit rewrites the drawing region every cycle T. Thus, a higher-definition frame image may be drawn in the drawing area.
[0021]
In addition, the present invention is an image generation system that performs image generation, a geometry processing unit that performs geometry processing on an object, and a frame image including an image of the object after geometry processing is rendered in a rendering area of a frame buffer, A drawing unit that rewrites the drawing area every period T. The drawing part rewrites the drawing area every period T in the first mode, and every period N × T (N is The present invention relates to an image generation system that rewrites a drawing area to an integer of 2 or more and draws a higher-definition frame image in the drawing area as compared with the case where the drawing area is rewritten every period T. The present invention also relates to a program that causes a computer to function as each of the above-described units. The present invention also relates to a computer-readable information storage medium that stores (records) a program that causes a computer to function as each unit.
[0022]
According to the present invention, in the first mode, the drawing area (all drawing areas) is rewritten every period T (the drawing area update period is T). On the other hand, in the second mode, the drawing area (all drawing areas) is rewritten every cycle N × T (the drawing region update cycle is N × T). In the second mode, high-definition drawing processing is performed as compared with the first mode. Therefore, although the drawing cycle becomes longer, the definition of the drawn frame image can be improved.
[0023]
DETAILED DESCRIPTION OF THE INVENTION
Hereinafter, the present embodiment will be described with reference to the drawings.
[0024]
In addition, this embodiment demonstrated below does not unduly limit the content of this invention described in the claim. In addition, all the configurations described in the present embodiment are not necessarily essential configuration requirements of the present invention.
[0025]
1. Constitution
FIG. 1 shows an example of a functional block diagram of an image generation system (game system) of the present embodiment. Note that the image generation system according to the present embodiment does not need to include all the components (respective parts) in FIG. 1 and omits some of them (for example, the
[0026]
The
[0027]
The
[0028]
The information storage medium 180 (computer-readable medium) stores programs, data, and the like, and functions as an optical disk (CD, DVD), magneto-optical disk (MO), magnetic disk, hard disk, and magnetic tape. Alternatively, it can be realized by hardware such as a memory (ROM). The
[0029]
The
[0030]
The
[0031]
The portable
[0032]
The
[0033]
Note that a program (data) for causing a computer to function as each unit of this embodiment is distributed from the information storage medium of the host device (server) to the information storage medium 180 (storage unit 170) via the network and the
[0034]
The processing unit 100 (processor) performs various processes such as a game process, an image generation process, and a sound generation process based on operation data from the
[0035]
The game process performed by the
[0036]
The
[0037]
The
[0038]
Modes set by the
[0039]
The movement processing unit 112 (simulation calculation unit) performs processing for obtaining movement information (position information, direction information, speed information, or acceleration information) of the moving object (object). That is, a process of moving the moving object in the object space is performed based on operation data input by the player through the
[0040]
More specifically, the
[0041]
Pk = Pk-1 + ΔP (1)
θk = θk-1 + △ θ (2)
Note that the processing performed by the
[0042]
The motion processing unit 114 (simulation calculation unit) performs processing for obtaining motion information of the moving object (position information and direction information of each part of the moving object). That is, based on operation data input by the player through the
[0043]
More specifically, the
[0044]
The
[0045]
The
[0046]
In the present embodiment, the
[0047]
The screen division mode is set by the
[0048]
In addition, the
[0049]
The
[0050]
Note that the image generation system of the present embodiment may be a system dedicated to the single player mode in which only one player can play, or not only the single player mode but also a multiplayer mode in which a plurality of players can play. The system may also be provided.
[0051]
Further, when a plurality of players play, game images and game sounds to be provided to the plurality of players may be generated using one terminal, or connected via a network (transmission line, communication line) or the like. Alternatively, it may be generated using a plurality of terminals (game machine, mobile phone).
[0052]
2. Method of this embodiment
Next, the method of this embodiment will be described with reference to the drawings.
[0053]
2.1 Drawing cycle control according to the number of screen divisions
In the present embodiment, the rendering cycle (frame rate) is controlled according to the number of screen divisions.
[0054]
FIG. 2A shows an example of a game image in the normal mode in which the display screen SC (screen of the display unit) is not divided. While watching the game image displayed on the display screen SC, the player operates the moving object MOB (car or the like) using the operation unit to run on the course. The display screen SC displays an image (frame image) that can be seen from the viewpoint of the player in the object space (virtual three-dimensional space).
[0055]
On the other hand, FIG. 2B shows an example of a game image in the screen division mode in which the display screen is divided into a plurality of screens. In FIG. 2B, the display screen SC is displayed on screens SC1, SC2, SC3, and SC4 for first, second, third, and fourth players (hereinafter referred to as 1P, 2P, 3P, and 4P players as appropriate). It is divided.
[0056]
As shown in FIG. 3, these screens SC1 to SC4 (first to Kth screens in a broad sense) have viewpoints of 1P to 4P players (first to Kth players in a broad sense) in the object space. Images visible from VP1 to VP4 are displayed. That is, images (first to Kth images, perspective transformation images) that should be seen from the viewpoint of the 1P to 4P player in the object space are drawn in the drawing areas DR1 to DR4 of the frame buffer corresponding to the screens SC1 to SC4. .
[0057]
Then, the 1P to 4P player operates the moving objects MOB1 to MOB4 using the operation unit while viewing the images (images for the 1P to 4P player) displayed on these screens SC1 to SC4, so that the multiplayer game (competition) Enjoy games, battle games, cooperative games).
[0058]
Now, in the screen division mode shown in FIG. 2 (B), moving objects MOB1 to MOB4 for 1P to 4P players and backgrounds such as maps, buildings, and sky must be displayed on the screens SC1 to SC4. That is, in FIG. 2B, it is necessary to draw four sets of display objects having the same drawing data amount as in FIG. Therefore, the drawing processing load is about four times that of FIG. For this reason, it has been found that even if the amount of drawing data is reduced by a technique such as LOD, drawing processing may not be completed within one frame period T (for example, 1/60 seconds).
[0059]
Therefore, in this embodiment, a method of variably controlling the drawing cycle (frame rate) according to the number of screen divisions is adopted.
[0060]
Specifically, as shown in FIG. 4, in the normal mode (FIG. 2A), rewriting of the drawing area of the frame buffer (rewriting of image data of all drawing areas is performed at every cycle T (frame period). Start rewriting the area). That is, the drawing area is rewritten (updated) in all
[0061]
On the other hand, in the screen division mode (FIG. 2B), for example, rewriting of the drawing area (rewriting of image data of all the drawing areas. Rewriting of the drawing area every
[0062]
In this way, in the screen split mode, it is only necessary to complete the drawing area rewriting process (image data drawing process) within the
[0063]
In FIG. 4, the drawing cycle in the normal mode is T, and the drawing cycle in the four-screen split mode is 2T. However, the setting of N of the drawing cycle N × T is arbitrary. For example, the drawing cycle may be switched from T to 2T when the two-screen split mode or the three-screen split mode is entered. Alternatively, N = 2 can be set in the two-screen split mode, and N> 3 can be set in the three-screen split mode or higher.
[0064]
The frame period T is determined based on the vertical synchronization interrupt (vertical synchronization signal) of the display unit. Specifically, the frame period T is a period from when the first pulse of the vertical synchronization interrupt (VSYNC) becomes active until the next second pulse becomes active. For example, when the frame rate FPS (Frame Per Second) is 60, T = 1/60 seconds. Therefore, when the drawing area is updated every cycle T, the drawing area is updated once every time the vertical synchronization interrupt becomes active, and when the drawing area is updated every cycle N × T, the vertical synchronization is performed. Every time the interrupt becomes active N times, the drawing area is updated once.
[0065]
2B and FIG. 3, the example in which the display screen is divided for each player of the multiplayer game has been described, but the screen division mode of the present embodiment is not limited to this. For example, the principle of the present embodiment can be applied to a screen division mode in which a sub screen (an image displayed on a rearview mirror or an image seen through an optical device such as a binocular or a scope is displayed) and a main screen are divided. Is applicable.
[0066]
2.2 Moving processing of moving objects
In the present embodiment, as shown in FIG. 4, the drawing cycle (frame rate) is changed according to the number of screen divisions. However, on the other hand, the cycle of the moving process of the moving object (simulation process, parameter numerical calculation process, operation data receiving process, operation process) is constant regardless of the number of screen divisions.
[0067]
More specifically, as shown by A1 in FIG. 5, movement information (position, direction, speed, acceleration, etc.) of the moving object MOB is obtained based on operation data from the operation unit, and the MOB is moved in the object space. The processing to be performed is performed every frame period T, for example. That is, the moving object MOB positions P1, P2, P3, P4, P5... And directions (angles) D1, D2, D3, D4, D5. It is obtained by simulation calculation (numerical calculation) according to a predetermined algorithm. For example, the position P2 in the
[0068]
On the other hand, as shown by A2 in FIG. 5, the rewriting of the drawing area (drawing in the drawing area) is performed every
[0069]
In this way, the moving process of the moving object MOB is performed every short cycle T, and therefore accurate numerical calculation is possible. Therefore, it is possible to prevent a situation in which the movement of the moving object MOB becomes unnatural or the numerical calculation error becomes too large. On the other hand, since the rewriting of the drawing area is performed every 2T, the time for drawing processing can be increased and a high-quality image can be generated. Furthermore, the program module for the movement process (simulation process) can be commonly used when the drawing area is rewritten every period T and every
[0070]
Even when the drawing area is rewritten every cycle N × T, the processing desirably performed every cycle T is not limited to the moving processing of the moving object. For example, it is desirable that processing for receiving operation data (processing for sampling), object motion reproduction processing, processing for calculating various parameter values such as status parameters, and the like be performed every period T.
[0071]
2.3 Drawing processing for each divided drawing area
In the present embodiment, first to Nth drawing areas are secured in the frame buffer. Then, by rewriting the first to Nth drawing areas, for example, in the order of the first to Nth drawing areas at every cycle T, the entire drawing area can be rewritten every cycle N × T. Yes.
[0072]
Specifically, as shown in FIG. 6, the upper first drawing area DRA is rewritten in the
[0073]
Although FIG. 6 shows a case where the drawing area of the frame buffer is divided into two, it may be divided into three or more. For example, when the drawing area is divided into first, second, third, and fourth drawing areas, the first drawing area in
[0074]
When a display area (display buffer) is secured in the frame buffer (VRAM) in addition to the drawing area (drawing buffer), the frame buffer drawing area is rewritten before the frame buffer drawing area is rewritten. A frame image (a frame image that has already been rewritten) is copied to the display area. In this case, copying is performed for all frames, for example. Further, the frame image stored in the display area of the frame buffer is displayed on the display unit.
[0075]
In the case of the interlace method, either the odd scan line frame image or the even scan line frame image in the drawing area of the frame buffer is alternately copied to the display area of the frame buffer every period T. .
[0076]
More specifically, as shown in FIG. 7, for example, in
[0077]
That is, in the method of rewriting the entire drawing area every 2T without dividing the drawing area, the display area needs to hold a frame image for a period of 2T. It must be set to the same size as the drawing area.
[0078]
On the other hand, in the methods shown in FIGS. 6 and 7, since only the DRA or DRB that is a half of the entire drawing area needs to be rewritten, the rewriting can be completed within the period T. Therefore, even if the frame image is copied from the drawing area to the display area every period T, there is no problem that the image being drawn is copied. Therefore, even if the size of the display area is set to half of the drawing area, the above-described problem does not occur, and the display area is compared with the method in which the entire drawing area is rewritten every 2T without dividing the drawing area. Can be reduced in size and memory capacity can be saved.
[0079]
When drawing processing is performed with the drawing area divided as shown in FIG. 6, the boundary of the divided drawing area and the boundary of the divided screen (drawing area corresponding to the divided screen) are at least partially matched. It is desirable.
[0080]
Specifically, as shown in FIG. 8A, the drawing areas DR1 to DR4 (first to Kth drawing) corresponding to the divided screens SC1 to SC4 (first to Kth screens) in FIG. 2B. The boundary BD13 in the region) and the boundary BDAB of the upper half drawing area DRA and the lower half drawing area DRB (first to Nth drawing areas) that are alternately rewritten by the method of FIG. Alternatively, when the left half drawing area DRC and the right half drawing area DRD are rewritten alternately, as shown in FIG. 8B, the boundary BD12 in the drawing areas DR1 to DR4 and the boundary between the drawing areas DRC and DRD Match with BDCD.
[0081]
In this way, for example, as shown in FIG. 8C, it is possible to prevent a situation in which a display object is displaced at the boundary BD13 (BDAB) and the quality of the image is lowered. That is, according to the method of FIG. 8A, the boundary BDAB of the drawing areas DRA, DRB coincides with the boundary BDSC (BD13) of the divided screens SC1, SC2, SC3, and SC4 of FIG. . Since game images of different players are displayed on the upper side and the lower side of the boundary BDSC, the displacement of the display object as shown in FIG. 8C does not originally become a problem. Therefore, it is possible to prevent a situation where the quality of the image is lowered due to the displacement of the display object, and it is possible to generate a high quality image.
[0082]
2.4 Trade-off with LOD
The technique of rewriting the drawing area for each cycle N × T can also be used as a trade-off with LOD.
[0083]
For example, as shown in FIG. 9, in the first mode, the drawing area is rewritten every period T. On the other hand, in the second mode, the drawing area is rewritten every
[0084]
That is, in the first mode, drawing processing is performed with normal definition, so that the drawing processing can be completed within the period T even if the drawing area is rewritten in synchronization with the period T (frame period). . On the other hand, in the second mode, since the drawing process is performed with high definition, the drawing process may not be completed within the period T. However, in the method of FIG. 9, in the second mode, it is only necessary to complete the rewriting of the drawing area within the
[0085]
Therefore, for example, when priority is given to the speed of the frame rate over the definition of the frame image, the drawing process is performed in the first mode. On the other hand, when priority is given to the definition of the frame image over the speed of the frame rate, the drawing process is performed in the second mode. In this way, various selection options can be given to the player, and the variety of generated images can be increased.
[0086]
There are various methods for controlling the definition of the frame image. For example, as shown in FIG. 10A, the fineness of the drawing process may be controlled by changing the number of polygons of the moving object (the number of primitive surfaces in a broad sense). For example, a moving object with a small number of polygons is used in the first mode, and a moving object with a large number of polygons is used in the second mode.
[0087]
In addition, as shown in FIG. 10B, the definition of the drawing process may be controlled by changing the number of divisions of the map (the map representing the terrain). For example, a map with a small number of divisions is used in the first mode, and a map with a large number of divisions is used in the second mode.
[0088]
Further, the definition of the drawing process may be controlled by changing the number of objects (display objects) displayed on the display screen. For example, in the first mode, the number of appearing objects is reduced, and in the second mode, the number of objects is increased.
[0089]
Further, the fineness of the drawing process may be controlled by changing the type of texture mapped to the object. For example, in the first mode, a normal definition texture is mapped to an object, and in the second mode, a high definition texture is mapped to an object.
[0090]
In addition, the rendering method may be changed to control the definition of the drawing process. For example, in the first mode, a rendering method capable of generating a normal-definition frame image is employed, and in the second mode, a rendering method capable of generating a high-definition frame image is employed. More specifically, for example, rendering is performed with a Gouraud shading illumination model in the first mode, and rendering is performed with a von shading illumination model in the second mode. Alternatively, in the first mode, the shading process is performed with a normal number of light sources, and in the second mode, the shading process is performed with an increased number of light sources. Alternatively, a shadow generation algorithm with a low processing load is employed in the first mode, and a shadow generation algorithm capable of generating a real shadow with a high processing load is employed in the second mode.
[0091]
The switching between the first and second modes may be performed by the player selecting on the mode setting screen, or depending on the progress of the game, the game scene, the content of the game, etc. ) May be switched automatically.
[0092]
3. Processing of this embodiment
Next, a detailed example of the processing of this embodiment will be described using the flowcharts of FIGS.
[0093]
FIG. 11 is a flowchart for realizing processing for changing the drawing cycle in accordance with the number of screen divisions.
[0094]
First, the number of players is set (step S1). Then, i is set to 0 (step S2). Then, it is determined whether or not the number of players is 3 to 4 (step S3). In the case of 3 to 4 people (3 to 4 screen divisions), N is set to 2 and 1 to 2 people (no screen division). In the case of two screen division), N = 1 is set (steps S4 and S5).
[0095]
Next, it is determined whether i is 0 (step S6). If i is 0, the frame image (image data) is copied from the drawing area of the frame buffer to the display area (step S7). On the other hand, if i is not 0, the process of step S7 is omitted.
[0096]
Next, the moving process of moving objects described in FIG. 5 (simulation process for calculating numerical parameters in units of one frame) is performed (step S8).
[0097]
Next, it is determined whether i is 0 (step S9). If i is 0, the drawing / rewriting process for all the drawing areas is performed (step S10). On the other hand, if i is not 0, the process of step S10 is omitted.
[0098]
Next, i is incremented to i + 1 (step S11). Then, it is determined whether N is equal to i (step S12). If i is equal, i is set to 0 (step S13). Then, other processing is performed (step S14).
[0099]
Then, it is determined whether or not the next frame has started (step S15). For example, if a vertical synchronization interrupt has occurred, it can be determined that the next frame has started. If the next frame has started, it is determined whether or not the game is over (step S16). If the game is not over, the process returns to step S6.
[0100]
According to the processing of FIG. 11, when the screen is divided into three or four screens, for example, the copy and drawing / rewriting process of steps S7 and S10 is performed in the first frame (odd frame), and step S7 is performed in the next frame (even frame). , The copy and drawing / rewriting process of S10 is not performed. On the other hand, in the case of no screen division or two-screen division, the copy and drawing / rewriting processes in steps S7 and S10 are performed in any frame. Thereby, the method described in FIG. 4 can be realized.
[0101]
FIG. 12 is a flowchart for realizing the processing described in FIG.
[0102]
First, the number of players is set (step S21). Then, i is set to 2 (step S22).
[0103]
Next, the frame image is copied from the drawing area of the frame buffer to the display area (step S23). Then, the moving object moving process (simulation process) described in FIG. 5 is performed (step S24).
[0104]
Next, it is determined whether or not the number of players is 3 to 4 (step S25). If the number of players is 1 to 2 (no screen splitting, 2 screen splitting), drawing / rewriting processing for all drawing areas is performed. This is performed (step S26).
[0105]
On the other hand, in the case of 3 to 4 persons (3 to 4 screen divisions), it is determined whether i is 1 (step S27). If i is 1, the drawing / rewriting process of the upper first drawing area (DRA) is performed (step S28). On the other hand, if i is not 1, drawing / rewriting processing of the lower second drawing area (DRB) is performed (step S29).
[0106]
Next, i is decremented to i-1 (step S30), and it is determined whether i is 0 (step S31). If i is 0, i is reset to 2 (step S32). On the other hand, if i is not 0, the process of step S32 is omitted.
[0107]
Next, other processing is performed (step S33). Then, it is determined whether or not the next frame has started (step S34). If the next frame has started, it is determined whether or not the game is over (step S35). If the game is not over, the process returns to step S23.
[0108]
According to the processing of FIG. 12, when the screen is divided into three or four screens, for example, in the first frame (odd frame), the drawing / rewriting process of the first drawing area in step S28 is performed, and the next frame (even frame). Then, the drawing / rewriting process of the second drawing area in step S29 is performed. On the other hand, in the case of no screen division or two-screen division, the drawing / rewriting process of the entire screen area in step S26 is performed in any frame. Thereby, the method described in FIG. 6 can be realized.
[0109]
FIG. 13 is a flowchart for realizing the processing described in FIG.
[0110]
First, i is set to 0 (step S41). A frame rate (rendering cycle) is set (step S42).
[0111]
Next, it is determined whether or not the set frame rate is 30 FPS (Frame Per Second) (step S43). If the frame rate is 30 FPS, N is set to 2 (step S44). On the other hand, if the frame rate is 60 FPS, N is set to 1 (step S45).
[0112]
Next, it is determined whether or not i is 0 (step S46). If i is 0, copying from the drawing area of the frame buffer to the display area is performed (step S47). On the other hand, if i is not 0, the process of step S47 is omitted.
[0113]
Next, a movement process (simulation process) is performed (step S48). Then, it is determined whether i is 0 (step S49). If i is 0, it is determined whether N is 1 (step S50). If N is 1, the drawing area is drawn and rewritten by a drawing process with normal definition (step S51). On the other hand, if N is not 1, the drawing area is drawn and rewritten by high-definition drawing processing (step S52). If i is not 0, the processes of steps S50, S51, and S52 are omitted.
[0114]
Next, i is incremented to i + 1 (step S53). Then, it is determined whether N is equal to i (step S54). If equal, i is set to 0 (step S55). On the other hand, if they are not equal, the process of step S55 is omitted.
[0115]
Next, other processing is performed (step S56). Then, it is determined whether or not the next frame has started (step S57). If the next frame has started, it is determined whether or not the game is over (step S58). If the game is not over, the process returns to step S46.
[0116]
According to the process of FIG. 13, when the frame rate is 30 FPS (in the second mode), for example, in the first frame (odd frame), the high-definition drawing / rewriting process in step S52 is performed. In this frame (even frame), the drawing / rewriting process in step S52 is not performed. On the other hand, when the frame rate is 60 FPS (in the first mode), the normal definition drawing / rewriting process in step S51 is performed in any frame. Thereby, the method described in FIG. 9 can be realized.
[0117]
4). Hardware configuration
Next, an example of a hardware configuration capable of realizing the present embodiment will be described with reference to FIG.
[0118]
The
[0119]
The
[0120]
The
[0121]
The
[0122]
The drawing
[0123]
The
[0124]
Operation data from the game controller 942 (lever, button, chassis, pad type controller, gun type controller, etc.), save data from the
[0125]
The
[0126]
The
[0127]
The
[0128]
The CD drive 980 drives a CD 982 (information storage medium) in which programs, image data, sound data, and the like are stored, and enables access to these programs and data.
[0129]
The
[0130]
Note that all the units (units) of the present embodiment may be realized only by hardware, or only by a program stored in an information storage medium or a program distributed via a communication interface. May be. Alternatively, it may be realized by both hardware and a program.
[0131]
And when each part of this embodiment is implement | achieved by both hardware and a program, the program for functioning hardware (computer) as each part of this embodiment is stored in an information storage medium. Become. More specifically, the program instructs each
[0132]
FIG. 15A shows an example in which the present embodiment is applied to an arcade game system (image generation system). The player enjoys the game by operating the operation unit 1102 (lever, button) while watching the game image displayed on the
[0133]
FIG. 15B shows an example in which the present embodiment is applied to a home game system (image generation system). The player enjoys the game by operating the
[0134]
FIG. 15C shows a
[0135]
In the case of the configuration of FIG. 15C, each unit of the present embodiment may be realized by being distributed between a host device (server) and a terminal. Further, the storage program (storage information) for realizing each unit of the present embodiment may be distributed and stored in the information storage medium of the host device (server) and the information storage medium of the terminal.
[0136]
The terminal connected to the network may be a home game system or an arcade game system.
[0137]
The present invention is not limited to that described in the above embodiment, and various modifications can be made.
[0138]
For example, broad terms in the description or drawings (first to Kth screens, first to Kth players, N × T, primitive surface, simulation processing, first to Nth drawing areas, etc.) Terms (screens SC1 to SC4, 1P to 4P players, 2T, polygons, movement processing, drawing area DRA / DRB, etc.) may be replaced with broad terms in the specification or other descriptions in the drawings. it can.
[0139]
Further, the number of divisions of the screen and the drawing area and the way of division are not limited to those described in the present embodiment, and various modifications can be made.
[0140]
The order and method of the drawing process (rewrite process) and the copy process are not limited to those described in the present embodiment, and various modifications can be made.
[0141]
In the invention according to the dependent claims of the present invention, a part of the constituent features of the dependent claims can be omitted. Moreover, the principal part of the invention according to one independent claim of the present invention can be made dependent on another independent claim.
[0142]
Further, the present invention can be applied to various games (such as fighting games, competitive games, shooting games, robot battle games, sports games, role playing games, etc.).
[0143]
The present invention is also applicable to various image generation systems (game systems) such as a business game system, a home game system, a large attraction system in which a large number of players participate, a simulator, a multimedia terminal, and a system board for generating game images. Applicable.
[Brief description of the drawings]
FIG. 1 is a functional block diagram of an image generation system according to an embodiment.
FIGS. 2A and 2B are explanatory diagrams of a screen division mode.
FIG. 3 is an explanatory diagram of an image generation method in a screen division mode.
FIG. 4 is an explanatory diagram of a method of changing a frame rate according to the number of screen divisions.
FIG. 5 is an explanatory diagram of movement processing (simulation processing).
FIG. 6 is an explanatory diagram of a technique for dividing and rewriting a drawing area.
FIG. 7 is an explanatory diagram of a copy method in the case of an interlace scanning method.
FIGS. 8A, 8B, and 8C are explanatory diagrams of a technique for matching boundaries.
FIG. 9 is an explanatory diagram of a method of changing a frame rate according to the definition of rendering processing.
FIGS. 10A and 10B are explanatory diagrams of a technique for changing the drawing definition. FIGS.
FIG. 11 is a flowchart example of processing of the present embodiment.
FIG. 12 is a flowchart example of processing of the present embodiment.
FIG. 13 is an example of a flowchart of processing of the present embodiment.
FIG. 14 is a hardware configuration example.
FIGS. 15A to 15C show examples of various forms of systems.
[Explanation of symbols]
100 processing unit, 110 mode setting unit, 112 movement processing unit,
114 motion processing units, 116 geometry processing units, 120 drawing units,
130 sound generation unit, 160 operation unit, 170 storage unit, 172 main storage unit,
174 frame buffer, 180 information storage medium, 190 display unit
192 sound output unit, 194 portable information storage device, 196 communication unit
Claims (11)
オブジェクト空間に配置された視点を基準としてオブジェクトに対してジオメトリ処理を施すジオメトリ処理部と、
ジオメトリ処理後のオブジェクトの画像を含むフレーム画像をフレームバッファの描画領域に描画することによって、周期T毎に描画領域の書き換えを行う描画部とを含み、
表示画面が複数の分割画面に分割される画面分割モード時に、オブジェクト空間に各分割画面に対応する複数の視点が配置され、
前記描画部が、
前記画面分割モード時に、前記フレームバッファを前記複数の分割画面に対応させて分割した複数の分割描画領域を所定の順序で書き換え対象として設定し、周期T毎に前記所定の順序で書き換え対象を変更しながら、前記複数の視点のうち書き換え対象の分割描画領域に対応する視点から見えるべきフレーム画像を、書き換え対象の分割描画領域に対して描画することによって、周期N×T毎(Nは2以上の整数)に全ての分割描画領域の書き換えを行うことを特徴とする画像生成システム。An image generation system for generating an image,
A geometry processing unit that performs geometry processing on an object based on a viewpoint arranged in the object space ;
A drawing unit that rewrites the drawing area every period T by drawing a frame image including an image of the object after geometry processing in the drawing area of the frame buffer;
In the split screen mode where the display screen is split into multiple split screens, multiple viewpoints corresponding to each split screen are placed in the object space,
The drawing unit
In the screen division mode, a plurality of divided drawing areas obtained by dividing the frame buffer so as to correspond to the plurality of divided screens are set as rewrite targets in a predetermined order, and the rewrite targets are changed in the predetermined order every period T. However, a frame image that should be seen from a viewpoint corresponding to the divided drawing area to be rewritten among the plurality of viewpoints is drawn on the divided drawing area to be rewritten, so that every cycle N × T (N is 2 or more) An image generation system characterized by rewriting all the divided drawing areas.
移動オブジェクトの移動情報を求め、移動オブジェクトをオブジェクト空間内で移動させるシミュレーション処理を行う移動処理部を含み、
前記移動処理部が、
前記画面分割モード時に周期N×T毎に全ての分割描画領域の書き換えが行われている場合にも、前記シミュレーション処理を周期T毎に行うことを特徴とする画像生成システム。In claim 1 ,
It includes a movement processing unit that performs a simulation process for obtaining movement information of the moving object and moving the moving object in the object space.
The movement processing unit is
The screen when the rewriting of all the divided drawing area for each period N × T to divide mode is being performed also, image generation system characterized by performing the simulation processing for each period T.
前記複数の分割描画領域の境界が前記複数の分割画面の境界の一部又は全部と一致するように、前記フレームバッファの描画領域が前記複数の分割描画領域に分割されていることを特徴とする画像生成システム。In claim 1 or 2 ,
The drawing area of the frame buffer is divided into the plurality of divided drawing areas so that boundaries of the plurality of divided drawing areas coincide with some or all of the boundaries of the plurality of divided screens. Image generation system.
フレームバッファが描画領域と表示領域を有し、
前記描画部が、
フレームバッファの描画領域の奇数走査ラインのフレーム画像と偶数走査ラインのフレーム画像のいずれか一方を、周期T毎に交互に、フレームバッファの表示領域にコピーすることを特徴とする画像生成システム。In any one of Claims 1 thru | or 3 ,
The frame buffer has a drawing area and a display area,
The drawing unit
An image generation system, wherein either one of a frame image of an odd-numbered scan line or a frame image of an even-numbered scan line in a drawing area of a frame buffer is copied to a display area of a frame buffer alternately every period T.
前記描画部が、
フレームバッファの描画領域を複数の分割描画領域に分割して周期N×T毎に当該描画領域の書き換えを行う場合には、フレームバッファの描画領域を分割せずに周期T毎に当該描画領域の書き換えを行う場合に比べて精細度を高めた画像を前記複数のフレーム画像として前記複数の分割描画領域に描画することを特徴とする画像生成システム。In any one of Claims 1 thru | or 4 ,
The drawing unit
When performed by dividing the drawing area of the frame buffer into a plurality of divided drawing area for each period N × T rewriting of the drawing area, every period T without dividing the drawing area of the frame buffer of the drawing area An image generation system characterized in that an image with higher definition than that in the case of rewriting is drawn in the plurality of divided drawing areas as the plurality of frame images .
オブジェクト空間に配置された視点を基準としてオブジェクトに対してジオメトリ処理を施すジオメトリ処理部と、
ジオメトリ処理後のオブジェクトの画像を含むフレーム画像をフレームバッファの描画領域に描画することによって、周期T毎に描画領域の書き換えを行う描画部として、
コンピュータを機能させると共に、
表示画面が複数の分割画面に分割される画面分割モード時に、オブジェクト空間に各分割画面に対応する複数の視点が配置され、
前記描画部が、
前記画面分割モード時に、前記フレームバッファを前記複数の分割画面に対応させて分割した複数の分割描画領域を所定の順序で書き換え対象として設定し、周期T毎に前記所定の順序で書き換え対象を変更しながら、前記複数の視点のうち書き換え対象の分割描画 領域に対応する視点から見えるべきフレーム画像を、書き換え対象の分割描画領域に対して描画することによって、周期N×T毎(Nは2以上の整数)に全ての分割描画領域の書き換えを行うことを特徴とするプログラム。A program for generating an image,
A geometry processing unit that performs geometry processing on an object based on a viewpoint arranged in the object space ;
As a drawing unit that rewrites the drawing area every period T by drawing a frame image including the image of the object after geometry processing in the drawing area of the frame buffer,
Make the computer work,
In the split screen mode where the display screen is split into multiple split screens, multiple viewpoints corresponding to each split screen are placed in the object space,
The drawing unit
In the screen division mode, a plurality of divided drawing areas obtained by dividing the frame buffer so as to correspond to the plurality of divided screens are set as rewrite targets in a predetermined order, and the rewrite targets are changed in the predetermined order every period T. However, a frame image that should be seen from the viewpoint corresponding to the divided drawing area to be rewritten among the plurality of viewpoints is drawn on the divided drawing area to be rewritten, so that every cycle N × T (N is 2 or more) A program characterized by rewriting all divided drawing areas.
移動オブジェクトの移動情報を求め、移動オブジェクトをオブジェクト空間内で移動させるシミュレーション処理を行う移動処理部としてコンピュータを機能させると共に、
前記移動処理部が、
前記画面分割モード時に周期N×T毎に全ての分割描画領域の書き換えが行われている場合にも、前記シミュレーション処理を周期T毎に行うことを特徴とするプログラム。In claim 6 ,
While obtaining the movement information of the moving object and causing the computer to function as a movement processing unit that performs a simulation process of moving the moving object in the object space,
The movement processing unit is
The screen when the rewriting of all the divided drawing area are performed every cycle N × T to divide mode also, the program and performs the simulation processing for each period T.
前記複数の分割描画領域の境界が前記複数の分割画面の境界の一部又は全部と一致するように、前記フレームバッファの描画領域が前記複数の分割描画領域に分割されていることを特徴とするプログラム。In claim 6 or 7 ,
The drawing area of the frame buffer is divided into the plurality of divided drawing areas so that boundaries of the plurality of divided drawing areas coincide with some or all of the boundaries of the plurality of divided screens. program.
フレームバッファが描画領域と表示領域を有し、
前記描画部が、
フレームバッファの描画領域の奇数走査ラインのフレーム画像と偶数走査ラインのフレーム画像のいずれか一方を、周期T毎に交互に、フレームバッファの表示領域にコピーすることを特徴とするプログラム。In any of claims 6 to 8 ,
The frame buffer has a drawing area and a display area,
The drawing unit
A program for copying either a frame image of an odd-numbered scan line or a frame image of an even-numbered scan line in a drawing area of a frame buffer alternately to a display area of a frame buffer every period T.
前記描画部が、
フレームバッファの描画領域を複数の分割描画領域に分割して周期N×T毎に当該描画領域の書き換えを行う場合には、フレームバッファの描画領域を分割せずに周期T毎に当該描画領域の書き換えを行う場合に比べて精細度を高めた画像を前記複数のフレーム画像として前記複数の分割描画領域に描画することを特徴とするプログラム。In any one of Claims 6 thru | or 9 .
The drawing unit
When performed by dividing the drawing area of the frame buffer into a plurality of divided drawing area for each period N × T rewriting of the drawing area, every period T without dividing the drawing area of the frame buffer of the drawing area A program characterized in that an image with a higher definition than in the case of rewriting is drawn in the plurality of divided drawing areas as the plurality of frame images .
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2002329814A JP3990258B2 (en) | 2002-11-13 | 2002-11-13 | Image generation system, program, and information storage medium |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2002329814A JP3990258B2 (en) | 2002-11-13 | 2002-11-13 | Image generation system, program, and information storage medium |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2006340101A Division JP4447000B2 (en) | 2006-12-18 | 2006-12-18 | Image generation system, program, and information storage medium |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2004159922A JP2004159922A (en) | 2004-06-10 |
JP3990258B2 true JP3990258B2 (en) | 2007-10-10 |
Family
ID=32807708
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2002329814A Expired - Fee Related JP3990258B2 (en) | 2002-11-13 | 2002-11-13 | Image generation system, program, and information storage medium |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3990258B2 (en) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP5183923B2 (en) * | 2006-12-28 | 2013-04-17 | 株式会社三共 | Game machine |
JP2009000288A (en) * | 2007-06-21 | 2009-01-08 | Aruze Corp | Game system |
JP2012085876A (en) * | 2010-10-20 | 2012-05-10 | Sony Computer Entertainment Inc | Image processing system, image processing method, program, and information storage medium |
JP5724575B2 (en) * | 2011-04-20 | 2015-05-27 | 株式会社セガ | GAME PROGRAM, GAME SYSTEM, GAME DEVICE, AND STORAGE MEDIUM |
JP5951957B2 (en) | 2011-10-27 | 2016-07-13 | 任天堂株式会社 | GAME SYSTEM, GAME DEVICE, GAME PROGRAM, AND GAME PROCESSING METHOD |
JP2014018491A (en) * | 2012-07-19 | 2014-02-03 | Sankyo Co Ltd | Game machine |
JP5444446B2 (en) * | 2012-12-11 | 2014-03-19 | 株式会社三共 | Game machine |
JP2013128777A (en) * | 2013-01-21 | 2013-07-04 | Universal Entertainment Corp | Game system |
JP6837802B2 (en) * | 2016-10-12 | 2021-03-03 | 株式会社コーエーテクモゲームス | Game programs and recording media |
US10950010B2 (en) | 2019-01-15 | 2021-03-16 | Square Enix Ltd. | Dynamic levels of destructive detail in electronic game display |
-
2002
- 2002-11-13 JP JP2002329814A patent/JP3990258B2/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JP2004159922A (en) | 2004-06-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3668019B2 (en) | Recording medium, image processing apparatus, and image processing method | |
JP4610747B2 (en) | Image generation system, program, and information storage medium | |
US8072458B2 (en) | Storage medium having game program stored thereon and game apparatus | |
JP3990258B2 (en) | Image generation system, program, and information storage medium | |
JP4447000B2 (en) | Image generation system, program, and information storage medium | |
JP4749198B2 (en) | Program, information storage medium, and image generation system | |
JP2002216158A (en) | Image generation system, program and information storage medium | |
JP3280355B2 (en) | Image generation system and information storage medium | |
JP4502678B2 (en) | Program, information storage medium, and image generation system | |
JP2006011539A (en) | Program, information storage medium, and image generating system | |
JP4245356B2 (en) | GAME SYSTEM AND INFORMATION STORAGE MEDIUM | |
JP4333889B2 (en) | Image generation system and information storage medium | |
JP2001084402A (en) | Picture generation system and information storage medium | |
JP4544555B2 (en) | GAME SYSTEM AND INFORMATION STORAGE MEDIUM | |
JP4394211B2 (en) | Image generation system and information storage medium | |
JP2003051032A (en) | Game information, information storage medium and game device | |
JP2004038639A (en) | System for generating picture, program and medium for recording information | |
JP4054708B2 (en) | GAME DEVICE AND GAME PROGRAM | |
JP4632855B2 (en) | Program, information storage medium, and image generation system | |
JP4771903B2 (en) | Image generation system, program, and information storage medium | |
JP4391633B2 (en) | Image generation system and information storage medium | |
JP4521811B2 (en) | Program, information storage medium, and image generation system | |
JP2008077406A (en) | Image generation system, program, and information storage medium | |
JP2005209217A (en) | Game system and information storage medium | |
JP2006318196A (en) | Program, information storage medium and image generation system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20051031 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20061018 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20061218 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20070411 |
|
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: 20070704 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20070719 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100727 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 3990258 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100727 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100727 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110727 Year of fee payment: 4 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110727 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120727 Year of fee payment: 5 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120727 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120727 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130727 Year of fee payment: 6 |
|
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 |
|
S533 | Written request for registration of change of name |
Free format text: JAPANESE INTERMEDIATE CODE: R313533 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
R370 | Written measure of declining of transfer procedure |
Free format text: JAPANESE INTERMEDIATE CODE: R370 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
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 |