스프라이트 확대 및 축소

페이지 업데이트 :
페이지 생성 날짜 :

요약

스프라이트를 볼 수 있도록 스프라이트의 크기를 조절합니다.

スプライトを拡大縮小表示する

운영 환경

필수 구성 요소

지원되는 XNA 버전
  • 2.0
  • 3.0
  • 3.1
  • 4.0
지원되는 플랫폼
  • Windows(XP SP2 이상, Vista, 7)
  • 엑스박스 360
  • 윈도우 폰 7
Windows 필수 버텍스 셰이더 버전 2.0
Windows 필수 픽셀 셰이더 버전 2.0

운영 환경

플랫폼
  • 윈도우 7
  • 엑스박스 360
  • Windows Phone 7 에뮬레이터

물질

스프라이트를 표시하도록 배율을 조정하려면 "SpriteBatch.Draw" 메서드의 7번째 인수로 지정합니다. 이를 지정하는 방법에는 두 가지가 있습니다: 동일한 배율인 float 지정과 다른 배율로 지정할 수 있는 Vector2.

// スプライトを2倍にして描画する
this.spriteBatch.Draw(this.texture, new Vector2(170.0f, 20.0f), null,
    Color.White, 0.0f, Vector2.Zero, 2.0f,
    SpriteEffects.None, 0.0f);

// スプライトを横に2倍、縦に 0.5 倍にして描画する
this.spriteBatch.Draw(this.texture, new Vector2(20.0f, 320.0f), null,
    Color.White, 0.0f, Vector2.Zero, new Vector2(2.0f, 0.5f),
    SpriteEffects.None, 0.0f);

SpriteBatch.Draw 메서드

스프라이트 드로잉 배치 목록에 스프라이트를 추가합니다.

텍스처 텍스처2D 스프라이트로 표시할 텍스처를 지정합니다.
위치 벡터2 스프라이트가 표시되어야 하는 위치입니다. 화면의 왼쪽 상단을 기준으로 화면 좌표를 지정합니다. 스프라이트의 원점은 왼쪽 상단에 있습니다.
sourceRectangle (영문) Nullable<Rectangle입니다> 텍스처의 전송 영역을 지정합니다. 전체 텍스처를 스프라이트로 표시하려면 null을 지정할 수 있습니다. 이 매개 변수를 지정하면 임의의 영역만 스프라이트로 표시되도록 할 수 있습니다.
스프라이트의 색에 곱할 색을 지정합니다. Color.White를 지정하면 스프라이트의 기본 색상으로 표시됩니다. Color.Black을 지정하면 스프라이트는 색상에 관계없이 전체 검정색으로 표시됩니다. 공식은 "결과 = 스프라이트 색상 * 색상"입니다.
회전 뜨다 스프라이트의 회전 각도입니다. 단위는 라디안으로 지정됩니다. 회전축은 스프라이트의 왼쪽 상단에 있습니다.
기원 벡터2 스프라이트를 회전할 때 회전축의 위치를 지정합니다. 스프라이트의 어느 위치가 회전축이 될지 지정하지만, 실제로는 회전축의 위치가 스프라이트의 왼쪽 상단에 고정되고 스프라이트의 표시 위치는 -origin만큼 이동합니다.
저울 뜨다 스프라이트의 배율을 지정합니다. 1.0을 기준으로 세로 및 가로로 크기를 조정합니다. 확대의 원점은 스프라이트의 왼쪽 상단 모서리에 있습니다.
효과 스프라이트 이펙트 스프라이트의 반전 효과를 지정합니다. 다른 작업을 수행하지 않으면 SpriteEffects.None을 지정합니다.
layerDepth (레이어깊이) 뜨다 스프라이트가 표시되는 깊이를 지정합니다. 주로 전경과 후면에 스프라이트를 표시하는 데 사용됩니다. 0.0~1.0 범위로 지정하며, 0.0은 앞면, 1.0은 뒷면입니다.

크기 조정을 위한 참조 위치는 스프라이트의 왼쪽 위 위치입니다.

