Pārbaudiet, vai fails ir pieejams
Kopsavilkuma
Pārbauda, vai norādītais fails pastāv.
Darbības vide
Priekšnoteikumi
Atbalstītās XNA versijas |
|
Atbalstītās platformas |
|
Windows nepieciešamā Vertex Shader versija | 1.1 |
Windows nepieciešamā Pixel Shader versija | 1.1 |
Darbības vide
platforma |
Kā strādāt ar paraugu
Darbojas tastatūraXbox | 360 kontrolpele | ||
---|---|---|---|
Ierīces izvēle, lai pārbaudītu faila esamību | A | A | - |
viela
Mērķa fails, kuram vēlaties pārbaudīt faila esamību
Mērķa faili, attiecībā uz kuriem šajā paraugā tiek pārbaudīta faila esamība, ir šādi faili.
- Fonta fails "Font.xnb" (vienmēr atrodas šajā paraugā)
- Manekena fails "AAA.txt" (neeksistējošs fails)
- Datu glabāšanas fails "SaveData.txt" (atkarībā no tā, vai izveidojāt šo failu ar citiem XNA paraugiem)
Pārbaudiet, vai iepriekš minētajiem trim failiem ir fails, bet jo īpaši trešajam failam, tas, vai fails ir vai nav, ir atkarīgs no faila, ko saglabā padomi sadaļā "Datu saglabāšana" un atmiņas ierīces izvēle.
lauks
Katram failam norādiet karodziņa mainīgo, kas norāda, vai fails pastāv. Saglabāto datu failu nevar pārbaudīt, kamēr nav atlasīta saglabāšanas ierīce, tāpēc varat izmantot "bool?" un aizstāt nulli, kamēr tā nav pārbaudīta.
<summary>
保存したデータが存在するか
</summary>
private bool? isExistSaveDataFile = null;
<summary>
フォントファイルが存在するか
</summary>
private bool isExistFontFile = false;
<summary>
ダミーファイルが存在するか
</summary>
private bool isExistDummyFile = false;
System.IO nosaukumvieta
Tā kā izmantojat ar failiem saistītas klases, pārliecinieties, vai iepriekš varat izmantot System.IO nosaukumvietu. (kur "izmantojot System.IO;" Varat arī norādīt klases nosaukumu tieši no nosaukumvietas.)
using System;
using System.Collections.Generic;
using System.IO;
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.Net;
using Microsoft.Xna.Framework.Storage;
Fonta faila ceļš
Tā kā fonta faila ceļš atrodas mapes, kurā ir izpildāmais fails, mapē Saturs, apvienojiet mapes ceļu ar izpildāmo failu (ko iegūst ar rekvizītu StorageContainer.TitleLocation) un mapes, kurā ir fonta fails, ceļu, izmantojot metodi Path.Comb.
Kas attiecas uz manekena faila ceļu, tas var būt jebkur, kamēr nav faila.
// フォントファイルのパス
string fontFilePath =
Path.Combine(StorageContainer.TitleLocation, @"Content\Font.xnb");
Faila esamības pārbaude
Lai pārbaudītu, vai fails pastāv, izmantojiet metodi File.Exists.
// フォントファイルがあるか確認する
this.isExistFontFile = File.Exists(fontFilePath);
Metodes File.Exists pirmais arguments ir faila ceļš, un, ja fails pastāv, tiek atgriezts patiess. Ja faila nav, tiek atgriezts aplams.
File.Exists
metode
Pārbauda, vai norādītais fails pastāv.
Ceļu | Virkne | Pārbaudāmais fails. |
Atgrieztās vērtības | piepeši | patiess, ja ir norādīts fails; aplams, ja faila nav. |
Pārbaude, vai pastāv glabāšanā saglabāti faili
Failiem, kas saglabāti krātuvē, varat pārbaudīt faila esamību, izmantojot metodi File.Exists pēc atmiņas ierīces izvēles. Apvienojiet rekvizītu StorageContainer.Path ar faila relatīvo ceļu.
// ストレージコンテナを開きます
using (StorageContainer container = storageDevice.OpenContainer("XNASample"))
{
// 保存されたファイルのパス
string filePath = Path.Combine(container.Path, "SaveData.txt");
// ファイルがあるか確認する
this.isExistSaveDataFile = File.Exists(filePath);
}
Visi kodi
using System;
using System.Collections.Generic;
using System.IO;
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.Net;
using Microsoft.Xna.Framework.Storage;
namespace ExistsFile
{
<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 bool? isExistSaveDataFile = null;
<summary>
フォントファイルが存在するか
</summary>
private bool isExistFontFile = false;
<summary>
ダミーファイルが存在するか
</summary>
private bool isExistDummyFile = false;
<summary>
直線のキーボード入力の状態
</summary>
private KeyboardState oldKeyboardState = new KeyboardState();
<summary>
直線のゲームパッド入力の状態
</summary>
private GamePadState oldGamePadState = new GamePadState();
<summary>
GameMain コンストラクタ
</summary>
public GameMain()
{
// グラフィックデバイス管理クラスの作成
this.graphics = new GraphicsDeviceManager(this);
// ゲームコンテンツのルートディレクトリを設定
this.Content.RootDirectory = "Content";
// ゲームサービスコンポーネントを追加
this.Components.Add(new GamerServicesComponent(this));
}
<summary>
ゲームが始まる前の初期化処理を行うメソッド
グラフィック以外のデータの読み込み、コンポーネントの初期化を行う
</summary>
protected override void Initialize()
{
// フォントファイルのパス
string fontFilePath =
Path.Combine(StorageContainer.TitleLocation, @"Content\Font.xnb");
// フォントファイルがあるか確認する
this.isExistFontFile = File.Exists(fontFilePath);
// ダミーファイルのパス
string dummyFilePath = Path.Combine(StorageContainer.TitleLocation, "AAA.txt");
// ダミーファイルがあるか確認する
this.isExistDummyFile = File.Exists(dummyFilePath);
// コンポーネントの初期化などを行います
base.Initialize();
}
<summary>
ゲームが始まるときに一回だけ呼ばれ
すべてのゲームコンテンツを読み込みます
</summary>
protected override void LoadContent()
{
// テクスチャーを描画するためのスプライトバッチクラスを作成します
this.spriteBatch = new SpriteBatch(this.GraphicsDevice);
// フォントをコンテンツパイプラインから読み込む
this.font = this.Content.Load<SpriteFont>("Font");
}
<summary>
ゲームが終了するときに一回だけ呼ばれ
すべてのゲームコンテンツをアンロードします
</summary>
protected override void UnloadContent()
{
// TODO: ContentManager で管理されていないコンテンツを
// ここでアンロードしてください
}
<summary>
描画以外のデータ更新等の処理を行うメソッド
主に入力処理、衝突判定などの物理計算、オーディオの再生など
</summary>
<param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
protected override void Update(GameTime gameTime)
{
// キーボードの情報取得
KeyboardState keyboardState = Keyboard.GetState();
// ゲームパッドの情報取得
GamePadState gamePadState = GamePad.GetState(PlayerIndex.One);
// Xbox360 コントローラの BACK ボタンを押したときにゲームを終了させます
if (gamePadState.Buttons.Back == ButtonState.Pressed)
{
this.Exit();
}
if ((keyboardState.IsKeyDown(Keys.A) && this.oldKeyboardState.IsKeyUp(Keys.A)) ||
(gamePadState.Buttons.A == ButtonState.Pressed &&
this.oldGamePadState.Buttons.A == ButtonState.Released))
{
// A ボタンが押されたとき /////
// ストレージデバイス選択UIを表示するための設定を行います
Guide.BeginShowStorageDeviceSelector(this.GetStorageDevice, null);
}
// 入力情報を記憶
this.oldKeyboardState = keyboardState;
this.oldGamePadState = gamePadState;
// 登録された GameComponent を更新する
base.Update(gameTime);
}
<summary>
ストレージデバイスを取得するために呼ばれる
</summary>
<param name="result">非同期処理の結果</param>
private void GetStorageDevice(IAsyncResult result)
{
// 結果をもとにストレージデバイスの選択UIを終了してストレージデバイスを取得します
StorageDevice storageDevice = Guide.EndShowStorageDeviceSelector(result);
if (storageDevice != null && storageDevice.IsConnected)
{
// ストレージデバイスの取得に成功し、接続されている場合 /////
// ストレージコンテナを開きます
using (StorageContainer container = storageDevice.OpenContainer("XNASample"))
{
// 保存されたファイルのパス
string filePath = Path.Combine(container.Path, "SaveData.txt");
// ファイルがあるか確認する
this.isExistSaveDataFile = File.Exists(filePath);
}
}
}
<summary>
描画処理を行うメソッド
</summary>
<param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
protected override void Draw(GameTime gameTime)
{
// 画面を指定した色でクリアします
this.GraphicsDevice.Clear(Color.CornflowerBlue);
// スプライトの描画準備
this.spriteBatch.Begin();
// テキスト描画
this.spriteBatch.DrawString(this.font,
"A : Select Storage Device.",
new Vector2(50.0f, 50.0f), Color.White);
// フォントファイルの存在確認
this.spriteBatch.DrawString(this.font,
"FontFile : " + this.isExistFontFile,
new Vector2(50.0f, 70.0f), Color.White);
// ダミーファイルの存在確認
this.spriteBatch.DrawString(this.font,
"DummyFile : " + this.isExistDummyFile,
new Vector2(50.0f, 90.0f), Color.White);
// 保存ファイルの存在確認
string saveDataText = "SavedDateFile : ";
if (this.isExistSaveDataFile != null)
{
saveDataText += this.isExistSaveDataFile;
}
else
{
saveDataText += "?";
}
this.spriteBatch.DrawString(this.font,
saveDataText,
new Vector2(50.0f, 110.0f), Color.White);
// スプライトの一括描画
this.spriteBatch.End();
// 登録された DrawableGameComponent を描画する
base.Draw(gameTime);
}
}
}