Sương mù BasicEffect
tóm tắt
Thao tác các tham số liên quan đến phần sương mù của BasicEffect để xem mô hình được hiển thị như thế nào.
Môi trường hoạt động
Điều kiện tiên quyết
Các phiên bản XNA được hỗ trợ |
|
Nền tảng được hỗ trợ |
|
Phiên bản Vertex Shader bắt buộc của Windows | 2.0 |
Phiên bản Pixel Shader bắt buộc của Windows | 2.0 |
Môi trường hoạt động
nền tảng |
|
Làm thế nào để làm việc với mẫu
điều khiển XboxBàn phím hoạt độngBộ | 360cảm ứng chuột | |||
---|---|---|---|---|
Chọn các thông số bạn muốn thay đổi | ↑、↓ | Thanh trái ↑, ↓ | Nút bên trái | - |
Thay đổi thông số | ←、→ | Gậy trái ←, → | ←→ Kéo | - |
chất
sương mù
Sương mù đề cập đến ý nghĩa của sương mù, và nó có thể được thể hiện theo cách mà vật thể càng ở xa vị trí quan sát, sương mù làm cho khó nhìn thấy. Sương mù không phải là một cài đặt phổ biến như tham số môi trường, nhưng được đặt cho từng hiệu ứng.
Các thông số sương mù bao gồm:
Đã kích hoạt sương mù | Chỉ định có sử dụng sương mù hay không. |
Màu sương mù | Chỉ định màu của sương mù. |
Bắt đầu sương mù | Xác định khoảng cách từ vị trí điểm quan sát trước khi sương mù bắt đầu. |
FogEnd | Chỉ định khoảng cách từ điểm quan sát mà tại đó màu sương mù được phản chiếu 100%. |
Hình ảnh sương mù thay đổi
Hình ảnh dưới đây cho thấy mỗi giá trị sương mù khác nhau.
Không có sương mù
Trạng thái khi sương mù được loại bỏ.
Kích hoạt | Sai |
Màu (Đỏ) | 1 |
Màu sắc (Xanh lá cây) | 1 |
Màu (Xanh dương) | 1 |
Bắt đầu | 60 |
Kết thúc | 100 |
Trạng thái ban đầu
Đây là trạng thái khi mẫu được đưa ra.
Kích hoạt | Thật |
Màu (Đỏ) | 1 |
Màu sắc (Xanh lá cây) | 1 |
Màu (Xanh dương) | 1 |
Bắt đầu | 60 |
Kết thúc | 100 |
Thay đổi màu sắc
Màu sương mù được đặt thành màu đỏ.
Kích hoạt | Thật |
Màu (Đỏ) | 1 |
Màu sắc (Xanh lá cây) | 0 |
Màu (Xanh dương) | 0 |
Bắt đầu | 60 |
Kết thúc | 100 |
Sửa đổi FogStart
Thay đổi giá trị của FogStart. Vì sương mù bắt đầu từ 0, bạn có thể thấy rằng sương mù được nội suy từ điểm quan sát đến khoảng cách FogEnd.
Kích hoạt | Thật |
Màu (Đỏ) | 1 |
Màu sắc (Xanh lá cây) | 0 |
Màu (Xanh dương) | 0 |
Bắt đầu | 0 |
Kết thúc | 100 |
Sửa đổi FogEnd
Thay đổi giá trị của FogEnd. Bạn có thể thấy rằng khoảng cách của FogEnd là hoàn toàn trắng.
Kích hoạt | Thật |
Màu (Đỏ) | 1 |
Màu sắc (Xanh lá cây) | 1 |
Màu (Xanh dương) | 1 |
Bắt đầu | 34.33 |
Kết thúc | 61.66 |
trường
Trường có thông tin sương mù để đặt thành BasicEffect. Ngoài ra, nó có các tham số để chọn menu, nhưng vì nó chỉ là một tham số để hoạt động, tôi sẽ bỏ qua các chi tiết.
<summary>
フォグの有効フラグ
</summary>
private bool fogEnabled = true;
<summary>
フォグの色
</summary>
private Vector3 fogColor = Vector3.One;
<summary>
フォグの開始距離
</summary>
private float fogStart = 60.0f;
<summary>
フォグの終了距離
</summary>
private float fogEnd = 100.0f;
Cài đặt sương mù
Giá trị thay đổi được đặt thành tham số sương mù của hiệu ứng.
// フォグを設定
foreach (ModelMesh mesh in this.model.Meshes)
{
foreach (BasicEffect effect in mesh.Effects)
{
// フォグの有効フラグ
effect.FogEnabled = this.fogEnabled;
// フォグの色
effect.FogColor = this.fogColor;
// フォグの開始距離
effect.FogStart = this.fogStart;
// フォグの終了距離
effect.FogEnd = this.fogEnd;
}
}
BasicEffect.FogEnabled
tài sản
Chỉ định có nên sử dụng sương mù hay không. | bool | nhận, thiết lập |
BasicEffect.FogColor
tài sản
Chỉ định màu của sương mù. | Vectơ3 | nhận, thiết lập |
BasicEffect.FogStart
tài sản
Chỉ định khoảng cách bắt đầu của sương mù. Đây sẽ là khoảng cách từ quan điểm. | nổi | nhận, thiết lập |
BasicEffect.FogEnd
tài sản
Chỉ định khoảng cách kết thúc mà tại đó màu sương mù hoàn thành. Đây sẽ là khoảng cách từ quan điểm. | nổi | nhận, thiết lập |
Tất cả các mã
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.Xna.Framework;
using Microsoft.Xna.Framework.Audio;
using Microsoft.Xna.Framework.Content;
using Microsoft.Xna.Framework.GamerServices;
using Microsoft.Xna.Framework.Graphics;
using Microsoft.Xna.Framework.Input;
using Microsoft.Xna.Framework.Media;
#if WINDOWS_PHONE
using Microsoft.Xna.Framework.Input.Touch;
#endif
namespace BasicEffectFog
{
<summary>
ゲームメインクラス
</summary>
public class GameMain : Microsoft.Xna.Framework.Game
{
<summary>
グラフィックデバイス管理クラス
</summary>
private GraphicsDeviceManager graphics = null;
<summary>
スプライトのバッチ化クラス
</summary>
private SpriteBatch spriteBatch = null;
<summary>
スプライトでテキストを描画するためのフォント
</summary>
private SpriteFont font = null;
<summary>
直前のキーボード入力の状態
</summary>
private KeyboardState oldKeyboardState = new KeyboardState();
<summary>
直前のマウスの状態
</summary>
private MouseState oldMouseState = new MouseState();
<summary>
直前のゲームパッド入力の状態
</summary>
private GamePadState oldGamePadState = new GamePadState();
<summary>
モデル
</summary>
private Model model = null;
<summary>
フォグの有効フラグ
</summary>
private bool fogEnabled = true;
<summary>
フォグの色
</summary>
private Vector3 fogColor = Vector3.One;
<summary>
フォグの開始距離
</summary>
private float fogStart = 60.0f;
<summary>
フォグの終了距離
</summary>
private float fogEnd = 100.0f;
<summary>
選択しているメニューのインデックス
</summary>
private int selectedMenuIndex = 0;
<summary>
メニューリスト
</summary>
private static string[] MenuNameList = new string[]
{
"Enabled",
"Color (Red)",
"Color (Green)",
"Color (Blue)",
"Start",
"End"
};
<summary>
パラメータテキストリスト
</summary>
private string[] parameters = new string[6];
<summary>
GameMain コンストラクタ
</summary>
public GameMain()
{
// グラフィックデバイス管理クラスの作成
this.graphics = new GraphicsDeviceManager(this);
// ゲームコンテンツのルートディレクトリを設定
this.Content.RootDirectory = "Content";
#if WINDOWS_PHONE
// Windows Phone のデフォルトのフレームレートは 30 FPS
this.TargetElapsedTime = TimeSpan.FromTicks(333333);
// バックバッファサイズの設定
this.graphics.PreferredBackBufferWidth = 480;
this.graphics.PreferredBackBufferHeight = 800;
// フルスクリーン表示
this.graphics.IsFullScreen = true;
#endif
// ウインドウ上でマウスのポインタを表示するようにする
this.IsMouseVisible = true;
}
<summary>
ゲームが始まる前の初期化処理を行うメソッド
グラフィック以外のデータの読み込み、コンポーネントの初期化を行う
</summary>
protected override void Initialize()
{
// TODO: ここに初期化ロジックを書いてください
// コンポーネントの初期化などを行います
base.Initialize();
}
<summary>
ゲームが始まるときに一回だけ呼ばれ
すべてのゲームコンテンツを読み込みます
</summary>
protected override void LoadContent()
{
// テクスチャーを描画するためのスプライトバッチクラスを作成します
this.spriteBatch = new SpriteBatch(this.GraphicsDevice);
// フォントをコンテンツパイプラインから読み込む
this.font = this.Content.Load<SpriteFont>("Font");
// モデルを作成
this.model = this.Content.Load<Model>("Model");
// ライトとビュー、プロジェクションはあらかじめ設定しておく
foreach (ModelMesh mesh in this.model.Meshes)
{
foreach (BasicEffect effect in mesh.Effects)
{
// デフォルトのライト適用
effect.EnableDefaultLighting();
// ビューマトリックスをあらかじめ設定
effect.View = Matrix.CreateLookAt(
new Vector3(0.0f, 30.0f, 50.0f),
new Vector3(0.0f, -10.0f, 0.0f),
Vector3.Up
);
// プロジェクションマトリックスをあらかじめ設定
effect.Projection = Matrix.CreatePerspectiveFieldOfView(
MathHelper.ToRadians(45.0f),
(float)this.GraphicsDevice.Viewport.Width /
(float)this.GraphicsDevice.Viewport.Height,
1.0f,
100.0f
);
}
}
}
<summary>
ゲームが終了するときに一回だけ呼ばれ
すべてのゲームコンテンツをアンロードします
</summary>
protected override void UnloadContent()
{
// TODO: ContentManager で管理されていないコンテンツを
// ここでアンロードしてください
}
<summary>
描画以外のデータ更新等の処理を行うメソッド
主に入力処理、衝突判定などの物理計算、オーディオの再生など
</summary>
<param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
protected override void Update(GameTime gameTime)
{
// 入力デバイスの状態取得
KeyboardState keyboardState = Keyboard.GetState();
MouseState mouseState = Mouse.GetState();
GamePadState gamePadState = GamePad.GetState(PlayerIndex.One);
// Xbox 360 コントローラ、Windows Phone の BACK ボタンを押したときに
// ゲームを終了させます
if (gamePadState.Buttons.Back == ButtonState.Pressed)
{
this.Exit();
}
// メニューの選択
if ((keyboardState.IsKeyDown(Keys.Up) && this.oldKeyboardState.IsKeyUp(Keys.Up)) ||
(gamePadState.ThumbSticks.Left.Y >= 0.5f &&
this.oldGamePadState.ThumbSticks.Left.Y < 0.5f))
{
// 選択メニューをひとつ上に移動
this.selectedMenuIndex =
(this.selectedMenuIndex + this.parameters.Length - 1) % this.parameters.Length;
}
if ((keyboardState.IsKeyDown(Keys.Down) && this.oldKeyboardState.IsKeyUp(Keys.Down)) ||
(gamePadState.ThumbSticks.Left.Y <= -0.5f &&
this.oldGamePadState.ThumbSticks.Left.Y > -0.5f) ||
(this.oldMouseState.LeftButton == ButtonState.Pressed &&
mouseState.LeftButton == ButtonState.Released))
{
// 選択メニューをひとつ下に移動
this.selectedMenuIndex =
(this.selectedMenuIndex + this.parameters.Length + 1) % this.parameters.Length;
}
// 各マテリアルの値を操作
float moveValue = 0.0f;
if (keyboardState.IsKeyDown(Keys.Left))
{
moveValue -= (float)gameTime.ElapsedGameTime.TotalSeconds;
}
if (keyboardState.IsKeyDown(Keys.Right))
{
moveValue += (float)gameTime.ElapsedGameTime.TotalSeconds;
}
if (mouseState.LeftButton == ButtonState.Pressed)
{
moveValue += (mouseState.X - this.oldMouseState.X) * 0.005f;
}
if (gamePadState.IsConnected)
{
moveValue += gamePadState.ThumbSticks.Left.X *
(float)gameTime.ElapsedGameTime.TotalSeconds;
}
if (moveValue != 0.0f)
{
switch (this.selectedMenuIndex)
{
case 0: // フォグの有効フラグ
this.fogEnabled = (moveValue > 0.0f);
break;
case 1: // フォグの色 (赤)
this.fogColor.X = MathHelper.Clamp(this.fogColor.X + moveValue,
0.0f,
1.0f);
break;
case 2: // フォグの色 (緑)
this.fogColor.Y = MathHelper.Clamp(this.fogColor.Y + moveValue,
0.0f,
1.0f);
break;
case 3: // フォグの色 (青)
this.fogColor.Z = MathHelper.Clamp(this.fogColor.Z + moveValue,
0.0f,
1.0f);
break;
case 4: // フォグの開始距離
this.fogStart = MathHelper.Clamp(this.fogStart + moveValue * 10.0f,
0.0f,
100.0f);
break;
case 5: // フォグの終了距離
this.fogEnd = MathHelper.Clamp(this.fogEnd + moveValue * 10.0f,
0.0f,
100.0f);
break;
}
}
// フォグを設定
foreach (ModelMesh mesh in this.model.Meshes)
{
foreach (BasicEffect effect in mesh.Effects)
{
// フォグの有効フラグ
effect.FogEnabled = this.fogEnabled;
// フォグの色
effect.FogColor = this.fogColor;
// フォグの開始距離
effect.FogStart = this.fogStart;
// フォグの終了距離
effect.FogEnd = this.fogEnd;
}
}
// 入力情報を記憶
this.oldKeyboardState = keyboardState;
this.oldMouseState = mouseState;
this.oldGamePadState = gamePadState;
// 登録された GameComponent を更新する
base.Update(gameTime);
}
<summary>
描画処理を行うメソッド
</summary>
<param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
protected override void Draw(GameTime gameTime)
{
// 画面を指定した色でクリアします
this.GraphicsDevice.Clear(Color.CornflowerBlue);
// 深度バッファを有効にする
this.GraphicsDevice.DepthStencilState = DepthStencilState.Default;
// モデルを描画
foreach (ModelMesh mesh in this.model.Meshes)
{
#if WINDOWS_PHONE
foreach (BasicEffect effect in mesh.Effects)
{
effect.World = Matrix.CreateScale(new Vector3(0.5f, 1, 1));
}
#endif
mesh.Draw();
}
// スプライトの描画準備
this.spriteBatch.Begin();
// 操作
this.spriteBatch.DrawString(this.font,
"Up, Down : Select Menu",
new Vector2(20.0f, 20.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
"Left, right : Change Value",
new Vector2(20.0f, 45.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
"MouseClick & Drag :",
new Vector2(20.0f, 70.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
" Select Menu & Change Value",
new Vector2(20.0f, 95.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
"Up, Down : Select Menu",
new Vector2(19.0f, 19.0f), Color.White);
this.spriteBatch.DrawString(this.font,
"Left, right : Change Value",
new Vector2(19.0f, 44.0f), Color.White);
this.spriteBatch.DrawString(this.font,
"MouseClick & Drag :",
new Vector2(19.0f, 69.0f), Color.White);
this.spriteBatch.DrawString(this.font,
" Select Menu & Change Value",
new Vector2(19.0f, 94.0f), Color.White);
// 各メニュー //
for (int i = 0; i < MenuNameList.Length; i++)
{
this.spriteBatch.DrawString(this.font,
MenuNameList[i],
new Vector2(40.0f, 120.0f + i * 20.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
MenuNameList[i],
new Vector2(39.0f, 119.0f + i * 20.0f), Color.White);
}
// 各パラメータ //
// フォグの有効フラグ
this.parameters[0] = this.fogEnabled.ToString();
// フォグの色 (赤)
this.parameters[1] = this.fogColor.X.ToString();
// フォグの色 (緑)
this.parameters[2] = this.fogColor.Y.ToString();
// フォグの色 (青)
this.parameters[3] = this.fogColor.Z.ToString();
// フォグの開始距離
this.parameters[4] = this.fogStart.ToString();
// フォグの終了距離
this.parameters[5] = this.fogEnd.ToString();
for (int i = 0; i < this.parameters.Length; i++)
{
this.spriteBatch.DrawString(this.font,
this.parameters[i],
new Vector2(220.0f, 120.0f + i * 20.0f), Color.Black);
this.spriteBatch.DrawString(this.font,
this.parameters[i],
new Vector2(219.0f, 119.0f + i * 20.0f), Color.White);
}
// 選択インデックス
this.spriteBatch.DrawString(this.font, "*",
new Vector2(20.0f, 120.0f + this.selectedMenuIndex * 20.0f), Color.Black);
this.spriteBatch.DrawString(this.font, "*",
new Vector2(19.0f, 119.0f + this.selectedMenuIndex * 20.0f), Color.White);
// スプライトの一括描画
this.spriteBatch.End();
// 登録された DrawableGameComponent を描画する
base.Draw(gameTime);
}
}
}