「MonoGame/クラスライブラリ/RenderTargetUsage列挙体」の版間の差分

提供: MonoBook
ナビゲーションに移動 検索に移動
35行目: 35行目:
 
</source>
 
</source>
  
ちなみにGraphicsDeviceが最初から持っているレンダリングターゲット([[DirectX]]でいう[[プライマリサーフェイス]]、SetRenterTarget(null))に相当するものはDiscardContentsに設定されている。
+
ちなみにGraphicsDeviceが最初から持っているレンダリングターゲット([[DirectX]]でいう[[プライマリサーフェイス]]、SetRenterTarget(null))に相当するものは問答無用でDiscardContentsに設定されている。
  
 
このため、たとば以下のコードは正常に動作しない。
 
このため、たとば以下のコードは正常に動作しない。

2020年9月15日 (火) 02:45時点における版

RenderTargetUsage列挙体は、グラフィックデバイス(GraphicsDeviceクラス)に新たなレンダリングターゲット(RenderTarget2Dクラス)を設定したとき、そのレンダリングターゲットのデータをどのように処理するかを指定するのに使用する列挙体である。

名前空間

Microsoft.Xna.Framework.Graphics名前空間

構文

public enum RenderTargetUsage

フィールド

概要
DiscardContents 常にレンダリングターゲットのデータを削除する。
PlatformContents プラットフォームに応じて扱いを変える。使うな危険。
PreserveContents 常にレンダリングターゲットのデータを保持する。

備考

PreserveContentsは遅い

PreserveContentsはVRAM容量が少ない環境ではメインメモリへの保存と復元が発生するため絶望的なほど遅くなる。 PCではまず問題になることはないようだが、一部のスマホでは絶望的な速度になるようだ。 なるべくDiscardContentsを使ったほうが良さそうだ。

DiscardContentsの注意点

DiscardContents設定になっていると「GraphicsDevice.SetRenderTargetするたびに破棄(初期化)される」という特徴がある。この特性があるためレンダリング系APIの呼出順序を間違えると残念なことになる。

GraphicsDevice.SetRenderTarget(このRenderTargetは初期化される);

ちなみにGraphicsDeviceが最初から持っているレンダリングターゲット(DirectXでいうプライマリサーフェイス、SetRenterTarget(null))に相当するものは問答無用でDiscardContentsに設定されている。

このため、たとば以下のコードは正常に動作しない。

protected override void Draw(GameTime gameTime)
{
    var gd = _graphics.GraphicsDevice;

    // (1)プライマリサーフェイスを塗りつぶす
    gd.Clear(Color.CornflowerBlue);

    // (2)レンダリングターゲットを切り替える
    gd.SetRenderTarget(new RenderTarget2D(GraphicsDevice, 128, 128));

    // (3)レンダリングターゲットをプライマリサーフェイスに戻す
    // プライマリサーフェイスは問答無用でDiscardContents設定なので
    // 内容はクリアされ(1)の塗りつぶしは無かったことにされる。
    // (2)のレンダーターゲットは影響を受けない。
    gd.SetRenderTarget(null);

    base.Draw(gameTime);
}

DiscardContentsの場合は以下のような呼出順序で書かなければならない。

protected override void Draw(GameTime gameTime)
{
    var gd = _graphics.GraphicsDevice;

    // (1)レンダリングターゲットを切り替える
    gd.SetRenderTarget(new RenderTarget2D(GraphicsDevice, 128, 128));

    // (2)レンダリングターゲットをプライマリサーフェイスに戻す(と同時にまっさらになる)
    // (1)のレンダーターゲットは影響を受けない。
    gd.SetRenderTarget(null);

    // (3)プライマリサーフェイスを塗りつぶす
    gd.Clear(Color.CornflowerBlue);

    base.Draw(gameTime);
}

関連項目