3テラバイト

プログラム関連備忘録サイト。主にゲーム。

RPGツクールMV

RPGツクールMV – 自作プラグインで文字を表示する

投稿日:2020年5月20日 更新日:

こんにちは、今日はRPGツクールMVの自作プラグインで独自の画面に任意の文字を表示する方法についてまとめていきます。

確認環境

RPGツクールMV Version 1.6.2

文字を表示する関数

Window_Baseクラスに定義されている以下の関数を使用して文字を表示します。
第一引数に表示したい文字列、第二引数にX座標、第三引数にY座標を指定します。

drawText("文字表示", 0, 0);

複数行表示したい場合は、同じくWindow_Baseクラスに定義されているlineHeight関数で一行の高さが取得できるため、この値を使用してY座標の調整を行います。

lineHeight

文字色を変更したい場合は以下のように変更します。
textColorの引数により文字色が変わります。

this.changeTextColor(this.textColor(1));

文字色を元に戻す場合は以下の関数を呼び出します。

this.resetTextColor();

サンプル

プラグインコマンド「TestScene」を実行すると独自のシーンを呼び出し、そのシーン文字を表示するサンプルです。

(function() {
    var _Game_Interpreter_pluginCommand = Game_Interpreter.prototype.pluginCommand;
    Game_Interpreter.prototype.pluginCommand = function(command, args) {
        _Game_Interpreter_pluginCommand.call(this, command, args);
        switch(command){
            case 'TestScene':
                SceneManager.push(Scene_Test);
            break;
        }
    };

    //--------------------------------------------------
    // Name : Scene_Test
    // Desc : テストシーンクラス
    //--------------------------------------------------
    function Scene_Test() {
        this.initialize.apply(this, arguments);
    }

    Scene_Test.prototype = Object.create(Scene_Base.prototype);
    Scene_Test.prototype.constructor = Scene_Test;

    Scene_Test.prototype.initialize = function() {
        Scene_Base.prototype.initialize.call(this);
    };

    Scene_Test.prototype.create = function() {
        Scene_Base.prototype.create.call(this);
        this.createBackground();
        this.createWindowLayer();

        this._testWindow = new Window_Test(0, 0, 400, 300);
        this.addWindow(this._testWindow);
    };

    Scene_Test.prototype.update = function() {
        Scene_Base.prototype.update.call(this);
    };

    Scene_Test.prototype.createBackground = function() {
        this._backgroundSprite = new Sprite();
        this._backgroundSprite.bitmap = SceneManager.backgroundBitmap();
        this.addChild(this._backgroundSprite);
    };

    //--------------------------------------------------
    // Name : Window_Test
    // Desc : テストウィンドウクラス
    //--------------------------------------------------
    function Window_Test() {
        this.initialize.apply(this, arguments);
    }

    Window_Test.prototype = Object.create(Window_Base.prototype);
    Window_Test.prototype.constructor = Window_Test;

    Window_Test.prototype.initialize = function(x, y, width, height) {
        Window_Base.prototype.initialize.call(this, x, y, width, height);
    };

	Window_Test.prototype.update = function() {
        Window_Base.prototype.update.call(this);

        this.contents.clear();
        var textPosY = 0;

        this.drawText("文字表示", 0, textPosY);
        textPosY += this.lineHeight();

        this.changeTextColor(this.textColor(1));
        this.drawText("文字色を変更する", 0, textPosY);
        textPosY += this.lineHeight();

        this.resetTextColor();
        this.drawText("文字色を元に戻す", 0, textPosY);
        textPosY += this.lineHeight();

        this.drawText("変数0001 : " + $gameVariables.value(1), 0, textPosY);
        textPosY += this.lineHeight();

        this.drawText("スイッチ0001 : " + $gameSwitches.value(1), 0, textPosY);
        textPosY += this.lineHeight();
	};

})();

-RPGツクールMV


comment

メールアドレスが公開されることはありません。

関連記事

no image

RPGツクールMV – 自作プラグインでマップ画面に独自のウィンドウを表示する

こんにちは、今日はRPGツクールMVの自作プラグインでマップ画面に独自のウィンドウを表示する方法についてまとめていきます。 確認環境 RPGツクールMV Version 1.6.2 マップ画面開始時の …

no image

RPGツクールMVでスクリプトから指定の武器防具を装備しているか判定する

$gameParty.isAnyMemberEquipped($dataWeapons[1]) $gameParty.isAnyMemberEquipped($dataArmors&#x5B …

no image

データベースをExcelなどにエクスポート・インポートできるRPGツクールMVプラグインDatabaseConverterの使い方

確認環境 RPGツクールMV Version 1.6.3DatabaseConverter Version 1.1.3 使い方 データベースのエクスポート 手順についてはプラグインヘルプの書き出し手順 …

no image

RPGツクールMV – スクリプトで”文章の表示”を行う方法

こんにちは、今日はRPGツクールMVでイベントコマンドの”スクリプト”から、同じくイベントコマンドの”文章の表示”の処理を行う方法についてまとめていきます。 確認環境 RPGツクールMV Versio …

no image

RPGツクールMVで画面の色調変更をスクリプトから行う

スクリプトコード 第一引数に赤、緑、青、グレーの値の配列を、第二引数に時間を指定します。 $gameScreen.startTint([0,0,0,0], 60); イベントコマンドの内容 …