忍者ブログ
〓 Admin 〓
製作しているゲームの近況や私事など
[12]  [11]  [10]  [9]  [8]  [7]  [6]  [5]  [4]  [3]  [2
×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

2Dゲームで画面を揺らそうと思った時、一時的にテクスチャへ描画し、それを動かして描画するのが一般的ですよね。
XNAでもそのような処理は実装されているのですが、なかなか仕様が分かりづらかったので書き留めておきます。

テクスチャへの書き込みの指定はGameクラスが持っているGraphicDeviceから行います。
targetをRenderTarget2Dクラスとして、
manager.GraphicsDevice.SetRenderTarget(target);

と書くとそのフレームの描画がtargetに対して行われます。

ここで注意すべきなのは、この宣言だけではテクスチャに書き込んだだけでウィンドウに表示されないことです。
ウィンドウにテクスチャを描画するために描画終了後に
Game.GraphicsDevice.SetRenderTarget(null);
sprite.Begin();
sprite.Draw(target, TexturePosition,Color.White);
sprite.End();

としてテクスチャを描画しましょう。
ちなみにspriteはSpriteBatchクラス、TexturePositionはVector2クラスです。
ここでのポイントは最初の行でレンダ対象をnullにしていることですね。
このメソッドの引数をnullにするとウィンドウへの直接描画になります。
レンダ対象になっているテクスチャはDrawメソッドで描画できないので(当然といえば当然ですが。)このように切り替え処理を挟む必要があります。

これでグラフィックをテクスチャに書きこんで表示できるようになりました。
TexturePositionを0,0からずらすと画面ごとずらせているのがわかるかと思います。
そうそう、この処理は全部の描画が終わってから行ってください。
GameComponentを利用している場合は注意が必要かと思います。

では今回はここまで。

PR
この記事にコメントする
お名前
タイトル
文字色
メールアドレス
URL
コメント
パスワード   Vodafone絵文字 i-mode絵文字 Ezweb絵文字
secret (管理人しか読むことができません)
この記事へのトラックバック
この記事にトラックバックする:
カレンダー
12 2025/01 02
S M T W T F S
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
フリーエリア
最新CM
[06/24 ym]
最新TB
プロフィール
HN:
TALE
HP:
性別:
非公開
職業:
ふつーな大学生
趣味:
ゲーム作り・作曲・動画作り等々
バーコード
ブログ内検索
P R
Copyright(c) TalesBlog All Rights Reserved.* Powered by NinjaBlog
* material by Pearl Box * Template by tsukika

忍者ブログ [PR]