拡大縮小の基準位置

모든 코드

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 ScaleSprite
{
    /// <summary>
    /// ゲームメインクラス
    /// </summary>
    public class GameMain : Microsoft.Xna.Framework.Game
    {
        /// <summary>
        /// グラフィックデバイス管理クラス
        /// </summary>
        private GraphicsDeviceManager graphics = null;

        /// <summary>
        /// スプライトのバッチ化クラス
        /// </summary>
        private SpriteBatch spriteBatch = null;

        /// <summary>
        /// テクスチャー
        /// </summary>
        private Texture2D texture = null;


        /// <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
        }

        /// <summary>
        /// ゲームが始まる前の初期化処理を行うメソッド
        /// グラフィック以外のデータの読み込み、コンポーネントの初期化を行う
        /// </summary>
        protected override void Initialize()
        {
            // TODO: ここに初期化ロジックを書いてください

            // コンポーネントの初期化などを行います
            base.Initialize();
        }

        /// <summary>
        /// ゲームが始まるときに一回だけ呼ばれ
        /// すべてのゲームコンテンツを読み込みます
        /// </summary>
        protected override void LoadContent()
        {
            // テクスチャーを描画するためのスプライトバッチクラスを作成します
            this.spriteBatch = new SpriteBatch(this.GraphicsDevice);

            // テクスチャーをコンテンツパイプラインから読み込む
            this.texture = this.Content.Load<Texture2D>("Texture");
        }

        /// <summary>
        /// ゲームが終了するときに一回だけ呼ばれ
        /// すべてのゲームコンテンツをアンロードします
        /// </summary>
        protected override void UnloadContent()
        {
            // TODO: ContentManager で管理されていないコンテンツを
            //       ここでアンロードしてください
        }

        /// <summary>
        /// 描画以外のデータ更新等の処理を行うメソッド
        /// 主に入力処理、衝突判定などの物理計算、オーディオの再生など
        /// </summary>
        /// <param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
        protected override void Update(GameTime gameTime)
        {
            // Xbox 360 コントローラ、Windows Phone の BACK ボタンを押したときに
            // ゲームを終了させます
            if (GamePad.GetState(PlayerIndex.One).Buttons.Back == ButtonState.Pressed)
            {
                this.Exit();
            }

            // TODO: ここに更新処理を記述してください

            // 登録された GameComponent を更新する
            base.Update(gameTime);
        }

        /// <summary>
        /// 描画処理を行うメソッド
        /// </summary>
        /// <param name="gameTime">このメソッドが呼ばれたときのゲーム時間</param>
        protected override void Draw(GameTime gameTime)
        {
            // 画面を指定した色でクリアします
            this.GraphicsDevice.Clear(Color.CornflowerBlue);

            // スプライトの描画準備
            this.spriteBatch.Begin();

            // スプライトを普通に描画する
            this.spriteBatch.Draw(this.texture, new Vector2(20.0f, 20.0f), null,
                Color.White, 0.0f, Vector2.Zero, 1.0f,
                SpriteEffects.None, 0.0f);

            // スプライトを 0.5 倍にして描画する
            this.spriteBatch.Draw(this.texture, new Vector2(20.0f, 170.0f), null,
                Color.White, 0.0f, Vector2.Zero, 0.5f,
                SpriteEffects.None, 0.0f);

            // スプライトを2倍にして描画する
            this.spriteBatch.Draw(this.texture, new Vector2(170.0f, 20.0f), null,
                Color.White, 0.0f, Vector2.Zero, 2.0f,
                SpriteEffects.None, 0.0f);

            // スプライトを横に2倍、縦に 0.5 倍にして描画する
            this.spriteBatch.Draw(this.texture, new Vector2(20.0f, 320.0f), null,
                Color.White, 0.0f, Vector2.Zero, new Vector2(2.0f, 0.5f),
                SpriteEffects.None, 0.0f);

            // スプライトの一括描画
            this.spriteBatch.End();

            // 登録された DrawableGameComponent を描画する
            base.Draw(gameTime);
        }
    }
}